@windingtree/org.id-resolver 2.4.0 → 3.0.0-beta.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +13 -221
- package/dist/package.json +59 -0
- package/dist/src/index.d.ts +118 -0
- package/dist/src/index.js +341 -0
- package/dist/src/index.js.map +1 -0
- package/package.json +39 -43
- package/dist/cli.js +0 -5
- package/dist/dns.js +0 -10
- package/dist/http.js +0 -5
- package/dist/index.js +0 -98
- package/dist/linkedIn.js +0 -5
- package/dist/twitter.js +0 -6
- package/dist/utils/cli.js +0 -23
- package/dist/utils/constants.js +0 -2
- package/dist/utils/document.js +0 -2
- package/dist/utils/expect.js +0 -20
- package/dist/utils/vc.js +0 -16
- package/dist/whois.js +0 -3
package/dist/index.js
DELETED
@@ -1,98 +0,0 @@
|
|
1
|
-
"use strict";require("core-js/modules/es.symbol.js");require("core-js/modules/es.array.filter.js");require("core-js/modules/es.object.get-own-property-descriptor.js");require("core-js/modules/es.array.for-each.js");require("core-js/modules/web.dom-collections.for-each.js");require("core-js/modules/es.object.get-own-property-descriptors.js");require("core-js/modules/es.promise.js");require("core-js/modules/es.array.slice.js");require("core-js/modules/es.array.from.js");require("core-js/modules/es.string.iterator.js");require("core-js/modules/es.symbol.description.js");require("core-js/modules/es.symbol.iterator.js");require("regenerator-runtime/runtime.js");require("core-js/modules/es.array.map.js");require("core-js/modules/es.array.includes.js");require("core-js/modules/es.object.assign.js");require("core-js/modules/es.array.concat.js");require("core-js/modules/es.date.to-iso-string.js");require("core-js/modules/es.regexp.exec.js");require("core-js/modules/es.string.split.js");require("core-js/modules/es.regexp.constructor.js");require("core-js/modules/es.regexp.to-string.js");require("core-js/modules/es.string.match.js");require("core-js/modules/es.array.join.js");require("core-js/modules/es.object.keys.js");require("core-js/modules/es.string.replace.js");require("core-js/modules/es.object.to-string.js");require("core-js/modules/es.array.iterator.js");require("core-js/modules/web.dom-collections.iterator.js");require("core-js/modules/es.function.name.js");function _toConsumableArray(arr){return _arrayWithoutHoles(arr)||_iterableToArray(arr)||_unsupportedIterableToArray(arr)||_nonIterableSpread()}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _iterableToArray(iter){if(typeof Symbol!=="undefined"&&Symbol.iterator in Object(iter))return Array.from(iter)}function _arrayWithoutHoles(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr)}function _typeof(obj){"@babel/helpers - typeof";if(typeof Symbol==="function"&&typeof Symbol.iterator==="symbol"){_typeof=function _typeof(obj){return typeof obj}}else{_typeof=function _typeof(obj){return obj&&typeof Symbol==="function"&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj}}return _typeof(obj)}function _createForOfIteratorHelper(o,allowArrayLike){var it;if(typeof Symbol==="undefined"||o[Symbol.iterator]==null){if(Array.isArray(o)||(it=_unsupportedIterableToArray(o))||allowArrayLike&&o&&typeof o.length==="number"){if(it)o=it;var i=0;var F=function F(){};return{s:F,n:function n(){if(i>=o.length)return{done:true};return{done:false,value:o[i++]}},e:function e(_e){throw _e},f:F}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var normalCompletion=true,didErr=false,err;return{s:function s(){it=o[Symbol.iterator]()},n:function n(){var step=it.next();normalCompletion=step.done;return step},e:function e(_e2){didErr=true;err=_e2},f:function f(){try{if(!normalCompletion&&it.return!=null)it.return()}finally{if(didErr)throw err}}}}function _unsupportedIterableToArray(o,minLen){if(!o)return;if(typeof o==="string")return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(o);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}function _arrayLikeToArray(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++){arr2[i]=arr[i]}return arr2}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)})}}function ownKeys(object,enumerableOnly){var keys=Object.keys(object);if(Object.getOwnPropertySymbols){var symbols=Object.getOwnPropertySymbols(object);if(enumerableOnly)symbols=symbols.filter(function(sym){return Object.getOwnPropertyDescriptor(object,sym).enumerable});keys.push.apply(keys,symbols)}return keys}function _objectSpread(target){for(var i=1;i<arguments.length;i++){var source=arguments[i]!=null?arguments[i]:{};if(i%2){ownKeys(Object(source),true).forEach(function(key){_defineProperty(target,key,source[key])})}else if(Object.getOwnPropertyDescriptors){Object.defineProperties(target,Object.getOwnPropertyDescriptors(source))}else{ownKeys(Object(source)).forEach(function(key){Object.defineProperty(target,key,Object.getOwnPropertyDescriptor(source,key))})}}return target}function _defineProperty(obj,key,value){if(key in obj){Object.defineProperty(obj,key,{value:value,enumerable:true,configurable:true,writable:true})}else{obj[key]=value}return obj}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError("Cannot call a class as a function")}}function _defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if("value"in descriptor)descriptor.writable=true;Object.defineProperty(target,descriptor.key,descriptor)}}function _createClass(Constructor,protoProps,staticProps){if(protoProps)_defineProperties(Constructor.prototype,protoProps);if(staticProps)_defineProperties(Constructor,staticProps);return Constructor}var packageJson=require("../package.json");var _require=require("./utils/vc"),validateVc=_require.validateVc;var didDocumentSchema=require("org.json-schema-0.3");var didDocumentSchema04=require("org.json-schema-0.4");var _require2=require("@windingtree/org.id"),OrgIdContract=_require2.OrgIdContract;var _require3=require("@windingtree/org.id-lif-deposit"),LifDepositContract=_require3.LifDepositContract;var Ajv=require("ajv");// Utilities
|
2
|
-
var expect=require("./utils/expect");var _require4=require("./utils/document"),makeHash=_require4.makeHash;// Modules
|
3
|
-
var httpFetchMethod=require("./http");var linkedInFetchMethod=require("./linkedIn");var twitterFetchMethod=require("./twitter");var whoisService=require("./whois");var _require5=require("./dns"),getDnsData=_require5.getDnsData,ResourceRecordTypes=_require5.ResourceRecordTypes;var _require6=require("./utils/constants"),zeroAddress=_require6.zeroAddress;// Errors types definitions
|
4
|
-
var checksTypes=["DID_SYNTAX","ORGID","DID_DOCUMENT","TRUST_ASSERTIONS","LIF_STAKE"];/**
|
5
|
-
* ORG.ID resolver class
|
6
|
-
* @class OrgIdResolver
|
7
|
-
*/var OrgIdResolver=/*#__PURE__*/function(){/**
|
8
|
-
* Creates an instance of OrgIdResolver.
|
9
|
-
* @param {Obejct} options Contructor parameters
|
10
|
-
* @memberof OrgIdResolver
|
11
|
-
*/function OrgIdResolver(){var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};_classCallCheck(this,OrgIdResolver);expect.all(options,{web3:{type:"object"},orgId:{type:"address"},lifDeposit:{type:"address",required:false},authorizedTrustProofsIssuers:{type:"object",required:false}});this.methodName="orgid";this.fetchSocialMethods={};this.fetchMethods={};this.serviceMethods={};this.web3=options.web3;this.orgIdAddress=options.orgId;this.lifDepositAddress=options.lifDeposit;this.authorizedTrustProofsIssuers=options.authorizedTrustProofsIssuers;this.validator=null;this.resolutionStart=null;this.resultTemplate=null;this.cache=null;this.result=null;this.reset()}/**
|
12
|
-
* Sets defaults
|
13
|
-
* @memberof OrgIdResolver
|
14
|
-
*/_createClass(OrgIdResolver,[{key:"reset",value:function reset(){this.validator=new Ajv;this.resolutionStart=null;this.resultTemplate=_objectSpread(_objectSpread({didDocument:null,organization:null,checks:checksTypes.map(function(type){return{type:type,passed:["TRUST_ASSERTIONS","LIF_STAKE"].includes(type)?false:true}}),trust:[]},this.lifDepositAddress?{lifDeposit:null}:{}),{},{resolverMetadata:{retrieved:null,duration:null}});this.cache={};this.result=Object.assign({},this.resultTemplate)}/**
|
15
|
-
* Resolvs DID into its document
|
16
|
-
* and makes proper validations and verifications
|
17
|
-
* @memberof OrgIdResolver
|
18
|
-
* @param {string} did DID
|
19
|
-
* @returns {Promise<{Object}>} Resolving result
|
20
|
-
*/},{key:"resolve",value:function(){var _resolve=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee(did){return regeneratorRuntime.wrap(function _callee$(_context){while(1){switch(_context.prev=_context.next){case 0:expect.all({did:did},{did:{type:"string"}});this.reset();this.resolutionStart=Date.now();_context.prev=3;_context.next=6;return this.validateDidSyntax(did);case 6:_context.next=8;return this.getOrganization(this.result.id);case 8:_context.next=10;return this.getDidDocument(this.result.organization);case 10:_context.next=12;return this.validateDidDocument(this.result.didDocument);case 12:_context.next=14;return this.verifyTrustRecords(this.result.didDocument);case 14:_context.next=16;return this.verifyLifStake(this.result.id);case 16:_context.next=21;break;case 18:_context.prev=18;_context.t0=_context["catch"](3);throw new Error("Resolving flow has been terminated due to serious error: ".concat(_context.t0.message,"; ").concat(_context.t0.stack));case 21:this.result.resolverMetadata.version=packageJson.version;this.result.resolverMetadata.retrieved=new Date().toISOString();this.result.resolverMetadata.duration=Date.now()-this.resolutionStart;this.result.resolverMetadata.orgIdAddress=this.orgIdAddress;return _context.abrupt("return",this.result);case 26:case"end":return _context.stop();}}},_callee,this,[[3,18]])}));function resolve(_x){return _resolve.apply(this,arguments)}return resolve}()/**
|
21
|
-
* Validates the given DID syntax
|
22
|
-
* @memberof OrgIdResolver
|
23
|
-
* @param {string} did DID
|
24
|
-
* @returns {Promise<{string}>} Organization Id
|
25
|
-
*/},{key:"validateDidSyntax",value:function(){var _validateDidSyntax=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee2(did){var parts,subParts;return regeneratorRuntime.wrap(function _callee2$(_context2){while(1){switch(_context2.prev=_context2.next){case 0:expect.all({did:did},{did:{type:"string"}});parts=did.split(":");if(parts[0]!=="did"){this.addCheckResult({type:"DID_SYNTAX",error:"Invalid DID prefix: ".concat(parts[0]),throw:true})}if(parts[1]!==this.methodName){this.addCheckResult({type:"DID_SYNTAX",error:"Unsupported DID method: ".concat(parts[1]),throw:true})}// Split paths, method parameters and queries
|
26
|
-
subParts=parts[2].split(/(?:#|;|\?)/);if(!new RegExp("^0x[a-fA-F0-9]{64}$").test(subParts[0])){this.addCheckResult({type:"DID_SYNTAX",error:"Invalid method specific Id: ".concat(subParts[0]),throw:true})}this.result.id=subParts[0];return _context2.abrupt("return",this.result.id);case 8:case"end":return _context2.stop();}}},_callee2,this)}));function validateDidSyntax(_x2){return _validateDidSyntax.apply(this,arguments)}return validateDidSyntax}()/**
|
27
|
-
* Validates the given DID document
|
28
|
-
* @memberof OrgIdResolver
|
29
|
-
* @param {Object} didDocument DID document
|
30
|
-
* @returns {Promise<{boolean}>} Validation result
|
31
|
-
*/},{key:"validateDidDocument",value:function(){var _validateDidDocument=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee3(didDocument){var _this=this;var schema,result;return regeneratorRuntime.wrap(function _callee3$(_context3){while(1){switch(_context3.prev=_context3.next){case 0:expect.all({didDocument:didDocument},{didDocument:{type:"object"}});schema=didDocument.schemaVersion&&didDocument.schemaVersion.match(/^0.4/)?didDocumentSchema04:didDocumentSchema;// Use the Ajv validator
|
32
|
-
// didDocumentSchema is obtained from @windingtree/org.json-schema
|
33
|
-
result=this.validator.validate(schema,didDocument);if(this.validator.errors!==null){this.validator.errors.map(function(detail){return _this.addCheckResult({type:"DID_DOCUMENT",warning:detail})})}return _context3.abrupt("return",result);case 5:case"end":return _context3.stop();}}},_callee3,this)}));function validateDidDocument(_x3){return _validateDidDocument.apply(this,arguments)}return validateDidDocument}()/**
|
34
|
-
* Verifies trust objects from the DID document
|
35
|
-
* @memberof OrgIdResolver
|
36
|
-
* @param {Object} didDocument DID document
|
37
|
-
* @returns {Promise}
|
38
|
-
*/},{key:"verifyTrustRecords",value:function(){var _verifyTrustRecords=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee4(didDocument){var trust,id,isProofsFound,i,assertion,assertionContent,proofFound,whoisInfo,_iterator,_step,record,rootDomain;return regeneratorRuntime.wrap(function _callee4$(_context4){while(1){switch(_context4.prev=_context4.next){case 0:if(!(!didDocument.trust||!Array.isArray(didDocument.trust.assertions))){_context4.next=2;break}return _context4.abrupt("return",{});case 2:// Cloned trust section
|
39
|
-
trust=JSON.parse(JSON.stringify(didDocument.trust));// Organization Id part of the DID
|
40
|
-
id=didDocument.id.match(/^did:orgid:(0x[a-fA-F0-9]{64}){1}$/im)[1];// Proofs existence flag
|
41
|
-
isProofsFound=false;// Assertions verification
|
42
|
-
i=0;case 6:if(!(i<trust.assertions.length)){_context4.next=105;break}assertion=trust.assertions[i];assertionContent=void 0;proofFound=false;// WHOIS information about domain
|
43
|
-
whoisInfo=void 0;_context4.t0=assertion.type;_context4.next=_context4.t0==="dns"?14:_context4.t0==="social"?50:_context4.t0==="domain"?50:97;break;case 14:if(ResourceRecordTypes[assertion.proof]){_context4.next=17;break}this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: proof value \"").concat(assertion.proof,"\"\n not in the range of [").concat(Object.keys(ResourceRecordTypes).join(","),"]")});return _context4.abrupt("break",98);case 17:_context4.prev=17;_context4.next=20;return getDnsData(assertion.claim,assertion.proof);case 20:assertionContent=_context4.sent;if(!(assertionContent.length===0)){_context4.next=24;break}this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: claim source is empty")});return _context4.abrupt("break",98);case 24:_iterator=_createForOfIteratorHelper(assertionContent);_context4.prev=25;_iterator.s();case 27:if((_step=_iterator.n()).done){_context4.next=34;break}record=_step.value;if(!RegExp(didDocument.id,"g").test(record.data)){_context4.next=32;break}proofFound=true;return _context4.abrupt("break",34);case 32:_context4.next=27;break;case 34:_context4.next=39;break;case 36:_context4.prev=36;_context4.t1=_context4["catch"](25);_iterator.e(_context4.t1);case 39:_context4.prev=39;_iterator.f();return _context4.finish(39);case 42:if(!proofFound){this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: proof not found")})}_context4.next=49;break;case 45:_context4.prev=45;_context4.t2=_context4["catch"](17);this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: cannot get the proof")});return _context4.abrupt("break",98);case 49:return _context4.abrupt("break",98);case 50:_context4.prev=50;if(!(assertion.type==="domain"&&this.serviceMethods.whois)){_context4.next=58;break}rootDomain=assertion.claim.match(/[^.]+\.[^.]+$/)[0];_context4.next=55;return this.serviceMethods.whois.fetch(rootDomain);case 55:whoisInfo=_context4.sent;proofFound=true;return _context4.abrupt("break",98);case 58:_context4.next=63;break;case 60:_context4.prev=60;_context4.t3=_context4["catch"](50);this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: unable to fetch whois information")});case 63:if(!assertion.proof.match(/^did.orgid/)){_context4.next=78;break}_context4.prev=64;_context4.next=67;return validateVc(this,assertion.proof,assertion.claim);case 67:proofFound=true;return _context4.abrupt("break",98);case 71:_context4.prev=71;_context4.t4=_context4["catch"](64);console.log("###",_context4.t4);this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: VC DID not pass verification")});return _context4.abrupt("break",98);case 76:_context4.next=96;break;case 78:if(RegExp("^(http|https)://(www.){0,1}".concat(assertion.claim.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"))).test(assertion.proof)){_context4.next=81;break}this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: claim is not in the domain namespace")});return _context4.abrupt("break",98);case 81:_context4.prev=81;_context4.next=84;return this.fetchFileByUri(assertion.proof);case 84:assertionContent=_context4.sent;assertionContent=_typeof(assertionContent)==="object"?JSON.stringify(assertionContent):assertionContent;_context4.next=92;break;case 88:_context4.prev=88;_context4.t5=_context4["catch"](81);this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: cannot get the proof")});return _context4.abrupt("break",98);case 92:if(RegExp(id,"im").test(assertionContent)){_context4.next=95;break}this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: DID not found in the claim")});return _context4.abrupt("break",98);case 95:proofFound=true;case 96:return _context4.abrupt("break",98);case 97:// For cases where unknown assertion type has been provided
|
44
|
-
this.addCheckResult({type:"TRUST_ASSERTIONS",error:"trust.assertions[".concat(i,"]: unknown assertion type \"").concat(assertion.type,"\"")});case 98:assertion.verified=proofFound;assertion=_objectSpread(_objectSpread({},assertion),whoisInfo?{whois:whoisInfo}:{});trust.assertions[i]=assertion;if(proofFound){isProofsFound=true}case 102:i++;_context4.next=6;break;case 105:if(isProofsFound){// Just mark as passed
|
45
|
-
this.addCheckResult({type:"TRUST_ASSERTIONS"})}this.result.trust=trust;return _context4.abrupt("return",this.result.trust);case 108:case"end":return _context4.stop();}}},_callee4,this,[[17,45],[25,36,39,42],[50,60],[64,71],[81,88]])}));function verifyTrustRecords(_x4){return _verifyTrustRecords.apply(this,arguments)}return verifyTrustRecords}()/**
|
46
|
-
* Get the organization data
|
47
|
-
* @memberof OrgIdResolver
|
48
|
-
* @param {string} id The organization Id
|
49
|
-
* @returns {Promise}
|
50
|
-
*/},{key:"verifyLifStake",value:function(){var _verifyLifStake=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee5(id){var deposit,withdrawalRequest,lifDepositContract,requestSource;return regeneratorRuntime.wrap(function _callee5$(_context5){while(1){switch(_context5.prev=_context5.next){case 0:if(this.lifDepositAddress){_context5.next=2;break}return _context5.abrupt("return");case 2:expect.all({id:id},{id:{type:"string"}});deposit=0;withdrawalRequest=null;lifDepositContract=new this.web3.eth.Contract(LifDepositContract.abi,this.lifDepositAddress);_context5.prev=6;_context5.next=9;return lifDepositContract.methods["balanceOf(bytes32)"](id).call();case 9:deposit=_context5.sent;_context5.next=12;return lifDepositContract.methods["getWithdrawalRequest(bytes32)"](id).call();case 12:requestSource=_context5.sent;if(requestSource.exists){withdrawalRequest={value:requestSource.value.toString(),withdrawTime:requestSource.withdrawTime.toString()}}this.result.lifDeposit={deposit:deposit,withdrawalRequest:withdrawalRequest};if(deposit!=="0"&&!withdrawalRequest){// Just mark as passed
|
51
|
-
this.addCheckResult({type:"LIF_STAKE"})}else if(deposit!=="0"&&withdrawalRequest){this.addCheckResult({type:"LIF_STAKE",warning:"The organization sent a withdrawal request"})}_context5.next=21;break;case 18:_context5.prev=18;_context5.t0=_context5["catch"](6);this.addCheckResult({type:"LIF_STAKE",error:_context5.t0.message});case 21:case"end":return _context5.stop();}}},_callee5,this,[[6,18]])}));function verifyLifStake(_x5){return _verifyLifStake.apply(this,arguments)}return verifyLifStake}()/**
|
52
|
-
* Fetch a file by the given URI
|
53
|
-
* @memberof OrgIdResolver
|
54
|
-
* @param {string} uri The file URI
|
55
|
-
* @returns {Promise<{Object|string}>} Fetched file
|
56
|
-
*/},{key:"fetchFileByUri",value:function(){var _fetchFileByUri=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee6(uri){var fetch,f,_f,document;return regeneratorRuntime.wrap(function _callee6$(_context6){while(1){switch(_context6.prev=_context6.next){case 0:expect.all({uri:uri},{uri:{type:"string"}});if(!(uri==="")){_context6.next=3;break}throw new Error("Fetcher error: empty URI");case 3:if(!(Object.keys(this.fetchMethods).length===0)){_context6.next=5;break}throw new Error("Incomplete configuration: at least one fetching method should be registered");case 5:_context6.t0=regeneratorRuntime.keys(this.fetchSocialMethods);case 6:if((_context6.t1=_context6.t0()).done){_context6.next=13;break}f=_context6.t1.value;if(!RegExp(this.fetchSocialMethods[f].pattern).test(uri)){_context6.next=11;break}fetch=this.fetchSocialMethods[f].fetch;return _context6.abrupt("break",13);case 11:_context6.next=6;break;case 13:if(fetch){_context6.next=22;break}_context6.t2=regeneratorRuntime.keys(this.fetchMethods);case 15:if((_context6.t3=_context6.t2()).done){_context6.next=22;break}_f=_context6.t3.value;if(!RegExp(this.fetchMethods[_f].pattern).test(uri)){_context6.next=20;break}fetch=this.fetchMethods[_f].fetch;return _context6.abrupt("break",22);case 20:_context6.next=15;break;case 22:if(fetch){_context6.next=24;break}throw new Error("Fetcher error: unable to determine the fetching method for URI: ".concat(uri));case 24:_context6.next=26;return fetch(uri);case 26:document=_context6.sent;if(document){_context6.next=29;break}throw new Error("Fetcher error: file not found by the given URI: ".concat(uri));case 29:return _context6.abrupt("return",document);case 30:case"end":return _context6.stop();}}},_callee6,this)}));function fetchFileByUri(_x6){return _fetchFileByUri.apply(this,arguments)}return fetchFileByUri}()/**
|
57
|
-
* Fetch a DID document by the given Id
|
58
|
-
* @memberof OrgIdResolver
|
59
|
-
* @param {Object} organization The organization object
|
60
|
-
* @returns {Promise<{Object}>} DID document
|
61
|
-
*/},{key:"getDidDocument",value:function(){var _getDidDocument=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee8(){var _this2=this;var organization,orgId,orgJsonHash,orgJsonUri,orgJsonUriBackup1,orgJsonUriBackup2,firstSettled,didDocument,didObject,_args8=arguments;return regeneratorRuntime.wrap(function _callee8$(_context8){while(1){switch(_context8.prev=_context8.next){case 0:organization=_args8.length>0&&_args8[0]!==undefined?_args8[0]:{};expect.all(organization,{orgId:{type:"hash"},orgJsonUri:{type:"string"},orgJsonUriBackup1:{type:"string",required:false},orgJsonUriBackup2:{type:"string",required:false}});orgId=organization.orgId,orgJsonHash=organization.orgJsonHash,orgJsonUri=organization.orgJsonUri,orgJsonUriBackup1=organization.orgJsonUriBackup1,orgJsonUriBackup2=organization.orgJsonUriBackup2;// Resolve first settled promise
|
62
|
-
firstSettled=/*#__PURE__*/function(){var _ref=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee7(fetches){var result,errors,_iterator2,_step2,fetchPromise;return regeneratorRuntime.wrap(function _callee7$(_context7){while(1){switch(_context7.prev=_context7.next){case 0:errors=[];_iterator2=_createForOfIteratorHelper(fetches);_context7.prev=2;_iterator2.s();case 4:if((_step2=_iterator2.n()).done){_context7.next=18;break}fetchPromise=_step2.value;_context7.prev=6;_context7.next=9;return fetchPromise();case 9:result=_context7.sent;return _context7.abrupt("return",result);case 13:_context7.prev=13;_context7.t0=_context7["catch"](6);errors.push(_context7.t0.message);case 16:_context7.next=4;break;case 18:_context7.next=23;break;case 20:_context7.prev=20;_context7.t1=_context7["catch"](2);_iterator2.e(_context7.t1);case 23:_context7.prev=23;_iterator2.f();return _context7.finish(23);case 26:throw new Error("Unable to fetch DID Document from given sources.\n ".concat(errors.length?errors.join("; "):""));case 27:case"end":return _context7.stop();}}},_callee7,null,[[2,20,23,26],[6,13]])}));return function firstSettled(_x7){return _ref.apply(this,arguments)}}();_context8.prev=4;_context8.next=7;return firstSettled([orgJsonUri,orgJsonUriBackup1,orgJsonUriBackup2].map(function(uri){return function(){return _this2.fetchFileByUri(uri)}}));case 7:didDocument=_context8.sent;_context8.next=13;break;case 10:_context8.prev=10;_context8.t0=_context8["catch"](4);this.addCheckResult({type:"DID_DOCUMENT",error:_context8.t0.message,throw:true});case 13:try{didObject=JSON.parse(didDocument)}catch(error){this.addCheckResult({type:"DID_DOCUMENT",error:"Broken ORG.JSON. Unable to parse"})}// Comparing of the stored and actual hash
|
63
|
-
if(makeHash(didDocument,this.web3)!==orgJsonHash){this.addCheckResult({type:"DID_DOCUMENT",error:"Invalid DID Document hash"})}// DID document should containing a proper DID
|
64
|
-
if("did:".concat(this.methodName,":").concat(orgId)!==didObject.id){this.addCheckResult({type:"DID_DOCUMENT",error:"Invalid DID Document id. Expected to be: ".concat(orgId,",\n but actual is: ").concat(didObject.id)})}this.result.didDocument=didObject;return _context8.abrupt("return",this.result.didDocument);case 18:case"end":return _context8.stop();}}},_callee8,this,[[4,10]])}));function getDidDocument(){return _getDidDocument.apply(this,arguments)}return getDidDocument}()/**
|
65
|
-
* Register a fetching method for social accounts
|
66
|
-
* @memberof OrgIdResolver
|
67
|
-
* @param {Object} methodConfig The fetching method configuration config
|
68
|
-
* @param {Object} methodOptions The fetching method options (API key, etc)
|
69
|
-
*/},{key:"registerSocialFetchMethod",value:function registerSocialFetchMethod(){var methodConfig=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var methodOptions=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};expect.all(methodConfig,{name:{type:"string"},pattern:{type:"string"},fetch:{type:"function"}});this.fetchSocialMethods[methodConfig.name]=_objectSpread(_objectSpread({},methodConfig),{},{fetch:function(){var _fetch=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee9(uri){var options;return regeneratorRuntime.wrap(function _callee9$(_context9){while(1){switch(_context9.prev=_context9.next){case 0:options=methodOptions;_context9.next=3;return methodConfig.fetch(uri,options);case 3:return _context9.abrupt("return",_context9.sent);case 4:case"end":return _context9.stop();}}},_callee9)}));function fetch(_x8){return _fetch.apply(this,arguments)}return fetch}()})}/**
|
70
|
-
* Register a fetching method
|
71
|
-
* @memberof OrgIdResolver
|
72
|
-
* @param {Object} methodConfig The fetching method configuration config
|
73
|
-
*/},{key:"registerFetchMethod",value:function registerFetchMethod(){var methodConfig=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};expect.all(methodConfig,{name:{type:"string"},pattern:{type:"string"},fetch:{type:"function"}});this.fetchMethods[methodConfig.name]=methodConfig}/**
|
74
|
-
* Register a service method
|
75
|
-
* @memberof OrgIdResolver
|
76
|
-
* @param {Object} methodConfig The service method configuration config
|
77
|
-
*/},{key:"registerService",value:function registerService(){var methodConfig=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};expect.all(methodConfig,{name:{type:"string"},fetch:{type:"function"}});this.serviceMethods[methodConfig.name]=methodConfig}/**
|
78
|
-
* Get the OrgId contract instance
|
79
|
-
* @memberof OrgIdResolver
|
80
|
-
* @returns {Object} The OrgId contract instance
|
81
|
-
*/},{key:"getOrgIdContract",value:function getOrgIdContract(){if(this.cache.orgIdContract){return this.cache.orgIdContract}this.cache.orgIdContract=new this.web3.eth.Contract(OrgIdContract.abi,this.orgIdAddress);return this.cache.orgIdContract}/**
|
82
|
-
* Get the organization data
|
83
|
-
* @memberof OrgIdResolver
|
84
|
-
* @param {string} id The organization Id
|
85
|
-
* @returns {Promise<Object>} The OrgId contract instance
|
86
|
-
*/},{key:"getOrganization",value:function(){var _getOrganization=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee10(id){var orgIdContract,org,exists,orgId,orgJsonHash,orgJsonUri,orgJsonUriBackup1,orgJsonUriBackup2,parentOrgId,owner,director,isActive,isDirectorshipAccepted;return regeneratorRuntime.wrap(function _callee10$(_context10){while(1){switch(_context10.prev=_context10.next){case 0:expect.all({id:id},{id:{type:"string"}});if(!this.cache.organization){_context10.next=3;break}return _context10.abrupt("return",this.cache.organization);case 3:orgIdContract=this.getOrgIdContract();_context10.next=6;return orgIdContract.methods["getOrganization(bytes32)"](id).call();case 6:org=_context10.sent;exists=org.exists,orgId=org.orgId,orgJsonHash=org.orgJsonHash,orgJsonUri=org.orgJsonUri,orgJsonUriBackup1=org.orgJsonUriBackup1,orgJsonUriBackup2=org.orgJsonUriBackup2,parentOrgId=org.parentOrgId,owner=org.owner,director=org.director,isActive=org.isActive,isDirectorshipAccepted=org.isDirectorshipAccepted;if(!exists){this.addCheckResult({type:"ORGID",error:"Organization ".concat(id," not found"),throw:true})}if(!isActive){this.addCheckResult({type:"ORGID",warning:"Organization ".concat(id," is disabled")})}if(director!==zeroAddress&&!isDirectorshipAccepted){this.addCheckResult({type:"ORGID",warning:"Directorship of the organization ".concat(id," is not accepted")})}// Save normalised origanization object
|
87
|
-
this.cache.organization={orgId:orgId,orgJsonHash:orgJsonHash,orgJsonUri:orgJsonUri,orgJsonUriBackup1:orgJsonUriBackup1,orgJsonUriBackup2:orgJsonUriBackup2,parentOrgId:parentOrgId,owner:owner,director:director,isActive:isActive,isDirectorshipAccepted:isDirectorshipAccepted};this.result.organization=this.cache.organization;return _context10.abrupt("return",this.result.organization);case 14:case"end":return _context10.stop();}}},_callee10,this)}));function getOrganization(_x9){return _getOrganization.apply(this,arguments)}return getOrganization}()/**
|
88
|
-
* Get the list of registered fetching methods names
|
89
|
-
* @memberof OrgIdResolver
|
90
|
-
* @returns {string[]} Registered fetching nethods names
|
91
|
-
*/},{key:"getFetchMethods",value:function getFetchMethods(){return Object.keys(this.fetchMethods)}/**
|
92
|
-
* Adds a specific check result
|
93
|
-
* and throws a error if this behaviour is set in the options
|
94
|
-
* @memberof OrgIdResolver
|
95
|
-
* @returns {string[]} Registered fetching nethods names
|
96
|
-
*/},{key:"addCheckResult",value:function addCheckResult(options){expect.all(options,{type:{type:"enum",values:checksTypes},error:{type:"string",required:false},warning:{type:"string",required:false},throw:{type:"boolean",required:false}});var type=options.type,error=options.error,warning=options.warning;// Extract specific check
|
97
|
-
this.result.checks=this.result.checks.map(function(check){if(check.type===type){check=_objectSpread(_objectSpread(_objectSpread({},check),error?{errors:[].concat(_toConsumableArray(check.errors||[]),[error])}:{}),warning?{warnings:[].concat(_toConsumableArray(check.warning||[]),[warning])}:{});check.passed=!check.errors||check.errors&&check.errors.length===0}return check});if(options.throw){throw new Error("".concat(type,": ").concat(error))}}},{key:"spawnResolver",value:function spawnResolver(){var spawnedResolver=new OrgIdResolver({web3:this.web3,orgId:this.orgIdAddress,lifDeposit:this.lifDepositAddress});spawnedResolver.fetchSocialMethods=this.fetchSocialMethods;spawnedResolver.fetchMethods=this.fetchMethods;spawnedResolver.serviceMethods=this.serviceMethods;return spawnedResolver}}]);return OrgIdResolver}();module.exports.OrgIdResolver=OrgIdResolver;module.exports.httpFetchMethod=httpFetchMethod;module.exports.linkedInFetchMethod=linkedInFetchMethod;module.exports.twitterFetchMethod=twitterFetchMethod;module.exports.whoisService=whoisService;module.exports.checksTypes=Object.assign({},checksTypes);
|
98
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["packageJson","require","validateVc","didDocumentSchema","didDocumentSchema04","OrgIdContract","LifDepositContract","Ajv","expect","makeHash","httpFetchMethod","linkedInFetchMethod","twitterFetchMethod","whoisService","getDnsData","ResourceRecordTypes","zeroAddress","checksTypes","OrgIdResolver","options","all","web3","type","orgId","lifDeposit","required","authorizedTrustProofsIssuers","methodName","fetchSocialMethods","fetchMethods","serviceMethods","orgIdAddress","lifDepositAddress","validator","resolutionStart","resultTemplate","cache","result","reset","didDocument","organization","checks","map","passed","includes","trust","resolverMetadata","retrieved","duration","Object","assign","did","Date","now","validateDidSyntax","getOrganization","id","getDidDocument","validateDidDocument","verifyTrustRecords","verifyLifStake","Error","message","stack","version","toISOString","parts","split","addCheckResult","error","throw","subParts","RegExp","test","schema","schemaVersion","match","validate","errors","detail","warning","Array","isArray","assertions","JSON","parse","stringify","isProofsFound","i","length","assertion","assertionContent","proofFound","whoisInfo","proof","keys","join","claim","record","data","whois","rootDomain","fetch","console","log","replace","fetchFileByUri","verified","deposit","withdrawalRequest","lifDepositContract","eth","Contract","abi","methods","call","requestSource","exists","value","toString","withdrawTime","uri","f","pattern","document","orgJsonUri","orgJsonUriBackup1","orgJsonUriBackup2","orgJsonHash","firstSettled","fetches","fetchPromise","push","didObject","methodConfig","methodOptions","name","orgIdContract","getOrgIdContract","org","parentOrgId","owner","director","isActive","isDirectorshipAccepted","values","check","warnings","spawnedResolver","module","exports"],"mappings":"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","sourcesContent":["const packageJson = require('../package.json');\nconst { validateVc } = require('./utils/vc');\nconst didDocumentSchema = require('org.json-schema-0.3');\nconst didDocumentSchema04 = require('org.json-schema-0.4');\nconst { OrgIdContract } = require('@windingtree/org.id');\nconst { LifDepositContract } = require('@windingtree/org.id-lif-deposit');\nconst Ajv = require('ajv');\n\n// Utilities\nconst expect = require('./utils/expect');\nconst { makeHash } = require('./utils/document');\n\n// Modules\nconst httpFetchMethod = require('./http');\nconst linkedInFetchMethod = require('./linkedIn');\nconst twitterFetchMethod = require('./twitter');\nconst whoisService = require('./whois');\nconst { getDnsData, ResourceRecordTypes } = require('./dns');\nconst { zeroAddress } = require('./utils/constants');\n\n// Errors types definitions\nconst checksTypes = [\n    'DID_SYNTAX',\n    'ORGID',\n    'DID_DOCUMENT',\n    'TRUST_ASSERTIONS',\n    'LIF_STAKE'\n];\n\n/**\n * ORG.ID resolver class\n * @class OrgIdResolver\n */\nclass OrgIdResolver {\n\n    /**\n     * Creates an instance of OrgIdResolver.\n     * @param {Obejct} options Contructor parameters\n     * @memberof OrgIdResolver\n     */\n    constructor (options = {}) {\n        expect.all(options, {\n            web3: {\n                type: 'object'\n            },\n            orgId: {\n                type: 'address'\n            },\n            lifDeposit: {\n                type: 'address',\n                required: false\n            },\n            authorizedTrustProofsIssuers: {\n                type: 'object',\n                required: false\n            }\n        });\n\n        this.methodName = 'orgid';\n        this.fetchSocialMethods = {};\n        this.fetchMethods = {};\n        this.serviceMethods = {};\n        this.web3 = options.web3;\n        this.orgIdAddress = options.orgId;\n        this.lifDepositAddress = options.lifDeposit;\n        this.authorizedTrustProofsIssuers = options.authorizedTrustProofsIssuers;\n\n        this.validator = null;\n        this.resolutionStart = null;\n        this.resultTemplate = null;\n        this.cache = null;\n        this.result = null;\n\n        this.reset();\n    }\n\n    /**\n     * Sets defaults\n     * @memberof OrgIdResolver\n     */\n    reset () {\n        this.validator = new Ajv();\n        this.resolutionStart = null;\n        this.resultTemplate = {\n            didDocument: null,\n            organization: null,\n            checks: checksTypes.map(type => ({\n                type,\n                passed: ['TRUST_ASSERTIONS', 'LIF_STAKE'].includes(type)\n                    ? false\n                    : true\n            })),\n            trust: [],\n            ...(\n                this.lifDepositAddress\n                    ? {\n                        lifDeposit: null\n                    }\n                    : {}\n            ),\n            resolverMetadata: {\n                retrieved: null,\n                duration: null\n            }\n        };\n        this.cache = {};\n        this.result = Object.assign({}, this.resultTemplate);\n    }\n\n    /**\n     * Resolvs DID into its document\n     * and makes proper validations and verifications\n     * @memberof OrgIdResolver\n     * @param {string} did DID\n     * @returns {Promise<{Object}>} Resolving result\n     */\n    async resolve (did) {\n        expect.all({ did }, {\n            did: {\n                type: 'string'\n            }\n        });\n\n        this.reset();\n        this.resolutionStart = Date.now();\n\n        try {\n            await this.validateDidSyntax(did);\n            await this.getOrganization(this.result.id);\n            await this.getDidDocument(this.result.organization);\n            await this.validateDidDocument(this.result.didDocument);\n            await this.verifyTrustRecords(this.result.didDocument);\n            await this.verifyLifStake(this.result.id);\n        } catch(error) {\n\n            throw new Error(\n                `Resolving flow has been terminated due to serious error: ${error.message}; ${error.stack}`\n            );\n        }\n\n        this.result.resolverMetadata.version = packageJson.version;\n        this.result.resolverMetadata.retrieved = new Date().toISOString();\n        this.result.resolverMetadata.duration =\n            Date.now() - this.resolutionStart;\n        this.result.resolverMetadata.orgIdAddress = this.orgIdAddress;\n        return this.result;\n    }\n\n    /**\n     * Validates the given DID syntax\n     * @memberof OrgIdResolver\n     * @param {string} did DID\n     * @returns {Promise<{string}>} Organization Id\n     */\n    async validateDidSyntax (did) {\n        expect.all({ did }, {\n            did: {\n                type: 'string'\n            }\n        });\n\n        const parts = did.split(':');\n\n        if (parts[0] !== 'did') {\n\n            this.addCheckResult({\n                type: 'DID_SYNTAX',\n                error: `Invalid DID prefix: ${parts[0]}`,\n                throw: true\n            });\n        }\n\n        if (parts[1] !== this.methodName) {\n\n            this.addCheckResult({\n                type: 'DID_SYNTAX',\n                error: `Unsupported DID method: ${parts[1]}`,\n                throw: true\n            });\n        }\n\n        // Split paths, method parameters and queries\n        const subParts = parts[2].split(/(?:#|;|\\?)/);\n\n        if (!new RegExp('^0x[a-fA-F0-9]{64}$').test(subParts[0])) {\n\n            this.addCheckResult({\n                type: 'DID_SYNTAX',\n                error: `Invalid method specific Id: ${subParts[0]}`,\n                throw: true\n            });\n        }\n\n        this.result.id = subParts[0];\n        return this.result.id;\n    }\n\n    /**\n     * Validates the given DID document\n     * @memberof OrgIdResolver\n     * @param {Object} didDocument DID document\n     * @returns {Promise<{boolean}>} Validation result\n     */\n    async validateDidDocument (didDocument) {\n        expect.all({ didDocument }, {\n            didDocument: {\n                type: 'object'\n            }\n        });\n\n        const schema = didDocument.schemaVersion && didDocument.schemaVersion.match(/^0.4/)\n            ? didDocumentSchema04\n            : didDocumentSchema;\n\n        // Use the Ajv validator\n        // didDocumentSchema is obtained from @windingtree/org.json-schema\n        const result = this.validator.validate(schema, didDocument);\n\n        if (this.validator.errors !== null) {\n\n            this.validator.errors.map(detail => this.addCheckResult({\n                type: 'DID_DOCUMENT',\n                warning: detail\n            }));\n        }\n\n        return result;\n    }\n\n    /**\n     * Verifies trust objects from the DID document\n     * @memberof OrgIdResolver\n     * @param {Object} didDocument DID document\n     * @returns {Promise}\n     */\n    async verifyTrustRecords (didDocument) {\n\n        if (!didDocument.trust || !Array.isArray(didDocument.trust.assertions)) {\n            // Nothing to verify\n            return {};\n        }\n\n        // Cloned trust section\n        const trust = JSON.parse(JSON.stringify(didDocument.trust));\n\n        // Organization Id part of the DID\n        const id = didDocument.id.match(/^did:orgid:(0x[a-fA-F0-9]{64}){1}$/im)[1];\n\n        // Proofs existence flag\n        let isProofsFound = false;\n\n        // Assertions verification\n        for (let i = 0; i < trust.assertions.length; i++) {\n            let assertion = trust.assertions[i];\n            let assertionContent;\n            let proofFound = false;\n\n            // WHOIS information about domain\n            let whoisInfo;\n\n            switch (assertion.type) {\n\n                // For proof records that placed into DNS textual records\n                // HINFO,SPF,TXT records types are supported\n                case 'dns':\n\n                    if (!ResourceRecordTypes[assertion.proof]) {\n\n                        this.addCheckResult({\n                            type: 'TRUST_ASSERTIONS',\n                            error: `trust.assertions[${i}]: proof value \"${assertion.proof}\"\n                                not in the range of [${Object.keys(ResourceRecordTypes).join(',')}]`\n                        });\n                        break;\n                    }\n\n                    try {\n                        assertionContent = await getDnsData(assertion.claim, assertion.proof);\n\n                        if (assertionContent.length === 0) {\n\n                            this.addCheckResult({\n                                type: 'TRUST_ASSERTIONS',\n                                error: `trust.assertions[${i}]: claim source is empty`\n                            });\n                            break;\n                        }\n\n                        for (const record of assertionContent) {\n\n                            if (RegExp(didDocument.id, 'g').test(record.data)) {\n                                proofFound = true;\n                                break;\n                            }\n                        }\n\n                        if (!proofFound) {\n\n                            this.addCheckResult({\n                                type: 'TRUST_ASSERTIONS',\n                                error: `trust.assertions[${i}]: proof not found`\n                            });\n                        }\n\n                    } catch (err) {\n\n                        this.addCheckResult({\n                            type: 'TRUST_ASSERTIONS',\n                            error: `trust.assertions[${i}]: cannot get the proof`\n                        });\n                        break;\n                    }\n\n                    break;\n\n                // These types are used for handle proofs that related to\n                // web sites and social accounts\n                case 'social':\n                case 'domain':\n\n                    try {\n                        // Fetch WHOIS information for domain\n                        if (assertion.type === 'domain' && this.serviceMethods.whois) {\n                            const rootDomain = assertion.claim.match(/[^.]+\\.[^.]+$/)[0];\n                            whoisInfo = await this.serviceMethods.whois.fetch(rootDomain);\n                            proofFound = true;\n                            break;\n                        }\n                    } catch (err) {\n                        this.addCheckResult({\n                            type: 'TRUST_ASSERTIONS',\n                            error: `trust.assertions[${i}]: unable to fetch whois information`\n                        });\n                    }\n\n                    // If an object provided as VC proof then\n                    // we need to validate this proof as a Verifiable credential\n                    if (assertion.proof.match(/^did.orgid/)) {\n                        try {\n                            await validateVc(\n                                this,\n                                assertion.proof,\n                                assertion.claim\n                            );\n\n                            proofFound = true;\n                            break;\n                        } catch (err) {\n                            console.log('###', err);\n\n                            this.addCheckResult({\n                                type: 'TRUST_ASSERTIONS',\n                                error: `trust.assertions[${i}]: VC DID not pass verification`\n                            });\n                            break;\n                        }\n\n                    } else {\n                        // Validate assertion.proof record as URL to the proof\n\n                        // should be in the assertion.claim namespace\n                        if (!RegExp(`^(http|https)://(www.){0,1}${assertion.claim.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&')}`)\n                            .test(assertion.proof)) {\n\n                            this.addCheckResult({\n                                type: 'TRUST_ASSERTIONS',\n                                error: `trust.assertions[${i}]: claim is not in the domain namespace`\n                            });\n                            break;\n                        }\n\n                        // Fetch file with proof by URI\n                        try {\n                            assertionContent = await this.fetchFileByUri(assertion.proof);\n                            assertionContent = typeof assertionContent === 'object'\n                                ? JSON.stringify(assertionContent)\n                                : assertionContent;\n                        } catch (err) {\n\n                            this.addCheckResult({\n                                type: 'TRUST_ASSERTIONS',\n                                error: `trust.assertions[${i}]: cannot get the proof`\n                            });\n                            break;\n                        }\n\n                        // Look for a did inside the file obtained\n                        if (!RegExp(id, 'im').test(assertionContent)) {\n\n                            this.addCheckResult({\n                                type: 'TRUST_ASSERTIONS',\n                                error: `trust.assertions[${i}]: DID not found in the claim`\n                            });\n                            break;\n                        }\n\n                        proofFound = true;\n                    }\n\n                    break;\n\n                default:\n\n                    // For cases where unknown assertion type has been provided\n                    this.addCheckResult({\n                        type: 'TRUST_ASSERTIONS',\n                        error: `trust.assertions[${i}]: unknown assertion type \"${assertion.type}\"`\n                    });\n            }\n\n            assertion.verified = proofFound;\n            assertion = {\n                ...assertion,\n                ...(\n                    whoisInfo\n                        ? {\n                            whois: whoisInfo\n                        }\n                        : {}\n                )\n            };\n            trust.assertions[i] = assertion;\n\n            if (proofFound) {\n                isProofsFound = true;\n            }\n        }\n\n        if (isProofsFound) {\n            // Just mark as passed\n            this.addCheckResult({\n                type: 'TRUST_ASSERTIONS'\n            });\n        }\n\n        this.result.trust = trust;\n        return this.result.trust;\n    }\n\n    /**\n     * Get the organization data\n     * @memberof OrgIdResolver\n     * @param {string} id The organization Id\n     * @returns {Promise}\n     */\n    async verifyLifStake (id) {\n        if (!this.lifDepositAddress) {\n            return;\n        }\n\n        expect.all({ id }, {\n            id: {\n                type: 'string'\n            }\n        });\n\n        let deposit = 0;\n        let withdrawalRequest = null;\n        const lifDepositContract = new this.web3.eth.Contract(\n            LifDepositContract.abi,\n            this.lifDepositAddress\n        );\n\n        try {\n            deposit = await lifDepositContract\n                .methods['balanceOf(bytes32)'](id).call();\n\n            const requestSource = await lifDepositContract\n                .methods['getWithdrawalRequest(bytes32)'](id).call();\n\n            if (requestSource.exists) {\n\n                withdrawalRequest = {\n                    value: requestSource.value.toString(),\n                    withdrawTime: requestSource.withdrawTime.toString()\n                };\n            }\n\n            this.result.lifDeposit = {\n                deposit,\n                withdrawalRequest\n            };\n\n            if (deposit !== '0' && !withdrawalRequest) {\n                // Just mark as passed\n                this.addCheckResult({\n                    type: 'LIF_STAKE'\n                });\n            } else if (deposit !== '0' && withdrawalRequest) {\n                this.addCheckResult({\n                    type: 'LIF_STAKE',\n                    warning: 'The organization sent a withdrawal request'\n                });\n            }\n        } catch (error) {\n\n            this.addCheckResult({\n                type: 'LIF_STAKE',\n                error: error.message\n            });\n        }\n    }\n\n    /**\n     * Fetch a file by the given URI\n     * @memberof OrgIdResolver\n     * @param {string} uri The file URI\n     * @returns {Promise<{Object|string}>} Fetched file\n     */\n    async fetchFileByUri (uri) {\n        expect.all({ uri }, {\n            uri: {\n                type: 'string'\n            }\n        });\n\n        if (uri === '') {\n\n            throw new Error(\n                'Fetcher error: empty URI'\n            );\n        }\n\n        let fetch;\n\n        if (Object.keys(this.fetchMethods).length === 0) {\n\n            throw new Error(\n                'Incomplete configuration: at least one fetching method should be registered'\n            );\n        }\n\n        // Try to choose a social fetch methods\n        for (const f in this.fetchSocialMethods) {\n\n            if (RegExp(this.fetchSocialMethods[f].pattern).test(uri)) {\n                fetch = this.fetchSocialMethods[f].fetch;\n                break;\n            }\n        }\n\n        if (!fetch) {\n            // Try to choose another fetching method\n            for (const f in this.fetchMethods) {\n\n                if (RegExp(this.fetchMethods[f].pattern).test(uri)) {\n                    fetch = this.fetchMethods[f].fetch;\n                    break;\n                }\n            }\n        }\n\n        if (!fetch) {\n\n            throw new Error(\n                `Fetcher error: unable to determine the fetching method for URI: ${uri}`\n            );\n        }\n\n        // Trying to fetch the file\n        const document = await fetch(uri);\n\n        if (!document) {\n\n            throw new Error(\n                `Fetcher error: file not found by the given URI: ${uri}`\n            );\n        }\n\n        return  document;\n    }\n\n    /**\n     * Fetch a DID document by the given Id\n     * @memberof OrgIdResolver\n     * @param {Object} organization The organization object\n     * @returns {Promise<{Object}>} DID document\n     */\n    async getDidDocument (organization = {}) {\n        expect.all(organization, {\n            orgId: {\n                type: 'hash'\n            },\n            orgJsonUri: {\n                type: 'string'\n            },\n            orgJsonUriBackup1: {\n                type: 'string',\n                required: false\n            },\n            orgJsonUriBackup2: {\n                type: 'string',\n                required: false\n            }\n        });\n\n        const {\n            orgId,\n            orgJsonHash,\n            orgJsonUri,\n            orgJsonUriBackup1,\n            orgJsonUriBackup2\n        } = organization;\n\n        // Resolve first settled promise\n        const firstSettled = async fetches => {\n            let result;\n            let errors = [];\n\n            for (const fetchPromise of fetches) {\n                try {\n                    result = await fetchPromise();\n                    return result;\n                } catch (error) {\n                    errors.push(error.message);\n                }\n            }\n\n            throw new Error(\n                `Unable to fetch DID Document from given sources.\n                    ${errors.length ? errors.join('; ') : ''}`\n            );\n        };\n\n        let didDocument;\n\n        try {\n            didDocument = await firstSettled(\n                [\n                    orgJsonUri,\n                    orgJsonUriBackup1,\n                    orgJsonUriBackup2\n                ].map(\n                    uri => () => this.fetchFileByUri(uri)\n                )\n            );\n        } catch (error) {\n\n            this.addCheckResult({\n                type: 'DID_DOCUMENT',\n                error: error.message,\n                throw: true\n            });\n        }\n\n        let didObject;\n\n        try {\n            didObject = JSON.parse(didDocument);\n        } catch (error) {\n\n            this.addCheckResult({\n                type: 'DID_DOCUMENT',\n                error: 'Broken ORG.JSON. Unable to parse'\n            });\n        }\n\n        // Comparing of the stored and actual hash\n        if (makeHash(didDocument, this.web3) !== orgJsonHash) {\n\n            this.addCheckResult({\n                type: 'DID_DOCUMENT',\n                error: 'Invalid DID Document hash'\n            });\n        }\n\n        // DID document should containing a proper DID\n        if (`did:${this.methodName}:${orgId}` !== didObject.id) {\n\n            this.addCheckResult({\n                type: 'DID_DOCUMENT',\n                error: `Invalid DID Document id. Expected to be: ${orgId},\n                    but actual is: ${didObject.id}`\n            });\n        }\n\n        this.result.didDocument = didObject;\n        return this.result.didDocument;\n    }\n\n    /**\n     * Register a fetching method for social accounts\n     * @memberof OrgIdResolver\n     * @param {Object} methodConfig The fetching method configuration config\n     * @param {Object} methodOptions The fetching method options (API key, etc)\n     */\n    registerSocialFetchMethod (methodConfig = {}, methodOptions = {}) {\n        expect.all(methodConfig, {\n            name: {\n                type: 'string'\n            },\n            pattern: {\n                type: 'string'\n            },\n            fetch: {\n                type: 'function'\n            }\n        });\n\n        this.fetchSocialMethods[methodConfig.name] = {\n            ...methodConfig,\n            fetch: async uri => {\n                const options = methodOptions;\n                return await methodConfig.fetch(uri, options);\n            }\n        };\n    }\n\n    /**\n     * Register a fetching method\n     * @memberof OrgIdResolver\n     * @param {Object} methodConfig The fetching method configuration config\n     */\n    registerFetchMethod (methodConfig = {}) {\n        expect.all(methodConfig, {\n            name: {\n                type: 'string'\n            },\n            pattern: {\n                type: 'string'\n            },\n            fetch: {\n                type: 'function'\n            }\n        });\n\n        this.fetchMethods[methodConfig.name] = methodConfig;\n    }\n\n    /**\n     * Register a service method\n     * @memberof OrgIdResolver\n     * @param {Object} methodConfig The service method configuration config\n     */\n    registerService (methodConfig = {}) {\n        expect.all(methodConfig, {\n            name: {\n                type: 'string'\n            },\n            fetch: {\n                type: 'function'\n            }\n        });\n\n        this.serviceMethods[methodConfig.name] = methodConfig;\n    }\n\n    /**\n     * Get the OrgId contract instance\n     * @memberof OrgIdResolver\n     * @returns {Object} The OrgId contract instance\n     */\n    getOrgIdContract () {\n\n        if (this.cache.orgIdContract) {\n            return this.cache.orgIdContract;\n        }\n\n        this.cache.orgIdContract = new this.web3.eth.Contract(\n            OrgIdContract.abi,\n            this.orgIdAddress\n        );\n        return this.cache.orgIdContract;\n    }\n\n    /**\n     * Get the organization data\n     * @memberof OrgIdResolver\n     * @param {string} id The organization Id\n     * @returns {Promise<Object>} The OrgId contract instance\n     */\n    async getOrganization (id) {\n        expect.all({ id }, {\n            id: {\n                type: 'string'\n            }\n        });\n\n        if (this.cache.organization) {\n            return this.cache.organization;\n        }\n\n        const orgIdContract = this.getOrgIdContract();\n        const org = await orgIdContract\n            .methods['getOrganization(bytes32)'](id).call();\n\n        const {\n            exists,\n            orgId,\n            orgJsonHash,\n            orgJsonUri,\n            orgJsonUriBackup1,\n            orgJsonUriBackup2,\n            parentOrgId,\n            owner,\n            director,\n            isActive,\n            isDirectorshipAccepted\n        } = org;\n\n        if (!exists) {\n\n            this.addCheckResult({\n                type: 'ORGID',\n                error: `Organization ${id} not found`,\n                throw: true\n            });\n        }\n\n        if (!isActive) {\n\n            this.addCheckResult({\n                type: 'ORGID',\n                warning: `Organization ${id} is disabled`\n            });\n        }\n\n        if (director !== zeroAddress && !isDirectorshipAccepted) {\n\n            this.addCheckResult({\n                type: 'ORGID',\n                warning: `Directorship of the organization ${id} is not accepted`\n            });\n        }\n\n        // Save normalised origanization object\n        this.cache.organization = {\n            orgId,\n            orgJsonHash,\n            orgJsonUri,\n            orgJsonUriBackup1,\n            orgJsonUriBackup2,\n            parentOrgId,\n            owner,\n            director,\n            isActive,\n            isDirectorshipAccepted\n        };\n\n        this.result.organization = this.cache.organization;\n        return this.result.organization;\n    }\n\n    /**\n     * Get the list of registered fetching methods names\n     * @memberof OrgIdResolver\n     * @returns {string[]} Registered fetching nethods names\n     */\n    getFetchMethods () {\n        return Object.keys(this.fetchMethods);\n    }\n\n    /**\n     * Adds a specific check result\n     * and throws a error if this behaviour is set in the options\n     * @memberof OrgIdResolver\n     * @returns {string[]} Registered fetching nethods names\n     */\n    addCheckResult (options) {\n        expect.all(options, {\n            type: {\n                type: 'enum',\n                values: checksTypes\n            },\n            error: {\n                type: 'string',\n                required: false\n            },\n            warning: {\n                type: 'string',\n                required: false\n            },\n            throw: {\n                type: 'boolean',\n                required: false\n            }\n        });\n\n        const { type, error, warning } = options;\n\n        // Extract specific check\n        this.result.checks = this.result.checks.map(\n            check => {\n                if (check.type === type) {\n                    check = {\n                        ...check,\n                        ...(\n                            error\n                                ? {\n                                    errors: [\n                                        ...(check.errors || []),\n                                        ...[error]\n                                    ]\n                                }\n                                : {}\n                        ),\n                        ...(\n                            warning\n                                ? {\n                                    warnings: [\n                                        ...(check.warning || []),\n                                        ...[warning]\n                                    ]\n                                }\n                                : {}\n                        )\n                    };\n\n                    check.passed = !check.errors ||\n                        (check.errors && check.errors.length === 0);\n                }\n\n                return check;\n            }\n        );\n\n        if (options.throw) {\n            throw new Error(\n                `${type}: ${error}`\n            );\n        }\n    }\n\n    spawnResolver () {\n        const spawnedResolver = new OrgIdResolver({\n            web3: this.web3,\n            orgId: this.orgIdAddress,\n            lifDeposit: this.lifDepositAddress\n        });\n\n        spawnedResolver.fetchSocialMethods = this.fetchSocialMethods;\n        spawnedResolver.fetchMethods = this.fetchMethods;\n        spawnedResolver.serviceMethods = this.serviceMethods;\n        return spawnedResolver;\n    }\n}\n\nmodule.exports.OrgIdResolver = OrgIdResolver;\nmodule.exports.httpFetchMethod = httpFetchMethod;\nmodule.exports.linkedInFetchMethod = linkedInFetchMethod;\nmodule.exports.twitterFetchMethod = twitterFetchMethod;\nmodule.exports.whoisService = whoisService;\nmodule.exports.checksTypes = Object.assign({}, checksTypes);\n"]}
|
package/dist/linkedIn.js
DELETED
@@ -1,5 +0,0 @@
|
|
1
|
-
"use strict";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.object.to-string.js");require("core-js/modules/es.promise.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 axios=require("axios");// Configuration of the HTTP fetching method
|
2
|
-
module.exports={name:"linkedin",pattern:"linkedin",fetch:function(){var _fetch=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee(uri,options){var activityId,source,timeout,response;return regeneratorRuntime.wrap(function _callee$(_context){while(1){switch(_context.prev=_context.next){case 0:activityId=uri.split(":activity:")[1];source=axios.CancelToken.source();timeout=setTimeout(function(){return source.cancel("Cannot connect to the source: ".concat(uri))},7000);// connection timeout
|
3
|
-
_context.next=5;return axios({method:"get",url:"https://api.linkedin.com/v2/activities?ids=List(".concat(activityId,")"),headers:{"Authorization":"Bearer ".concat(options.key),"cache-control":"no-cache","X-Restli-Protocol-Version":"2.0.0"},transformResponse:[function(data){return data}],// Do not convert JSON to object
|
4
|
-
cancelToken:source.token});case 5:response=_context.sent;clearTimeout(timeout);console.log("@@@@@@@@@@@@@@@@@@@@@",response);return _context.abrupt("return",response.data);case 9:case"end":return _context.stop();}}},_callee)}));function fetch(_x,_x2){return _fetch.apply(this,arguments)}return fetch}()};
|
5
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9saW5rZWRJbi5qcyJdLCJuYW1lcyI6WyJheGlvcyIsInJlcXVpcmUiLCJtb2R1bGUiLCJleHBvcnRzIiwibmFtZSIsInBhdHRlcm4iLCJmZXRjaCIsInVyaSIsIm9wdGlvbnMiLCJhY3Rpdml0eUlkIiwic3BsaXQiLCJzb3VyY2UiLCJDYW5jZWxUb2tlbiIsInRpbWVvdXQiLCJzZXRUaW1lb3V0IiwiY2FuY2VsIiwibWV0aG9kIiwidXJsIiwiaGVhZGVycyIsImtleSIsInRyYW5zZm9ybVJlc3BvbnNlIiwiZGF0YSIsImNhbmNlbFRva2VuIiwidG9rZW4iLCJyZXNwb25zZSIsImNsZWFyVGltZW91dCIsImNvbnNvbGUiLCJsb2ciXSwibWFwcGluZ3MiOiJ1eUJBQUEsR0FBTUEsQ0FBQUEsS0FBSyxDQUFHQyxPQUFPLENBQUMsT0FBRCxDQUFyQixDQUVBO0FBQ0FDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFpQixDQUNiQyxJQUFJLENBQUUsVUFETyxDQUViQyxPQUFPLENBQUUsVUFGSSxDQUdiQyxLQUFLLDhFQUFFLGlCQUFPQyxHQUFQLENBQVlDLE9BQVosd0pBQ0dDLFVBREgsQ0FDZ0JGLEdBQUcsQ0FBQ0csS0FBSixDQUFVLFlBQVYsRUFBd0IsQ0FBeEIsQ0FEaEIsQ0FFR0MsTUFGSCxDQUVZWCxLQUFLLENBQUNZLFdBQU4sQ0FBa0JELE1BQWxCLEVBRlosQ0FHR0UsT0FISCxDQUdhQyxVQUFVLENBQUMsaUJBQU1ILENBQUFBLE1BQU0sQ0FBQ0ksTUFBUCx5Q0FDSVIsR0FESixFQUFOLENBQUQsQ0FFdkIsSUFGdUIsQ0FIdkIsQ0FLTTtBQUxOLHNCQU1vQlAsQ0FBQUEsS0FBSyxDQUN4QixDQUNJZ0IsTUFBTSxDQUFFLEtBRFosQ0FFSUMsR0FBRywyREFBcURSLFVBQXJELEtBRlAsQ0FHSVMsT0FBTyxDQUFFLENBQ0wsaUNBQTJCVixPQUFPLENBQUNXLEdBQW5DLENBREssQ0FFTCxnQkFBaUIsVUFGWixDQUdMLDRCQUE2QixPQUh4QixDQUhiLENBUUlDLGlCQUFpQixDQUFFLENBQUMsU0FBQUMsSUFBSSxRQUFJQSxDQUFBQSxJQUFKLENBQUwsQ0FSdkIsQ0FRdUM7QUFDbkNDLFdBQVcsQ0FBRVgsTUFBTSxDQUFDWSxLQVR4QixDQUR3QixDQU56QixRQU1HQyxRQU5ILGVBbUJIQyxZQUFZLENBQUNaLE9BQUQsQ0FBWixDQUNBYSxPQUFPLENBQUNDLEdBQVIsQ0FBWSx1QkFBWixDQUFxQ0gsUUFBckMsRUFwQkcsZ0NBcUJJQSxRQUFRLENBQUNILElBckJiLHVEQUFGLDZFQUhRLENBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgYXhpb3MgPSByZXF1aXJlKCdheGlvcycpO1xuXG4vLyBDb25maWd1cmF0aW9uIG9mIHRoZSBIVFRQIGZldGNoaW5nIG1ldGhvZFxubW9kdWxlLmV4cG9ydHMgPSB7XG4gICAgbmFtZTogJ2xpbmtlZGluJyxcbiAgICBwYXR0ZXJuOiAnbGlua2VkaW4nLFxuICAgIGZldGNoOiBhc3luYyAodXJpLCBvcHRpb25zKSA9PiB7XG4gICAgICAgIGNvbnN0IGFjdGl2aXR5SWQgPSB1cmkuc3BsaXQoJzphY3Rpdml0eTonKVsxXTtcbiAgICAgICAgY29uc3Qgc291cmNlID0gYXhpb3MuQ2FuY2VsVG9rZW4uc291cmNlKCk7XG4gICAgICAgIGNvbnN0IHRpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHNvdXJjZS5jYW5jZWwoXG4gICAgICAgICAgICBgQ2Fubm90IGNvbm5lY3QgdG8gdGhlIHNvdXJjZTogJHt1cml9YFxuICAgICAgICApLCA3MDAwKTsvLyBjb25uZWN0aW9uIHRpbWVvdXRcbiAgICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBheGlvcyhcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBtZXRob2Q6ICdnZXQnLFxuICAgICAgICAgICAgICAgIHVybDogYGh0dHBzOi8vYXBpLmxpbmtlZGluLmNvbS92Mi9hY3Rpdml0aWVzP2lkcz1MaXN0KCR7YWN0aXZpdHlJZH0pYCxcbiAgICAgICAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICAgICAgICAgICdBdXRob3JpemF0aW9uJzogYEJlYXJlciAke29wdGlvbnMua2V5fWAsXG4gICAgICAgICAgICAgICAgICAgICdjYWNoZS1jb250cm9sJzogJ25vLWNhY2hlJyxcbiAgICAgICAgICAgICAgICAgICAgJ1gtUmVzdGxpLVByb3RvY29sLVZlcnNpb24nOiAnMi4wLjAnXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICB0cmFuc2Zvcm1SZXNwb25zZTogW2RhdGEgPT4gZGF0YV0sIC8vIERvIG5vdCBjb252ZXJ0IEpTT04gdG8gb2JqZWN0XG4gICAgICAgICAgICAgICAgY2FuY2VsVG9rZW46IHNvdXJjZS50b2tlblxuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgICAgICBjbGVhclRpbWVvdXQodGltZW91dCk7XG4gICAgICAgIGNvbnNvbGUubG9nKCdAQEBAQEBAQEBAQEBAQEBAQEBAQEAnLCByZXNwb25zZSk7XG4gICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH1cbn07XG4iXX0=
|
package/dist/twitter.js
DELETED
@@ -1,6 +0,0 @@
|
|
1
|
-
"use strict";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.object.to-string.js");require("core-js/modules/es.promise.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 axios=require("axios");// https://twitter.com/mindsaur/status/1263529968690225152
|
2
|
-
// Configuration of the HTTP fetching method
|
3
|
-
module.exports={name:"twitter",pattern:"twitter",fetch:function(){var _fetch=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee(uri,options){var tweetId,source,timeout,response;return regeneratorRuntime.wrap(function _callee$(_context){while(1){switch(_context.prev=_context.next){case 0:tweetId=uri.split("/status/")[1];source=axios.CancelToken.source();timeout=setTimeout(function(){return source.cancel("Cannot connect to the source: ".concat(uri))},7000);// connection timeout
|
4
|
-
_context.next=5;return axios({method:"get",url:"https://api.twitter.com/2/tweets/".concat(tweetId),headers:{"Authorization":"Bearer ".concat(options.key),"cache-control":"no-cache"},transformResponse:[function(data){return data}],// Do not convert JSON to object
|
5
|
-
cancelToken:source.token});case 5:response=_context.sent;clearTimeout(timeout);return _context.abrupt("return",response.data);case 8:case"end":return _context.stop();}}},_callee)}));function fetch(_x,_x2){return _fetch.apply(this,arguments)}return fetch}()};
|
6
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90d2l0dGVyLmpzIl0sIm5hbWVzIjpbImF4aW9zIiwicmVxdWlyZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJuYW1lIiwicGF0dGVybiIsImZldGNoIiwidXJpIiwib3B0aW9ucyIsInR3ZWV0SWQiLCJzcGxpdCIsInNvdXJjZSIsIkNhbmNlbFRva2VuIiwidGltZW91dCIsInNldFRpbWVvdXQiLCJjYW5jZWwiLCJtZXRob2QiLCJ1cmwiLCJoZWFkZXJzIiwia2V5IiwidHJhbnNmb3JtUmVzcG9uc2UiLCJkYXRhIiwiY2FuY2VsVG9rZW4iLCJ0b2tlbiIsInJlc3BvbnNlIiwiY2xlYXJUaW1lb3V0Il0sIm1hcHBpbmdzIjoidXlCQUFBLEdBQU1BLENBQUFBLEtBQUssQ0FBR0MsT0FBTyxDQUFDLE9BQUQsQ0FBckIsQ0FFQTtBQUVBO0FBQ0FDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFpQixDQUNiQyxJQUFJLENBQUUsU0FETyxDQUViQyxPQUFPLENBQUUsU0FGSSxDQUdiQyxLQUFLLDhFQUFFLGlCQUFPQyxHQUFQLENBQVlDLE9BQVoscUpBQ0dDLE9BREgsQ0FDYUYsR0FBRyxDQUFDRyxLQUFKLENBQVUsVUFBVixFQUFzQixDQUF0QixDQURiLENBRUdDLE1BRkgsQ0FFWVgsS0FBSyxDQUFDWSxXQUFOLENBQWtCRCxNQUFsQixFQUZaLENBR0dFLE9BSEgsQ0FHYUMsVUFBVSxDQUFDLGlCQUFNSCxDQUFBQSxNQUFNLENBQUNJLE1BQVAseUNBQ0lSLEdBREosRUFBTixDQUFELENBRXZCLElBRnVCLENBSHZCLENBS007QUFMTixzQkFNb0JQLENBQUFBLEtBQUssQ0FDeEIsQ0FDSWdCLE1BQU0sQ0FBRSxLQURaLENBRUlDLEdBQUcsNENBQXNDUixPQUF0QyxDQUZQLENBR0lTLE9BQU8sQ0FBRSxDQUNMLGlDQUEyQlYsT0FBTyxDQUFDVyxHQUFuQyxDQURLLENBRUwsZ0JBQWlCLFVBRlosQ0FIYixDQU9JQyxpQkFBaUIsQ0FBRSxDQUFDLFNBQUFDLElBQUksUUFBSUEsQ0FBQUEsSUFBSixDQUFMLENBUHZCLENBT3VDO0FBQ25DQyxXQUFXLENBQUVYLE1BQU0sQ0FBQ1ksS0FSeEIsQ0FEd0IsQ0FOekIsUUFNR0MsUUFOSCxlQWtCSEMsWUFBWSxDQUFDWixPQUFELENBQVosQ0FsQkcsZ0NBbUJJVyxRQUFRLENBQUNILElBbkJiLHVEQUFGLDZFQUhRLENBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgYXhpb3MgPSByZXF1aXJlKCdheGlvcycpO1xuXG4vLyBodHRwczovL3R3aXR0ZXIuY29tL21pbmRzYXVyL3N0YXR1cy8xMjYzNTI5OTY4NjkwMjI1MTUyXG5cbi8vIENvbmZpZ3VyYXRpb24gb2YgdGhlIEhUVFAgZmV0Y2hpbmcgbWV0aG9kXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBuYW1lOiAndHdpdHRlcicsXG4gICAgcGF0dGVybjogJ3R3aXR0ZXInLFxuICAgIGZldGNoOiBhc3luYyAodXJpLCBvcHRpb25zKSA9PiB7XG4gICAgICAgIGNvbnN0IHR3ZWV0SWQgPSB1cmkuc3BsaXQoJy9zdGF0dXMvJylbMV07XG4gICAgICAgIGNvbnN0IHNvdXJjZSA9IGF4aW9zLkNhbmNlbFRva2VuLnNvdXJjZSgpO1xuICAgICAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzb3VyY2UuY2FuY2VsKFxuICAgICAgICAgICAgYENhbm5vdCBjb25uZWN0IHRvIHRoZSBzb3VyY2U6ICR7dXJpfWBcbiAgICAgICAgKSwgNzAwMCk7Ly8gY29ubmVjdGlvbiB0aW1lb3V0XG4gICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgYXhpb3MoXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgbWV0aG9kOiAnZ2V0JyxcbiAgICAgICAgICAgICAgICB1cmw6IGBodHRwczovL2FwaS50d2l0dGVyLmNvbS8yL3R3ZWV0cy8ke3R3ZWV0SWR9YCxcbiAgICAgICAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICAgICAgICAgICdBdXRob3JpemF0aW9uJzogYEJlYXJlciAke29wdGlvbnMua2V5fWAsXG4gICAgICAgICAgICAgICAgICAgICdjYWNoZS1jb250cm9sJzogJ25vLWNhY2hlJ1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgdHJhbnNmb3JtUmVzcG9uc2U6IFtkYXRhID0+IGRhdGFdLCAvLyBEbyBub3QgY29udmVydCBKU09OIHRvIG9iamVjdFxuICAgICAgICAgICAgICAgIGNhbmNlbFRva2VuOiBzb3VyY2UudG9rZW5cbiAgICAgICAgICAgIH1cbiAgICAgICAgKTtcbiAgICAgICAgY2xlYXJUaW1lb3V0KHRpbWVvdXQpO1xuICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9XG59O1xuIl19
|
package/dist/utils/cli.js
DELETED
@@ -1,23 +0,0 @@
|
|
1
|
-
"use strict";require("core-js/modules/es.symbol.js");require("core-js/modules/es.symbol.description.js");require("core-js/modules/es.symbol.iterator.js");require("core-js/modules/es.array.iterator.js");require("core-js/modules/es.string.iterator.js");require("core-js/modules/web.dom-collections.iterator.js");require("core-js/modules/es.array.from.js");require("core-js/modules/es.function.name.js");require("core-js/modules/es.array.slice.js");require("core-js/modules/es.array.for-each.js");require("core-js/modules/web.dom-collections.for-each.js");require("core-js/modules/es.array.concat.js");require("core-js/modules/es.array.map.js");require("core-js/modules/es.regexp.exec.js");require("core-js/modules/es.string.split.js");require("core-js/modules/es.string.replace.js");require("core-js/modules/es.string.match.js");require("core-js/modules/es.parse-int.js");require("core-js/modules/es.object.to-string.js");require("core-js/modules/es.regexp.to-string.js");function _typeof(obj){"@babel/helpers - typeof";if(typeof Symbol==="function"&&typeof Symbol.iterator==="symbol"){_typeof=function _typeof(obj){return typeof obj}}else{_typeof=function _typeof(obj){return obj&&typeof Symbol==="function"&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj}}return _typeof(obj)}function _toConsumableArray(arr){return _arrayWithoutHoles(arr)||_iterableToArray(arr)||_unsupportedIterableToArray(arr)||_nonIterableSpread()}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(o,minLen){if(!o)return;if(typeof o==="string")return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(o);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}function _iterableToArray(iter){if(typeof Symbol!=="undefined"&&Symbol.iterator in Object(iter))return Array.from(iter)}function _arrayWithoutHoles(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr)}function _arrayLikeToArray(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++){arr2[i]=arr[i]}return arr2}/**
|
2
|
-
* Parse argv parameters
|
3
|
-
* @param {String[]} argv Argv array to parce
|
4
|
-
* @param {Number} skip Count of parameters to skip from beginning of the array
|
5
|
-
* @returns {Object} Object with command line arguments
|
6
|
-
*/module.exports.parseArgv=function(argv){var skip=arguments.length>1&&arguments[1]!==undefined?arguments[1]:0;if(!Array.isArray(argv)){throw new Error("ERROR_INVALID_ARGV")}argv=argv.slice(skip);var normalised=[];var args={};argv.forEach(function(arg){// Splitting and cleananup
|
7
|
-
normalised=[].concat(_toConsumableArray(normalised),_toConsumableArray(arg.split("=").map(function(a){return a.replace(/^-{1,2}/g,"")})))});for(var i=0;i<normalised.length;i+=2){args[normalised[i]]=normalised[i+1]?normalised[i+1]:""}return args};/**
|
8
|
-
* Parse command parameters
|
9
|
-
* @param {Object} params
|
10
|
-
* @returns {String[]}
|
11
|
-
*/module.exports.parseParams=function(params){if(!params){return[]}return params.split(",").map(function(p){var template=/^number:/g;return p.match(template)?parseInt(p.replace(template,"")):p})};/**
|
12
|
-
* Replace properties in the arguments array
|
13
|
-
* @param {string[]} source Array of arguments
|
14
|
-
* @param {Object} options Replacements object
|
15
|
-
* @returns {string[]}
|
16
|
-
*/module.exports.applyArgs=function(){var source=arguments.length>0&&arguments[0]!==undefined?arguments[0]:[];var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};return source.map(function(i){return options[i]?options[i]:i})};// Converting result property
|
17
|
-
// Calling recursively on objects and arrays
|
18
|
-
var convertProperty=function convertProperty(prop){if(typeof prop==="string"){return prop}if(typeof prop==="number"){return String(prop)}if(web3.utils.isBN(prop)||web3.utils.isBigNumber(prop)){return prop.toString()}if(Array.isArray(prop)){return prop.map(function(p){return convertProperty(p)})}if(_typeof(prop)==="object"){for(var p in prop){prop[p]=convertProperty(prop[p])}return prop}return prop};/**
|
19
|
-
* Converting web3 result to string value
|
20
|
-
* @param {*} result web3 call result
|
21
|
-
* @returns {*}
|
22
|
-
*/module.exports.parseCallResult=function(result){return convertProperty(result)};
|
23
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jbGkuanMiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsInBhcnNlQXJndiIsImFyZ3YiLCJza2lwIiwiQXJyYXkiLCJpc0FycmF5IiwiRXJyb3IiLCJzbGljZSIsIm5vcm1hbGlzZWQiLCJhcmdzIiwiZm9yRWFjaCIsImFyZyIsInNwbGl0IiwibWFwIiwiYSIsInJlcGxhY2UiLCJpIiwibGVuZ3RoIiwicGFyc2VQYXJhbXMiLCJwYXJhbXMiLCJwIiwidGVtcGxhdGUiLCJtYXRjaCIsInBhcnNlSW50IiwiYXBwbHlBcmdzIiwic291cmNlIiwib3B0aW9ucyIsImNvbnZlcnRQcm9wZXJ0eSIsInByb3AiLCJTdHJpbmciLCJ3ZWIzIiwidXRpbHMiLCJpc0JOIiwiaXNCaWdOdW1iZXIiLCJ0b1N0cmluZyIsInBhcnNlQ2FsbFJlc3VsdCIsInJlc3VsdCJdLCJtYXBwaW5ncyI6Im16RUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FDQUEsTUFBTSxDQUFDQyxPQUFQLENBQWVDLFNBQWYsQ0FBMkIsU0FBQ0MsSUFBRCxDQUFvQixJQUFiQyxDQUFBQSxJQUFhLDJEQUFOLENBQU0sQ0FFM0MsR0FBSSxDQUFDQyxLQUFLLENBQUNDLE9BQU4sQ0FBY0gsSUFBZCxDQUFMLENBQTBCLENBQ3RCLEtBQU0sSUFBSUksQ0FBQUEsS0FBSixDQUFVLG9CQUFWLENBQ1QsQ0FFREosSUFBSSxDQUFHQSxJQUFJLENBQUNLLEtBQUwsQ0FBV0osSUFBWCxDQUFQLENBRUEsR0FBSUssQ0FBQUEsVUFBVSxDQUFHLEVBQWpCLENBQ0EsR0FBTUMsQ0FBQUEsSUFBSSxDQUFHLEVBQWIsQ0FFQVAsSUFBSSxDQUFDUSxPQUFMLENBQWEsU0FBQ0MsR0FBRCxDQUFTLENBRWxCO0FBQ0FILFVBQVUsOEJBQU9BLFVBQVAscUJBQXVCRyxHQUFHLENBQUNDLEtBQUosQ0FBVSxHQUFWLENBQUQsQ0FDM0JDLEdBRDJCLENBQ3ZCLFNBQUFDLENBQUMsUUFBSUEs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ZUFBZSxDQUFDUyxNQUFELENBQW5CLENBQXZDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBQYXJzZSBhcmd2IHBhcmFtZXRlcnNcbiAqIEBwYXJhbSB7U3RyaW5nW119IGFyZ3YgQXJndiBhcnJheSB0byBwYXJjZVxuICogQHBhcmFtIHtOdW1iZXJ9IHNraXAgQ291bnQgb2YgcGFyYW1ldGVycyB0byBza2lwIGZyb20gYmVnaW5uaW5nIG9mICB0aGUgYXJyYXlcbiAqIEByZXR1cm5zIHtPYmplY3R9IE9iamVjdCB3aXRoIGNvbW1hbmQgbGluZSBhcmd1bWVudHNcbiAqL1xubW9kdWxlLmV4cG9ydHMucGFyc2VBcmd2ID0gKGFyZ3YsIHNraXAgPSAwKSA9PiB7XG5cbiAgICBpZiAoIUFycmF5LmlzQXJyYXkoYXJndikpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdFUlJPUl9JTlZBTElEX0FSR1YnKTtcbiAgICB9XG5cbiAgICBhcmd2ID0gYXJndi5zbGljZShza2lwKTtcblxuICAgIGxldCBub3JtYWxpc2VkID0gW107XG4gICAgY29uc3QgYXJncyA9IHt9O1xuXG4gICAgYXJndi5mb3JFYWNoKChhcmcpID0+IHtcblxuICAgICAgICAvLyBTcGxpdHRpbmcgYW5kIGNsZWFuYW51cFxuICAgICAgICBub3JtYWxpc2VkID0gWy4uLm5vcm1hbGlzZWQsIC4uLihhcmcuc3BsaXQoJz0nKSlcbiAgICAgICAgICAgIC5tYXAoYSA9PiBhLnJlcGxhY2UoL14tezEsMn0vZywgJycpKV07XG4gICAgfSk7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IG5vcm1hbGlzZWQubGVuZ3RoOyBpICs9IDIpIHtcbiAgICAgICAgYXJnc1tub3JtYWxpc2VkW2ldXSA9IG5vcm1hbGlzZWRbaSArIDFdID8gbm9ybWFsaXNlZFtpICsgMV0gOiAnJztcbiAgICB9XG5cbiAgICByZXR1cm4gYXJncztcbn07XG5cbi8qKlxuICogUGFyc2UgY29tbWFuZCBwYXJhbWV0ZXJzXG4gKiBAcGFyYW0ge09iamVjdH0gcGFyYW1zXG4gKiBAcmV0dXJucyB7U3RyaW5nW119XG4gKi9cbm1vZHVsZS5leHBvcnRzLnBhcnNlUGFyYW1zID0gcGFyYW1zID0+IHtcblxuICAgIGlmICghcGFyYW1zKSB7XG4gICAgICAgIHJldHVybiBbXTtcbiAgICB9XG5cbiAgICByZXR1cm4gcGFyYW1zLnNwbGl0KCcsJykubWFwKHAgPT4ge1xuICAgICAgICBjb25zdCB0ZW1wbGF0ZSA9IC9ebnVtYmVyOi9nO1xuICAgICAgICByZXR1cm4gcC5tYXRjaCh0ZW1wbGF0ZSkgPyBwYXJzZUludChwLnJlcGxhY2UodGVtcGxhdGUsICcnKSkgOiBwO1xuICAgIH0pO1xufTtcblxuLyoqXG4gKiBSZXBsYWNlIHByb3BlcnRpZXMgaW4gdGhlIGFyZ3VtZW50cyBhcnJheVxuICogQHBhcmFtIHtzdHJpbmdbXX0gc291cmNlIEFycmF5IG9mIGFyZ3VtZW50c1xuICogQHBhcmFtIHtPYmplY3R9IG9wdGlvbnMgUmVwbGFjZW1lbnRzIG9iamVjdFxuICogQHJldHVybnMge3N0cmluZ1tdfVxuICovXG5tb2R1bGUuZXhwb3J0cy5hcHBseUFyZ3MgPSAoc291cmNlID0gW10sIG9wdGlvbnMgPSB7fSkgPT4gc291cmNlLm1hcChcbiAgICBpID0+IG9wdGlvbnNbaV0gPyBvcHRpb25zW2ldIDogaVxuKTtcblxuLy8gQ29udmVydGluZyByZXN1bHQgcHJvcGVydHlcbi8vIENhbGxpbmcgcmVjdXJzaXZlbHkgb24gb2JqZWN0cyBhbmQgYXJyYXlzXG5jb25zdCBjb252ZXJ0UHJvcGVydHkgPSBwcm9wID0+IHtcblxuICAgIGlmICh0eXBlb2YgcHJvcCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgcmV0dXJuIHByb3A7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBwcm9wID09PSAnbnVtYmVyJykge1xuICAgICAgICByZXR1cm4gU3RyaW5nKHByb3ApO1xuICAgIH1cblxuICAgIGlmICh3ZWIzLnV0aWxzLmlzQk4ocHJvcCkgfHwgd2ViMy51dGlscy5pc0JpZ051bWJlcihwcm9wKSkge1xuICAgICAgICByZXR1cm4gcHJvcC50b1N0cmluZygpO1xuICAgIH1cblxuICAgIGlmIChBcnJheS5pc0FycmF5KHByb3ApKSB7XG4gICAgICAgIHJldHVybiBwcm9wLm1hcChwID0+IGNvbnZlcnRQcm9wZXJ0eShwKSk7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBwcm9wID09PSAnb2JqZWN0Jykge1xuICAgICAgICBmb3IgKGNvbnN0IHAgaW4gcHJvcCkge1xuICAgICAgICAgICAgcHJvcFtwXSA9IGNvbnZlcnRQcm9wZXJ0eShwcm9wW3BdKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcHJvcDtcbiAgICB9XG5cbiAgICByZXR1cm4gcHJvcDtcbn07XG5cbi8qKlxuICogQ29udmVydGluZyB3ZWIzIHJlc3VsdCB0byBzdHJpbmcgdmFsdWVcbiAqIEBwYXJhbSB7Kn0gcmVzdWx0IHdlYjMgY2FsbCByZXN1bHRcbiAqIEByZXR1cm5zIHsqfVxuICovXG5tb2R1bGUuZXhwb3J0cy5wYXJzZUNhbGxSZXN1bHQgPSByZXN1bHQgPT4gY29udmVydFByb3BlcnR5KHJlc3VsdCk7XG4iXX0=
|
package/dist/utils/constants.js
DELETED
@@ -1,2 +0,0 @@
|
|
1
|
-
"use strict";module.exports.zeroAddress="0x0000000000000000000000000000000000000000";
|
2
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jb25zdGFudHMuanMiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsInplcm9BZGRyZXNzIl0sIm1hcHBpbmdzIjoiYUFBQUEsTUFBTSxDQUFDQyxPQUFQLENBQWVDLFdBQWYsQ0FBNkIsNENBQTdCIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHMuemVyb0FkZHJlc3MgPSAnMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwJztcbiJdfQ==
|
package/dist/utils/document.js
DELETED
@@ -1,2 +0,0 @@
|
|
1
|
-
"use strict";var makeHash=function makeHash(jsonString,web3){return web3.utils.soliditySha3(jsonString)};module.exports.makeHash=makeHash;
|
2
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9kb2N1bWVudC5qcyJdLCJuYW1lcyI6WyJtYWtlSGFzaCIsImpzb25TdHJpbmciLCJ3ZWIzIiwidXRpbHMiLCJzb2xpZGl0eVNoYTMiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiYUFBQSxHQUFNQSxDQUFBQSxRQUFRLENBQUcsUUFBWEEsQ0FBQUEsUUFBVyxDQUFDQyxVQUFELENBQWFDLElBQWIsUUFBc0JBLENBQUFBLElBQUksQ0FBQ0MsS0FBTCxDQUNsQ0MsWUFEa0MsQ0FDckJILFVBRHFCLENBQXRCLENBQWpCLENBRUFJLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlTixRQUFmLENBQTBCQSxRQUExQiIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IG1ha2VIYXNoID0gKGpzb25TdHJpbmcsIHdlYjMpID0+IHdlYjMudXRpbHNcbiAgICAuc29saWRpdHlTaGEzKGpzb25TdHJpbmcpO1xubW9kdWxlLmV4cG9ydHMubWFrZUhhc2ggPSBtYWtlSGFzaDtcbiJdfQ==
|
package/dist/utils/expect.js
DELETED
@@ -1,20 +0,0 @@
|
|
1
|
-
"use strict";require("core-js/modules/es.object.set-prototype-of.js");require("core-js/modules/es.object.get-prototype-of.js");require("core-js/modules/es.array.index-of.js");require("core-js/modules/es.reflect.construct.js");require("core-js/modules/es.map.js");require("core-js/modules/es.string.iterator.js");require("core-js/modules/esnext.map.delete-all.js");require("core-js/modules/esnext.map.every.js");require("core-js/modules/esnext.map.filter.js");require("core-js/modules/esnext.map.find.js");require("core-js/modules/esnext.map.find-key.js");require("core-js/modules/esnext.map.includes.js");require("core-js/modules/esnext.map.key-of.js");require("core-js/modules/esnext.map.map-keys.js");require("core-js/modules/esnext.map.map-values.js");require("core-js/modules/esnext.map.merge.js");require("core-js/modules/esnext.map.reduce.js");require("core-js/modules/esnext.map.some.js");require("core-js/modules/esnext.map.update.js");require("core-js/modules/es.symbol.js");require("core-js/modules/es.symbol.description.js");require("core-js/modules/es.symbol.iterator.js");require("core-js/modules/es.object.keys.js");require("core-js/modules/es.array.reduce.js");require("core-js/modules/es.regexp.exec.js");require("core-js/modules/es.string.split.js");require("core-js/modules/es.array.iterator.js");require("core-js/modules/es.object.to-string.js");require("core-js/modules/web.dom-collections.iterator.js");require("core-js/modules/es.array.includes.js");require("core-js/modules/es.string.includes.js");require("core-js/modules/es.array.concat.js");require("core-js/modules/es.regexp.constructor.js");require("core-js/modules/es.regexp.to-string.js");function _typeof(obj){"@babel/helpers - typeof";if(typeof Symbol==="function"&&typeof Symbol.iterator==="symbol"){_typeof=function _typeof(obj){return typeof obj}}else{_typeof=function _typeof(obj){return obj&&typeof Symbol==="function"&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj}}return _typeof(obj)}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError("Cannot call a class as a function")}}function _inherits(subClass,superClass){if(typeof superClass!=="function"&&superClass!==null){throw new TypeError("Super expression must either be null or a function")}subClass.prototype=Object.create(superClass&&superClass.prototype,{constructor:{value:subClass,writable:true,configurable:true}});if(superClass)_setPrototypeOf(subClass,superClass)}function _createSuper(Derived){var hasNativeReflectConstruct=_isNativeReflectConstruct();return function _createSuperInternal(){var Super=_getPrototypeOf(Derived),result;if(hasNativeReflectConstruct){var NewTarget=_getPrototypeOf(this).constructor;result=Reflect.construct(Super,arguments,NewTarget)}else{result=Super.apply(this,arguments)}return _possibleConstructorReturn(this,result)}}function _possibleConstructorReturn(self,call){if(call&&(_typeof(call)==="object"||typeof call==="function")){return call}return _assertThisInitialized(self)}function _assertThisInitialized(self){if(self===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return self}function _wrapNativeSuper(Class){var _cache=typeof Map==="function"?new Map:undefined;_wrapNativeSuper=function _wrapNativeSuper(Class){if(Class===null||!_isNativeFunction(Class))return Class;if(typeof Class!=="function"){throw new TypeError("Super expression must either be null or a function")}if(typeof _cache!=="undefined"){if(_cache.has(Class))return _cache.get(Class);_cache.set(Class,Wrapper)}function Wrapper(){return _construct(Class,arguments,_getPrototypeOf(this).constructor)}Wrapper.prototype=Object.create(Class.prototype,{constructor:{value:Wrapper,enumerable:false,writable:true,configurable:true}});return _setPrototypeOf(Wrapper,Class)};return _wrapNativeSuper(Class)}function _construct(Parent,args,Class){if(_isNativeReflectConstruct()){_construct=Reflect.construct}else{_construct=function _construct(Parent,args,Class){var a=[null];a.push.apply(a,args);var Constructor=Function.bind.apply(Parent,a);var instance=new Constructor;if(Class)_setPrototypeOf(instance,Class.prototype);return instance}}return _construct.apply(null,arguments)}function _isNativeReflectConstruct(){if(typeof Reflect==="undefined"||!Reflect.construct)return false;if(Reflect.construct.sham)return false;if(typeof Proxy==="function")return true;try{Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}));return true}catch(e){return false}}function _isNativeFunction(fn){return Function.toString.call(fn).indexOf("[native code]")!==-1}function _setPrototypeOf(o,p){_setPrototypeOf=Object.setPrototypeOf||function _setPrototypeOf(o,p){o.__proto__=p;return o};return _setPrototypeOf(o,p)}function _getPrototypeOf(o){_getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf:function _getPrototypeOf(o){return o.__proto__||Object.getPrototypeOf(o)};return _getPrototypeOf(o)}var _require=require("web3"),web3utils=_require.utils;/**
|
2
|
-
* ExpectError class
|
3
|
-
* @class ExpectError
|
4
|
-
* @extends {Error}
|
5
|
-
*/var ExpectError=/*#__PURE__*/function(_Error){_inherits(ExpectError,_Error);var _super=_createSuper(ExpectError);/**
|
6
|
-
* Creates an instance of ExpectError.
|
7
|
-
* @param {String} message
|
8
|
-
* @memberof ExpectError
|
9
|
-
*/function ExpectError(){var _this;var message=arguments.length>0&&arguments[0]!==undefined?arguments[0]:"Unknown error";_classCallCheck(this,ExpectError);// eslint-disable-line space-before-function-paren
|
10
|
-
_this=_super.call(this,message);for(var _len=arguments.length,args=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){args[_key-1]=arguments[_key]}_this.args=args;return _this}return ExpectError}(/*#__PURE__*/_wrapNativeSuper(Error));;module.exports.ExpectError=ExpectError;/**
|
11
|
-
* Ensuring expected parameters helper
|
12
|
-
* @param {Object} options
|
13
|
-
* @param {Object} model
|
14
|
-
*/var all=function all(){var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var model=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};if(_typeof(options)!=="object"||Object.keys(options).length===0){throw new ExpectError("Options for \"expect.all\" must be an object")}if(_typeof(model)!=="object"||Object.keys(model).length===0){throw new ExpectError("Model for \"expect.all\" must be an object")}for(var _i=0,_Object$keys=Object.keys(model);_i<_Object$keys.length;_i++){var key=_Object$keys[_i];if(!model[key].type){throw new ExpectError("Model property must have a \"type\" defined")}var value=key.split(".").reduce(function(acc,part){return acc&&acc[part]!==undefined?acc[part]:null},options);if(options[key]===undefined&&(model[key].required===true||model[key].required===undefined)){throw new ExpectError("The \"".concat(key,"\" property not found"),{expected:model[key].type,key:key,value:value})}switch(model[key].type){case"enum":if(!model[key].values||!Array.isArray(model[key].values)){throw new ExpectError("Enumerator conditions array not defined in the model",{expected:"enum",values:model[key].values,key:key,value:value})}if(!model[key].values.includes(value)&&(model[key].required===true||model[key].required===undefined)){throw new ExpectError("The value type of the \"".concat(String(key),"\" property is not valid. Expected type one of ").concat(model[key].values," but got: ").concat(String(value)),{expected:"enum",values:model[key].values,key:key,value:value})}break;case"address":if(!new RegExp("^0x[a-fA-F0-9]{40}$").test(value)&&(model[key].required===true||model[key].required===undefined)){throw new ExpectError("Ethereum address is required as value for the property: \"".concat(key,"\""),{expected:"address",key:key,value:value})}break;case"hash":if(!new RegExp("^0x[a-fA-F0-9]{64}$").test(value)&&(model[key].required===true||model[key].required===undefined)){throw new ExpectError("Ethereum tx hash is required as value for the property: \"".concat(key,"\""),{expected:"hash",key:key,value:value})}break;case"bn":if(!web3utils.isBN(value)&&(model[key].required===true||model[key].required===undefined)){throw new ExpectError("BN instance expected as value for the property \"".concat(key,"\" but got: ").concat(value),{expected:"bn",key:key,value:value})}break;case"functionOrMember":if(typeof value==="function"){// It is OK
|
15
|
-
break}// If not then follow the next rule
|
16
|
-
// eslint-disable-next-line no-fallthrough
|
17
|
-
case"member":if(!model[key].provider||_typeof(model[key].provider)!=="object"){throw new ExpectError("Provider object must be defined as \"provider\" model option for \"".concat(key,"\""))}if(typeof value!=="string"){throw new ExpectError("Property with \"member\" type must be a string but actually, it is a \"".concat(_typeof(value),"\""))}// eslint-disable-next-line no-case-declarations
|
18
|
-
var memberValue=value.split(".").reduce(function(acc,part){return acc&&acc[part]!==undefined?acc[part]:null},model[key].provider);if(!memberValue){throw new ExpectError("Not a member",{expected:model[key].type,provider:model[key].provider,key:key,value:value})}break;default:// eslint-disable-next-line valid-typeof
|
19
|
-
if(_typeof(value)!==model[key].type&&(model[key].required===true||model[key].required===undefined)){throw new ExpectError("The \"".concat(key,"\" property value has a wrong type: ").concat(_typeof(value)),{expected:model[key].type,key:key,value:value})}}}};module.exports.all=all;
|
20
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/expect.js"],"names":["require","web3utils","utils","ExpectError","message","args","Error","module","exports","all","options","model","Object","keys","length","key","type","value","split","reduce","acc","part","undefined","required","expected","values","Array","isArray","includes","String","RegExp","test","isBN","provider","memberValue"],"mappings":"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","sourcesContent":["const { utils: web3utils } = require('web3');\n\n/**\n * ExpectError class\n * @class ExpectError\n * @extends {Error}\n */\nclass ExpectError extends Error {\n\n    /**\n     * Creates an instance of ExpectError.\n     * @param {String} message\n     * @memberof ExpectError\n     */\n    constructor(message = 'Unknown error', ...args) { // eslint-disable-line space-before-function-paren\n        super(message);\n        this.args = args;\n    }\n};\nmodule.exports.ExpectError = ExpectError;\n\n/**\n * Ensuring expected parameters helper\n * @param {Object} options\n * @param {Object} model\n */\nconst all = (options = {}, model = {}) => {\n\n    if (typeof options !== 'object' || Object.keys(options).length === 0) {\n\n        throw new ExpectError('Options for \"expect.all\" must be an object');\n    }\n\n    if (typeof model !== 'object' || Object.keys(model).length === 0) {\n\n        throw new ExpectError('Model for \"expect.all\" must be an object');\n    }\n\n    for (const key of Object.keys(model)) {\n\n        if (!model[key].type) {\n\n            throw new ExpectError('Model property must have a \"type\" defined');\n        }\n\n        const value = key.split('.').reduce((acc, part) => {\n            return acc && acc[part] !== undefined ? acc[part] : null;\n        }, options);\n\n        if (options[key] === undefined &&\n            (model[key].required === true || model[key].required === undefined)) {\n\n            throw new ExpectError(\n                `The \"${key}\" property not found`,\n                {\n                    expected: model[key].type,\n                    key,\n                    value\n                }\n            );\n        }\n\n        switch (model[key].type) {\n\n            case 'enum':\n\n                if (!model[key].values || !Array.isArray(model[key].values)) {\n\n                    throw new ExpectError(\n                        'Enumerator conditions array not defined in the model',\n                        {\n                            expected: 'enum',\n                            values: model[key].values,\n                            key,\n                            value\n                        }\n                    );\n                }\n\n                if (!model[key].values.includes(value) &&\n                    (model[key].required === true || model[key].required === undefined)) {\n\n                    throw new ExpectError(\n                        `The value type of the \"${String(key)}\" property is not valid. Expected type one of ${model[key].values} but got: ${String(value)}`,\n                        {\n                            expected: 'enum',\n                            values: model[key].values,\n                            key,\n                            value\n                        }\n                    );\n                }\n\n                break;\n\n            case 'address':\n\n                if (!new RegExp('^0x[a-fA-F0-9]{40}$').test(value) &&\n                    (model[key].required === true || model[key].required === undefined)) {\n\n                    throw new ExpectError(\n                        `Ethereum address is required as value for the property: \"${key}\"`,\n                        {\n                            expected: 'address',\n                            key,\n                            value\n                        }\n                    );\n                }\n\n                break;\n\n            case 'hash':\n\n                if (!new RegExp('^0x[a-fA-F0-9]{64}$').test(value) &&\n                    (model[key].required === true || model[key].required === undefined)) {\n\n                    throw new ExpectError(\n                        `Ethereum tx hash is required as value for the property: \"${key}\"`,\n                        {\n                            expected: 'hash',\n                            key,\n                            value\n                        }\n                    );\n                }\n\n                break;\n\n            case 'bn':\n\n                if (!web3utils.isBN(value) &&\n                    (model[key].required === true || model[key].required === undefined)) {\n\n                    throw new ExpectError(\n                        `BN instance expected as value for the property \"${key}\" but got: ${value}`,\n                        {\n                            expected: 'bn',\n                            key,\n                            value\n                        }\n                    );\n                }\n\n                break;\n\n            case 'functionOrMember':\n\n                if (typeof value === 'function') {\n\n                    // It is OK\n                    break;\n                }\n                // If not then follow the next rule\n\n                // eslint-disable-next-line no-fallthrough\n            case 'member':\n\n                if (!model[key].provider || typeof model[key].provider !== 'object') {\n                    throw new ExpectError(\n                        `Provider object must be defined as \"provider\" model option for \"${key}\"`\n                    );\n                }\n\n                if (typeof value !== 'string') {\n                    throw new ExpectError(\n                        `Property with \"member\" type must be a string but actually, it is a \"${typeof value}\"`\n                    );\n                }\n\n                // eslint-disable-next-line no-case-declarations\n                const memberValue = value.split('.').reduce((acc, part) => {\n                    return acc && acc[part] !== undefined ? acc[part] : null;\n                }, model[key].provider);\n\n                if (!memberValue) {\n\n                    throw new ExpectError('Not a member', {\n                        expected: model[key].type,\n                        provider: model[key].provider,\n                        key,\n                        value\n                    });\n                }\n\n                break;\n\n            default:\n\n                // eslint-disable-next-line valid-typeof\n                if (typeof value !== model[key].type &&\n                    (model[key].required === true || model[key].required === undefined)) {\n\n                    throw new ExpectError(\n                        `The \"${key}\" property value has a wrong type: ${typeof value}`,\n                        {\n                            expected: model[key].type,\n                            key,\n                            value\n                        }\n                    );\n                }\n        }\n    }\n};\nmodule.exports.all = all;\n"]}
|
package/dist/utils/vc.js
DELETED
@@ -1,16 +0,0 @@
|
|
1
|
-
"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
|
2
|
-
proofDid=proofDid.toLowerCase();// Check if the source DID is the same as the proof DID
|
3
|
-
if(!(proofDid===sourceDid)){_context.next=9;break}// Take already resolved DID
|
4
|
-
didResult=resolver.result;_context.next=13;break;case 9:// Make new resolution
|
5
|
-
proofResolver=resolver.spawnResolver();_context.next=12;return proofResolver.resolve(proof);case 12:didResult=_context.sent;case 13:if(didResult){_context.next=15;break}throw new Error("Unable to resolve DID of the proof: ".concat(proof));case 15:// Check if the proof DID document is valid
|
6
|
-
didDocumentValid=didResult.checks.filter(function(c){return c.type==="DID_DOCUMENT"})[0];if(!(!didDocumentValid||!didDocumentValid.passed)){_context.next=18;break}throw new Error("DID document of the proof is not valid: ".concat(proof));case 18:// Get VC from the proof DID document
|
7
|
-
vc=didResult.didDocument.trust.credentials.filter(function(c){return c.id===proof})[0];if(vc){_context.next=21;break}throw new Error("Unable to find VC of the proof: ".concat(proof));case 21:// Fetch verification key
|
8
|
-
verificationMethod=vc.proof.verificationMethod;verifierDid=verificationMethod.split("#")[0];// Check verifier DID existence
|
9
|
-
if(verifierDid){_context.next=25;break}throw new Error("Unable to find a verifier DID in the verificationMethod: ".concat(verificationMethod));case 25:// Normalize the verifier DID
|
10
|
-
verifierDid=verifierDid.toLowerCase();if(!(verifierDid===sourceDid)){_context.next=30;break}verifierDidResult=resolver.result;_context.next=34;break;case 30:verifierResolver=resolver.spawnResolver();_context.next=33;return verifierResolver.resolve(verifierDid);case 33:verifierDidResult=_context.sent;case 34:if(verifierDidResult){_context.next=36;break}throw new Error("Unable to resolve the proof verifier DID: ".concat(verifierDid));case 36:// Check if verifier DID document is valid
|
11
|
-
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
|
12
|
-
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
|
13
|
-
verificationResult=verifyVc(vc,vc.proof.type,verificationKey.publicKeyPem);// Check if the issuer DID is defined in the VC data
|
14
|
-
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
|
15
|
-
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)}}();
|
16
|
-
//# 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"]}
|
package/dist/whois.js
DELETED
@@ -1,3 +0,0 @@
|
|
1
|
-
"use strict";require("regenerator-runtime/runtime.js");require("core-js/modules/es.array.reduce.js");require("core-js/modules/es.array.map.js");require("core-js/modules/es.regexp.exec.js");require("core-js/modules/es.string.split.js");require("core-js/modules/es.string.trim.js");require("core-js/modules/es.string.replace.js");require("core-js/modules/es.object.to-string.js");require("core-js/modules/es.promise.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 whois=require("whois-light");var replacements={"Domain Name":"domainName","Registry Domain ID":"registryDomainId","Registrar WHOIS Server":"registrarWhoisServer","Registrar URL":"registrarUrl","Updated Date":"updatedDate","Creation Date":"creationDate","Registry Expiry Date":"expiryDate","Registrar":"registrar","Registrar IANA ID":"registrarIanaId","Registrar Abuse Contact Email":"registrarAbuseContactEmail","Registrar Abuse Contact Phone":"registrarAbuseContactPhone","Domain Status":"domainStatus","Name Server":"nameServer","DNSSEC":"DNSSEC"};// Configuration of the HTTP fetching method
|
2
|
-
module.exports={name:"whois",fetch:function(){var _fetch=_asyncToGenerator(/*#__PURE__*/regeneratorRuntime.mark(function _callee(domainName){var domainResolution;return regeneratorRuntime.wrap(function _callee$(_context){while(1){switch(_context.prev=_context.next){case 0:_context.next=2;return whois.lookup(domainName);case 2:domainResolution=_context.sent;return _context.abrupt("return",domainResolution.split("\r\n").map(function(l){return l.trim()}).reduce(function(a,v){v=v.replace(">>> ","");v=v.replace(" <<<","");if(v!==""){v=v.split(": ");if(v.length>1&&replacements[v[0]]){a[replacements[v[0]]]=v[1]}}return a},{}));case 4:case"end":return _context.stop();}}},_callee)}));function fetch(_x){return _fetch.apply(this,arguments)}return fetch}()};
|
3
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy93aG9pcy5qcyJdLCJuYW1lcyI6WyJ3aG9pcyIsInJlcXVpcmUiLCJyZXBsYWNlbWVudHMiLCJtb2R1bGUiLCJleHBvcnRzIiwibmFtZSIsImZldGNoIiwiZG9tYWluTmFtZSIsImxvb2t1cCIsImRvbWFpblJlc29sdXRpb24iLCJzcGxpdCIsIm1hcCIsImwiLCJ0cmltIiwicmVkdWNlIiwiYSIsInYiLCJyZXBsYWNlIiwibGVuZ3RoIl0sIm1hcHBpbmdzIjoiNjlCQUFBLEdBQU1BLENBQUFBLEtBQUssQ0FBR0MsT0FBTyxDQUFDLGFBQUQsQ0FBckIsQ0FFQSxHQUFNQyxDQUFBQSxZQUFZLENBQUcsQ0FDakIsY0FBZSxZQURFLENBRWpCLHFCQUFzQixrQkFGTCxDQUdqQix5QkFBMEIsc0JBSFQsQ0FJakIsZ0JBQWlCLGNBSkEsQ0FLakIsZUFBZ0IsYUFMQyxDQU1qQixnQkFBaUIsY0FOQSxDQU9qQix1QkFBd0IsWUFQUCxDQVFqQixZQUFhLFdBUkksQ0FTakIsb0JBQXFCLGlCQVRKLENBVWpCLGdDQUFpQyw0QkFWaEIsQ0FXakIsZ0NBQWlDLDRCQVhoQixDQVlqQixnQkFBaUIsY0FaQSxDQWFqQixjQUFlLFlBYkUsQ0FjakIsU0FBVSxRQWRPLENBQXJCLENBaUJBO0FBQ0FDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFpQixDQUNiQyxJQUFJLENBQUUsT0FETyxDQUViQyxLQUFLLDhFQUFFLGlCQUFPQyxVQUFQLDRKQUMwQlAsQ0FBQUEsS0FBSyxDQUFDUSxNQUFOLENBQWFELFVBQWIsQ0FEMUIsUUFDQ0UsZ0JBREQsK0NBRUlBLGdCQUFnQixDQUNsQkMsS0FERSxDQUNJLE1BREosRUFFRkMsR0FGRSxDQUVFLFNBQUFDLENBQUMsUUFBSUEsQ0FBQUEsQ0FBQyxDQUFDQyxJQUFGLEVBQUosQ0FGSCxFQUdGQyxNQUhFLENBSUMsU0FBQ0MsQ0FBRCxDQUFJQyxDQUFKLENBQVUsQ0FDTkEsQ0FBQyxDQUFHQSxDQUFDLENBQUNDLE9BQUYsQ0FBVSxNQUFWLENBQWtCLEVBQWxCLENBQUosQ0FDQUQsQ0FBQyxDQUFHQSxDQUFDLENBQUNDLE9BQUYsQ0FBVSxNQUFWLENBQWtCLEVBQWxCLENBQUosQ0FDQSxHQUFJRCxDQUFDLEdBQUssRUFBVixDQUFjLENBQ1ZBLENBQUMsQ0FBR0EsQ0FBQyxDQUFDTixLQUFGLENBQVEsSUFBUixDQUFKLENBQ0EsR0FBSU0sQ0FBQyxDQUFDRSxNQUFGLENBQVcsQ0FBWCxFQUFnQmhCLFlBQVksQ0FBQ2MsQ0FBQyxDQUFDLENBQUQsQ0FBRixDQUFoQyxDQUF3QyxDQUNwQ0QsQ0FBQyxDQUFDYixZQUFZLENBQUNjLENBQUMsQ0FBQyxDQUFELENBQUYsQ0FBYixDQUFELENBQXdCQSxDQUFDLENBQUMsQ0FBRCxDQUM1QixDQUNKLENBQ0QsTUFBT0QsQ0FBQUEsQ0FDVixDQWRGLENBZUMsRUFmRCxDQUZKLHVEQUFGLHlFQUZRLENBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3Qgd2hvaXMgPSByZXF1aXJlKCd3aG9pcy1saWdodCcpO1xuXG5jb25zdCByZXBsYWNlbWVudHMgPSB7XG4gICAgJ0RvbWFpbiBOYW1lJzogJ2RvbWFpbk5hbWUnLFxuICAgICdSZWdpc3RyeSBEb21haW4gSUQnOiAncmVnaXN0cnlEb21haW5JZCcsXG4gICAgJ1JlZ2lzdHJhciBXSE9JUyBTZXJ2ZXInOiAncmVnaXN0cmFyV2hvaXNTZXJ2ZXInLFxuICAgICdSZWdpc3RyYXIgVVJMJzogJ3JlZ2lzdHJhclVybCcsXG4gICAgJ1VwZGF0ZWQgRGF0ZSc6ICd1cGRhdGVkRGF0ZScsXG4gICAgJ0NyZWF0aW9uIERhdGUnOiAnY3JlYXRpb25EYXRlJyxcbiAgICAnUmVnaXN0cnkgRXhwaXJ5IERhdGUnOiAnZXhwaXJ5RGF0ZScsXG4gICAgJ1JlZ2lzdHJhcic6ICdyZWdpc3RyYXInLFxuICAgICdSZWdpc3RyYXIgSUFOQSBJRCc6ICdyZWdpc3RyYXJJYW5hSWQnLFxuICAgICdSZWdpc3RyYXIgQWJ1c2UgQ29udGFjdCBFbWFpbCc6ICdyZWdpc3RyYXJBYnVzZUNvbnRhY3RFbWFpbCcsXG4gICAgJ1JlZ2lzdHJhciBBYnVzZSBDb250YWN0IFBob25lJzogJ3JlZ2lzdHJhckFidXNlQ29udGFjdFBob25lJyxcbiAgICAnRG9tYWluIFN0YXR1cyc6ICdkb21haW5TdGF0dXMnLFxuICAgICdOYW1lIFNlcnZlcic6ICduYW1lU2VydmVyJyxcbiAgICAnRE5TU0VDJzogJ0ROU1NFQydcbn07XG5cbi8vIENvbmZpZ3VyYXRpb24gb2YgdGhlIEhUVFAgZmV0Y2hpbmcgbWV0aG9kXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBuYW1lOiAnd2hvaXMnLFxuICAgIGZldGNoOiBhc3luYyAoZG9tYWluTmFtZSkgPT4ge1xuICAgICAgICBsZXQgZG9tYWluUmVzb2x1dGlvbiA9IGF3YWl0IHdob2lzLmxvb2t1cChkb21haW5OYW1lKTtcbiAgICAgICAgcmV0dXJuIGRvbWFpblJlc29sdXRpb25cbiAgICAgICAgICAgIC5zcGxpdCgnXFxyXFxuJylcbiAgICAgICAgICAgIC5tYXAobCA9PiBsLnRyaW0oKSlcbiAgICAgICAgICAgIC5yZWR1Y2UoXG4gICAgICAgICAgICAgICAgKGEsIHYpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgdiA9IHYucmVwbGFjZSgnPj4+ICcsICcnKTtcbiAgICAgICAgICAgICAgICAgICAgdiA9IHYucmVwbGFjZSgnIDw8PCcsICcnKTtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHYgIT09ICcnKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB2ID0gdi5zcGxpdCgnOiAnKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmICh2Lmxlbmd0aCA+IDEgJiYgcmVwbGFjZW1lbnRzW3ZbMF1dKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYVtyZXBsYWNlbWVudHNbdlswXV1dID0gdlsxXTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gYTtcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHt9XG4gICAgICAgICAgICApO1xuICAgIH1cbn07XG4iXX0=
|