Skip to content

Commit

Permalink
Revert "Define peer2 resolution on peer_did itself"
Browse files Browse the repository at this point in the history
This reverts commit fbb62bd944ef2880b2ed17cf6277b9267e7a37ee.

Signed-off-by: Patrik Stas <patrik.stas@absa.africa>
  • Loading branch information
Patrik-Stas committed Jan 15, 2024
1 parent 1550c5e commit 3e04ff0
Show file tree
Hide file tree
Showing 6 changed files with 66 additions and 26 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,9 @@ use std::sync::Arc;
use did_parser::Did;
use did_peer::{
peer_did::{numalgos::numalgo2::Numalgo2, PeerDid},
resolver::options::PublicKeyEncoding,
resolver::{options::PublicKeyEncoding, PeerDidResolutionOptions, PeerDidResolver},
};
use did_resolver::traits::resolvable::{resolution_output::DidResolutionOutput, DidResolvable};
use did_resolver_registry::ResolverRegistry;
use messages::msg_fields::protocols::did_exchange::{
complete::Complete as CompleteMessage, request::Request, response::Response,
Expand Down Expand Up @@ -33,8 +34,16 @@ impl DidExchangeRequester<RequestSent> {
let their_did_document = resolver_registry
.resolve(their_did, &Default::default())
.await?
.did_document;
let did_document = our_peer_did.resolve(PublicKeyEncoding::Base58)?;
.did_document
.clone();
let DidResolutionOutput { did_document, .. } = PeerDidResolver::new()
.resolve(
our_peer_did.did(),
&PeerDidResolutionOptions {
encoding: Some(PublicKeyEncoding::Base58),
},
)
.await?;
let invitation_id = Uuid::new_v4().to_string();

let request = construct_request(invitation_id.clone(), our_peer_did.to_string());
Expand Down Expand Up @@ -73,9 +82,16 @@ impl DidExchangeRequester<RequestSent> {
} else {
let peer_did = PeerDid::<Numalgo2>::parse(response.content.did)
.map_err(to_transition_error(self.clone()))?;
peer_did
.resolve(PublicKeyEncoding::Base58)
.map_err(to_transition_error(self.clone()))?
let DidResolutionOutput { did_document, .. } = PeerDidResolver::new()
.resolve(
peer_did.did(),
&PeerDidResolutionOptions {
encoding: Some(PublicKeyEncoding::Base58),
},
)
.await
.map_err(to_transition_error(self.clone()))?;
did_document
};

let complete_message = construct_didexchange_complete(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,9 @@ use aries_vcx_core::wallet::base_wallet::BaseWallet;
use did_doc::schema::did_doc::DidDocument;
use did_peer::{
peer_did::{numalgos::numalgo2::Numalgo2, PeerDid},
resolver::options::PublicKeyEncoding,
resolver::{options::PublicKeyEncoding, PeerDidResolutionOptions, PeerDidResolver},
};
use did_resolver::traits::resolvable::{resolution_output::DidResolutionOutput, DidResolvable};
use did_resolver_registry::ResolverRegistry;
use messages::msg_fields::protocols::did_exchange::{
complete::Complete, request::Request, response::Response,
Expand Down Expand Up @@ -33,7 +34,17 @@ impl DidExchangeResponder<ResponseSent> {
invitation_key: Key,
) -> Result<TransitionResult<DidExchangeResponder<ResponseSent>, Response>, AriesVcxError> {
let their_ddo = resolve_ddo_from_request(&resolver_registry, &request).await?;
let our_did_document = our_peer_did.resolve(PublicKeyEncoding::Base58)?;
let DidResolutionOutput {
did_document: our_did_document,
..
} = PeerDidResolver::new()
.resolve(
our_peer_did.did(),
&PeerDidResolutionOptions {
encoding: Some(PublicKeyEncoding::Base58),
},
)
.await?;
// TODO: Response should sign the new *did* with invitation_key only if key was rotated
// In practice if the invitation was public, we definitely will be rotating to
// peer:did
Expand Down
16 changes: 14 additions & 2 deletions aries/aries_vcx/tests/test_did_exchange.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,9 @@ use did_doc::schema::{
use did_parser::Did;
use did_peer::{
peer_did::{numalgos::numalgo2::Numalgo2, PeerDid},
resolver::{options::PublicKeyEncoding, PeerDidResolver},
resolver::{options::PublicKeyEncoding, PeerDidResolutionOptions, PeerDidResolver},
};
use did_resolver::traits::resolvable::{resolution_output::DidResolutionOutput, DidResolvable};
use did_resolver_registry::ResolverRegistry;
use did_resolver_sov::resolution::DidSovResolver;
use log::info;
Expand Down Expand Up @@ -137,7 +138,18 @@ async fn did_exchange_test() -> Result<(), Box<dyn Error>> {
let responders_peer_did = PeerDid::<Numalgo2>::from_did_doc(responders_did_document.clone())?;
info!("Responder prepares their peer:did: {responders_peer_did}");

let check_diddoc = responders_peer_did.resolve(PublicKeyEncoding::Base58)?;
let DidResolutionOutput {
did_document: check_diddoc,
..
} = PeerDidResolver::new()
.resolve(
responders_peer_did.did(),
&PeerDidResolutionOptions {
encoding: Some(PublicKeyEncoding::Base58),
},
)
.await
.unwrap();
info!("Responder decodes constructed peer:did as did document: {check_diddoc}");

let TransitionResult {
Expand Down
13 changes: 11 additions & 2 deletions did_core/did_methods/did_peer/examples/demo.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,9 @@ use did_peer::{
numalgos::{numalgo2::Numalgo2, numalgo3::Numalgo3},
PeerDid,
},
resolver::options::PublicKeyEncoding,
resolver::{options::PublicKeyEncoding, PeerDidResolutionOptions, PeerDidResolver},
};
use did_resolver::traits::resolvable::{resolution_output::DidResolutionOutput, DidResolvable};

#[tokio::main(flavor = "current_thread")]
async fn main() -> Result<(), Box<dyn Error>> {
Expand Down Expand Up @@ -46,7 +47,15 @@ async fn demo() -> Result<(), Box<dyn Error>> {
peer_did_3_v2
);

let did_document = peer_did_2.resolve(PublicKeyEncoding::Base58)?;
let DidResolutionOutput { did_document, .. } = PeerDidResolver::new()
.resolve(
peer_did_2.did(),
&PeerDidResolutionOptions {
encoding: Some(PublicKeyEncoding::Base58),
},
)
.await
.unwrap();
println!(
"Decoded did document: \n{}",
serde_json::to_string_pretty(&did_document)?
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,17 +42,6 @@ impl PeerDid<Numalgo2> {
didpeer_elements_to_diddoc(did_doc_builder, self.did(), public_key_encoding)?;
Ok(did_doc_builder)
}

pub fn resolve(
&self,
public_key_encoding: PublicKeyEncoding,
) -> Result<DidDocument, DidPeerError> {
let builder: DidDocumentBuilder = self.to_did_doc_builder(public_key_encoding)?;
let did_doc = builder
.add_also_known_as(self.to_numalgo3()?.to_string().parse()?)
.build();
Ok(did_doc)
}
}

#[derive(Clone, Copy, Default, Debug, PartialEq)]
Expand Down
9 changes: 6 additions & 3 deletions did_core/did_methods/did_peer/src/resolver/mod.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
use async_trait::async_trait;
use did_doc::schema::did_doc::DidDocumentBuilder;
use did_parser::Did;
use did_resolver::{
error::GenericError,
Expand Down Expand Up @@ -28,7 +29,6 @@ impl PeerDidResolver {
pub struct PeerDidResolutionOptions {
pub encoding: Option<PublicKeyEncoding>,
}

#[async_trait]
impl DidResolvable for PeerDidResolver {
type DidResolutionOptions = PeerDidResolutionOptions;
Expand All @@ -41,8 +41,11 @@ impl DidResolvable for PeerDidResolver {
let peer_did = AnyPeerDid::parse(did.to_owned())?;
match peer_did {
AnyPeerDid::Numalgo2(peer_did) => {
let did_doc =
peer_did.resolve(options.encoding.unwrap_or(PublicKeyEncoding::Base58))?;
let encoding = options.encoding.unwrap_or(PublicKeyEncoding::Multibase);
let builder: DidDocumentBuilder = peer_did.to_did_doc_builder(encoding)?;
let did_doc = builder
.add_also_known_as(peer_did.to_numalgo3()?.to_string().parse()?)
.build();
let resolution_metadata = DidResolutionMetadata::builder()
.content_type("application/did+json".to_string())
.build();
Expand Down

0 comments on commit 3e04ff0

Please sign in to comment.