Radish alpha
h
Radicle Heartwood Protocol & Stack
Radicle
Git (anonymous pull)
Log in to clone via SSH
Move identity types to project
Alexis Sellier committed 3 years ago
commit 51f2d4e3fc17736740db6b7ea1f7d5fc31e90ed7
parent 00ed8793af94c296896b1e472fd85ee196961f9d
3 files changed +107 -96
modified radicle/src/identity.rs
@@ -1,108 +1,15 @@
pub mod project;

use std::ops::Deref;
-
use std::{ffi::OsString, fmt, str::FromStr};
+
use std::{fmt, str::FromStr};

use serde::{Deserialize, Serialize};
use thiserror::Error;

use crate::crypto;
-
use crate::git;
-
use crate::serde_ext;

pub use crypto::PublicKey;
-
pub use project::{Delegate, Doc};
-

-
#[derive(Error, Debug)]
-
pub enum IdError {
-
    #[error("invalid git object id: {0}")]
-
    InvalidOid(#[from] git2::Error),
-
    #[error(transparent)]
-
    Multibase(#[from] multibase::Error),
-
}
-

-
#[derive(Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
-
pub struct Id(git::Oid);
-

-
impl fmt::Display for Id {
-
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
-
        f.write_str(&self.to_human())
-
    }
-
}
-

-
impl fmt::Debug for Id {
-
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
-
        write!(f, "Id({})", self)
-
    }
-
}
-

-
impl Id {
-
    pub fn to_human(&self) -> String {
-
        multibase::encode(multibase::Base::Base58Btc, self.0.as_bytes())
-
    }
-

-
    pub fn from_human(s: &str) -> Result<Self, IdError> {
-
        let (_, bytes) = multibase::decode(s)?;
-
        let array: git::Oid = bytes.as_slice().try_into()?;
-

-
        Ok(Self(array))
-
    }
-
}
-

-
impl FromStr for Id {
-
    type Err = IdError;
-

-
    fn from_str(s: &str) -> Result<Self, Self::Err> {
-
        Self::from_human(s)
-
    }
-
}
-

-
impl TryFrom<OsString> for Id {
-
    type Error = IdError;
-

-
    fn try_from(value: OsString) -> Result<Self, Self::Error> {
-
        let string = value.to_string_lossy();
-
        Self::from_str(&string)
-
    }
-
}
-

-
impl From<git::Oid> for Id {
-
    fn from(oid: git::Oid) -> Self {
-
        Self(oid)
-
    }
-
}
-

-
impl From<git2::Oid> for Id {
-
    fn from(oid: git2::Oid) -> Self {
-
        Self(oid.into())
-
    }
-
}
-

-
impl Deref for Id {
-
    type Target = git::Oid;
-

-
    fn deref(&self) -> &Self::Target {
-
        &self.0
-
    }
-
}
-

-
impl serde::Serialize for Id {
-
    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
-
    where
-
        S: serde::Serializer,
-
    {
-
        serde_ext::string::serialize(self, serializer)
-
    }
-
}
-

-
impl<'de> serde::Deserialize<'de> for Id {
-
    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
-
    where
-
        D: serde::Deserializer<'de>,
-
    {
-
        serde_ext::string::deserialize(deserializer)
-
    }
-
}
+
pub use project::{Delegate, Doc, Id, IdError};

#[derive(Error, Debug)]
pub enum DidError {
modified radicle/src/identity/project.rs
@@ -1,3 +1,5 @@
+
mod id;
+

use std::collections::{BTreeMap, HashMap};
use std::fmt::Write as _;
use std::io;
@@ -14,11 +16,12 @@ use thiserror::Error;
use crate::crypto;
use crate::crypto::{Signature, Unverified, Verified};
use crate::git;
-
use crate::identity::{Did, Id};
+
use crate::identity::Did;
use crate::storage::git::trailers;
use crate::storage::{BranchName, ReadRepository, RemoteId, WriteRepository, WriteStorage};

pub use crypto::PublicKey;
+
pub use id::*;

/// Untrusted, well-formed input.
#[derive(Clone, Copy, Debug)]
added radicle/src/identity/project/id.rs
@@ -0,0 +1,101 @@
+
use std::ops::Deref;
+
use std::{ffi::OsString, fmt, str::FromStr};
+

+
use thiserror::Error;
+

+
use crate::crypto;
+
use crate::git;
+
use crate::serde_ext;
+

+
pub use crypto::PublicKey;
+

+
#[derive(Error, Debug)]
+
pub enum IdError {
+
    #[error("invalid git object id: {0}")]
+
    InvalidOid(#[from] git2::Error),
+
    #[error(transparent)]
+
    Multibase(#[from] multibase::Error),
+
}
+

+
#[derive(Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
+
pub struct Id(git::Oid);
+

+
impl fmt::Display for Id {
+
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
+
        f.write_str(&self.to_human())
+
    }
+
}
+

+
impl fmt::Debug for Id {
+
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
+
        write!(f, "Id({})", self)
+
    }
+
}
+

+
impl Id {
+
    pub fn to_human(&self) -> String {
+
        multibase::encode(multibase::Base::Base58Btc, self.0.as_bytes())
+
    }
+

+
    pub fn from_human(s: &str) -> Result<Self, IdError> {
+
        let (_, bytes) = multibase::decode(s)?;
+
        let array: git::Oid = bytes.as_slice().try_into()?;
+

+
        Ok(Self(array))
+
    }
+
}
+

+
impl FromStr for Id {
+
    type Err = IdError;
+

+
    fn from_str(s: &str) -> Result<Self, Self::Err> {
+
        Self::from_human(s)
+
    }
+
}
+

+
impl TryFrom<OsString> for Id {
+
    type Error = IdError;
+

+
    fn try_from(value: OsString) -> Result<Self, Self::Error> {
+
        let string = value.to_string_lossy();
+
        Self::from_str(&string)
+
    }
+
}
+

+
impl From<git::Oid> for Id {
+
    fn from(oid: git::Oid) -> Self {
+
        Self(oid)
+
    }
+
}
+

+
impl From<git2::Oid> for Id {
+
    fn from(oid: git2::Oid) -> Self {
+
        Self(oid.into())
+
    }
+
}
+

+
impl Deref for Id {
+
    type Target = git::Oid;
+

+
    fn deref(&self) -> &Self::Target {
+
        &self.0
+
    }
+
}
+

+
impl serde::Serialize for Id {
+
    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
+
    where
+
        S: serde::Serializer,
+
    {
+
        serde_ext::string::serialize(self, serializer)
+
    }
+
}
+

+
impl<'de> serde::Deserialize<'de> for Id {
+
    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
+
    where
+
        D: serde::Deserializer<'de>,
+
    {
+
        serde_ext::string::deserialize(deserializer)
+
    }
+
}