trust-graph-test/service/src/service_api.rs

91 lines
2.9 KiB
Rust
Raw Normal View History

2021-09-06 18:13:08 +03:00
use crate::dto::{Certificate, Trust};
use crate::results::{
2021-09-14 14:21:26 +03:00
AddRootResult, AddTrustResult, AllCertsResult, GetTrustMetadataResult, InsertResult,
IssueTrustResult, VerifyTrustResult, WeightResult,
2021-09-06 18:13:08 +03:00
};
use crate::service_impl::{
2021-09-14 14:21:26 +03:00
add_root_impl, add_trust_impl, get_all_certs_impl, get_trust_metadata_imp, get_weight_impl,
insert_cert_impl, insert_cert_impl_raw, issue_trust_impl, verify_trust_impl,
2021-09-06 18:13:08 +03:00
};
use marine_rs_sdk::{marine, CallParameters};
2021-02-12 14:34:23 +03:00
2021-08-01 16:31:13 +03:00
#[marine]
2021-02-12 14:27:22 +03:00
/// add a certificate in string representation to trust graph if it is valid
2021-02-12 14:34:23 +03:00
/// see `trust_graph::Certificate` class for string encoding/decoding
2021-09-14 14:21:26 +03:00
fn insert_cert_raw(certificate: String, timestamp_sec: u64) -> InsertResult {
insert_cert_impl_raw(certificate, timestamp_sec).into()
2021-02-12 14:34:23 +03:00
}
2021-08-01 16:31:13 +03:00
#[marine]
2021-02-12 14:34:23 +03:00
/// add a certificate in JSON representation to trust graph if it is valid
/// see `dto::Certificate` class for structure
2021-09-14 14:21:26 +03:00
fn insert_cert(certificate: Certificate, timestamp_sec: u64) -> InsertResult {
insert_cert_impl(certificate, timestamp_sec).into()
}
2021-09-16 16:24:46 +03:00
// TODO: return only valid, delete expired, return max weight
2021-08-01 16:31:13 +03:00
#[marine]
fn get_weight(peer_id: String, timestamp_sec: u64) -> WeightResult {
get_weight_impl(peer_id.clone(), timestamp_sec)
.map(|w| (w, peer_id))
.into()
}
2021-09-16 16:24:46 +03:00
// TODO: return only valid, delete expired
2021-08-01 16:31:13 +03:00
#[marine]
fn get_all_certs(issued_for: String, timestamp_sec: u64) -> AllCertsResult {
get_all_certs_impl(issued_for, timestamp_sec).into()
}
2021-08-01 16:31:13 +03:00
#[marine]
2021-02-12 14:54:08 +03:00
/// could add only a host of a trust graph service
2021-09-22 02:59:50 +03:00
// TODO: rename to add_root_weight_factor
fn add_root(peer_id: String, weight: u32) -> AddRootResult {
2021-08-01 16:31:13 +03:00
let call_parameters: CallParameters = marine_rs_sdk::get_call_parameters();
2021-02-12 14:54:08 +03:00
let init_peer_id = call_parameters.init_peer_id.clone();
2021-09-22 02:59:50 +03:00
if call_parameters.service_creator_peer_id == init_peer_id {
add_root_impl(peer_id, weight).into()
2021-02-12 14:54:08 +03:00
} else {
return AddRootResult {
2021-09-06 18:13:08 +03:00
success: false,
2021-09-22 02:59:50 +03:00
error: "Root could add only by trust graph service owner".to_string(),
2021-02-12 14:54:08 +03:00
};
}
}
#[marine]
2021-09-06 18:13:08 +03:00
fn get_trust_metadata(
issued_for_peer_id: String,
expires_at_sec: u64,
issued_at_sec: u64,
2021-09-06 18:13:08 +03:00
) -> GetTrustMetadataResult {
get_trust_metadata_imp(issued_for_peer_id, expires_at_sec, issued_at_sec).into()
}
2021-09-06 18:13:08 +03:00
#[marine]
fn issue_trust(
issued_for_peer_id: String,
expires_at_sec: u64,
issued_at_sec: u64,
2021-09-06 18:13:08 +03:00
signed_metadata: Vec<u8>,
) -> IssueTrustResult {
issue_trust_impl(
issued_for_peer_id,
expires_at_sec,
issued_at_sec,
signed_metadata,
)
.into()
2021-09-06 18:13:08 +03:00
}
#[marine]
2021-09-14 14:21:26 +03:00
fn verify_trust(trust: Trust, issuer_peer_id: String, timestamp_sec: u64) -> VerifyTrustResult {
verify_trust_impl(trust, issuer_peer_id, timestamp_sec).into()
2021-09-06 18:13:08 +03:00
}
// TODO: check issued_at earlier than timestamp_sec
2021-09-06 18:13:08 +03:00
#[marine]
2021-09-14 14:21:26 +03:00
fn add_trust(trust: Trust, issuer_peer_id: String, timestamp_sec: u64) -> AddTrustResult {
add_trust_impl(trust, issuer_peer_id, timestamp_sec).into()
2021-09-06 18:13:08 +03:00
}