mirror of
				https://github.com/SeriousBug/gandi-live-dns-rust
				synced 2025-10-26 02:27:17 -05:00 
			
		
		
		
	Compare commits
	
		
			6 commits
		
	
	
		
			35d60f0b29
			...
			f94222f048
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | f94222f048 | ||
|  | e2a343c59e | ||
|  | 220e368bf3 | ||
|  | 041c1109e0 | ||
|  | bbd7ce347a | ||
|  | 28984e1b52 | 
							
								
								
									
										240
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										240
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							|  | @ -4,18 +4,18 @@ version = 3 | |||
| 
 | ||||
| [[package]] | ||||
| name = "aho-corasick" | ||||
| version = "0.7.19" | ||||
| version = "0.7.20" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "b4f55bd91a0978cbfd91c457a164bab8b4001c833b7f323132c0a4e1922dd44e" | ||||
| checksum = "cc936419f96fa211c1b9166887b38e5e40b19958e5b895be7c1f93adec7071ac" | ||||
| dependencies = [ | ||||
|  "memchr", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "anyhow" | ||||
| version = "1.0.66" | ||||
| version = "1.0.67" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "216261ddc8289130e551ddcd5ce8a064710c0d064a4d2895c67151c92b5443f6" | ||||
| checksum = "7724808837b77f4b4de9d283820f9d98bcf496d5692934b857a2399d31ff22e6" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "ascii-canvas" | ||||
|  | @ -38,11 +38,11 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "async-channel" | ||||
| version = "1.7.1" | ||||
| version = "1.8.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "e14485364214912d3b19cc3435dde4df66065127f05fa0d75c712f36f12c2f28" | ||||
| checksum = "cf46fee83e5ccffc220104713af3292ff9bc7c64c7de289f66dae8e38d826833" | ||||
| dependencies = [ | ||||
|  "concurrent-queue 1.2.4", | ||||
|  "concurrent-queue", | ||||
|  "event-listener", | ||||
|  "futures-core", | ||||
| ] | ||||
|  | @ -55,7 +55,7 @@ checksum = "17adb73da160dfb475c183343c8cccd80721ea5a605d3eb57125f0a7b7a92d0b" | |||
| dependencies = [ | ||||
|  "async-lock", | ||||
|  "async-task", | ||||
|  "concurrent-queue 2.0.0", | ||||
|  "concurrent-queue", | ||||
|  "fastrand", | ||||
|  "futures-lite", | ||||
|  "slab", | ||||
|  | @ -78,13 +78,13 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "async-io" | ||||
| version = "1.10.0" | ||||
| version = "1.12.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "e8121296a9f05be7f34aa4196b1747243b3b62e048bb7906f644f3fbfc490cf7" | ||||
| checksum = "8c374dda1ed3e7d8f0d9ba58715f924862c63eae6849c92d3a18e7fbde9e2794" | ||||
| dependencies = [ | ||||
|  "async-lock", | ||||
|  "autocfg", | ||||
|  "concurrent-queue 1.2.4", | ||||
|  "concurrent-queue", | ||||
|  "futures-lite", | ||||
|  "libc", | ||||
|  "log", | ||||
|  | @ -93,7 +93,7 @@ dependencies = [ | |||
|  "slab", | ||||
|  "socket2", | ||||
|  "waker-fn", | ||||
|  "winapi", | ||||
|  "windows-sys 0.42.0", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
|  | @ -117,20 +117,20 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "async-process" | ||||
| version = "1.5.0" | ||||
| version = "1.6.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "02111fd8655a613c25069ea89fc8d9bb89331fa77486eb3bc059ee757cfa481c" | ||||
| checksum = "6381ead98388605d0d9ff86371043b5aa922a3905824244de40dc263a14fcba4" | ||||
| dependencies = [ | ||||
|  "async-io", | ||||
|  "async-lock", | ||||
|  "autocfg", | ||||
|  "blocking", | ||||
|  "cfg-if", | ||||
|  "event-listener", | ||||
|  "futures-lite", | ||||
|  "libc", | ||||
|  "once_cell", | ||||
|  "signal-hook", | ||||
|  "winapi", | ||||
|  "windows-sys 0.42.0", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
|  | @ -168,9 +168,9 @@ checksum = "7a40729d2133846d9ed0ea60a8b9541bccddab49cd30f0715a1da672fe9a2524" | |||
| 
 | ||||
| [[package]] | ||||
| name = "async-trait" | ||||
| version = "0.1.58" | ||||
| version = "0.1.60" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "1e805d94e6b5001b651426cf4cd446b1ab5f319d27bab5c644f61de0a804360c" | ||||
| checksum = "677d1d8ab452a3936018a687b20e6f7cf5363d713b732b8884001317b0e48aa3" | ||||
| dependencies = [ | ||||
|  "proc-macro2", | ||||
|  "quote", | ||||
|  | @ -189,7 +189,7 @@ version = "0.2.14" | |||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "d9b39be18770d11421cdb1b9947a45dd3f37e93092cbf377614828a319d5fee8" | ||||
| dependencies = [ | ||||
|  "hermit-abi", | ||||
|  "hermit-abi 0.1.19", | ||||
|  "libc", | ||||
|  "winapi", | ||||
| ] | ||||
|  | @ -240,16 +240,16 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" | |||
| 
 | ||||
| [[package]] | ||||
| name = "blocking" | ||||
| version = "1.2.0" | ||||
| version = "1.3.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "c6ccb65d468978a086b69884437ded69a90faab3bbe6e67f242173ea728acccc" | ||||
| checksum = "3c67b173a56acffd6d2326fb7ab938ba0b00a71480e14902b2591c87bc5741e8" | ||||
| dependencies = [ | ||||
|  "async-channel", | ||||
|  "async-lock", | ||||
|  "async-task", | ||||
|  "atomic-waker", | ||||
|  "fastrand", | ||||
|  "futures-lite", | ||||
|  "once_cell", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
|  | @ -260,15 +260,9 @@ checksum = "572f695136211188308f16ad2ca5c851a712c464060ae6974944458eb83880ba" | |||
| 
 | ||||
| [[package]] | ||||
| name = "bytes" | ||||
| version = "1.2.1" | ||||
| version = "1.3.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "ec8a7b6a70fde80372154c65702f00a0f56f3e1c36abbc6c440484be248856db" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "cache-padded" | ||||
| version = "1.2.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "c1db59621ec70f09c5e9b597b220c7a2b43611f4710dc03ceb8748637775692c" | ||||
| checksum = "dfb24e866b15a1af2a1b663f10c6b6b8f397a84aadb828f12e5b289ec23a3a3c" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "castaway" | ||||
|  | @ -278,9 +272,9 @@ checksum = "a2698f953def977c68f935bb0dfa959375ad4638570e969e2f1e9f433cbf1af6" | |||
| 
 | ||||
| [[package]] | ||||
| name = "cc" | ||||
| version = "1.0.76" | ||||
| version = "1.0.78" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "76a284da2e6fe2092f2353e51713435363112dfd60030e22add80be333fb928f" | ||||
| checksum = "a20104e2335ce8a659d6dd92a51a767a0c062599c73b343fd152cb401e828c3d" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "cfg-if" | ||||
|  | @ -290,14 +284,14 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" | |||
| 
 | ||||
| [[package]] | ||||
| name = "clap" | ||||
| version = "4.0.23" | ||||
| version = "4.0.29" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "0eb41c13df48950b20eb4cd0eefa618819469df1bffc49d11e8487c4ba0037e5" | ||||
| checksum = "4d63b9e9c07271b9957ad22c173bae2a4d9a81127680962039296abcd2f8251d" | ||||
| dependencies = [ | ||||
|  "atty", | ||||
|  "bitflags", | ||||
|  "clap_derive", | ||||
|  "clap_lex", | ||||
|  "is-terminal", | ||||
|  "once_cell", | ||||
|  "strsim", | ||||
|  "termcolor", | ||||
|  | @ -328,15 +322,6 @@ dependencies = [ | |||
|  "os_str_bytes", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "concurrent-queue" | ||||
| version = "1.2.4" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "af4780a44ab5696ea9e28294517f1fffb421a83a25af521333c838635509db9c" | ||||
| dependencies = [ | ||||
|  "cache-padded", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "concurrent-queue" | ||||
| version = "2.0.0" | ||||
|  | @ -348,9 +333,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "crossbeam-utils" | ||||
| version = "0.8.12" | ||||
| version = "0.8.14" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "edbafec5fa1f196ca66527c1b12c2ec4745ca14b50f1ad8f9f6f720b55d11fac" | ||||
| checksum = "4fb766fa798726286dbbb842f174001dab8abc7b627a1dd86e0b7222a95d929f" | ||||
| dependencies = [ | ||||
|  "cfg-if", | ||||
| ] | ||||
|  | @ -692,9 +677,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "gloo-timers" | ||||
| version = "0.2.4" | ||||
| version = "0.2.5" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "5fb7d06c1c8cc2a29bee7ec961009a0b2caa0793ee4900c2ffb348734ba1c8f9" | ||||
| checksum = "98c4a8d6391675c6b2ee1a6c8d06e8e2d03605c44cec1270675985a4c2a5500b" | ||||
| dependencies = [ | ||||
|  "futures-channel", | ||||
|  "futures-core", | ||||
|  | @ -704,9 +689,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "governor" | ||||
| version = "0.5.0" | ||||
| version = "0.5.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "de1b4626e87b9eb1d603ed23067ba1e29ec1d0b35325a2b96c3fe1cf20871f56" | ||||
| checksum = "c390a940a5d157878dd057c78680a33ce3415bcd05b4799509ea44210914b4d5" | ||||
| dependencies = [ | ||||
|  "cfg-if", | ||||
|  "dashmap", | ||||
|  | @ -760,6 +745,15 @@ dependencies = [ | |||
|  "libc", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "hermit-abi" | ||||
| version = "0.2.6" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "ee512640fe35acbfb4bb779db6f0d80704c2cacfa2e39b601ef3e3f47d1ae4c7" | ||||
| dependencies = [ | ||||
|  "libc", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "http" | ||||
| version = "0.2.8" | ||||
|  | @ -796,9 +790,9 @@ checksum = "c4a1e36c821dbe04574f602848a19f742f4fb3c98d40449f11bcad18d6b17421" | |||
| 
 | ||||
| [[package]] | ||||
| name = "httpmock" | ||||
| version = "0.6.6" | ||||
| version = "0.6.7" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "c159c4fc205e6c1a9b325cb7ec135d13b5f47188ce175dabb76ec847f331d9bd" | ||||
| checksum = "c6b56b6265f15908780cbee987912c1e98dbca675361f748291605a8a3a1df09" | ||||
| dependencies = [ | ||||
|  "assert-json-diff", | ||||
|  "async-object-pool", | ||||
|  | @ -848,9 +842,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "hyper-rustls" | ||||
| version = "0.23.0" | ||||
| version = "0.23.2" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "d87c48c02e0dc5e3b849a2041db3029fd066650f8f717c07bf8ed78ccb895cac" | ||||
| checksum = "1788965e61b367cd03a62950836d5cd41560c3577d90e40e0819373194d1661c" | ||||
| dependencies = [ | ||||
|  "http", | ||||
|  "hyper", | ||||
|  | @ -871,9 +865,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "indexmap" | ||||
| version = "1.9.1" | ||||
| version = "1.9.2" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "10a35a97730320ffe8e2d410b5d3b69279b98d2c14bdb8b70ea89ecf7888d41e" | ||||
| checksum = "1885e79c1fc4b10f0e172c475f458b7f7b93061064d98c3293e98c5ba0c8b399" | ||||
| dependencies = [ | ||||
|  "autocfg", | ||||
|  "hashbrown", | ||||
|  | @ -890,15 +884,31 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "io-lifetimes" | ||||
| version = "0.7.5" | ||||
| version = "1.0.3" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "59ce5ef949d49ee85593fc4d3f3f95ad61657076395cbbce23e2121fc5542074" | ||||
| checksum = "46112a93252b123d31a119a8d1a1ac19deac4fac6e0e8b0df58f0d4e5870e63c" | ||||
| dependencies = [ | ||||
|  "libc", | ||||
|  "windows-sys 0.42.0", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "ipnet" | ||||
| version = "2.5.1" | ||||
| version = "2.7.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "f88c5561171189e69df9d98bcf18fd5f9558300f7ea7b801eb8a0fd748bd8745" | ||||
| checksum = "11b0d96e660696543b251e58030cf9787df56da39dab19ad60eae7353040917e" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "is-terminal" | ||||
| version = "0.4.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "927609f78c2913a6f6ac3c27a4fe87f43e2a35367c0c4b0f8265e8f49a104330" | ||||
| dependencies = [ | ||||
|  "hermit-abi 0.2.6", | ||||
|  "io-lifetimes", | ||||
|  "rustix", | ||||
|  "windows-sys 0.42.0", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "isahc" | ||||
|  | @ -938,9 +948,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "itoa" | ||||
| version = "1.0.4" | ||||
| version = "1.0.5" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "4217ad341ebadf8d8e724e264f13e593e0648f5b3e94b3896a5df283be015ecc" | ||||
| checksum = "fad582f4b9e86b6caa621cabeb0963332d92eea04729ab12892c2533951e6440" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "js-sys" | ||||
|  | @ -1012,9 +1022,9 @@ checksum = "db13adb97ab515a3691f56e4dbab09283d0b86cb45abd991d8634a9d6f501760" | |||
| 
 | ||||
| [[package]] | ||||
| name = "libc" | ||||
| version = "0.2.137" | ||||
| version = "0.2.138" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "fc7fcc620a3bff7cdd7a365be3376c97191aeaccc2a603e600951e452615bf89" | ||||
| checksum = "db6d7e329c562c5dfab7a46a2afabc8b987ab9a4834c9d1ca04dc54c1546cef8" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "libnghttp2-sys" | ||||
|  | @ -1040,9 +1050,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "linux-raw-sys" | ||||
| version = "0.0.46" | ||||
| version = "0.1.4" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "d4d2456c373231a208ad294c33dc5bff30051eafd954cd4caae83a712b12854d" | ||||
| checksum = "f051f77a7c8e6957c0696eac88f26b0117e54f52d3fc682ab19397a8812846a4" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "lock_api" | ||||
|  | @ -1121,7 +1131,7 @@ version = "1.14.0" | |||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "f6058e64324c71e02bc2b150e4f3bc8286db6c83092132ffa3f6b1eab0f9def5" | ||||
| dependencies = [ | ||||
|  "hermit-abi", | ||||
|  "hermit-abi 0.1.19", | ||||
|  "libc", | ||||
| ] | ||||
| 
 | ||||
|  | @ -1139,9 +1149,9 @@ checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" | |||
| 
 | ||||
| [[package]] | ||||
| name = "openssl-sys" | ||||
| version = "0.9.77" | ||||
| version = "0.9.79" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "b03b84c3b2d099b81f0953422b4d4ad58761589d0229b5506356afca05a3670a" | ||||
| checksum = "5454462c0eced1e97f2ec09036abc8da362e66802f66fd20f86854d9d8cbcbc4" | ||||
| dependencies = [ | ||||
|  "autocfg", | ||||
|  "cc", | ||||
|  | @ -1152,9 +1162,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "os_str_bytes" | ||||
| version = "6.4.0" | ||||
| version = "6.4.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "7b5bf27447411e9ee3ff51186bf7a08e16c341efdde93f4d823e8844429bed7e" | ||||
| checksum = "9b7820b9daea5457c9f21c69448905d723fbd21136ccf521748f23fd49e723ee" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "parking" | ||||
|  | @ -1174,9 +1184,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "parking_lot_core" | ||||
| version = "0.9.4" | ||||
| version = "0.9.5" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "4dc9e0dc2adc1c69d09143aff38d3d30c5c3f0df0dad82e6d25547af174ebec0" | ||||
| checksum = "7ff9f3fef3968a3ec5945535ed654cb38ff72d7495a25619e2247fb15a2ed9ba" | ||||
| dependencies = [ | ||||
|  "cfg-if", | ||||
|  "libc", | ||||
|  | @ -1256,16 +1266,16 @@ checksum = "6ac9a59f73473f1b8d852421e59e64809f025994837ef743615c6d0c5b305160" | |||
| 
 | ||||
| [[package]] | ||||
| name = "polling" | ||||
| version = "2.4.0" | ||||
| version = "2.5.2" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "ab4609a838d88b73d8238967b60dd115cc08d38e2bbaf51ee1e4b695f89122e2" | ||||
| checksum = "22122d5ec4f9fe1b3916419b76be1e80bcb93f618d071d2edf841b137b2a2bd6" | ||||
| dependencies = [ | ||||
|  "autocfg", | ||||
|  "cfg-if", | ||||
|  "libc", | ||||
|  "log", | ||||
|  "wepoll-ffi", | ||||
|  "winapi", | ||||
|  "windows-sys 0.42.0", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
|  | @ -1306,9 +1316,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "proc-macro2" | ||||
| version = "1.0.47" | ||||
| version = "1.0.48" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "5ea3d908b0e36316caf9e9e2c4625cdde190a7e6f440d794667ed17a1855e725" | ||||
| checksum = "e9d89e5dba24725ae5678020bf8f1357a9aa7ff10736b551adbcd3f8d17d766f" | ||||
| dependencies = [ | ||||
|  "unicode-ident", | ||||
| ] | ||||
|  | @ -1331,9 +1341,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "quote" | ||||
| version = "1.0.21" | ||||
| version = "1.0.22" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "bbe448f377a7d6961e30f5955f9b8d106c3f5e449d493ee1b125c1d43c2b5179" | ||||
| checksum = "556d0f47a940e895261e77dc200d5eadfc6ef644c179c6f5edfc105e3a2292c8" | ||||
| dependencies = [ | ||||
|  "proc-macro2", | ||||
| ] | ||||
|  | @ -1416,9 +1426,9 @@ checksum = "456c603be3e8d448b072f410900c09faf164fbce2d480456f50eea6e25f9c848" | |||
| 
 | ||||
| [[package]] | ||||
| name = "reqwest" | ||||
| version = "0.11.12" | ||||
| version = "0.11.13" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "431949c384f4e2ae07605ccaa56d1d9d2ecdb5cadd4f9577ccfab29f2e5149fc" | ||||
| checksum = "68cc60575865c7831548863cc02356512e3f1dc2f3f82cb837d7fc4cc8f3c97c" | ||||
| dependencies = [ | ||||
|  "base64", | ||||
|  "bytes", | ||||
|  | @ -1470,9 +1480,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "rustix" | ||||
| version = "0.35.13" | ||||
| version = "0.36.5" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "727a1a6d65f786ec22df8a81ca3121107f235970dc1705ed681d3e6e8b9cd5f9" | ||||
| checksum = "a3807b5d10909833d3e9acd1eb5fb988f79376ff10fce42937de71a449c4c588" | ||||
| dependencies = [ | ||||
|  "bitflags", | ||||
|  "errno", | ||||
|  | @ -1505,15 +1515,15 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "rustversion" | ||||
| version = "1.0.9" | ||||
| version = "1.0.11" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "97477e48b4cf8603ad5f7aaf897467cf42ab4218a38ef76fb14c2d6773a6d6a8" | ||||
| checksum = "5583e89e108996506031660fe09baa5011b9dd0341b89029313006d1fb508d70" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "ryu" | ||||
| version = "1.0.11" | ||||
| version = "1.0.12" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "4501abdff3ae82a1c1b477a17252eb69cee9e66eb915c1abaa4f44d873df9f09" | ||||
| checksum = "7b4b9743ed687d4b4bcedf9ff5eaa7398495ae14e61cba0a295704edbc7decde" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "schannel" | ||||
|  | @ -1543,18 +1553,18 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "serde" | ||||
| version = "1.0.147" | ||||
| version = "1.0.151" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "d193d69bae983fc11a79df82342761dfbf28a99fc8d203dca4c3c1b590948965" | ||||
| checksum = "97fed41fc1a24994d044e6db6935e69511a1153b52c15eb42493b26fa87feba0" | ||||
| dependencies = [ | ||||
|  "serde_derive", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "serde_derive" | ||||
| version = "1.0.147" | ||||
| version = "1.0.151" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "4f1d362ca8fc9c3e3a7484440752472d68a6caa98f1ab81d99b5dfe517cec852" | ||||
| checksum = "255abe9a125a985c05190d687b320c12f9b1f0b99445e608c21ba0782c719ad8" | ||||
| dependencies = [ | ||||
|  "proc-macro2", | ||||
|  "quote", | ||||
|  | @ -1563,9 +1573,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "serde_json" | ||||
| version = "1.0.87" | ||||
| version = "1.0.90" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "6ce777b7b150d76b9cf60d28b55f5847135a003f7d7350c6be7a773508ce7d45" | ||||
| checksum = "8778cc0b528968fe72abec38b5db5a20a70d148116cd9325d2bc5f5180ca3faf" | ||||
| dependencies = [ | ||||
|  "itoa", | ||||
|  "ryu", | ||||
|  | @ -1615,9 +1625,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "similar" | ||||
| version = "2.2.0" | ||||
| version = "2.2.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "62ac7f900db32bf3fd12e0117dd3dc4da74bc52ebaac97f39668446d89694803" | ||||
| checksum = "420acb44afdae038210c99e69aae24109f32f15500aa708e81d46c9f29d55fcf" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "siphasher" | ||||
|  | @ -1688,9 +1698,9 @@ checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" | |||
| 
 | ||||
| [[package]] | ||||
| name = "syn" | ||||
| version = "1.0.103" | ||||
| version = "1.0.106" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "a864042229133ada95abf3b54fdc62ef5ccabe9515b64717bcb9a1919e59445d" | ||||
| checksum = "09ee3a69cd2c7e06684677e5629b3878b253af05e4714964204279c6bc02cf0b" | ||||
| dependencies = [ | ||||
|  "proc-macro2", | ||||
|  "quote", | ||||
|  | @ -1719,9 +1729,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "terminal_size" | ||||
| version = "0.2.2" | ||||
| version = "0.2.3" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "40ca90c434fd12083d1a6bdcbe9f92a14f96c8a1ba600ba451734ac334521f7a" | ||||
| checksum = "cb20089a8ba2b69debd491f8d2d023761cbf196e999218c591fa1e7e15a21907" | ||||
| dependencies = [ | ||||
|  "rustix", | ||||
|  "windows-sys 0.42.0", | ||||
|  | @ -1729,18 +1739,18 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "thiserror" | ||||
| version = "1.0.37" | ||||
| version = "1.0.38" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "10deb33631e3c9018b9baf9dcbbc4f737320d2b576bac10f6aefa048fa407e3e" | ||||
| checksum = "6a9cd18aa97d5c45c6603caea1da6628790b37f7a34b6ca89522331c5180fed0" | ||||
| dependencies = [ | ||||
|  "thiserror-impl", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "thiserror-impl" | ||||
| version = "1.0.37" | ||||
| version = "1.0.38" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "982d17546b47146b28f7c22e3d08465f6b8903d0ea13c1660d9d84a6e7adcdbb" | ||||
| checksum = "1fb327af4685e4d03fa8cbcf1716380da910eeb2bb8be417e7f9fd3fb164f36f" | ||||
| dependencies = [ | ||||
|  "proc-macro2", | ||||
|  "quote", | ||||
|  | @ -1773,9 +1783,9 @@ checksum = "cda74da7e1a664f795bb1f8a87ec406fb89a02522cf6e50620d016add6dbbf5c" | |||
| 
 | ||||
| [[package]] | ||||
| name = "tokio" | ||||
| version = "1.21.2" | ||||
| version = "1.23.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "a9e03c497dc955702ba729190dc4aac6f2a0ce97f913e5b1b5912fc5039d9099" | ||||
| checksum = "eab6d665857cc6ca78d6e80303a02cea7a7851e85dfbd77cbdc09bd129f1ef46" | ||||
| dependencies = [ | ||||
|  "autocfg", | ||||
|  "bytes", | ||||
|  | @ -1788,14 +1798,14 @@ dependencies = [ | |||
|  "signal-hook-registry", | ||||
|  "socket2", | ||||
|  "tokio-macros", | ||||
|  "winapi", | ||||
|  "windows-sys 0.42.0", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "tokio-macros" | ||||
| version = "1.8.0" | ||||
| version = "1.8.2" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "9724f9a975fb987ef7a3cd9be0350edcbe130698af5b8f7a631e23d42d052484" | ||||
| checksum = "d266c00fde287f55d3f1c3e96c500c362a2b8c695076ec180f27918820bc6df8" | ||||
| dependencies = [ | ||||
|  "proc-macro2", | ||||
|  "quote", | ||||
|  | @ -1829,9 +1839,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "toml" | ||||
| version = "0.5.9" | ||||
| version = "0.5.10" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "8d82e1a7758622a465f8cee077614c73484dac5b836c02ff6a40d5d1010324d7" | ||||
| checksum = "1333c76748e868a4d9d1017b5ab53171dfd095f70c712fdb4653a406547f598f" | ||||
| dependencies = [ | ||||
|  "serde", | ||||
| ] | ||||
|  | @ -1908,9 +1918,9 @@ checksum = "099b7128301d285f79ddd55b9a83d5e6b9e97c92e0ea0daebee7263e932de992" | |||
| 
 | ||||
| [[package]] | ||||
| name = "unicode-ident" | ||||
| version = "1.0.5" | ||||
| version = "1.0.6" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "6ceab39d59e4c9499d4e5a8ee0e2735b891bb7308ac83dfb4e80cad195c9f6f3" | ||||
| checksum = "84a22b9f218b40614adcb3f4ff08b703773ad44fa9423e4e0d346d5db86e4ebc" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "unicode-normalization" | ||||
|  | @ -2088,9 +2098,9 @@ dependencies = [ | |||
| 
 | ||||
| [[package]] | ||||
| name = "webpki-roots" | ||||
| version = "0.22.5" | ||||
| version = "0.22.6" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "368bfe657969fb01238bb756d351dcade285e0f6fcbd36dcb23359a5169975be" | ||||
| checksum = "b6c71e40d7d2c34a5106301fb632274ca37242cd0c9d3e64dbece371a40a2d87" | ||||
| dependencies = [ | ||||
|  "webpki", | ||||
| ] | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| [package] | ||||
| name = "gandi-live-dns" | ||||
| description = "Automatically updates your IP address in Gandi's Live DNS. Makes it possible to use Gandi as a dynamic DNS system." | ||||
| version = "1.5.0" | ||||
| version = "1.6.0" | ||||
| edition = "2021" | ||||
| authors = ["Kaan Barmore-Genç <kaan@bgenc.net>"] | ||||
| license = "MIT" | ||||
|  | @ -27,7 +27,7 @@ clap = { version = "4.0", features = [ | |||
|   "unicode", | ||||
|   "wrap_help", | ||||
| ] } | ||||
| tokio = { version = "1.20", features = ["full"] } | ||||
| tokio = { version = "1.23", features = ["full"] } | ||||
| futures = "0.3" | ||||
| anyhow = "1.0" | ||||
| governor = "0.5" | ||||
|  |  | |||
							
								
								
									
										34
									
								
								Readme.md
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								Readme.md
									
									
									
									
									
								
							|  | @ -1,6 +1,6 @@ | |||
| ## gandi-live-dns-rust | ||||
| 
 | ||||
| [](https://github.com/SeriousBug/gandi-live-dns-rust/actions/workflows/test.yml) [](https://codecov.io/gh/SeriousBug/gandi-live-dns-rust) [](https://github.com/SeriousBug/gandi-live-dns-rust/actions/workflows/lint.yml) [](https://github.com/SeriousBug/gandi-live-dns-rust/releases) [](https://hub.docker.com/r/seriousbug/gandi-live-dns-rust) [](https://github.com/SeriousBug/gandi-live-dns-rust/blob/master/LICENSE.txt) | ||||
| [](https://github.com/SeriousBug/gandi-live-dns-rust/actions/workflows/test.yml) [](https://codecov.io/gh/SeriousBug/gandi-live-dns-rust) [](https://github.com/SeriousBug/gandi-live-dns-rust/actions/workflows/lint.yml) [](https://github.com/SeriousBug/gandi-live-dns-rust/releases) [](https://hub.docker.com/r/seriousbug/gandi-live-dns-rust) [](https://github.com/SeriousBug/gandi-live-dns-rust/blob/master/LICENSE.txt) | ||||
| 
 | ||||
| A program that can set the IP addresses for configured DNS entries in | ||||
| [Gandi](https://gandi.net)'s domain configuration. Thanks to Gandi's | ||||
|  | @ -10,8 +10,8 @@ this creates a dynamic DNS system. | |||
| If you want to host web services but you don't have a static IP address, this | ||||
| tool will allow you to keep your domains pointed at the right IP address. This | ||||
| program can update both IPv4 and IPv6 addresses for one or more domains and | ||||
| subdomains. It's a one-shot tool that's meant to be managed with a systemd timer | ||||
| or cron. | ||||
| subdomains. It can be used as a one-shot tool managed with a systemd timer | ||||
| or cron, or a long-running process that reschedules itself. | ||||
| 
 | ||||
| ## Usage | ||||
| 
 | ||||
|  | @ -67,6 +67,34 @@ build it from source and you have a working rust install, you can use `cargo ins | |||
| 
 | ||||
| ## Automation | ||||
| 
 | ||||
| ### By running as a background process | ||||
| 
 | ||||
| `gandi-live-dns` can run as a daemon, a background process, periodically perform | ||||
| the IP address updates. To do so, add the `--repeat=<delay-in-seconds>` command | ||||
| line option. When given, this tool will not quit after updating your IP address | ||||
| and instead will continue to perform periodic updates. | ||||
| 
 | ||||
| If you are using Docker, you can add this option when starting it: | ||||
| 
 | ||||
| ```bash | ||||
| # This will update your IP now, then repeat every 24 hours | ||||
| docker run --rm -it -v $(pwd)/gandi.toml:/gandi.toml:ro seriousbug/gandi-live-dns-rust:latest --repeat=86400 | ||||
| ``` | ||||
| 
 | ||||
| Or with a `docker-compose.yml` file, add it in the arguments: | ||||
| 
 | ||||
| ```yml | ||||
|   gandi-live-dns: | ||||
|     image: seriousbug/gandi-live-dns-rust:latest | ||||
|     restart: always | ||||
|     volumes: | ||||
|       - ./gandi.toml:/gandi.toml:ro | ||||
|     # Repeat the update every day | ||||
|     command: --repeat=86400 | ||||
| ``` | ||||
| 
 | ||||
| ### With a Systemd timer | ||||
| 
 | ||||
| The `Packaging` folder contains a Systemd service and timer, which you can use | ||||
| to automatically run this tool. By default it will update the IP addresses after | ||||
| every boot up, and at least once a day. You can adjust the timer to speed this | ||||
|  |  | |||
|  | @ -1,5 +1,4 @@ | |||
| use crate::opts; | ||||
| use anyhow; | ||||
| use directories::ProjectDirs; | ||||
| use serde::Deserialize; | ||||
| use std::fs; | ||||
|  | @ -19,10 +18,10 @@ pub struct Entry { | |||
| } | ||||
| 
 | ||||
| fn default_ttl() -> u32 { | ||||
|     return 300; | ||||
|     300 | ||||
| } | ||||
| 
 | ||||
| #[derive(Deserialize, PartialEq, Debug)] | ||||
| #[derive(Deserialize, Debug, PartialEq, Eq)] | ||||
| pub enum IPSourceName { | ||||
|     Ipify, | ||||
|     Icanhazip, | ||||
|  | @ -47,7 +46,7 @@ pub struct Config { | |||
|     pub ttl: u32, | ||||
| } | ||||
| 
 | ||||
| const DEFAULT_TYPES: &'static [&'static str] = &["A"]; | ||||
| const DEFAULT_TYPES: &[&str] = &["A"]; | ||||
| 
 | ||||
| impl Config { | ||||
|     pub fn fqdn<'c>(entry: &'c Entry, config: &'c Config) -> &'c str { | ||||
|  | @ -58,7 +57,7 @@ impl Config { | |||
|         entry.ttl.unwrap_or(config.ttl) | ||||
|     } | ||||
| 
 | ||||
|     pub fn types<'e>(entry: &'e Entry) -> Vec<&'e str> { | ||||
|     pub fn types(entry: &Entry) -> Vec<&str> { | ||||
|         entry.types.iter().map(|t| t.as_str()).collect() | ||||
|     } | ||||
| } | ||||
|  | @ -70,11 +69,11 @@ fn load_config_from<P: std::convert::AsRef<std::path::Path>>(path: P) -> anyhow: | |||
| 
 | ||||
| pub fn load_config(opts: &opts::Opts) -> anyhow::Result<Config> { | ||||
|     let mut config = match &opts.config { | ||||
|         Some(config_path) => load_config_from(&config_path), | ||||
|         Some(config_path) => load_config_from(config_path), | ||||
|         None => { | ||||
|             let confpath = ProjectDirs::from("me", "kaangenc", "gandi-dynamic-dns") | ||||
|                 .and_then(|dir| Some(PathBuf::from(dir.config_dir()).join("config.toml"))) | ||||
|                 .ok_or(anyhow::anyhow!("Can't find config directory")); | ||||
|                 .map(|dir| PathBuf::from(dir.config_dir()).join("config.toml")) | ||||
|                 .ok_or_else(|| anyhow::anyhow!("Can't find config directory")); | ||||
|             confpath | ||||
|                 .and_then(|path| { | ||||
|                     println!("Checking for config: {}", path.to_string_lossy()); | ||||
|  | @ -93,11 +92,9 @@ pub fn load_config(opts: &opts::Opts) -> anyhow::Result<Config> { | |||
|             .entry | ||||
|             .into_iter() | ||||
|             .map(|mut entry| { | ||||
|                 entry.types = entry | ||||
|                 entry | ||||
|                     .types | ||||
|                     .into_iter() | ||||
|                     .filter(|v| (v == "A" && !opts.skip_ipv4) || (v == "AAAA" && !opts.skip_ipv6)) | ||||
|                     .collect(); | ||||
|                     .retain(|v| (v == "A" && !opts.skip_ipv4) || (v == "AAAA" && !opts.skip_ipv6)); | ||||
|                 entry | ||||
|             }) | ||||
|             .collect(); | ||||
|  | @ -107,13 +104,13 @@ pub fn load_config(opts: &opts::Opts) -> anyhow::Result<Config> { | |||
| 
 | ||||
| pub fn validate_config(config: &Config) -> anyhow::Result<()> { | ||||
|     for entry in &config.entry { | ||||
|         for entry_type in Config::types(&entry) { | ||||
|         for entry_type in Config::types(entry) { | ||||
|             if entry_type != "A" && entry_type != "AAAA" { | ||||
|                 anyhow::bail!("Entry {} has invalid type {}", entry.name, entry_type); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     return Ok(()); | ||||
|     Ok(()) | ||||
| } | ||||
| 
 | ||||
| #[cfg(test)] | ||||
|  |  | |||
|  | @ -1,4 +1,3 @@ | |||
| use anyhow; | ||||
| use async_trait::async_trait; | ||||
| 
 | ||||
| use super::ip_source::IPSource; | ||||
|  |  | |||
|  | @ -1,4 +1,3 @@ | |||
| use anyhow; | ||||
| use async_trait::async_trait; | ||||
| 
 | ||||
| #[async_trait] | ||||
|  |  | |||
|  | @ -1,4 +1,3 @@ | |||
| use anyhow; | ||||
| use async_trait::async_trait; | ||||
| 
 | ||||
| use super::ip_source::IPSource; | ||||
|  |  | |||
							
								
								
									
										34
									
								
								src/main.rs
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								src/main.rs
									
									
									
									
									
								
							|  | @ -1,21 +1,18 @@ | |||
| use crate::config::Config; | ||||
| use crate::gandi::GandiAPI; | ||||
| use crate::ip_source::{ip_source::IPSource, ipify::IPSourceIpify}; | ||||
| use anyhow; | ||||
| use clap::Parser; | ||||
| use config::IPSourceName; | ||||
| use futures; | ||||
| use ip_source::icanhazip::IPSourceIcanhazip; | ||||
| use reqwest::{header, Client, ClientBuilder, StatusCode}; | ||||
| use serde::Serialize; | ||||
| use std::{num::NonZeroU32, sync::Arc, time::Duration}; | ||||
| use tokio::{self, task::JoinHandle}; | ||||
| use tokio::{self, task::JoinHandle, time::sleep}; | ||||
| mod config; | ||||
| mod gandi; | ||||
| mod ip_source; | ||||
| mod opts; | ||||
| use die_exit_2::*; | ||||
| use governor; | ||||
| 
 | ||||
| /// 30 requests per minute, see https://api.gandi.net/docs/reference/
 | ||||
| const GANDI_RATE_LIMIT: u32 = 30; | ||||
|  | @ -33,7 +30,7 @@ fn api_client(api_key: &str) -> anyhow::Result<Client> { | |||
|     let accept_value = header::HeaderValue::from_static("application/json"); | ||||
|     headers.insert(header::ACCEPT, accept_value); | ||||
|     let client = client_builder.default_headers(headers).build()?; | ||||
|     return Ok(client); | ||||
|     Ok(client) | ||||
| } | ||||
| 
 | ||||
| #[derive(Serialize)] | ||||
|  | @ -42,8 +39,8 @@ pub struct APIPayload { | |||
|     pub rrset_ttl: u32, | ||||
| } | ||||
| 
 | ||||
| async fn run<IP: IPSource>(base_url: &str, conf: Config) -> anyhow::Result<()> { | ||||
|     config::validate_config(&conf).die_with(|error| format!("Invalid config: {}", error)); | ||||
| async fn run<IP: IPSource>(base_url: &str, conf: &Config) -> anyhow::Result<()> { | ||||
|     config::validate_config(conf).die_with(|error| format!("Invalid config: {}", error)); | ||||
|     println!("Finding out the IP address..."); | ||||
|     let ipv4_result = IP::get_ipv4().await; | ||||
|     let ipv6_result = IP::get_ipv6().await; | ||||
|  | @ -71,11 +68,11 @@ async fn run<IP: IPSource>(base_url: &str, conf: Config) -> anyhow::Result<()> { | |||
| 
 | ||||
|     for entry in &conf.entry { | ||||
|         for entry_type in Config::types(entry) { | ||||
|             let fqdn = Config::fqdn(&entry, &conf).to_string(); | ||||
|             let fqdn = Config::fqdn(entry, conf).to_string(); | ||||
|             let url = GandiAPI { | ||||
|                 fqdn: &fqdn, | ||||
|                 rrset_name: &entry.name, | ||||
|                 rrset_type: &entry_type, | ||||
|                 rrset_type: entry_type, | ||||
|                 base_url, | ||||
|             } | ||||
|             .url(); | ||||
|  | @ -86,7 +83,7 @@ async fn run<IP: IPSource>(base_url: &str, conf: Config) -> anyhow::Result<()> { | |||
|             }; | ||||
|             let payload = APIPayload { | ||||
|                 rrset_values: vec![ip.to_string()], | ||||
|                 rrset_ttl: Config::ttl(&entry, &conf), | ||||
|                 rrset_ttl: Config::ttl(entry, conf), | ||||
|             }; | ||||
|             let req = client.put(url).json(&payload); | ||||
|             let task_governor = governor.clone(); | ||||
|  | @ -124,6 +121,21 @@ async fn main() -> anyhow::Result<()> { | |||
|     let conf = config::load_config(&opts) | ||||
|         .die_with(|error| format!("Failed to read config file: {}", error)); | ||||
| 
 | ||||
|     // run indefinitely if repeat is given
 | ||||
|     if let Some(delay) = opts.repeat { | ||||
|         loop { | ||||
|             run_dispatch(&conf).await.ok(); | ||||
|             sleep(Duration::from_secs(delay)).await | ||||
|         } | ||||
|     } | ||||
|     // otherwise run just once
 | ||||
|     else { | ||||
|         run_dispatch(&conf).await?; | ||||
|         Ok(()) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| async fn run_dispatch(conf: &Config) -> anyhow::Result<()> { | ||||
|     match conf.ip_source { | ||||
|         IPSourceName::Ipify => run::<IPSourceIpify>("https://api.gandi.net", conf).await, | ||||
|         IPSourceName::Icanhazip => run::<IPSourceIcanhazip>("https://api.gandi.net", conf).await, | ||||
|  | @ -182,7 +194,7 @@ mod tests { | |||
|             ..Opts::default() | ||||
|         }; | ||||
|         let conf = config::load_config(&opts).expect("Failed to load config"); | ||||
|         run::<IPSourceMock>(server.base_url().as_str(), conf) | ||||
|         run::<IPSourceMock>(server.base_url().as_str(), &conf) | ||||
|             .await | ||||
|             .expect("Failed when running the update"); | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										10
									
								
								src/opts.rs
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/opts.rs
									
									
									
									
									
								
							|  | @ -17,4 +17,14 @@ pub struct Opts { | |||
|     /// If enabled, any IPv6 (AAAA) records in the configuration file are ignored.
 | ||||
|     #[clap(action, long)] | ||||
|     pub skip_ipv6: bool, | ||||
|     /// Repeat after specified delay, in seconds.
 | ||||
|     ///
 | ||||
|     /// If enabled, this will continue to run and perform the updates
 | ||||
|     /// periodically. The first update will happen immediately, and later
 | ||||
|     /// updates will be delayed by this many seconds.
 | ||||
|     ///
 | ||||
|     /// This process will not fork, so you may need to use something like
 | ||||
|     /// `nohup` to keep it running in the background.
 | ||||
|     #[clap(long)] | ||||
|     pub repeat: Option<u64>, | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue