mirror of
https://codeberg.org/slatian/service.echoip-slatecave.git
synced 2025-01-15 21:13:05 +01:00
Did some renaming because calling all those fields idna didn't really make sense.
Also switched to the less strict domain to ascii because the errors aren't exactly very well machine readable.
This commit is contained in:
parent
d202ebb14e
commit
1108b7d653
16
src/idna.rs
16
src/idna.rs
@ -14,7 +14,7 @@ pub enum NameType {
|
|||||||
Ascii,
|
Ascii,
|
||||||
#[default]
|
#[default]
|
||||||
Unicode,
|
Unicode,
|
||||||
IDNA,
|
IDN,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Note, that the
|
// Note, that the
|
||||||
@ -23,7 +23,7 @@ pub struct IdnaName {
|
|||||||
pub unicode: String,
|
pub unicode: String,
|
||||||
// if null the unicode version only contains ascii range chars,
|
// if null the unicode version only contains ascii range chars,
|
||||||
// not neccessary to encode
|
// not neccessary to encode
|
||||||
pub idna: Option<String>,
|
pub idn: Option<String>,
|
||||||
pub original_was: NameType,
|
pub original_was: NameType,
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub decoder_error: Option<String>,
|
pub decoder_error: Option<String>,
|
||||||
@ -37,7 +37,7 @@ impl IdnaName {
|
|||||||
let unicode: String;
|
let unicode: String;
|
||||||
let decoder_error;
|
let decoder_error;
|
||||||
if s.starts_with("xn--") && s.is_ascii() {
|
if s.starts_with("xn--") && s.is_ascii() {
|
||||||
original_was = NameType::IDNA;
|
original_was = NameType::IDN;
|
||||||
let (uc, ures) = idna::domain_to_unicode(s);
|
let (uc, ures) = idna::domain_to_unicode(s);
|
||||||
unicode = uc;
|
unicode = uc;
|
||||||
decoder_error = ures.map_or_else(|e| Some(e.to_string()), |_| None);
|
decoder_error = ures.map_or_else(|e| Some(e.to_string()), |_| None);
|
||||||
@ -45,10 +45,10 @@ impl IdnaName {
|
|||||||
unicode = s.clone();
|
unicode = s.clone();
|
||||||
decoder_error = None;
|
decoder_error = None;
|
||||||
};
|
};
|
||||||
let (idna, encoder_error) = match idna::domain_to_ascii_strict(s) {
|
let (idn, encoder_error) = match idna::domain_to_ascii(s) {
|
||||||
Ok(idna) => {
|
Ok(idn) => {
|
||||||
if &idna != s || original_was == NameType::IDNA{
|
if &idn != s || original_was == NameType::IDN {
|
||||||
(Some(idna), None)
|
(Some(idn), None)
|
||||||
} else {
|
} else {
|
||||||
original_was = NameType::Ascii;
|
original_was = NameType::Ascii;
|
||||||
(None, None)
|
(None, None)
|
||||||
@ -61,7 +61,7 @@ impl IdnaName {
|
|||||||
|
|
||||||
IdnaName {
|
IdnaName {
|
||||||
unicode: unicode,
|
unicode: unicode,
|
||||||
idna: idna,
|
idn: idn,
|
||||||
original_was: original_was,
|
original_was: original_was,
|
||||||
|
|
||||||
decoder_error: decoder_error,
|
decoder_error: decoder_error,
|
||||||
|
@ -77,7 +77,7 @@ pub struct IpResult {
|
|||||||
pub struct DigResult {
|
pub struct DigResult {
|
||||||
records: simple_dns::DnsLookupResult,
|
records: simple_dns::DnsLookupResult,
|
||||||
#[serde(skip_serializing_if = "IdnaName::was_ascii")]
|
#[serde(skip_serializing_if = "IdnaName::was_ascii")]
|
||||||
idna: IdnaName,
|
idn: IdnaName,
|
||||||
}
|
}
|
||||||
|
|
||||||
struct ServiceSharedState {
|
struct ServiceSharedState {
|
||||||
@ -487,9 +487,9 @@ async fn get_dig_result(
|
|||||||
DigResult {
|
DigResult {
|
||||||
records: simple_dns::lookup(
|
records: simple_dns::lookup(
|
||||||
&state.dns_resolver,
|
&state.dns_resolver,
|
||||||
&(idna_name.idna.clone().unwrap_or(name.to_owned())+"."),
|
&(idna_name.idn.clone().unwrap_or(name.to_owned())+"."),
|
||||||
true).await,
|
true).await,
|
||||||
idna: idna_name,
|
idn: idna_name,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user