New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@windingtree/org.id-resolver

Package Overview
Dependencies
Maintainers
3
Versions
67
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@windingtree/org.id-resolver - npm Package Compare versions

Comparing version 2.4.0 to 2.4.1

8

dist/utils/vc.js

@@ -12,6 +12,6 @@ "use strict";require("core-js/modules/es.object.to-string.js");require("core-js/modules/es.promise.js");require("regenerator-runtime/runtime.js");require("core-js/modules/es.regexp.exec.js");require("core-js/modules/es.string.split.js");require("core-js/modules/es.array.filter.js");require("core-js/modules/es.array.includes.js");require("core-js/modules/es.string.includes.js");function asyncGeneratorStep(gen,resolve,reject,_next,_throw,key,arg){try{var info=gen[key](arg);var value=info.value}catch(error){reject(error);return}if(info.done){resolve(value)}else{Promise.resolve(value).then(_next,_throw)}}function _asyncToGenerator(fn){return function(){var self=this,args=arguments;return new Promise(function(resolve,reject){var gen=fn.apply(self,args);function _next(value){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"next",value)}function _throw(err){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"throw",err)}_next(undefined)})}}var _require=require("@windingtree/vc"),verifyVc=_require.verifyVc;module.exports.validateVc=/*#__PURE__*/function(){var _ref=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee(resolver,proof,claim){var proofDid,sourceDid,didResult,proofResolver,didDocumentValid,vc,verificationMethod,verifierDid,verifierDidResult,verifierResolver,verifierDidDocumentValid,verificationKey,verificationResult;return regeneratorRuntime.wrap(function _callee$(_context){while(1){switch(_context.prev=_context.next){case 0:proofDid=proof.split("#")[0];sourceDid=resolver.result.didDocument.id.toLowerCase();if(proofDid){_context.next=4;break}throw new Error("Unable to find a proof DID in the proof: ".concat(proof));case 4:// Normalize the proof DID

verifierDidDocumentValid=verifierDidResult.checks.filter(function(c){return c.type==="DID_DOCUMENT"})[0];if(!(!verifierDidDocumentValid||!verifierDidDocumentValid.passed)){_context.next=39;break}throw new Error("DID document of the proof verifier is not valid: ".concat(proof));case 39:// Get verification key from the DID document
verificationKey=verifierDidResult.didDocument.publicKey.filter(function(c){return c.id===verificationMethod})[0];if(verificationKey){_context.next=42;break}throw new Error("Unable to find verification key: ".concat(verificationMethod));case 42:// Validate VC integrity
verificationKey=verifierDidResult.didDocument.publicKey.filter(function(c){return c.id===verificationMethod})[0];if(verificationKey){_context.next=42;break}throw new Error("Unable to find verification key: ".concat(verificationMethod));case 42:console.log("@@@",verificationKey.publicKeyPem);// Validate VC integrity
verificationResult=verifyVc(vc,vc.proof.type,verificationKey.publicKeyPem);// Check if the issuer DID is defined in the VC data
if(verificationResult.issuer){_context.next=45;break}throw new Error("Unable to find issuer DID in the VC data");case 45:// Normalize the issuer DID
verificationResult.issuer=verificationResult.issuer.toLowerCase();if(!(resolver.authorizedTrustProofsIssuers&&!resolver.authorizedTrustProofsIssuers.includes(verificationResult.issuer))){_context.next=48;break}throw new Error("Unauthorized trust proof issuer: ".concat(verificationResult.issuer));case 48:if(!(verificationResult.credentialSubject.id!==sourceDid)){_context.next=50;break}throw new Error("Unknown credential subject Id ".concat(verificationResult.credentialSubject.id));case 50:if(!(verificationResult.credentialSubject.claim!==claim)){_context.next=52;break}throw new Error("Unknown credential subject Claim ".concat(verificationResult.credentialSubject.claim));case 52:case"end":return _context.stop();}}},_callee)}));return function(_x,_x2,_x3){return _ref.apply(this,arguments)}}();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/vc.js"],"names":["require","verifyVc","module","exports","validateVc","resolver","proof","claim","proofDid","split","sourceDid","result","didDocument","id","toLowerCase","Error","didResult","proofResolver","spawnResolver","resolve","didDocumentValid","checks","filter","c","type","passed","vc","trust","credentials","verificationMethod","verifierDid","verifierDidResult","verifierResolver","verifierDidDocumentValid","verificationKey","publicKey","verificationResult","publicKeyPem","issuer","authorizedTrustProofsIssuers","includes","credentialSubject"],"mappings":"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","sourcesContent":["const { verifyVc } = require('@windingtree/vc');\n\nmodule.exports.validateVc = async (resolver, proof, claim) => {\n    let proofDid = proof.split('#')[0];\n    let sourceDid = resolver.result.didDocument.id.toLowerCase();\n    let didResult;\n\n    // Check if proof has a DID\n    if (!proofDid) {\n        throw new Error(`Unable to find a proof DID in the proof: ${proof}`);\n    }\n    // Normalize the proof DID\n    proofDid = proofDid.toLowerCase();\n\n    // Check if the source DID is the same as the proof DID\n    if (proofDid === sourceDid) {\n        // Take already resolved DID\n        didResult = resolver.result;\n    } else {\n        // Make new resolution\n        const proofResolver = resolver.spawnResolver();\n        didResult = await proofResolver.resolve(proof);\n    }\n    if (!didResult) {\n        throw new Error(`Unable to resolve DID of the proof: ${proof}`);\n    }\n\n    // Check if the proof DID document is valid\n    const didDocumentValid = didResult.checks.filter(c => c.type === 'DID_DOCUMENT')[0];\n    if (!didDocumentValid || !didDocumentValid.passed) {\n        throw new Error(`DID document of the proof is not valid: ${proof}`);\n    }\n\n    // Get VC from the proof DID document\n    const vc = didResult.didDocument.trust.credentials.filter(c => c.id === proof)[0];\n    if (!vc) {\n        throw new Error(`Unable to find VC of the proof: ${proof}`);\n    }\n\n    // Fetch verification key\n    const verificationMethod = vc.proof.verificationMethod;\n    let verifierDid = verificationMethod.split('#')[0];\n\n    // Check verifier DID existence\n    if (!verifierDid) {\n        throw new Error(`Unable to find a verifier DID in the verificationMethod: ${verificationMethod}`);\n    }\n    // Normalize the verifier DID\n    verifierDid = verifierDid.toLowerCase();\n\n    let verifierDidResult;\n    if (verifierDid === sourceDid) {\n        verifierDidResult = resolver.result;\n    } else {\n        const verifierResolver = resolver.spawnResolver();\n        verifierDidResult = await verifierResolver.resolve(verifierDid);\n    }\n    if (!verifierDidResult) {\n        throw new Error(`Unable to resolve the proof verifier DID: ${verifierDid}`);\n    }\n\n    // Check if verifier DID document is valid\n    const verifierDidDocumentValid = verifierDidResult.checks.filter(c => c.type === 'DID_DOCUMENT')[0];\n    if (!verifierDidDocumentValid || !verifierDidDocumentValid.passed) {\n        throw new Error(`DID document of the proof verifier is not valid: ${proof}`);\n    }\n\n    // Get verification key from the DID document\n    const verificationKey = verifierDidResult.didDocument.publicKey.filter(c => c.id === verificationMethod)[0];\n    if (!verificationKey) {\n        throw new Error(`Unable to find verification key: ${verificationMethod}`);\n    }\n\n    // Validate VC integrity\n    const verificationResult = verifyVc(\n        vc,\n        vc.proof.type,\n        verificationKey.publicKeyPem\n    );\n\n    // Check if the issuer DID is defined in the VC data\n    if (!verificationResult.issuer) {\n        throw new Error('Unable to find issuer DID in the VC data');\n    }\n    // Normalize the issuer DID\n    verificationResult.issuer = verificationResult.issuer.toLowerCase();\n\n    if (resolver.authorizedTrustProofsIssuers &&\n        !resolver.authorizedTrustProofsIssuers.includes(verificationResult.issuer)) {\n        throw new Error(`Unauthorized trust proof issuer: ${verificationResult.issuer}`);\n    }\n\n    // Validate a credential subject Id. Should be a company DID\n    if (verificationResult.credentialSubject.id !== sourceDid) {\n        throw new Error(`Unknown credential subject Id ${verificationResult.credentialSubject.id}`);\n    }\n\n    // Validate a credential subject Claim.\n    // Should be a provided trust assertion claim\n    if (verificationResult.credentialSubject.claim !== claim) {\n        throw new Error(`Unknown credential subject Claim ${verificationResult.credentialSubject.claim}`);\n    }\n};\n"]}
if(verificationResult.issuer){_context.next=46;break}throw new Error("Unable to find issuer DID in the VC data");case 46:// Normalize the issuer DID
verificationResult.issuer=verificationResult.issuer.toLowerCase();if(!(resolver.authorizedTrustProofsIssuers&&!resolver.authorizedTrustProofsIssuers.includes(verificationResult.issuer))){_context.next=49;break}throw new Error("Unauthorized trust proof issuer: ".concat(verificationResult.issuer));case 49:if(!(verificationResult.credentialSubject.id!==sourceDid)){_context.next=51;break}throw new Error("Unknown credential subject Id ".concat(verificationResult.credentialSubject.id));case 51:if(!(verificationResult.credentialSubject.claim!==claim)){_context.next=53;break}throw new Error("Unknown credential subject Claim ".concat(verificationResult.credentialSubject.claim));case 53:case"end":return _context.stop();}}},_callee)}));return function(_x,_x2,_x3){return _ref.apply(this,arguments)}}();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/vc.js"],"names":["require","verifyVc","module","exports","validateVc","resolver","proof","claim","proofDid","split","sourceDid","result","didDocument","id","toLowerCase","Error","didResult","proofResolver","spawnResolver","resolve","didDocumentValid","checks","filter","c","type","passed","vc","trust","credentials","verificationMethod","verifierDid","verifierDidResult","verifierResolver","verifierDidDocumentValid","verificationKey","publicKey","console","log","publicKeyPem","verificationResult","issuer","authorizedTrustProofsIssuers","includes","credentialSubject"],"mappings":"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","sourcesContent":["const { verifyVc } = require('@windingtree/vc');\n\nmodule.exports.validateVc = async (resolver, proof, claim) => {\n    let proofDid = proof.split('#')[0];\n    let sourceDid = resolver.result.didDocument.id.toLowerCase();\n    let didResult;\n\n    // Check if proof has a DID\n    if (!proofDid) {\n        throw new Error(`Unable to find a proof DID in the proof: ${proof}`);\n    }\n    // Normalize the proof DID\n    proofDid = proofDid.toLowerCase();\n\n    // Check if the source DID is the same as the proof DID\n    if (proofDid === sourceDid) {\n        // Take already resolved DID\n        didResult = resolver.result;\n    } else {\n        // Make new resolution\n        const proofResolver = resolver.spawnResolver();\n        didResult = await proofResolver.resolve(proof);\n    }\n    if (!didResult) {\n        throw new Error(`Unable to resolve DID of the proof: ${proof}`);\n    }\n\n    // Check if the proof DID document is valid\n    const didDocumentValid = didResult.checks.filter(c => c.type === 'DID_DOCUMENT')[0];\n    if (!didDocumentValid || !didDocumentValid.passed) {\n        throw new Error(`DID document of the proof is not valid: ${proof}`);\n    }\n\n    // Get VC from the proof DID document\n    const vc = didResult.didDocument.trust.credentials.filter(c => c.id === proof)[0];\n    if (!vc) {\n        throw new Error(`Unable to find VC of the proof: ${proof}`);\n    }\n\n    // Fetch verification key\n    const verificationMethod = vc.proof.verificationMethod;\n    let verifierDid = verificationMethod.split('#')[0];\n\n    // Check verifier DID existence\n    if (!verifierDid) {\n        throw new Error(`Unable to find a verifier DID in the verificationMethod: ${verificationMethod}`);\n    }\n    // Normalize the verifier DID\n    verifierDid = verifierDid.toLowerCase();\n\n    let verifierDidResult;\n    if (verifierDid === sourceDid) {\n        verifierDidResult = resolver.result;\n    } else {\n        const verifierResolver = resolver.spawnResolver();\n        verifierDidResult = await verifierResolver.resolve(verifierDid);\n    }\n    if (!verifierDidResult) {\n        throw new Error(`Unable to resolve the proof verifier DID: ${verifierDid}`);\n    }\n\n    // Check if verifier DID document is valid\n    const verifierDidDocumentValid = verifierDidResult.checks.filter(c => c.type === 'DID_DOCUMENT')[0];\n    if (!verifierDidDocumentValid || !verifierDidDocumentValid.passed) {\n        throw new Error(`DID document of the proof verifier is not valid: ${proof}`);\n    }\n\n    // Get verification key from the DID document\n    const verificationKey = verifierDidResult.didDocument.publicKey.filter(c => c.id === verificationMethod)[0];\n    if (!verificationKey) {\n        throw new Error(`Unable to find verification key: ${verificationMethod}`);\n    }\n\n    console.log('@@@', verificationKey.publicKeyPem);\n\n    // Validate VC integrity\n    const verificationResult = verifyVc(\n        vc,\n        vc.proof.type,\n        verificationKey.publicKeyPem\n    );\n\n    // Check if the issuer DID is defined in the VC data\n    if (!verificationResult.issuer) {\n        throw new Error('Unable to find issuer DID in the VC data');\n    }\n    // Normalize the issuer DID\n    verificationResult.issuer = verificationResult.issuer.toLowerCase();\n\n    if (resolver.authorizedTrustProofsIssuers &&\n        !resolver.authorizedTrustProofsIssuers.includes(verificationResult.issuer)) {\n        throw new Error(`Unauthorized trust proof issuer: ${verificationResult.issuer}`);\n    }\n\n    // Validate a credential subject Id. Should be a company DID\n    if (verificationResult.credentialSubject.id !== sourceDid) {\n        throw new Error(`Unknown credential subject Id ${verificationResult.credentialSubject.id}`);\n    }\n\n    // Validate a credential subject Claim.\n    // Should be a provided trust assertion claim\n    if (verificationResult.credentialSubject.claim !== claim) {\n        throw new Error(`Unknown credential subject Claim ${verificationResult.credentialSubject.claim}`);\n    }\n};\n"]}
{
"name": "@windingtree/org.id-resolver",
"version": "2.4.0",
"version": "2.4.1",
"description": "ORGiD DID resolver",

@@ -26,3 +26,3 @@ "keywords": [

"engines": {
"node": ">=12"
"node": ">=10"
},

@@ -29,0 +29,0 @@ "scripts": {

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc