The previous implementation blindly added HAProxy components without checking for existing configurations on the same port, which caused duplicate entries and errors when a service was updated. This commit refactors the logic to a robust "remove-then-add" strategy. The configure_service method now finds and removes any existing frontend and its dependent components (backend, servers, health check) before adding the new, complete service definition. This change makes the process fully idempotent, preventing configuration drift and ensuring a predictable state. Co-authored-by: Ian Letourneau <letourneau.ian@gmail.com> Reviewed-on: https://git.nationtech.io/NationTech/harmony/pulls/129
		
			
				
	
	
		
			32 lines
		
	
	
		
			806 B
		
	
	
	
		
			TOML
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			806 B
		
	
	
	
		
			TOML
		
	
	
	
	
	
| [package]
 | |
| name = "opnsense-config"
 | |
| edition = "2021"
 | |
| version.workspace = true
 | |
| readme.workspace = true
 | |
| license.workspace = true
 | |
| 
 | |
| [dependencies]
 | |
| serde = { version = "1.0.123", features = ["derive"] }
 | |
| log = { workspace = true }
 | |
| env_logger = { workspace = true }
 | |
| russh = { workspace = true }
 | |
| russh-keys = { workspace = true }
 | |
| thiserror = "1.0"
 | |
| async-trait = { workspace = true }
 | |
| tokio = { workspace = true }
 | |
| opnsense-config-xml = { path = "../opnsense-config-xml" }
 | |
| chrono = "0.4.38"
 | |
| russh-sftp = "2.0.6"
 | |
| serde_json = "1.0.133"
 | |
| tokio-util = { version = "0.7.13", features = ["codec"] }
 | |
| tokio-stream = "0.1.17"
 | |
| uuid.workspace = true
 | |
| sha2 = "0.10.9"
 | |
| 
 | |
| [dev-dependencies]
 | |
| pretty_assertions.workspace = true
 | |
| assertor.workspace = true
 | |
| 
 | |
| [lints.rust]
 | |
| unexpected_cfgs = { level = "warn", check-cfg = ['cfg(e2e_test)'] }
 |