mirror of
				https://github.com/SeriousBug/gandi-live-dns-rust
				synced 2025-10-25 02:07:01 -05:00 
			
		
		
		
	Add new IP source "seeip" (#90)
This commit is contained in:
		
							parent
							
								
									327b14a00a
								
							
						
					
					
						commit
						27a60d3ac2
					
				|  | @ -19,8 +19,9 @@ ttl = 300 | ||||||
| # Ipify is used by default. If you want to change it, uncomment the one you want | # Ipify is used by default. If you want to change it, uncomment the one you want | ||||||
| # to use. | # to use. | ||||||
| # | # | ||||||
| # ip_source = "Ipify" | #ip_source = "Ipify"     # An open source and public service. https://github.com/rdegges/ipify-api | ||||||
| # ip_source = "Icanhazip" | #ip_source = "Icanhazip" # A free service, currently run by Cloudflare. https://major.io/2021/06/06/a-new-future-for-icanhazip/ | ||||||
|  | #ip_source = "SeeIP"     # A free service, run by UNVIO, LLC. https://seeip.org/ | ||||||
| 
 | 
 | ||||||
| # For every domain or subdomain you want to update, create an entry below. | # For every domain or subdomain you want to update, create an entry below. | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -25,6 +25,7 @@ fn default_ttl() -> u32 { | ||||||
| pub enum IPSourceName { | pub enum IPSourceName { | ||||||
|     Ipify, |     Ipify, | ||||||
|     Icanhazip, |     Icanhazip, | ||||||
|  |     SeeIP, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Default for IPSourceName { | impl Default for IPSourceName { | ||||||
|  |  | ||||||
|  | @ -2,5 +2,5 @@ The IP sources. These are APIs that we can query to get the IP address of the | ||||||
| current service. | current service. | ||||||
| 
 | 
 | ||||||
| The tests under this directory are all marked to be skipped, the tests hit the | The tests under this directory are all marked to be skipped, the tests hit the | ||||||
| actual APIs and can be flakey in CI. Make sure to run the tests manually if you | actual APIs and can be flaky in CI. Make sure to run the tests manually if you | ||||||
| have to modify the code. | have to modify the code. | ||||||
|  |  | ||||||
|  | @ -1,3 +1,4 @@ | ||||||
| pub(crate) mod icanhazip; | pub(crate) mod icanhazip; | ||||||
| pub(crate) mod ip_source; | pub(crate) mod ip_source; | ||||||
| pub(crate) mod ipify; | pub(crate) mod ipify; | ||||||
|  | pub(crate) mod seeip; | ||||||
|  |  | ||||||
							
								
								
									
										53
									
								
								src/ip_source/seeip.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								src/ip_source/seeip.rs
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,53 @@ | ||||||
|  | use async_trait::async_trait; | ||||||
|  | 
 | ||||||
|  | use super::ip_source::IPSource; | ||||||
|  | 
 | ||||||
|  | pub(crate) struct IPSourceSeeIP; | ||||||
|  | 
 | ||||||
|  | async fn get_ip(api_url: &str) -> anyhow::Result<String> { | ||||||
|  |     let response = reqwest::get(api_url).await?; | ||||||
|  |     let text = response.text().await?; | ||||||
|  |     Ok(text) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[async_trait] | ||||||
|  | impl IPSource for IPSourceSeeIP { | ||||||
|  |     async fn get_ipv4(&self) -> anyhow::Result<String> { | ||||||
|  |         get_ip("https://ip4.seeip.org").await | ||||||
|  |     } | ||||||
|  |     async fn get_ipv6(&self) -> anyhow::Result<String> { | ||||||
|  |         get_ip("https://ip6.seeip.org").await | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[cfg(test)] | ||||||
|  | mod tests { | ||||||
|  |     use regex::Regex; | ||||||
|  | 
 | ||||||
|  |     use super::IPSource; | ||||||
|  |     use super::IPSourceSeeIP; | ||||||
|  | 
 | ||||||
|  |     #[tokio::test] | ||||||
|  |     #[ignore] | ||||||
|  |     async fn ipv4_test() { | ||||||
|  |         let ipv4 = IPSourceSeeIP | ||||||
|  |             .get_ipv4() | ||||||
|  |             .await | ||||||
|  |             .expect("Failed to get the IP address"); | ||||||
|  |         assert!(Regex::new(r"^\d+[.]\d+[.]\d+[.]\d+$") | ||||||
|  |             .unwrap() | ||||||
|  |             .is_match(ipv4.as_str())) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[tokio::test] | ||||||
|  |     #[ignore] | ||||||
|  |     async fn ipv6_test() { | ||||||
|  |         let ipv6 = IPSourceSeeIP | ||||||
|  |             .get_ipv6() | ||||||
|  |             .await | ||||||
|  |             .expect("Failed to get the IP address"); | ||||||
|  |         assert!(Regex::new(r"^([0-9a-fA-F]*:){7}[0-9a-fA-F]*$") | ||||||
|  |             .unwrap() | ||||||
|  |             .is_match(ipv6.as_str())) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @ -4,6 +4,7 @@ use crate::ip_source::{ip_source::IPSource, ipify::IPSourceIpify}; | ||||||
| use clap::Parser; | use clap::Parser; | ||||||
| use config::IPSourceName; | use config::IPSourceName; | ||||||
| use ip_source::icanhazip::IPSourceIcanhazip; | use ip_source::icanhazip::IPSourceIcanhazip; | ||||||
|  | use ip_source::seeip::IPSourceSeeIP; | ||||||
| use opts::Opts; | use opts::Opts; | ||||||
| use reqwest::{header, Client, ClientBuilder, StatusCode}; | use reqwest::{header, Client, ClientBuilder, StatusCode}; | ||||||
| use serde::Serialize; | use serde::Serialize; | ||||||
|  | @ -158,6 +159,7 @@ async fn main() -> anyhow::Result<()> { | ||||||
|     let ip_source: Box<dyn IPSource> = match conf.ip_source { |     let ip_source: Box<dyn IPSource> = match conf.ip_source { | ||||||
|         IPSourceName::Ipify => Box::new(IPSourceIpify), |         IPSourceName::Ipify => Box::new(IPSourceIpify), | ||||||
|         IPSourceName::Icanhazip => Box::new(IPSourceIcanhazip), |         IPSourceName::Icanhazip => Box::new(IPSourceIcanhazip), | ||||||
|  |         IPSourceName::SeeIP => Box::new(IPSourceSeeIP), | ||||||
|     }; |     }; | ||||||
|     config::validate_config(&conf).die_with(|error| format!("Invalid config: {}", error)); |     config::validate_config(&conf).die_with(|error| format!("Invalid config: {}", error)); | ||||||
|     run("https://api.gandi.net", &ip_source, &conf, &opts).await?; |     run("https://api.gandi.net", &ip_source, &conf, &opts).await?; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue