use serde_json::json;
use crate::config::AppConfig;
use crate::keys::{self};
pub fn build_did_document(
derived: &keys::DerivedEntityKeys,
config: &AppConfig,
add_mediator_service: bool,
additional_services: &Option<Vec<serde_json::Value>>,
) -> serde_json::Value {
build_did_document_inner(
derived,
None,
config,
true,
add_mediator_service,
additional_services,
)
}
pub fn build_vta_did_document_with_sealed_transfer(
derived: &keys::DerivedEntityKeys,
sealed_transfer: &keys::DerivedSealedTransferKey,
config: &AppConfig,
add_mediator_service: bool,
additional_services: &Option<Vec<serde_json::Value>>,
) -> serde_json::Value {
build_did_document_inner(
derived,
Some(sealed_transfer),
config,
true,
add_mediator_service,
additional_services,
)
}
pub(crate) fn build_did_document_with_options(
derived: &keys::DerivedEntityKeys,
config: &AppConfig,
include_ka: bool,
add_mediator_service: bool,
additional_services: &Option<Vec<serde_json::Value>>,
) -> serde_json::Value {
build_did_document_inner(
derived,
None,
config,
include_ka,
add_mediator_service,
additional_services,
)
}
fn build_did_document_inner(
derived: &keys::DerivedEntityKeys,
sealed_transfer: Option<&keys::DerivedSealedTransferKey>,
config: &AppConfig,
include_ka: bool,
add_mediator_service: bool,
additional_services: &Option<Vec<serde_json::Value>>,
) -> serde_json::Value {
let mut vm = vec![json!({
"id": "{DID}#key-0",
"type": "Multikey",
"controller": "{DID}",
"publicKeyMultibase": &derived.signing_pub
})];
let mut assertion_method = vec![json!("{DID}#key-0")];
let mut did_document = json!({
"@context": [
"https://www.w3.org/ns/did/v1",
"https://www.w3.org/ns/cid/v1"
],
"id": "{DID}",
"authentication": ["{DID}#key-0"]
});
if include_ka {
vm.push(json!({
"id": "{DID}#key-1",
"type": "Multikey",
"controller": "{DID}",
"publicKeyMultibase": &derived.ka_pub
}));
did_document["keyAgreement"] = json!(["{DID}#key-1"]);
}
if let Some(st) = sealed_transfer {
vm.push(json!({
"id": "{DID}#sealed-transfer-0",
"type": "Multikey",
"controller": "{DID}",
"publicKeyMultibase": &st.public_key
}));
assertion_method.push(json!("{DID}#sealed-transfer-0"));
}
did_document["assertionMethod"] = json!(assertion_method);
did_document["verificationMethod"] = json!(vm);
if add_mediator_service && let Some(ref msg) = config.messaging {
let services = did_document
.as_object_mut()
.unwrap()
.entry("service")
.or_insert_with(|| json!([]));
services.as_array_mut().unwrap().push(json!({
"id": "{DID}#vta-didcomm",
"type": "DIDCommMessaging",
"serviceEndpoint": [{
"accept": ["didcomm/v2"],
"uri": msg.mediator_did
}]
}));
}
if let Some(svcs) = additional_services {
let services = did_document
.as_object_mut()
.unwrap()
.entry("service")
.or_insert_with(|| json!([]));
for svc in svcs {
services.as_array_mut().unwrap().push(svc.clone());
}
}
#[cfg(feature = "tee")]
if config.tee.embed_in_did
&& let Some(ref public_url) = config.public_url
{
let services = did_document
.as_object_mut()
.unwrap()
.entry("service")
.or_insert_with(|| json!([]));
services.as_array_mut().unwrap().push(json!({
"id": "{DID}#tee-attestation",
"type": "TeeAttestation",
"serviceEndpoint": format!("{}/attestation/report", public_url.trim_end_matches('/'))
}));
}
did_document
}