Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cacao v3 #27

Open
wants to merge 70 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
70 commits
Select commit Hold shift + click to select a range
714e40f
move cacao v1 to it's own module
chunningham Feb 15, 2023
6164e1e
scaffold v2 mod, add multidid and varsig subcrates
chunningham Feb 15, 2023
6547936
impl varsig parsing, not exactly correct
chunningham Feb 17, 2023
45d203e
impl multidid further, not fully correct
chunningham Feb 17, 2023
ff4aff7
fix multidid parsing and writing
chunningham Mar 3, 2023
f7f0849
fix multidid codec writing for raw and key
chunningham Mar 3, 2023
d69cd0b
expand test
chunningham Mar 3, 2023
664239b
break multidid into modules
chunningham Mar 3, 2023
dbf1aed
stub out pkh multidid and stub Display impls
chunningham Mar 7, 2023
382f91d
varsig sig type trait
chunningham Mar 7, 2023
192ebc5
wip
chunningham Mar 9, 2023
efbfd82
move varsig trait to /traits, impl wrapper
chunningham Apr 13, 2023
8a26fcf
impl common varsig types as in the spec
chunningham Apr 13, 2023
aa6e780
move eip191 to ecdsa mod
chunningham Apr 13, 2023
1f00815
use common error for common sig types
chunningham Apr 13, 2023
411ddb1
make everything generic over const encoding value
chunningham Apr 13, 2023
e2a817f
convenience derives, add encoding constants and test
chunningham Apr 13, 2023
b261ae8
more exports, make jose sig type, fix EitherSig header check
chunningham Apr 13, 2023
87112f6
export common modules, remove commented test
chunningham Apr 13, 2023
ffe63f0
varsig minor utils
chunningham Apr 19, 2023
24920b4
fill out pkh byte parsing
chunningham Apr 19, 2023
5fa1d62
fix multidid
chunningham Apr 20, 2023
6728dad
updates to cacao v2
chunningham Apr 20, 2023
31e6a21
use published uco crate
chunningham Apr 25, 2023
6913326
use T over &mut T for io, add JoseCommon
chunningham Apr 26, 2023
a140c0a
wip cacaos, impl ucan-cacao
chunningham Apr 26, 2023
cf3b99b
wip cacao to/from ucan and recaps
chunningham May 1, 2023
b5c48a3
fix hedera pkh type
chunningham Jul 5, 2023
58452ea
fix key did, impl display/fromstr
chunningham Jul 5, 2023
4c26f98
add pkh specific error and privatise methods
chunningham Jul 5, 2023
8f5a143
impl serde in subcrates, remove serde-with
chunningham Jul 11, 2023
93ee8c8
use published siwe-recap
chunningham Jul 11, 2023
0784eb5
stub parse/to str for multidids
chunningham Jul 21, 2023
8a66cd6
add into_inner fns for varsig types
chunningham Jul 21, 2023
5ed5b35
rename JoseCommon -> JoseSig
chunningham Jul 21, 2023
64a7a04
fixes and into_inner fns for multidids
chunningham Jul 21, 2023
29bb08b
fixes, finish conversion to/from cacao base types (ucan/recap)
chunningham Jul 21, 2023
c4927ad
temp git links for dependancies
chunningham Jul 21, 2023
ec2f361
fixes for pkh, get eip55 working
chunningham Aug 14, 2023
802f347
parsing for multidids
chunningham Aug 14, 2023
1faea82
varsig util trait derives
chunningham Aug 29, 2023
76d24f0
cacao verification implementations
chunningham Aug 29, 2023
c773fb0
multidid util trait derives
chunningham Aug 29, 2023
f76ef7f
util fns and common verifier impls for base types
chunningham Aug 29, 2023
854d683
rename either -> common
chunningham Aug 29, 2023
b6fe47e
impl more pkh from/to string
chunningham Aug 29, 2023
96de9d6
remove lip9 and hedera
chunningham Aug 29, 2023
be8ad74
util into_inner fns for some types
chunningham Aug 30, 2023
b957218
update ucan, fix async traits for wasm
chunningham Sep 10, 2023
ddbb824
rename Ed25519 -> EdDSA
chunningham Sep 10, 2023
0084986
Common fixes and utilities
chunningham Sep 10, 2023
1dc3888
add test vectors
chunningham Sep 10, 2023
d8e8ee8
update ucan usage
chunningham Sep 19, 2023
f3a163d
derives
chunningham Sep 19, 2023
b604229
serialize_jwt util
chunningham Sep 19, 2023
cd2a659
better ucan error
chunningham Sep 19, 2023
878067e
remove SKEW const generic
chunningham Sep 19, 2023
f3fa7df
siwe to commoncacao conversion
chunningham Sep 20, 2023
40c59d5
fix multidid to_vec
chunningham Sep 20, 2023
88a78d5
fix multidid pkh and tests
chunningham Sep 20, 2023
a30415a
rename v2 -> v3 and export in lib
chunningham Sep 20, 2023
70ab0d0
make some recap facts optional
chunningham Sep 20, 2023
c1fe1b6
fix recap timestamp conversion + reconstruction
chunningham Sep 22, 2023
4c0139b
fix exp_info serde rename
chunningham Sep 22, 2023
bf12543
basic test for deser and verification
chunningham Sep 22, 2023
2217f77
clippy
chunningham Sep 22, 2023
004747e
more clippy
chunningham Sep 22, 2023
7d3d659
use generic for version to ensure correctness
chunningham Sep 27, 2023
fbfd79f
add payload type for builders
chunningham Sep 27, 2023
a68b398
add builders
chunningham Sep 27, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 17 additions & 4 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ license = "Apache-2.0"
description = "Core library for CACAO traits and data structures"
repository = "https://github.com/spruceid/cacao-rs/"

[workspace]
members = ["varsig", "multidid"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[features]
Expand All @@ -19,12 +21,23 @@ iri-string = { version = "0.6", features = ["serde"] }
thiserror = "1.0"
url = "2.2"
async-trait = "0.1"
serde = "1.0"
libipld = { version = "0.14", default-features = false, features = ["dag-cbor", "derive"]}
serde_with = "2.0"
time = { version = "0.3", features = ["parsing", "formatting"] }
serde = "1"
serde_json = "1"
libipld = { version = "0.16", default-features = false, features = ["derive", "serde-codec", "dag-cbor"]}
ucan-capabilities-object = "0.1"
ssi-ucan = { git = "https://github.com/spruceid/ssi.git", branch = "feat/ucan-0.10" }
ssi-jwk = { git = "https://github.com/spruceid/ssi.git", branch = "feat/ucan-0.10" }
ssi-jwt = { git = "https://github.com/spruceid/ssi.git", branch = "feat/ucan-0.10" }
ssi-dids = { git = "https://github.com/spruceid/ssi.git", branch = "feat/ucan-0.10" }
time = { version = "0.3", features = ["parsing", "formatting", "serde", "macros"] }
http = "0.2.5"
hex = { version = "0.4", optional = true }
varsig = { version = "0.1", path = "./varsig" }
multidid = { version = "0.1", path = "./multidid" }
siwe-recap = { version = "0.2" }

[dev-dependencies]
async-std = { version = "1.10", features = ["attributes"] }
base64 = "0.13"
serde_ipld_dagcbor = "0.4"
did-method-key = { git = "https://github.com/spruceid/ssi.git", branch = "feat/ucan-0.10" }
24 changes: 24 additions & 0 deletions multidid/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
[package]
name = "multidid"
version = "0.1.0"
edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[features]
default = ["serde"]
serde = ["dep:serde"]

[dependencies]
iri-string = { version = "0.6", features = ["serde"] }
unsigned-varint = { version = "0.7", features = ["std"] }
thiserror = "1"
bs58 = "0.5"
serde = { version = "1", optional = true }
bech32 = "0.9"
sha3 = "0.10.8"
hex = "0.4"

[dev-dependencies]
serde_json = "1"
serde = "1"
serde_with = { version = "2", features = ["hex"] }
21 changes: 21 additions & 0 deletions multidid/src/error.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
use crate::{key, pkh};

#[derive(Debug, thiserror::Error)]
pub enum Error {
#[error(transparent)]
Pkh(#[from] pkh::Error),
#[error(transparent)]
Key(#[from] key::Error),
#[error(transparent)]
Varint(#[from] unsigned_varint::io::ReadError),
#[error(transparent)]
Io(#[from] std::io::Error),
#[error("Invalid multidid varint prefix, expected 0x9d1a, recieved {0:x}")]
InvalidPrefix(u64),
#[error(transparent)]
Parameter(#[from] iri_string::validate::Error),
#[error(transparent)]
DidParse(#[from] std::string::FromUtf8Error),
#[error("multidid formatting error: {0}")]
Format(&'static str),
}
167 changes: 167 additions & 0 deletions multidid/src/key.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,167 @@
use std::io::{Error as IoError, Read, Write};
use std::{fmt::Display, str::FromStr};
use unsigned_varint::encode::{u64 as write_u64, u64_buffer};
use unsigned_varint::io::read_u64;

const SECP256K1_CODEC: u64 = 0xe7;
const BLS12_381_G1_CODEC: u64 = 0xea;
const BLS12_381_G2_CODEC: u64 = 0xeb;
const X25519_CODEC: u64 = 0xec;
const ED25519_CODEC: u64 = 0xed;
const P256_CODEC: u64 = 0x1200;
const P384_CODEC: u64 = 0x1201;
const P521_CODEC: u64 = 0x1202;
// const RSA_CODEC: u64 = 0x1205;

#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Hash)]
pub enum DidKeyTypes {
Secp256k1([u8; 33]),
Bls12_381G1([u8; 64]),
Bls12_381G2([u8; 96]),
X25519([u8; 32]),
Ed25519([u8; 32]),
P256([u8; 33]),
P384([u8; 49]),
P521([u8; 67]),
// RSA([u8; ??]),
}

#[derive(Debug, thiserror::Error)]
pub enum Error {
#[error(transparent)]
Io(#[from] IoError),
#[error("Invalid key type: {0:x}")]
InvalidCodec(u64),
}

impl DidKeyTypes {
pub fn codec(&self) -> u64 {
use DidKeyTypes::*;
match self {
Secp256k1(_) => SECP256K1_CODEC,
Bls12_381G1(_) => BLS12_381_G1_CODEC,
Bls12_381G2(_) => BLS12_381_G2_CODEC,
X25519(_) => X25519_CODEC,
Ed25519(_) => ED25519_CODEC,
P256(_) => P256_CODEC,
P384(_) => P384_CODEC,
P521(_) => P521_CODEC,
}
}

pub(crate) fn from_reader<R>(reader: &mut R, codec: u64) -> Result<Self, Error>
where
R: Read,
{
match codec {
SECP256K1_CODEC => {
let mut buf = [0; 33];
reader.read_exact(&mut buf)?;
Ok(Self::Secp256k1(buf))
}
BLS12_381_G1_CODEC => {
let mut buf = [0; 64];
reader.read_exact(&mut buf)?;
Ok(Self::Bls12_381G1(buf))
}
BLS12_381_G2_CODEC => {
let mut buf = [0; 96];
reader.read_exact(&mut buf)?;
Ok(Self::Bls12_381G2(buf))
}
X25519_CODEC => {
let mut buf = [0; 32];
reader.read_exact(&mut buf)?;
Ok(Self::X25519(buf))
}
ED25519_CODEC => {
let mut buf = [0; 32];
reader.read_exact(&mut buf)?;
Ok(Self::Ed25519(buf))
}
P256_CODEC => {
let mut buf = [0; 33];
reader.read_exact(&mut buf)?;
Ok(Self::P256(buf))
}
P384_CODEC => {
let mut buf = [0; 49];
reader.read_exact(&mut buf)?;
Ok(Self::P384(buf))
}
P521_CODEC => {
let mut buf = [0; 67];
reader.read_exact(&mut buf)?;
Ok(Self::P521(buf))
}
_ => Err(Error::InvalidCodec(codec)),
}
}

pub(crate) fn to_writer<W>(&self, writer: &mut W) -> Result<(), IoError>
where
W: ?Sized + Write,
{
let mut buf = u64_buffer();
writer.write_all(write_u64(self.codec(), &mut buf))?;
writer.write_all(self.bytes())
}

fn bytes(&self) -> &[u8] {
match self {
Self::Secp256k1(key) => key,
Self::Bls12_381G1(key) => key,
Self::Bls12_381G2(key) => key,
Self::X25519(key) => key,
Self::Ed25519(key) => key,
Self::P256(key) => key,
Self::P384(key) => key,
Self::P521(key) => key,
}
}

pub(crate) fn to_vec(&self) -> Vec<u8> {
let mut vec = Vec::new();
let mut buf = u64_buffer();
vec.extend(write_u64(self.codec(), &mut buf));
vec.extend(self.bytes());
vec
}
}

impl Display for DidKeyTypes {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "z{}", bs58::encode(self.to_vec()).into_string())
}
}

#[derive(Debug, thiserror::Error)]
pub enum ParseErr {
#[error("Invalid Base")]
InvalidBase,
#[error("Insufficient Length")]
InsuficientBytes,
#[error(transparent)]
Varint(#[from] unsigned_varint::io::ReadError),
#[error(transparent)]
Base58(#[from] bs58::decode::Error),
#[error(transparent)]
Decoding(#[from] Error),
}

impl FromStr for DidKeyTypes {
type Err = ParseErr;

fn from_str(s: &str) -> Result<Self, Self::Err> {
match (s.get(..1), s.get(1..)) {
(None, _) | (_, None) => Err(ParseErr::InsuficientBytes),
(Some("z"), Some(rest)) => {
let bytes = bs58::decode(rest).into_vec()?;
let mut br = bytes.as_slice();
let codec = read_u64(&mut br)?;
Ok(Self::from_reader(&mut br, codec)?)
}
_ => Err(ParseErr::InvalidBase),
}
}
}
Loading