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

113 lines
3.6 KiB
Rust
Raw Normal View History

use crate::dto::{Certificate, DtoConversionError, Trust};
2021-02-12 14:42:51 +03:00
use crate::storage_impl::get_data;
use fluence_keypair::error::DecodingError;
use fluence_keypair::PublicKey;
2021-02-12 14:42:51 +03:00
use std::convert::{Into, TryInto};
use std::str::FromStr;
use std::time::Duration;
use thiserror::Error as ThisError;
2021-02-12 14:54:38 +03:00
use trust_graph::{CertificateError, TrustGraphError};
use fluence_keypair::public_key::peer_id_to_fluence_pk;
use libp2p_core::PeerId;
2021-02-12 14:42:51 +03:00
#[derive(ThisError, Debug)]
pub enum ServiceError {
#[error("peer id parse error: {0}")]
PeerIdParseError(String),
#[error("public key extraction from peer id failed: {0}")]
PublicKeyExtractionError(String),
2021-02-15 13:01:22 +03:00
#[error("{0}")]
PublicKeyDecodeError(
#[from]
#[source]
2021-08-01 16:31:13 +03:00
DecodingError,
2021-02-15 13:01:22 +03:00
),
#[error("{0}")]
TGError(
#[from]
#[source]
TrustGraphError,
),
#[error("{0}")]
CertError(
#[from]
#[source]
CertificateError,
),
#[error("{0}")]
DtoError(
#[from]
#[source]
DtoConversionError,
),
2021-02-12 14:42:51 +03:00
}
fn parse_peer_id(peer_id: String) -> Result<PeerId, ServiceError> {
libp2p_core::PeerId::from_str(&peer_id).map_err(|e| ServiceError::PeerIdParseError(format!("{:?}", e)))
}
fn extract_public_key(peer_id: String) -> Result<PublicKey, ServiceError> {
peer_id_to_fluence_pk(parse_peer_id(peer_id)?).map_err(|e| ServiceError::PublicKeyExtractionError(e.to_string()))
}
pub fn get_weight_impl(peer_id: String) -> Result<Option<u32>, ServiceError> {
2021-02-12 14:42:51 +03:00
let tg = get_data().lock();
let public_key = extract_public_key(peer_id)?;
2021-02-12 14:42:51 +03:00
let weight = tg.weight(public_key)?;
Ok(weight)
}
fn add_cert(certificate: trust_graph::Certificate, duration: u64) -> Result<(), ServiceError> {
let duration = Duration::from_millis(duration);
let mut tg = get_data().lock();
tg.add(certificate, duration)?;
Ok(())
}
pub fn insert_cert_impl_raw(certificate: String, duration: u64) -> Result<(), ServiceError> {
let certificate = trust_graph::Certificate::from_str(&certificate)?;
add_cert(certificate, duration)?;
Ok(())
}
fn string_to_public_key(public_key: String) -> Result<PublicKey, ServiceError> {
let public_key = PublicKey::from_base58(&public_key)?;
Ok(public_key)
}
pub fn get_all_certs_impl(issued_for: String) -> Result<Vec<Certificate>, ServiceError> {
let tg = get_data().lock();
let public_key = extract_public_key(issued_for)?;
2021-02-12 14:42:51 +03:00
let certs = tg.get_all_certs(public_key, &[])?;
Ok(certs.into_iter().map(|c| c.into()).collect())
}
pub fn insert_cert_impl(certificate: Certificate, duration: u64) -> Result<(), ServiceError> {
let certificate: trust_graph::Certificate = certificate.try_into()?;
add_cert(certificate, duration)?;
Ok(())
}
2021-02-12 14:54:08 +03:00
pub fn add_root_impl(peer_id: String, weight: u32) -> Result<(), ServiceError> {
2021-02-12 14:54:08 +03:00
let mut tg = get_data().lock();
let public_key = extract_public_key(peer_id)?;
tg.add_root_weight(public_key, weight)?;
2021-02-12 14:54:08 +03:00
Ok(())
}
pub fn get_trust_metadata_imp(peer_id: String, expires_at: u64, issued_at: u64) -> Result<Vec<u8>, ServiceError> {
let public_key = extract_public_key(peer_id)?;
Ok(trust_graph::Trust::metadata_bytes(&public_key,
Duration::from_secs(expires_at),
Duration::from_secs(issued_at)))
}
// pub fn issue_trust_impl(peer_id: String, expires_at: u64, issued_at: u64, signed_metadata: Vec<u8>) -> Result<Trust, ServiceError> {
// let public_key = extract_public_key(peer_id)?;
// trust_graph::Trust::new(public_key, Duration::from_secs(expires_at), Duration::from_secs(issued_at),
// )
// }