Fixed a type system oopsie in NodeInfo

This commit is contained in:
Natty 2024-04-15 04:56:44 +02:00
parent e1fd078367
commit 4f4a871ae5
Signed by: natty
GPG Key ID: BF6CB659ADEE60EC
2 changed files with 10 additions and 11 deletions
ext_nodeinfo/src
src

View File

@ -57,8 +57,6 @@ pub struct NodeInfo10Usage {
#[derive(Clone, PartialEq, Debug, Deserialize, Serialize)] #[derive(Clone, PartialEq, Debug, Deserialize, Serialize)]
pub struct NodeInfo10 { pub struct NodeInfo10 {
#[doc = "The schema version, must be 1.0."]
pub version: String,
#[doc = "Free form key value pairs for software specific values. Clients should not rely on any "] #[doc = "Free form key value pairs for software specific values. Clients should not rely on any "]
#[doc = "specific key present."] #[doc = "specific key present."]
pub metadata: HashMap<String, serde_json::Value>, pub metadata: HashMap<String, serde_json::Value>,

View File

@ -3,11 +3,12 @@ use axum::Json;
use magnetar_common::config::MagnetarConfig; use magnetar_common::config::MagnetarConfig;
use magnetar_core::web_model::rel::{RelNodeInfo20, RelNodeInfo21}; use magnetar_core::web_model::rel::{RelNodeInfo20, RelNodeInfo21};
use magnetar_core::web_model::Rel; use magnetar_core::web_model::Rel;
use magnetar_nodeinfo::version_1_0::{
NodeInfo10Services, NodeInfo10Software, NodeInfo10Usage, NodeInfo10UsageUsers,
};
use magnetar_nodeinfo::version_2_0::NodeInfo20; use magnetar_nodeinfo::version_2_0::NodeInfo20;
use magnetar_nodeinfo::version_2_1::{NodeInfo21, NodeInfo21Software}; use magnetar_nodeinfo::version_2_1::{NodeInfo21, NodeInfo21Software};
use magnetar_nodeinfo::{
version_1_0::{NodeInfo10Services, NodeInfo10Software, NodeInfo10Usage, NodeInfo10UsageUsers},
NodeInfo,
};
use serde::Serialize; use serde::Serialize;
use serde_json::{json, Value}; use serde_json::{json, Value};
use std::collections::{HashMap, HashSet}; use std::collections::{HashMap, HashSet};
@ -43,8 +44,8 @@ pub async fn handle_nodeinfo(State(config): State<&'static MagnetarConfig>) -> J
Json(json!({ "links": links_serialized })) Json(json!({ "links": links_serialized }))
} }
pub async fn handle_nodeinfo_21(State(config): State<&'static MagnetarConfig>) -> Json<NodeInfo21> { pub async fn handle_nodeinfo_21(State(config): State<&'static MagnetarConfig>) -> Json<NodeInfo> {
Json(NodeInfo21 { Json(NodeInfo::V2_1(NodeInfo21 {
software: NodeInfo21Software { software: NodeInfo21Software {
name: config.branding.name.clone(), name: config.branding.name.clone(),
version: config.branding.version.clone(), version: config.branding.version.clone(),
@ -67,11 +68,11 @@ pub async fn handle_nodeinfo_21(State(config): State<&'static MagnetarConfig>) -
local_comments: Some(0), local_comments: Some(0),
}, },
metadata: HashMap::new(), metadata: HashMap::new(),
}) }))
} }
pub async fn handle_nodeinfo_20(State(config): State<&'static MagnetarConfig>) -> Json<NodeInfo20> { pub async fn handle_nodeinfo_20(State(config): State<&'static MagnetarConfig>) -> Json<NodeInfo> {
Json(NodeInfo20 { Json(NodeInfo::V2_0(NodeInfo20 {
software: NodeInfo10Software { software: NodeInfo10Software {
name: config.branding.name.clone(), name: config.branding.name.clone(),
version: config.branding.version.clone(), version: config.branding.version.clone(),
@ -92,7 +93,7 @@ pub async fn handle_nodeinfo_20(State(config): State<&'static MagnetarConfig>) -
local_comments: None, local_comments: None,
}, },
metadata: HashMap::new(), metadata: HashMap::new(),
}) }))
} }
#[cfg(test)] #[cfg(test)]