Skip to content

Commit

Permalink
rebasing off origin branch
Browse files Browse the repository at this point in the history
  • Loading branch information
Joey Silberman authored and Joey Silberman committed Nov 19, 2024
2 parents eef7f70 + f1ecd8b commit e5367e2
Show file tree
Hide file tree
Showing 7 changed files with 109 additions and 4 deletions.
4 changes: 2 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ http = "1.1.0"
# There may be a better way to handle this that doesn't require the `json-syntax` crate directly.
json-syntax = { version = "0.12.5", features = ["serde_json"] }
# jsonpath_lib = "0.3.0"
serde_json_path = "0.6.7"
serde_json_path = "0.7.1"
jsonschema = "0.18.0"
openid4vp-frontend = { version = "0.1.0", path = "openid4vp-frontend" }
p256 = { version = "0.13.2", features = ["jwk"] }
Expand All @@ -30,7 +30,7 @@ reqwest = { version = "0.12.5", features = ["rustls-tls"] }
serde = "1.0.188"
serde_json = "1.0.107"
serde_urlencoded = "0.7.1"
ssi = { version = "0.10", features = ["secp256r1"] }
ssi = { version = "0.10.1", features = ["secp256r1"] }
tokio = "1.32.0"
tracing = "0.1.37"
url = { version = "2.4.1", features = ["serde"] }
Expand Down
17 changes: 17 additions & 0 deletions src/core/authorization_request/mod.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
use std::ops::{Deref, DerefMut};

use anyhow::{anyhow, bail, Context, Error, Result};
use parameters::ClientMetadata;
use serde::{Deserialize, Serialize};
use serde_json::Value as Json;
use url::Url;
Expand All @@ -16,6 +17,7 @@ use self::{
};

use super::{
metadata::parameters::verifier::VpFormats,
object::{ParsingErrorContext, UntypedObject},
util::{base_request, AsyncHttpClient},
};
Expand Down Expand Up @@ -263,6 +265,21 @@ impl AuthorizationRequestObject {
pub fn nonce(&self) -> &Nonce {
&self.7
}

/// Return the `client_metadata` field from the authorization request.
pub fn client_metadata(&self) -> Result<ClientMetadata> {
self.0
.get()
.ok_or(anyhow!("missing `client_metadata` object"))?
}

/// Return the `VpFormats` from the `client_metadata` field.
pub fn vp_formats(&self) -> Result<VpFormats> {
self.client_metadata()?
.0
.get()
.ok_or(anyhow!("missing vp_formats"))?
}
}

impl From<AuthorizationRequestObject> for UntypedObject {
Expand Down
2 changes: 2 additions & 0 deletions src/core/authorization_request/verification/did.rs
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ pub async fn verify_with_resolver(

// This bypass is for unencoded JWT requests, but we will need to change this later
// so that trust is preserved when receiving unencoded requests
// NOTE: This requires that `Algorithm::None` is permitted in the wallet metadata
// Otherwise, this function will error in the previous assertion.
if alg.contains("none") {
return Ok(());
}
Expand Down
1 change: 1 addition & 0 deletions src/core/credential_format/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,7 @@ pub enum ClaimFormatPayload {
/// claim presentation algorithm types supported by a wallet.
#[serde(rename = "alg_values_supported")]
AlgValuesSupported(Vec<String>),
/// This variant is primarily used for `ldp`, `ldp_vc`, `ldp_vp`, `ac_vc`, and `ac_vp`
#[serde(rename = "proof_type")]
ProofType(Vec<String>),
#[serde(untagged)]
Expand Down
5 changes: 5 additions & 0 deletions src/core/input_descriptor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -209,6 +209,11 @@ impl Constraints {
self.fields.as_ref()
}

/// Returns the fields of the constraints object as a mutable reference.
pub fn fields_mut(&mut self) -> &mut Vec<ConstraintsField> {
self.fields.as_mut()
}

/// Set the limit disclosure value.
///
/// For all [Claims](https://identity.foundation/presentation-exchange/spec/v2.0.0/#term:claims) submitted in relation to [InputDescriptor] Objects that include a `constraints`
Expand Down
28 changes: 27 additions & 1 deletion src/core/metadata/parameters/verifier.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use crate::core::credential_format::ClaimFormatMap;
use crate::core::metadata::ClaimFormatPayload;
use crate::core::object::TypedParameter;
use crate::core::{credential_format::ClaimFormatMap, metadata::ClaimFormatDesignation};

use anyhow::{Context, Error};
use serde::{Deserialize, Serialize};
Expand All @@ -8,6 +9,31 @@ use serde_json::{Map, Value as Json};
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct VpFormats(pub ClaimFormatMap);

impl VpFormats {
/// Returns a boolean to denote whether the format and cryptosuite provided
/// are supported in the VP formats.
///
/// NOTE: This method is interested in the cryptosuite of the claim format
/// payload and not the claim format designation.
///
/// For example, the cryptosuite would need to match one of the `alg`
/// values in the claim format payload.
pub fn supports_cryptosuite(
&self,
format: &ClaimFormatDesignation,
cryptosuite: &String,
) -> bool {
match self.0.get(format) {
Some(ClaimFormatPayload::Alg(alg_values))
| Some(ClaimFormatPayload::AlgValuesSupported(alg_values)) => {
alg_values.contains(cryptosuite)
}
Some(ClaimFormatPayload::ProofType(proof_types)) => proof_types.contains(cryptosuite),
_ => false,
}
}
}

impl TypedParameter for VpFormats {
const KEY: &'static str = "vp_formats";
}
Expand Down
56 changes: 55 additions & 1 deletion src/core/response/parameters.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,13 @@ use crate::core::object::TypedParameter;
use anyhow::Error;
use serde::{Deserialize, Serialize};
use serde_json::Value as Json;
use ssi::{claims::vc, one_or_many::OneOrManyRef, prelude::AnyJsonPresentation, OneOrMany};
use ssi::{
claims::vc::{self, v2::SpecializedJsonCredential},
json_ld::syntax::Object,
one_or_many::OneOrManyRef,
prelude::{AnyDataIntegrity, AnyJsonPresentation, AnySuite, DataIntegrity},
OneOrMany,
};

#[derive(Debug, Clone)]
pub struct IdToken(pub String);
Expand Down Expand Up @@ -106,6 +112,12 @@ impl From<vc::v2::syntax::JsonPresentation> for VpToken {
}
}

impl From<vc::v2::syntax::JsonPresentation<SpecializedJsonCredential<Object>>> for VpToken {
fn from(value: vc::v2::syntax::JsonPresentation<SpecializedJsonCredential<Object>>) -> Self {
Self(vec![value.into()])
}
}

impl From<AnyJsonPresentation> for VpToken {
fn from(value: AnyJsonPresentation) -> Self {
Self(vec![value.into()])
Expand Down Expand Up @@ -159,6 +171,20 @@ impl From<String> for VpTokenItem {
}
}

impl From<AnyDataIntegrity> for VpTokenItem {
fn from(value: AnyDataIntegrity) -> Self {
let serde_json::Value::Object(obj) = serde_json::to_value(&value)
// SAFETY: by definition a Data Integrity Object is a Json LD Node and is a JSON object.
.unwrap()
else {
// SAFETY: by definition a Data Integrity Object is a Json LD Node and is a JSON object.
unreachable!()
};

Self::JsonObject(obj)
}
}

impl From<vc::v1::syntax::JsonPresentation> for VpTokenItem {
fn from(value: vc::v1::syntax::JsonPresentation) -> Self {
let serde_json::Value::Object(obj) = serde_json::to_value(value)
Expand Down Expand Up @@ -187,6 +213,20 @@ impl From<vc::v2::syntax::JsonPresentation> for VpTokenItem {
}
}

impl From<vc::v2::syntax::JsonPresentation<SpecializedJsonCredential<Object>>> for VpTokenItem {
fn from(value: vc::v2::syntax::JsonPresentation<SpecializedJsonCredential<Object>>) -> Self {
let serde_json::Value::Object(obj) = serde_json::to_value(value)
// SAFETY: by definition a VCDM2.0 presentation is a JSON object.
.unwrap()
else {
// SAFETY: by definition a VCDM2.0 presentation is a JSON object.
unreachable!()
};

Self::JsonObject(obj)
}
}

impl From<AnyJsonPresentation> for VpTokenItem {
fn from(value: AnyJsonPresentation) -> Self {
let serde_json::Value::Object(obj) = serde_json::to_value(value)
Expand All @@ -200,3 +240,17 @@ impl From<AnyJsonPresentation> for VpTokenItem {
Self::JsonObject(obj)
}
}

impl From<DataIntegrity<AnyJsonPresentation, AnySuite>> for VpTokenItem {
fn from(value: DataIntegrity<AnyJsonPresentation, AnySuite>) -> Self {
let serde_json::Value::Object(obj) = serde_json::to_value(value)
// SAFETY: by definition a VCDM2.0 presentation is a JSON object.
.unwrap()
else {
// SAFETY: by definition a VCDM2.0 presentation is a JSON object.
unreachable!()
};

Self::JsonObject(obj)
}
}

0 comments on commit e5367e2

Please sign in to comment.