diff --git a/.mocharc.json b/.mocharc.json index 954b0050..08de8748 100644 --- a/.mocharc.json +++ b/.mocharc.json @@ -4,6 +4,6 @@ ], "spec": "tests/**/*.test.ts", "require": "ts-node/register", - "timeout": "300000", + "timeout": "400000", "maxDiffSize": "10000" } diff --git a/package-lock.json b/package-lock.json index 39f2a423..0828a485 100644 --- a/package-lock.json +++ b/package-lock.json @@ -81,76 +81,73 @@ "license": "MIT" }, "node_modules/@cspell/cspell-bundled-dicts": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/cspell-bundled-dicts/-/cspell-bundled-dicts-8.16.0.tgz", - "integrity": "sha512-R0Eqq5kTZnmZ0elih5uY3TWjMqqAeMl7ciU7maUs+m1FNjCEdJXtJ9wrQxNgjmXi0tX8cvahZRO3O558tEz/KA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@cspell/dict-ada": "^4.0.5", - "@cspell/dict-al": "^1.0.3", - "@cspell/dict-aws": "^4.0.7", - "@cspell/dict-bash": "^4.1.8", - "@cspell/dict-companies": "^3.1.7", - "@cspell/dict-cpp": "^6.0.1", - "@cspell/dict-cryptocurrencies": "^5.0.3", - "@cspell/dict-csharp": "^4.0.5", - "@cspell/dict-css": "^4.0.16", - "@cspell/dict-dart": "^2.2.4", - "@cspell/dict-django": "^4.1.3", - "@cspell/dict-docker": "^1.1.11", - "@cspell/dict-dotnet": "^5.0.8", - "@cspell/dict-elixir": "^4.0.6", - "@cspell/dict-en_us": "^4.3.26", - "@cspell/dict-en-common-misspellings": "^2.0.7", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/cspell-bundled-dicts/-/cspell-bundled-dicts-8.14.2.tgz", + "integrity": "sha512-Kv2Utj/RTSxfufGXkkoTZ/3ErCsYWpCijtDFr/FwSsM7mC0PzLpdlcD9xjtgrJO5Kwp7T47iTG21U4Mwddyi8Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "@cspell/dict-ada": "^4.0.2", + "@cspell/dict-aws": "^4.0.3", + "@cspell/dict-bash": "^4.1.3", + "@cspell/dict-companies": "^3.1.4", + "@cspell/dict-cpp": "^5.1.12", + "@cspell/dict-cryptocurrencies": "^5.0.0", + "@cspell/dict-csharp": "^4.0.2", + "@cspell/dict-css": "^4.0.13", + "@cspell/dict-dart": "^2.0.3", + "@cspell/dict-django": "^4.1.0", + "@cspell/dict-docker": "^1.1.7", + "@cspell/dict-dotnet": "^5.0.2", + "@cspell/dict-elixir": "^4.0.3", + "@cspell/dict-en_us": "^4.3.23", + "@cspell/dict-en-common-misspellings": "^2.0.4", "@cspell/dict-en-gb": "1.1.33", - "@cspell/dict-filetypes": "^3.0.8", - "@cspell/dict-flutter": "^1.0.3", - "@cspell/dict-fonts": "^4.0.3", - "@cspell/dict-fsharp": "^1.0.4", - "@cspell/dict-fullstack": "^3.2.3", - "@cspell/dict-gaming-terms": "^1.0.8", - "@cspell/dict-git": "^3.0.3", - "@cspell/dict-golang": "^6.0.16", - "@cspell/dict-google": "^1.0.4", - "@cspell/dict-haskell": "^4.0.4", - "@cspell/dict-html": "^4.0.10", - "@cspell/dict-html-symbol-entities": "^4.0.3", - "@cspell/dict-java": "^5.0.10", - "@cspell/dict-julia": "^1.0.4", - "@cspell/dict-k8s": "^1.0.9", - "@cspell/dict-latex": "^4.0.3", - "@cspell/dict-lorem-ipsum": "^4.0.3", - "@cspell/dict-lua": "^4.0.6", - "@cspell/dict-makefile": "^1.0.3", - "@cspell/dict-markdown": "^2.0.7", - "@cspell/dict-monkeyc": "^1.0.9", - "@cspell/dict-node": "^5.0.5", - "@cspell/dict-npm": "^5.1.11", - "@cspell/dict-php": "^4.0.13", - "@cspell/dict-powershell": "^5.0.13", - "@cspell/dict-public-licenses": "^2.0.11", - "@cspell/dict-python": "^4.2.12", - "@cspell/dict-r": "^2.0.4", - "@cspell/dict-ruby": "^5.0.7", - "@cspell/dict-rust": "^4.0.9", - "@cspell/dict-scala": "^5.0.6", - "@cspell/dict-software-terms": "^4.1.13", - "@cspell/dict-sql": "^2.1.8", - "@cspell/dict-svelte": "^1.0.5", - "@cspell/dict-swift": "^2.0.4", - "@cspell/dict-terraform": "^1.0.6", - "@cspell/dict-typescript": "^3.1.11", - "@cspell/dict-vue": "^3.0.3" + "@cspell/dict-filetypes": "^3.0.4", + "@cspell/dict-fonts": "^4.0.0", + "@cspell/dict-fsharp": "^1.0.1", + "@cspell/dict-fullstack": "^3.2.0", + "@cspell/dict-gaming-terms": "^1.0.5", + "@cspell/dict-git": "^3.0.0", + "@cspell/dict-golang": "^6.0.9", + "@cspell/dict-google": "^1.0.1", + "@cspell/dict-haskell": "^4.0.1", + "@cspell/dict-html": "^4.0.5", + "@cspell/dict-html-symbol-entities": "^4.0.0", + "@cspell/dict-java": "^5.0.7", + "@cspell/dict-julia": "^1.0.1", + "@cspell/dict-k8s": "^1.0.6", + "@cspell/dict-latex": "^4.0.0", + "@cspell/dict-lorem-ipsum": "^4.0.0", + "@cspell/dict-lua": "^4.0.3", + "@cspell/dict-makefile": "^1.0.0", + "@cspell/dict-monkeyc": "^1.0.6", + "@cspell/dict-node": "^5.0.1", + "@cspell/dict-npm": "^5.0.18", + "@cspell/dict-php": "^4.0.8", + "@cspell/dict-powershell": "^5.0.5", + "@cspell/dict-public-licenses": "^2.0.7", + "@cspell/dict-python": "^4.2.4", + "@cspell/dict-r": "^2.0.1", + "@cspell/dict-ruby": "^5.0.2", + "@cspell/dict-rust": "^4.0.5", + "@cspell/dict-scala": "^5.0.3", + "@cspell/dict-software-terms": "^4.0.6", + "@cspell/dict-sql": "^2.1.5", + "@cspell/dict-svelte": "^1.0.2", + "@cspell/dict-swift": "^2.0.1", + "@cspell/dict-terraform": "^1.0.0", + "@cspell/dict-typescript": "^3.1.6", + "@cspell/dict-vue": "^3.0.0" }, "engines": { "node": ">=18" } }, "node_modules/@cspell/cspell-pipe": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/cspell-pipe/-/cspell-pipe-8.16.0.tgz", - "integrity": "sha512-WoCgrv/mrtwCY4lhc6vEcqN3AQ7lT6K0NW5ShoSo116U2tRaW0unApIYH4Va8u7T9g3wyspFEceQRR1xD9qb9w==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/cspell-pipe/-/cspell-pipe-8.14.2.tgz", + "integrity": "sha512-aWMoXZAXEre0/M9AYWOW33YyOJZ06i4vvsEpWBDWpHpWQEmsR/7cMMgld8Pp3wlEjIUclUAKTYmrZ61PFWU/og==", "dev": true, "license": "MIT", "engines": { @@ -158,9 +155,9 @@ } }, "node_modules/@cspell/cspell-resolver": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/cspell-resolver/-/cspell-resolver-8.16.0.tgz", - "integrity": "sha512-b+99bph43ptkXlQHgPXSkN/jK6LQHy2zL1Fm9up7+x6Yr64bxAzWzoeqJAPtnrPvFuOrFN0jZasZzKBw8CvrrQ==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/cspell-resolver/-/cspell-resolver-8.14.2.tgz", + "integrity": "sha512-pSyBsAvslaN0dx0pHdvECJEuFDDBJGAD6G8U4BVbIyj2OPk0Ox0HrZIj6csYxxoJERAgNO/q7yCPwa4j9NNFXg==", "dev": true, "license": "MIT", "dependencies": { @@ -171,9 +168,9 @@ } }, "node_modules/@cspell/cspell-service-bus": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/cspell-service-bus/-/cspell-service-bus-8.16.0.tgz", - "integrity": "sha512-+fn763JKA4EYCOv+1VShFq015UMEBAFRDr+rlCnesgLE0fv9TSFVLsjOfh9/g6GuGQLCRLUqKztwwuueeErstQ==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/cspell-service-bus/-/cspell-service-bus-8.14.2.tgz", + "integrity": "sha512-WUF7xf3YgXYIqjmBwLcVugYIrYL4WfXchgSo9rmbbnOcAArzsK+HKfzb4AniZAJ1unxcIQ0JnVlRmnCAKPjjLg==", "dev": true, "license": "MIT", "engines": { @@ -181,9 +178,9 @@ } }, "node_modules/@cspell/cspell-types": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/cspell-types/-/cspell-types-8.16.0.tgz", - "integrity": "sha512-bGrIK7p4NVsK+QX/CYWmjax+FkzfSIZaIaoiBESGV5gmwgXDVRMJ3IP6tQVAmTtckOYHCmtT5CZgI8zXWr8dHQ==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/cspell-types/-/cspell-types-8.14.2.tgz", + "integrity": "sha512-MRY8MjBNOKGMDSkxAKueYAgVL43miO+lDcLCBBP+7cNXqHiUFMIZteONcGp3kJT0dWS04dN6lKAXvaNF0aWcng==", "dev": true, "license": "MIT", "engines": { @@ -191,16 +188,9 @@ } }, "node_modules/@cspell/dict-ada": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/@cspell/dict-ada/-/dict-ada-4.0.5.tgz", - "integrity": "sha512-6/RtZ/a+lhFVmrx/B7bfP7rzC4yjEYe8o74EybXcvu4Oue6J4Ey2WSYj96iuodloj1LWrkNCQyX5h4Pmcj0Iag==", - "dev": true, - "license": "MIT" - }, - "node_modules/@cspell/dict-al": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/@cspell/dict-al/-/dict-al-1.0.3.tgz", - "integrity": "sha512-V1HClwlfU/qwSq2Kt+MkqRAsonNu3mxjSCDyGRecdLGIHmh7yeEeaxqRiO/VZ4KP+eVSiSIlbwrb5YNFfxYZbw==", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@cspell/dict-ada/-/dict-ada-4.0.2.tgz", + "integrity": "sha512-0kENOWQeHjUlfyId/aCM/mKXtkEgV0Zu2RhUXCBr4hHo9F9vph+Uu8Ww2b0i5a4ZixoIkudGA+eJvyxrG1jUpA==", "dev": true, "license": "MIT" }, @@ -226,9 +216,9 @@ "license": "MIT" }, "node_modules/@cspell/dict-cpp": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/@cspell/dict-cpp/-/dict-cpp-6.0.2.tgz", - "integrity": "sha512-yw5eejWvY4bAnc6LUA44m4WsFwlmgPt2uMSnO7QViGMBDuoeopMma4z9XYvs4lSjTi8fIJs/A1YDfM9AVzb8eg==", + "version": "5.1.16", + "resolved": "https://registry.npmjs.org/@cspell/dict-cpp/-/dict-cpp-5.1.16.tgz", + "integrity": "sha512-32fU5RkuOM55IRcxjByiSoKbjr+C4danDfYjHaQNRWdvjzJzci3fLDGA2wTXiclkgDODxGiV8LCTUwCz+3TNWA==", "dev": true, "license": "MIT" }, @@ -296,9 +286,9 @@ "license": "MIT" }, "node_modules/@cspell/dict-en_us": { - "version": "4.3.27", - "resolved": "https://registry.npmjs.org/@cspell/dict-en_us/-/dict-en_us-4.3.27.tgz", - "integrity": "sha512-7JYHahRWpi0VykWFTSM03KL/0fs6YtYfpOaTAg4N/d0wB2GfwVG/FJ/SBCjD4LBc6Rx9dzdo95Hs4BB8GPQbOA==", + "version": "4.3.23", + "resolved": "https://registry.npmjs.org/@cspell/dict-en_us/-/dict-en_us-4.3.23.tgz", + "integrity": "sha512-l0SoEQBsi3zDSl3OuL4/apBkxjuj4hLIg/oy6+gZ7LWh03rKdF6VNtSZNXWAmMY+pmb1cGA3ouleTiJIglbsIg==", "dev": true, "license": "MIT" }, @@ -323,13 +313,6 @@ "dev": true, "license": "MIT" }, - "node_modules/@cspell/dict-flutter": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/@cspell/dict-flutter/-/dict-flutter-1.0.3.tgz", - "integrity": "sha512-52C9aUEU22ptpgYh6gQyIdA4MP6NPwzbEqndfgPh3Sra191/kgs7CVqXiO1qbtZa9gnYHUoVApkoxRE7mrXHfg==", - "dev": true, - "license": "MIT" - }, "node_modules/@cspell/dict-fonts": { "version": "4.0.3", "resolved": "https://registry.npmjs.org/@cspell/dict-fonts/-/dict-fonts-4.0.3.tgz", @@ -449,19 +432,6 @@ "dev": true, "license": "MIT" }, - "node_modules/@cspell/dict-markdown": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/@cspell/dict-markdown/-/dict-markdown-2.0.7.tgz", - "integrity": "sha512-F9SGsSOokFn976DV4u/1eL4FtKQDSgJHSZ3+haPRU5ki6OEqojxKa8hhj4AUrtNFpmBaJx/WJ4YaEzWqG7hgqg==", - "dev": true, - "license": "MIT", - "peerDependencies": { - "@cspell/dict-css": "^4.0.16", - "@cspell/dict-html": "^4.0.10", - "@cspell/dict-html-symbol-entities": "^4.0.3", - "@cspell/dict-typescript": "^3.1.11" - } - }, "node_modules/@cspell/dict-monkeyc": { "version": "1.0.9", "resolved": "https://registry.npmjs.org/@cspell/dict-monkeyc/-/dict-monkeyc-1.0.9.tgz", @@ -470,9 +440,9 @@ "license": "MIT" }, "node_modules/@cspell/dict-node": { - "version": "5.0.5", - "resolved": "https://registry.npmjs.org/@cspell/dict-node/-/dict-node-5.0.5.tgz", - "integrity": "sha512-7NbCS2E8ZZRZwlLrh2sA0vAk9n1kcTUiRp/Nia8YvKaItGXLfxYqD2rMQ3HpB1kEutal6hQLVic3N2Yi1X7AaA==", + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/@cspell/dict-node/-/dict-node-5.0.1.tgz", + "integrity": "sha512-lax/jGz9h3Dv83v8LHa5G0bf6wm8YVRMzbjJPG/9rp7cAGPtdrga+XANFq+B7bY5+jiSA3zvj10LUFCFjnnCCg==", "dev": true, "license": "MIT" }, @@ -571,9 +541,9 @@ "license": "MIT" }, "node_modules/@cspell/dict-terraform": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/@cspell/dict-terraform/-/dict-terraform-1.0.6.tgz", - "integrity": "sha512-Sqm5vGbXuI9hCFcr4w6xWf4Y25J9SdleE/IqfM6RySPnk8lISEmVdax4k6+Kinv9qaxyvnIbUUN4WFLWcBPQAg==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@cspell/dict-terraform/-/dict-terraform-1.0.1.tgz", + "integrity": "sha512-29lmUUnZgPh+ieZ5hunick8hzNIpNRtiJh9vAusNskPCrig3RTW6u7F+GG1a8uyslbzSw+Irjf40PTOan1OJJA==", "dev": true, "license": "MIT" }, @@ -592,9 +562,9 @@ "license": "MIT" }, "node_modules/@cspell/dynamic-import": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/dynamic-import/-/dynamic-import-8.16.0.tgz", - "integrity": "sha512-FH+B5y71qfunagXiLSJhXP9h/Vwb1Z8Cc/hLmliGekw/Y8BuYknL86tMg9grXBYNmM0kifIv6ZesQl8Km/p/rA==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/dynamic-import/-/dynamic-import-8.14.2.tgz", + "integrity": "sha512-5MbqtIligU7yPwHWU/5yFCgMvur4i1bRAF1Cy8y2dDtHsa204S/w/SaXs+51EFLp2eNbCiBisCBrwJFT7R1RxA==", "dev": true, "license": "MIT", "dependencies": { @@ -605,16 +575,16 @@ } }, "node_modules/@cspell/eslint-plugin": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/eslint-plugin/-/eslint-plugin-8.16.0.tgz", - "integrity": "sha512-j4vmbq30cq2kRR5xMAjfLraFW6ZrSxlAbEk06vC1T3Zxl9fOclOQVsxZ2afLd7TB0NKsrSjS2mFBHBlNkDmSFA==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/eslint-plugin/-/eslint-plugin-8.14.2.tgz", + "integrity": "sha512-SU8OPwkNFjRmYyMuwA1O6L1GsKw2pjLogBKsIR1iBQaVNvIf2JiwqjO0xB+UQnJHlqHzR2VuarR9mJUMNuy4tg==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/cspell-types": "8.16.0", - "@cspell/url": "8.16.0", - "cspell-lib": "8.16.0", - "synckit": "^0.9.2" + "@cspell/cspell-types": "8.14.2", + "@cspell/url": "8.14.2", + "cspell-lib": "8.14.2", + "synckit": "^0.9.1" }, "engines": { "node": ">=18" @@ -624,9 +594,9 @@ } }, "node_modules/@cspell/filetypes": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/filetypes/-/filetypes-8.16.0.tgz", - "integrity": "sha512-u2Ub0uSwXFPJFvXhAO/0FZBj3sMr4CeYCiQwTUsdFRkRMFpbTc7Vf+a+aC2vIj6WcaWrYXrJy3NZF/yjqF6SGw==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/filetypes/-/filetypes-8.14.2.tgz", + "integrity": "sha512-ZevArA0mWeVTTqHicxCPZIAeCibpY3NwWK/x6d1Lgu7RPk/daoGAM546Q2SLChFu+r10tIH7pRG212A6Q9ihPA==", "dev": true, "license": "MIT", "engines": { @@ -634,9 +604,9 @@ } }, "node_modules/@cspell/strong-weak-map": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/strong-weak-map/-/strong-weak-map-8.16.0.tgz", - "integrity": "sha512-R6N12wEIQpBk2uyni/FU1SFSIjP0uql7ynXVcF1ob8/JJeRoikssydi9Xq5J6ghMw+X50u35mFvg9BgWKz0d+g==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/strong-weak-map/-/strong-weak-map-8.14.2.tgz", + "integrity": "sha512-7sRzJc392CQYNNrtdPEfOHJdRqsqf6nASCtbS5A9hL2UrdWQ4uN7r/D+Y1HpuizwY9eOkZvarcFfsYt5wE0Pug==", "dev": true, "license": "MIT", "engines": { @@ -644,9 +614,9 @@ } }, "node_modules/@cspell/url": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/@cspell/url/-/url-8.16.0.tgz", - "integrity": "sha512-zW+6hAieD/FjysfjY4mVv7iHWWasBP3ldj6L+xy2p4Kuax1nug7uuJqMHlAVude/OywNwENG0rYaP/P9Pg4O+w==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/@cspell/url/-/url-8.14.2.tgz", + "integrity": "sha512-YmWW+B/2XQcCynLpiAQF77Bitm5Cynw3/BICZkbdveKjJkUzEmXB+U2qWuwXOyU8xUYuwkP63YM8McnI567rUA==", "dev": true, "license": "MIT", "engines": { @@ -2110,9 +2080,9 @@ "license": "MIT" }, "node_modules/@types/node": { - "version": "20.17.6", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.6.tgz", - "integrity": "sha512-VEI7OdvK2wP7XHnsuXbAJnEpEkF6NjSN45QJlL4VGqZSXsnicpesdTWsg9RISeSdYd3yeRj/y3k5KGjUXYnFwQ==", + "version": "20.16.5", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.16.5.tgz", + "integrity": "sha512-VwYCweNo3ERajwy0IUlqqcyZ8/A7Zwa9ZP3MnENWcB11AejO+tLy3pu850goUW2FC/IJMdZUfKpX/yxL1gymCA==", "dev": true, "license": "MIT", "dependencies": { @@ -3456,13 +3426,13 @@ } }, "node_modules/cspell-config-lib": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/cspell-config-lib/-/cspell-config-lib-8.16.0.tgz", - "integrity": "sha512-PGT6ohLtIYXYLIm+R5hTcTrF0dzj8e7WAUJSJe5WlV/7lrwVdwgWaliLcXtSSPmfxgczr6sndX9TMJ2IEmPrmg==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/cspell-config-lib/-/cspell-config-lib-8.14.2.tgz", + "integrity": "sha512-yHP1BdcH5dbjb8qiZr6+bxEnJ+rxTULQ00wBz3eBPWCghJywEAYYvMWoYuxVtPpndlkKYC1wJAHsyNkweQyepA==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/cspell-types": "8.16.0", + "@cspell/cspell-types": "8.14.2", "comment-json": "^4.2.5", "yaml": "^2.6.0" }, @@ -3471,15 +3441,15 @@ } }, "node_modules/cspell-dictionary": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/cspell-dictionary/-/cspell-dictionary-8.16.0.tgz", - "integrity": "sha512-Y3sN6ttLBKbu0dOLcduY641n5QP1srUvZkW4bOTnG455DbIZfilrP1El/2Hl0RS6hC8LN9PM4bsIm/2xgdbApA==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/cspell-dictionary/-/cspell-dictionary-8.14.2.tgz", + "integrity": "sha512-gWuAvf6queGGUvGbfAxxUq55cZ0OevWPbjnCrSB0PpJ4tqdFd8dLcvVrIKzoE2sBXKPw2NDkmoEngs6iGavC0w==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/cspell-pipe": "8.16.0", - "@cspell/cspell-types": "8.16.0", - "cspell-trie-lib": "8.16.0", + "@cspell/cspell-pipe": "8.14.2", + "@cspell/cspell-types": "8.14.2", + "cspell-trie-lib": "8.14.2", "fast-equals": "^5.0.1" }, "engines": { @@ -3487,28 +3457,28 @@ } }, "node_modules/cspell-glob": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/cspell-glob/-/cspell-glob-8.16.0.tgz", - "integrity": "sha512-xJSXRHwfENCNFmjpVSEucXY8E3BrpSCA+TukmOYtLyaMKtn6EAwoCpEU7Oj2tZOjdivprPmQ74k4Dqb1RHjIVQ==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/cspell-glob/-/cspell-glob-8.14.2.tgz", + "integrity": "sha512-9Q1Kgoo1ev3fKTpp9y5n8M4RLxd8B0f5o4y5FQe4dBU0j/bt+/YDrLZNWDm77JViV606XQ6fimG1FTTq6pT9/g==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/url": "8.16.0", - "micromatch": "^4.0.8" + "@cspell/url": "8.14.2", + "micromatch": "^4.0.7" }, "engines": { "node": ">=18" } }, "node_modules/cspell-grammar": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/cspell-grammar/-/cspell-grammar-8.16.0.tgz", - "integrity": "sha512-vvbJEkBqXocGH/H975RtkfMzVpNxNGMd0JCDd+NjbpeRyZceuChFw5Tie7kHteFY29SwZovub+Am3F4H1kmf9A==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/cspell-grammar/-/cspell-grammar-8.14.2.tgz", + "integrity": "sha512-eYwceVP80FGYVJenE42ALnvEKOXaXjq4yVbb1Ni1umO/9qamLWNCQ1RP6rRACy5e/cXviAbhrQ5Mtw6n+pyPEQ==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/cspell-pipe": "8.16.0", - "@cspell/cspell-types": "8.16.0" + "@cspell/cspell-pipe": "8.14.2", + "@cspell/cspell-types": "8.14.2" }, "bin": { "cspell-grammar": "bin.mjs" @@ -3518,42 +3488,42 @@ } }, "node_modules/cspell-io": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/cspell-io/-/cspell-io-8.16.0.tgz", - "integrity": "sha512-WIK5uhPMjGsTAzm2/fGRbIdr7zWsMVG1fn8wNJYUiYELuyvzvLelfI1VG6szaFCGYqd6Uvgb/fS0uNbwGqCLAQ==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/cspell-io/-/cspell-io-8.14.2.tgz", + "integrity": "sha512-uaKpHiY3DAgfdzgKMQml6U8F8o9udMuYxGqYa5FVfN7D5Ap7B2edQzSLTUYwxrFEn4skSfp6XY73+nzJvxzH4Q==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/cspell-service-bus": "8.16.0", - "@cspell/url": "8.16.0" + "@cspell/cspell-service-bus": "8.14.2", + "@cspell/url": "8.14.2" }, "engines": { "node": ">=18" } }, "node_modules/cspell-lib": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/cspell-lib/-/cspell-lib-8.16.0.tgz", - "integrity": "sha512-fU8CfECyuhT12COIi4ViQu2bTkdqaa+05YSd2ZV8k8NA7lapPaMFnlooxdfcwwgZJfHeMhRVMzvQF1OhWmwGfA==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/cspell-lib/-/cspell-lib-8.14.2.tgz", + "integrity": "sha512-d2oiIXHXnADmnhIuFLOdNE63L7OUfzgpLbYaqAWbkImCUDkevfGrOgnX8TJ03fUgZID4nvQ+3kgu/n2j4eLZjQ==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/cspell-bundled-dicts": "8.16.0", - "@cspell/cspell-pipe": "8.16.0", - "@cspell/cspell-resolver": "8.16.0", - "@cspell/cspell-types": "8.16.0", - "@cspell/dynamic-import": "8.16.0", - "@cspell/filetypes": "8.16.0", - "@cspell/strong-weak-map": "8.16.0", - "@cspell/url": "8.16.0", + "@cspell/cspell-bundled-dicts": "8.14.2", + "@cspell/cspell-pipe": "8.14.2", + "@cspell/cspell-resolver": "8.14.2", + "@cspell/cspell-types": "8.14.2", + "@cspell/dynamic-import": "8.14.2", + "@cspell/filetypes": "8.14.2", + "@cspell/strong-weak-map": "8.14.2", + "@cspell/url": "8.14.2", "clear-module": "^4.1.2", "comment-json": "^4.2.5", - "cspell-config-lib": "8.16.0", - "cspell-dictionary": "8.16.0", - "cspell-glob": "8.16.0", - "cspell-grammar": "8.16.0", - "cspell-io": "8.16.0", - "cspell-trie-lib": "8.16.0", + "cspell-config-lib": "8.14.2", + "cspell-dictionary": "8.14.2", + "cspell-glob": "8.14.2", + "cspell-grammar": "8.14.2", + "cspell-io": "8.14.2", + "cspell-trie-lib": "8.14.2", "env-paths": "^3.0.0", "fast-equals": "^5.0.1", "gensequence": "^7.0.0", @@ -3568,14 +3538,14 @@ } }, "node_modules/cspell-trie-lib": { - "version": "8.16.0", - "resolved": "https://registry.npmjs.org/cspell-trie-lib/-/cspell-trie-lib-8.16.0.tgz", - "integrity": "sha512-Io1qqI0r4U9ewAWBLClFBBlxLeAoIi15PUGJi4Za1xrlgQJwRE8PMNIJNHKmPEIp78Iute3o/JyC2OfWlxl4Sw==", + "version": "8.14.2", + "resolved": "https://registry.npmjs.org/cspell-trie-lib/-/cspell-trie-lib-8.14.2.tgz", + "integrity": "sha512-rZMbaEBGoyy4/zxKECaMyVyGLbuUxYmZ5jlEgiA3xPtEdWwJ4iWRTo5G6dWbQsXoxPYdAXXZ0/q0GQ2y6Jt0kw==", "dev": true, "license": "MIT", "dependencies": { - "@cspell/cspell-pipe": "8.16.0", - "@cspell/cspell-types": "8.16.0", + "@cspell/cspell-pipe": "8.14.2", + "@cspell/cspell-types": "8.14.2", "gensequence": "^7.0.0" }, "engines": { @@ -7572,9 +7542,9 @@ } }, "node_modules/tslib": { - "version": "2.8.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz", - "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==", + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.7.0.tgz", + "integrity": "sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA==", "license": "0BSD" }, "node_modules/tsutils": { @@ -7888,9 +7858,9 @@ "peer": true }, "node_modules/webpack": { - "version": "5.96.1", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.96.1.tgz", - "integrity": "sha512-l2LlBSvVZGhL4ZrPwyr8+37AunkcYj5qh8o6u2/2rzoPc8gxFJkLj1WxNgooi9pnoc06jh0BjuXnamM4qlujZA==", + "version": "5.94.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.94.0.tgz", + "integrity": "sha512-KcsGn50VT+06JH/iunZJedYGUJS5FGjow8wb9c0v5n1Om8O1g4L6LjtfxwlXIATopoQu+vOXXa7gYisWxCoPyg==", "dev": true, "license": "MIT", "peer": true, diff --git a/src/circuits/auth-v2.ts b/src/circuits/auth-v2.ts index 8396a05d..b2219d79 100644 --- a/src/circuits/auth-v2.ts +++ b/src/circuits/auth-v2.ts @@ -1,7 +1,13 @@ import { Hash, Proof } from '@iden3/js-merkletree'; import { Claim, Id } from '@iden3/js-iden3-core'; import { CircuitError, GISTProof, TreeState } from './models'; -import { BaseConfig, getNodeAuxValue, prepareSiblingsStr } from './common'; +import { + BaseConfig, + getNodeAuxValue, + IStateInfoPubSignals, + prepareSiblingsStr, + StatesInfo +} from './common'; import { Signature } from '@iden3/js-crypto'; import { byteDecoder, byteEncoder } from '../utils'; @@ -117,7 +123,7 @@ interface AuthV2CircuitInputs { * @public * @class AuthV2PubSignals */ -export class AuthV2PubSignals { +export class AuthV2PubSignals implements IStateInfoPubSignals { userID!: Id; challenge!: bigint; GISTRoot!: Hash; @@ -143,4 +149,11 @@ export class AuthV2PubSignals { this.GISTRoot = Hash.fromString(sVals[2]); return this; } + + getStatesInfo(): StatesInfo { + return { + states: [], + gists: [{ id: this.userID, root: this.GISTRoot }] + }; + } } diff --git a/src/iden3comm/handlers/contract-request.ts b/src/iden3comm/handlers/contract-request.ts index bb055320..8779a6ac 100644 --- a/src/iden3comm/handlers/contract-request.ts +++ b/src/iden3comm/handlers/contract-request.ts @@ -12,7 +12,6 @@ import { BasicHandlerOptions, IProtocolMessageHandler } from './message-handler'; - /** * Interface that allows the processing of the contract request * @@ -69,6 +68,7 @@ export class ContractRequestHandler implements IContractRequestHandler, IProtocolMessageHandler { private readonly _supportedCircuits = [ + CircuitId.AuthV2, CircuitId.AtomicQueryMTPV2OnChain, CircuitId.AtomicQuerySigV2OnChain, CircuitId.AtomicQueryV3OnChain @@ -125,12 +125,19 @@ export class ContractRequestHandler throw new Error(`Invalid chain id ${chain_id}`); } const verifierDid = message.from ? DID.parse(message.from) : undefined; + + const { scope = [] } = message.body; + const zkpResponses = await processZeroKnowledgeProofRequests( did, - message?.body?.scope, + scope, verifierDid, this._proofService, - { ethSigner, challenge, supportedCircuits: this._supportedCircuits } + { + ethSigner, + challenge, + supportedCircuits: this._supportedCircuits + } ); const methodId = message.body.transaction_data.method_id.replace('0x', ''); diff --git a/src/iden3comm/utils/contract-request.utils.ts b/src/iden3comm/utils/contract-request.utils.ts new file mode 100644 index 00000000..179926b0 --- /dev/null +++ b/src/iden3comm/utils/contract-request.utils.ts @@ -0,0 +1,66 @@ +import { keccak256 } from 'ethers'; +import { byteEncoder, hexToBytes, isEthereumIdentity } from '../../utils'; +import { CircuitId } from '../../circuits'; +import { Hex } from '@iden3/js-crypto'; +import { DID } from '@iden3/js-iden3-core'; +import { IProofService } from '../../proof'; +import { ZeroKnowledgeProofResponse } from '../types'; + +/** + * @beta + * Retrieves the request ID from circuit string. + * CircuitId.AuthV2 - 940499666 + * @returns The request ID. + */ +export function calculateRequestIdForCircuit(circuitId: CircuitId): number { + const circuitHash = keccak256(byteEncoder.encode(circuitId)); + const dataView = new DataView(Hex.decodeString(circuitHash.replace('0x', '')).buffer); + const id = dataView.getUint32(0); + return id; +} + +/** + * Prepares the zero-knowledge proof response for the AuthV2 circuit. + * @beta + * @param address - The address associated with the request. + * @param senderDid - The sender's decentralized identifier (DID). + * @param proofService - The proof service used to generate the proof. + * @returns A promise that resolves to an array of ZeroKnowledgeProofResponse objects. + */ +export async function prepareAuthV2ZeroKnowledgeResponse( + address: string, + senderDid: DID, + proofService: IProofService +): Promise { + const circuitId = CircuitId.AuthV2; + + // this is now hardcoded calculated value for 'authV2' that can be changed in the future. + const id = 940499666; + + if (isEthereumIdentity(senderDid)) { + return [ + { + circuitId, + id, + pub_signals: [], + proof: { + pi_a: [], + pi_b: [], + pi_c: [], + protocol: 'groth16' + } + } + ]; + } + const hash = Uint8Array.from([...hexToBytes(address), ...new Uint8Array(12)]).reverse(); + const { proof, pub_signals } = await proofService.generateAuthV2Proof(hash, senderDid); + + return [ + { + circuitId, + id, + pub_signals, + proof + } + ]; +} diff --git a/src/iden3comm/utils/index.ts b/src/iden3comm/utils/index.ts index 68f7ae88..a4006873 100644 --- a/src/iden3comm/utils/index.ts +++ b/src/iden3comm/utils/index.ts @@ -1,4 +1,5 @@ export * from './envelope'; export * from './message'; export * from './did'; +export * from './contract-request.utils'; export * from './accept-profile'; diff --git a/src/proof/proof-service.ts b/src/proof/proof-service.ts index 02719bd1..8d81bbad 100644 --- a/src/proof/proof-service.ts +++ b/src/proof/proof-service.ts @@ -131,6 +131,15 @@ export interface IProofService { */ generateAuthV2Inputs(hash: Uint8Array, did: DID, circuitId: CircuitId): Promise; + /** + * generates auth inputs + * + * @param {Uint8Array} hash - challenge that will be signed + * @param {DID} did - identity that will generate a proof + * @returns `Promise` + */ + generateAuthV2Proof(hash: Uint8Array, did: DID): Promise; + /** * state verification function * @@ -488,6 +497,14 @@ export class ProofService implements IProofService { return authInputs.inputsMarshal(); } + /** {@inheritdoc IProofService.generateAuthV2Proof} */ + async generateAuthV2Proof(challenge: Uint8Array, did: DID): Promise { + const authInputs = await this.generateAuthV2Inputs(challenge, did, CircuitId.AuthV2); + + const zkProof = await this._prover.generate(authInputs, CircuitId.AuthV2); + return zkProof; + } + async verifyState( circuitId: string, pubSignals: string[], diff --git a/src/storage/blockchain/onchain-zkp-verifier.ts b/src/storage/blockchain/onchain-zkp-verifier.ts index 271901aa..6c7df6cd 100644 --- a/src/storage/blockchain/onchain-zkp-verifier.ts +++ b/src/storage/blockchain/onchain-zkp-verifier.ts @@ -8,11 +8,12 @@ import { } from '../../iden3comm'; import abi from './abi/ZkpVerifier.json'; import { TransactionService } from '../../blockchain'; -import { DID } from '@iden3/js-iden3-core'; +import { chainIDfromDID, DID, Id } from '@iden3/js-iden3-core'; import { AtomicQueryMTPV2OnChainPubSignals, AtomicQuerySigV2OnChainPubSignals, AtomicQueryV3OnChainPubSignals, + AuthV2PubSignals, CircuitId, StatesInfo } from '../../circuits'; @@ -43,6 +44,12 @@ export type OnChainZKPVerifierOptions = { didResolverUrl?: string; }; +type OnChainZKPVerifierCircuitId = + | CircuitId.AuthV2 + | CircuitId.AtomicQueryMTPV2OnChain + | CircuitId.AtomicQuerySigV2OnChain + | CircuitId.AtomicQueryV3OnChain; + /** * OnChainZKPVerifier is a class that allows to interact with the OnChainZKPVerifier contract * and submitZKPResponse. @@ -54,12 +61,20 @@ export class OnChainZKPVerifier implements IOnChainZKPVerifier { /** * supported circuits */ - private static readonly _supportedCircuits = [ + private static readonly _supportedCircuits: OnChainZKPVerifierCircuitId[] = [ + CircuitId.AuthV2, CircuitId.AtomicQueryMTPV2OnChain, CircuitId.AtomicQuerySigV2OnChain, CircuitId.AtomicQueryV3OnChain ]; + private static readonly _supportedCircuitsPubSignalsMap = { + [CircuitId.AtomicQueryMTPV2OnChain]: AtomicQueryMTPV2OnChainPubSignals, + [CircuitId.AtomicQuerySigV2OnChain]: AtomicQuerySigV2OnChainPubSignals, + [CircuitId.AtomicQueryV3OnChain]: AtomicQueryV3OnChainPubSignals, + [CircuitId.AuthV2]: AuthV2PubSignals + }; + /** * * Creates an instance of OnChainZKPVerifier. @@ -221,6 +236,44 @@ export class OnChainZKPVerifier implements IOnChainZKPVerifier { return new Map().set(txnHash, zkProofResponses); } + private static getCrossChainResolvers( + source: { + id: Id; + root?: Hash; + state?: Hash; + }[], + txDataChainId: number, + type: 'gist' | 'state', + didResolverUrl: string + ) { + return [ + ...new Set( + source.map((info) => + JSON.stringify({ + id: info.id.string(), + [type]: type === 'gist' ? info.root?.string() : info.state?.string() + }) + ) + ) + ].reduce((acc: Promise[], s: string) => { + const info = JSON.parse(s); + const id = Id.fromString(info.id); + const chainId = chainIDfromDID(DID.parseFromId(id)); + + if (txDataChainId === chainId) { + return acc; + } + const promise = this.resolveDidDocumentEip712MessageAndSignature( + DID.parseFromId(Id.fromString(info.id)), + didResolverUrl, + { + [type]: Hash.fromString(info[type]) + } + ); + return [...acc, promise]; + }, []); + } + public static async prepareTxArgsSubmitV2( resolverUrl: string, txData: ContractInvokeTransactionData, @@ -231,21 +284,29 @@ export class OnChainZKPVerifier implements IOnChainZKPVerifier { `submit cross chain doesn't implement requested method id. Only '0x${FunctionSignatures.SubmitZKPResponseV2}' is supported.` ); } - const gistUpdateArr = []; - const stateUpdateArr = []; + + const gistUpdates = []; + const stateUpdates = []; const payload = []; - // Resolved gists and states to avoid duplicate requests - const gistUpdateResolutionsPending: string[] = []; - const stateUpdateResolutionsPending: string[] = []; + const emptyBytes = '0x'; for (const zkProof of zkProofResponses) { - const requestID = zkProof.id; - const inputs = zkProof.pub_signals; + const { id: requestId, pub_signals: inputs } = zkProof; + const proofCircuitId = zkProof.circuitId as OnChainZKPVerifierCircuitId; - if (!this._supportedCircuits.includes(zkProof.circuitId as CircuitId)) { + if (!this._supportedCircuits.includes(proofCircuitId)) { throw new Error(`Circuit ${zkProof.circuitId} not supported by OnChainZKPVerifier`); } + if (inputs.length === 0) { + payload.push({ + requestId: requestId, + zkProof: emptyBytes, + data: emptyBytes + }); + continue; + } + const zkProofEncoded = this.packZkpProof( inputs, zkProof.proof.pi_a.slice(0, 2), @@ -256,55 +317,28 @@ export class OnChainZKPVerifier implements IOnChainZKPVerifier { zkProof.proof.pi_c.slice(0, 2) ); - const stateInfo = this.getOnChainGistRootStatePubSignals( - zkProof.circuitId as - | CircuitId.AtomicQueryMTPV2OnChain - | CircuitId.AtomicQuerySigV2OnChain - | CircuitId.AtomicQueryV3OnChain, - zkProof.pub_signals - ); - - const gistUpdateResolutions = []; - for (const gist of stateInfo.gists) { - const gistResolutionPending = gistUpdateResolutionsPending.find( - (g) => g == JSON.stringify(gist) - ); - - if (gistResolutionPending) { - continue; - } - gistUpdateResolutionsPending.push(JSON.stringify(gist)); - - gistUpdateResolutions.push( - this.resolveDidDocumentEip712MessageAndSignature(DID.parseFromId(gist.id), resolverUrl, { - gist: gist.root - }) - ); - } + const stateInfo = this.getOnChainGistRootStatePubSignals(proofCircuitId, inputs); - const stateUpdateResolutions = []; - for (const state of stateInfo.states) { - const stateResolutionPending = stateUpdateResolutionsPending.find( - (s) => s == JSON.stringify(state) - ); - - if (stateResolutionPending) { - continue; - } - stateUpdateResolutionsPending.push(JSON.stringify(state)); + const chainId = txData.chain_id; + const gistUpdateResolutions = this.getCrossChainResolvers( + stateInfo.gists, + chainId, + 'gist', + resolverUrl + ); - stateUpdateResolutions.push( - this.resolveDidDocumentEip712MessageAndSignature(DID.parseFromId(state.id), resolverUrl, { - state: state.state - }) - ); - } + const stateUpdateResolutions = this.getCrossChainResolvers( + stateInfo.states, + chainId, + 'state', + resolverUrl + ); if (gistUpdateResolutions.length > 0) { - gistUpdateArr.push(...((await Promise.all(gistUpdateResolutions)) as GlobalStateUpdate[])); + gistUpdates.push(...((await Promise.all(gistUpdateResolutions)) as GlobalStateUpdate[])); } if (stateUpdateResolutions.length > 0) { - stateUpdateArr.push( + stateUpdates.push( ...((await Promise.all(stateUpdateResolutions)) as IdentityStateUpdate[]) ); } @@ -328,15 +362,18 @@ export class OnChainZKPVerifier implements IOnChainZKPVerifier { } } - const metadata = metadataArr.length ? this.packMetadatas(metadataArr) : '0x'; + const metadata = metadataArr.length ? this.packMetadatas(metadataArr) : emptyBytes; payload.push({ - requestId: requestID, + requestId: requestId, zkProof: zkProofEncoded, data: metadata }); } - const crossChainProofs = this.packCrossChainProofs(gistUpdateArr, stateUpdateArr); + const crossChainProofs = + gistUpdates.length || stateUpdates.length + ? this.packCrossChainProofs(gistUpdates, stateUpdates) + : emptyBytes; return [payload, crossChainProofs]; } @@ -431,24 +468,14 @@ export class OnChainZKPVerifier implements IOnChainZKPVerifier { } private static getOnChainGistRootStatePubSignals( - onChainCircuitId: - | CircuitId.AtomicQueryMTPV2OnChain - | CircuitId.AtomicQuerySigV2OnChain - | CircuitId.AtomicQueryV3OnChain, + onChainCircuitId: OnChainZKPVerifierCircuitId, inputs: string[] ): StatesInfo { - let atomicQueryPubSignals; - switch (onChainCircuitId) { - case CircuitId.AtomicQueryMTPV2OnChain: - atomicQueryPubSignals = new AtomicQueryMTPV2OnChainPubSignals(); - break; - case CircuitId.AtomicQuerySigV2OnChain: - atomicQueryPubSignals = new AtomicQuerySigV2OnChainPubSignals(); - break; - case CircuitId.AtomicQueryV3OnChain: - atomicQueryPubSignals = new AtomicQueryV3OnChainPubSignals(); - break; + const PubSignals = this._supportedCircuitsPubSignalsMap[onChainCircuitId]; + if (!PubSignals) { + throw new Error(`Circuit ${onChainCircuitId} not supported by OnChainZKPVerifier`); } + const atomicQueryPubSignals = new PubSignals(); const encodedInputs = byteEncoder.encode(JSON.stringify(inputs)); atomicQueryPubSignals.pubSignalsUnmarshal(encodedInputs); return atomicQueryPubSignals.getStatesInfo(); diff --git a/src/utils/did-helper.ts b/src/utils/did-helper.ts index 132a5030..f4561e1d 100644 --- a/src/utils/did-helper.ts +++ b/src/utils/did-helper.ts @@ -134,10 +134,13 @@ export const resolveDidDocument = async ( if (opts?.gist) { url += `${url.includes('?') ? '&' : '?'}gist=${opts.gist.hex()}`; } - const resp = await fetch(url); - const data = await resp.json(); - - return data; + try { + const resp = await fetch(url); + const data = await resp.json(); + return data; + } catch (e) { + throw new Error(`Failed to resolve DID document for ${did} ${e}`); + } }; export const buildDIDFromEthPubKey = (didType: Uint8Array, pubKeyEth: string): DID => { diff --git a/tests/handlers/contract-request.test.ts b/tests/handlers/contract-request.test.ts index b968a2c8..9e4aec79 100644 --- a/tests/handlers/contract-request.test.ts +++ b/tests/handlers/contract-request.test.ts @@ -10,7 +10,8 @@ import { EthStateStorage, OnChainZKPVerifier, defaultEthConnectionConfig, - hexToBytes + hexToBytes, + FunctionSignatures } from '../../src'; import { IDataStorage, IStateStorage, IOnChainZKPVerifier } from '../../src/storage/interfaces'; import { InMemoryDataSource, InMemoryMerkleTreeStorage } from '../../src/storage/memory'; @@ -55,7 +56,13 @@ import { expect } from 'chai'; import { CredentialStatusResolverRegistry } from '../../src/credentials'; import { RHSResolver } from '../../src/credentials'; import { ethers, JsonRpcProvider, Signer } from 'ethers'; -import { registerKeyProvidersInMemoryKMS, RPC_URL } from '../helpers'; +import { + createIdentity, + getInMemoryDataStorage, + registerKeyProvidersInMemoryKMS, + RPC_URL, + SEED_USER +} from '../helpers'; import { AbstractMessageHandler } from '../../src/iden3comm/handlers/message-handler'; describe('contract-request', () => { @@ -746,49 +753,58 @@ describe('contract-request', () => { // cross chain integration test it.skip('cross chain contract request flow - integration test', async () => { - const privadoTestRpcUrl = '< >'; - const privadoMainRpcUrl = '< >'; - const amoyRpcUrl = '< >'; - const amoyStateContract = '< >'; - const privadoStateContract = '< >'; - const lineaSepoliaRpc = '< >'; - const erc20Verifier = '0xcfe3f46048cb9dAa40c90fd574F6E1deB534b9e7'; - - const issuerAmoyStateEthConfig = { - ...defaultEthConnectionConfig, - url: amoyRpcUrl, - contractAddress: amoyStateContract, - chainId: 80002 + const CONTRACTS = { + AMOY_STATE_CONTRACT: '0x1a4cC30f2aA0377b0c3bc9848766D90cb4404124', + AMOY_UNIVERSAL_VERIFIER: '0x1Df0B05F15b5ea9648B8a081aca8ad0dE065bD1F', + PRIVADO_STATE_CONTRACT: '0x975556428F077dB5877Ea2474D783D6C69233742', + AUTH_V2_AMOY_VALIDATOR: '0x1a593E1aD3843b4363Dfa42585c4bBCA885553c0' }; - const issuerStateEthConfig = { - ...defaultEthConnectionConfig, - url: privadoTestRpcUrl, - contractAddress: privadoStateContract, - chainId: 21001 + const networkConfigs = { + amoy: (contractAddress) => ({ + ...defaultEthConnectionConfig, + url: '<>', + contractAddress, + chainId: 80002 + }), + privadoMain: (contractAddress) => ({ + ...defaultEthConnectionConfig, + url: '<>', + contractAddress, + chainId: 21000 + }), + privadoTest: (contractAddress) => ({ + ...defaultEthConnectionConfig, + url: 'https://rpc-testnet.privado.id', + contractAddress, + chainId: 21001 + }), + lineaSepolia: (contractAddress) => ({ + ...defaultEthConnectionConfig, + url: '<>', + contractAddress, + chainId: 80001 + }) }; - const userStateEthConfig = { - ...defaultEthConnectionConfig, - url: privadoMainRpcUrl, - contractAddress: privadoStateContract, - chainId: 21000 - }; + const issuerAmoyStateEthConfig = networkConfigs.amoy(CONTRACTS.AMOY_STATE_CONTRACT); + + const issuerPrivadoTestStateEthConfig = networkConfigs.privadoTest( + CONTRACTS.PRIVADO_STATE_CONTRACT + ); + + // const userStateEthConfig = networkConfigs.amoy(CONTRACTS.AMOY_STATE_CONTRACT); + const userStateEthConfig = networkConfigs.privadoMain(CONTRACTS.PRIVADO_STATE_CONTRACT); const kms = registerKeyProvidersInMemoryKMS(); - dataStorage = { - credential: new CredentialStorage(new InMemoryDataSource()), - identity: new IdentityStorage( - new InMemoryDataSource(), - new InMemoryDataSource() - ), - mt: new InMemoryMerkleTreeStorage(40), - states: new EthStateStorage([ + dataStorage = getInMemoryDataStorage( + new EthStateStorage([ issuerAmoyStateEthConfig, userStateEthConfig, - issuerStateEthConfig + issuerPrivadoTestStateEthConfig ]) - }; + ); + const circuitStorage = new FSCircuitStorage({ dirname: path.join(__dirname, '../proofs/testdata') }); @@ -810,29 +826,13 @@ describe('contract-request', () => { proofService.verifyState.bind(proofService) ); - const { did: userDID, credential: cred } = await idWallet.createIdentity({ - method: DidMethod.Iden3, + const { did: userDID } = await createIdentity(idWallet, { + seed: SEED_USER, blockchain: Blockchain.Privado, - networkId: NetworkId.Main, - seed: seedPhrase, - revocationOpts: { - type: CredentialStatusType.Iden3ReverseSparseMerkleTreeProof, - id: rhsUrl - } + networkId: NetworkId.Main }); - expect(cred).not.to.be.undefined; - - const { did: issuerDID, credential: issuerAuthCredential } = await idWallet.createIdentity({ - method: DidMethod.Iden3, - blockchain: Blockchain.Polygon, - networkId: NetworkId.Amoy, - seed: seedPhraseIssuer, - revocationOpts: { - type: CredentialStatusType.Iden3ReverseSparseMerkleTreeProof, - id: rhsUrl - } - }); + const { did: issuerDID, credential: issuerAuthCredential } = await createIdentity(idWallet); expect(issuerAuthCredential).not.to.be.undefined; const claimReq: CredentialRequest = { @@ -854,6 +854,8 @@ describe('contract-request', () => { await credWallet.save(issuerCred); + // ADD proofReq to scope + // eslint-disable-next-line @typescript-eslint/no-unused-vars const proofReqs: ZeroKnowledgeProofRequest[] = [ { id: 138, @@ -874,28 +876,24 @@ describe('contract-request', () => { } ]; - const conf = { - ...defaultEthConnectionConfig, - contractAddress: erc20Verifier, - url: lineaSepoliaRpc, - chainId: 59141 - }; + const zkpVerifierNetworkConfig = networkConfigs.amoy(CONTRACTS.AMOY_UNIVERSAL_VERIFIER); - const zkpVerifier = new OnChainZKPVerifier([conf], { + const zkpVerifier = new OnChainZKPVerifier([zkpVerifierNetworkConfig], { didResolverUrl: 'https://resolver-dev.privado.id' }); + contractRequestHandler = new ContractRequestHandler(packageMgr, proofService, zkpVerifier); const transactionData: ContractInvokeTransactionData = { - contract_address: erc20Verifier, - method_id: 'ade09fcd', - chain_id: conf.chainId + contract_address: zkpVerifierNetworkConfig.contractAddress, + method_id: FunctionSignatures.SubmitZKPResponseV2, + chain_id: zkpVerifierNetworkConfig.chainId }; const ciRequestBody: ContractInvokeRequestBody = { reason: 'reason', transaction_data: transactionData, - scope: [...proofReqs] + scope: proofReqs }; const id = uuid.v4();