forked from mirrors/relay
Support relay.dog nodeinfo format
This commit is contained in:
parent
a528046a68
commit
0b7ca46e08
1 changed files with 74 additions and 13 deletions
|
@ -31,7 +31,7 @@ impl QueryNodeinfo {
|
||||||
.fetch::<WellKnown>(self.listener.as_str())
|
.fetch::<WellKnown>(self.listener.as_str())
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let href = if let Some(link) = well_known.links.into_iter().next() {
|
let href = if let Some(link) = well_known.links.into_iter().find(|l| l.rel.is_supported()) {
|
||||||
link.href
|
link.href
|
||||||
} else {
|
} else {
|
||||||
return Ok(());
|
return Ok(());
|
||||||
|
@ -86,17 +86,32 @@ struct WellKnown {
|
||||||
|
|
||||||
#[derive(serde::Deserialize)]
|
#[derive(serde::Deserialize)]
|
||||||
struct Link {
|
struct Link {
|
||||||
#[allow(dead_code)]
|
rel: MaybeSupported<SupportedNodeinfo>,
|
||||||
rel: SupportedNodeinfo,
|
|
||||||
|
|
||||||
href: String,
|
href: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
struct SupportedVersion;
|
#[derive(serde::Deserialize)]
|
||||||
struct SupportedNodeinfo;
|
#[serde(untagged)]
|
||||||
|
enum MaybeSupported<T> {
|
||||||
|
Supported(T),
|
||||||
|
Unsupported(String),
|
||||||
|
}
|
||||||
|
|
||||||
static SUPPORTED_VERSION: &'static str = "2.0";
|
impl<T> MaybeSupported<T> {
|
||||||
static SUPPORTED_NODEINFO: &'static str = "http://nodeinfo.diaspora.software/ns/schema/2.0";
|
fn is_supported(&self) -> bool {
|
||||||
|
match self {
|
||||||
|
MaybeSupported::Supported(_) => true,
|
||||||
|
_ => false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct SupportedVersion(String);
|
||||||
|
struct SupportedNodeinfo(String);
|
||||||
|
|
||||||
|
static SUPPORTED_VERSIONS: &'static str = "2.";
|
||||||
|
static SUPPORTED_NODEINFO: &'static str = "http://nodeinfo.diaspora.software/ns/schema/2.";
|
||||||
|
|
||||||
struct SupportedVersionVisitor;
|
struct SupportedVersionVisitor;
|
||||||
struct SupportedNodeinfoVisitor;
|
struct SupportedNodeinfoVisitor;
|
||||||
|
@ -105,15 +120,15 @@ impl<'de> serde::de::Visitor<'de> for SupportedVersionVisitor {
|
||||||
type Value = SupportedVersion;
|
type Value = SupportedVersion;
|
||||||
|
|
||||||
fn expecting(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
fn expecting(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
||||||
write!(f, "the string '{}'", SUPPORTED_VERSION)
|
write!(f, "a string starting with '{}'", SUPPORTED_VERSIONS)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn visit_str<E>(self, s: &str) -> Result<Self::Value, E>
|
fn visit_str<E>(self, s: &str) -> Result<Self::Value, E>
|
||||||
where
|
where
|
||||||
E: serde::de::Error,
|
E: serde::de::Error,
|
||||||
{
|
{
|
||||||
if s == SUPPORTED_VERSION {
|
if s.starts_with(SUPPORTED_VERSIONS) {
|
||||||
Ok(SupportedVersion)
|
Ok(SupportedVersion(s.to_owned()))
|
||||||
} else {
|
} else {
|
||||||
Err(serde::de::Error::custom("Invalid nodeinfo version"))
|
Err(serde::de::Error::custom("Invalid nodeinfo version"))
|
||||||
}
|
}
|
||||||
|
@ -124,15 +139,15 @@ impl<'de> serde::de::Visitor<'de> for SupportedNodeinfoVisitor {
|
||||||
type Value = SupportedNodeinfo;
|
type Value = SupportedNodeinfo;
|
||||||
|
|
||||||
fn expecting(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
fn expecting(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
||||||
write!(f, "the string '{}'", SUPPORTED_NODEINFO)
|
write!(f, "a string starting with '{}'", SUPPORTED_NODEINFO)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn visit_str<E>(self, s: &str) -> Result<Self::Value, E>
|
fn visit_str<E>(self, s: &str) -> Result<Self::Value, E>
|
||||||
where
|
where
|
||||||
E: serde::de::Error,
|
E: serde::de::Error,
|
||||||
{
|
{
|
||||||
if s == SUPPORTED_NODEINFO {
|
if s.starts_with(SUPPORTED_NODEINFO) {
|
||||||
Ok(SupportedNodeinfo)
|
Ok(SupportedNodeinfo(s.to_owned()))
|
||||||
} else {
|
} else {
|
||||||
Err(serde::de::Error::custom("Invalid nodeinfo version"))
|
Err(serde::de::Error::custom("Invalid nodeinfo version"))
|
||||||
}
|
}
|
||||||
|
@ -156,3 +171,49 @@ impl<'de> serde::de::Deserialize<'de> for SupportedNodeinfo {
|
||||||
deserializer.deserialize_str(SupportedNodeinfoVisitor)
|
deserializer.deserialize_str(SupportedNodeinfoVisitor)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::{Nodeinfo, WellKnown};
|
||||||
|
|
||||||
|
const BANANA_DOG: &'static str = r#"{"links":[{"rel":"http://nodeinfo.diaspora.software/ns/schema/2.0","href":"https://banana.dog/nodeinfo/2.0"},{"rel":"http://nodeinfo.diaspora.software/ns/schema/2.1","href":"https://banana.dog/nodeinfo/2.1"}]}"#;
|
||||||
|
const ASONIX_DOG: &'static str = r#"{"links":[{"rel":"http://nodeinfo.diaspora.software/ns/schema/2.0","href":"https://asonix.dog/nodeinfo/2.0"}]}"#;
|
||||||
|
const RELAY_ASONIX_DOG: &'static str = r#"{"links":[{"rel":"http://nodeinfo.diaspora.software/ns/schema/2.0","href":"https://relay.asonix.dog/nodeinfo/2.0.json"}]}"#;
|
||||||
|
|
||||||
|
const BANANA_DOG_NODEINFO: &'static str = r#"{"version":"2.1","software":{"name":"corgidon","version":"3.1.3+corgi","repository":"https://github.com/msdos621/corgidon"},"protocols":["activitypub"],"usage":{"users":{"total":203,"activeMonth":115,"activeHalfyear":224},"localPosts":28856},"openRegistrations":true,"metadata":{"nodeName":"Banana.dog","nodeDescription":"\u003c/p\u003e\r\n\u003cp\u003e\r\nOfficially endorsed by \u003ca href=\"https://mastodon.social/@Gargron/100059130444127703\"\u003e@Gargron\u003c/a\u003e as a joke instance (along with \u003ca href=\"https://freedom.horse/about\"\u003efreedom.horse\u003c/a\u003e). Things that make banana.dog unique as an instance.\r\n\u003c/p\u003e\r\n\u003cul\u003e\r\n\u003cli\u003eFederates with TOR servers\u003c/li\u003e\r\n\u003cli\u003eStays up to date, often running newest mastodon code\u003c/li\u003e\r\n\u003cli\u003eUnique color scheme\u003c/li\u003e\r\n\u003cli\u003eA thorough set of rules\u003c/li\u003e\r\n\u003cli\u003eA BananaDogInc company. Visit our other sites sites including \u003ca href=\"https://betamax.video\"\u003ebetaMax.video\u003c/a\u003e, \u003ca href=\"https://psychicdebugging.com\"\u003epsychicdebugging\u003c/a\u003e and \u003ca href=\"https://somebody.once.told.me.the.world.is.gonnaroll.me/\"\u003egonnaroll\u003c/a\u003e\u003c/li\u003e\r\n\u003c/ul\u003e\r\n\u003cp\u003e\r\n\u003cem\u003eWho we are looking for:\u003c/em\u003e\r\nThis instance only allows senior toot engineers. If you have at least 10+ years of mastodon experience please apply here (https://banana.dog). We are looking for rockstar ninja rocket scientists and we offer unlimited PTO as well as a fully stocked snack bar (with soylent). We are a lean, agile, remote friendly mastodon startup that pays in the bottom 25% for senior tooters. All new members get equity via an innovative ICO call BananaCoin.\r\n\u003c/p\u003e\r\n\u003cp\u003e\r\n\u003cem\u003eThe interview process\u003c/em\u003e\r\nTo join we have a take home exam that involves you writing several hundred toots that we can use to screen you. We will then throw these away during your interview so that we can do a technical screening where we use a whiteboard to evaluate your ability to re-toot memes and shitpost in front of a panel. This panel will be composed of senior tooters who are all 30 year old cis white males (coincidence).\r\n\u003c/p\u003e\r\n\u003cp\u003e\r\n\u003cem\u003eHere are the reasons you may want to join:\u003c/em\u003e\r\nWe are an agile tooting startup (a tootup). That means for every senior tooter we have a designer, a UX person, a product manager, project manager and scrum master. We meet for 15min every day and plan twice a week in a 3 hour meeting but it’s cool because you get lunch and have to attend. Our tooters love it, I would know if they didn’t since we all have standing desks in an open office layouts d can hear everything!\r\n\u003c/p\u003e\r\n\u003cp\u003e\r\n\u003ca href=\"https://www.patreon.com/bePatron?u=178864\" data-patreon-widget-type=\"become-patron-button\"\u003eSupport our sites on Patreon\u003c/a\u003e\r\n\u003c/p\u003e\r\n\u003cp\u003e","nodeTerms":"","siteContactEmail":"corgi@banana.dog","domainCount":5841,"features":["mastodon_api","mastodon_api_streaming"],"invitesEnabled":true,"federation":{"rejectMedia":[],"rejectReports":[],"silence":[],"suspend":[]}},"services":{"outbound":[],"inbound":[]}}"#;
|
||||||
|
const ASONIX_DOG_NODEINFO: &'static str = r#"{"version":"2.0","software":{"name":"mastodon","version":"3.1.3-asonix-changes"},"protocols":["activitypub"],"usage":{"users":{"total":19,"activeMonth":5,"activeHalfyear":5},"localPosts":43036},"openRegistrations":false}"#;
|
||||||
|
const RELAY_ASONIX_DOG_NODEINFO: &'static str = r#"{"version":"2.0","software":{"name":"aoderelay","version":"v0.1.0-master"},"protocols":["activitypub"],"services":{"inbound":[],"outbound":[]},"openRegistrations":false,"usage":{"users":{"total":1,"activeHalfyear":1,"activeMonth":1},"localPosts":0,"localComments":0},"metadata":{"peers":[],"blocks":[]}}"#;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn banana_dog() {
|
||||||
|
is_supported(BANANA_DOG);
|
||||||
|
de::<Nodeinfo>(BANANA_DOG_NODEINFO);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn asonix_dog() {
|
||||||
|
is_supported(ASONIX_DOG);
|
||||||
|
de::<Nodeinfo>(ASONIX_DOG_NODEINFO);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn relay_asonix_dog() {
|
||||||
|
is_supported(RELAY_ASONIX_DOG);
|
||||||
|
de::<Nodeinfo>(RELAY_ASONIX_DOG_NODEINFO);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_supported(s: &str) {
|
||||||
|
de::<WellKnown>(s)
|
||||||
|
.links
|
||||||
|
.into_iter()
|
||||||
|
.find(|l| l.rel.is_supported())
|
||||||
|
.unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
fn de<T>(s: &str) -> T
|
||||||
|
where
|
||||||
|
T: serde::de::DeserializeOwned,
|
||||||
|
{
|
||||||
|
serde_json::from_str(s).unwrap()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue