diff --git a/package-lock.json b/package-lock.json index 658431b04..eaa47ab1a 100644 --- a/package-lock.json +++ b/package-lock.json @@ -72,6 +72,30 @@ "node": ">=6.0.0" } }, + "node_modules/@aurowallet/mina-provider": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@aurowallet/mina-provider/-/mina-provider-1.0.2.tgz", + "integrity": "sha512-zzQtY5MZ5gpSexyFIDxTvfnjDVu09bmOF2Pqb/+3wCZ74HU4D8XQcASbd9NrUI52SIXQl10iWgm8F3/xZLKkKA==", + "dependencies": { + "@types/eventemitter3": "^2.0.2", + "@types/uuid": "^8.3.1", + "eventemitter3": "^4.0.7", + "uuid": "^8.3.2" + } + }, + "node_modules/@aurowallet/mina-provider/node_modules/eventemitter3": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", + "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==" + }, + "node_modules/@aurowallet/mina-provider/node_modules/uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", + "bin": { + "uuid": "dist/bin/uuid" + } + }, "node_modules/@babel/code-frame": { "version": "7.24.2", "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.2.tgz", @@ -86,27 +110,27 @@ } }, "node_modules/@babel/compat-data": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.24.1.tgz", - "integrity": "sha512-Pc65opHDliVpRHuKfzI+gSA4zcgr65O4cl64fFJIWEEh8JoHIHh0Oez1Eo8Arz8zq/JhgKodQaxEwUPRtZylVA==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.24.4.tgz", + "integrity": "sha512-vg8Gih2MLK+kOkHJp4gBEIkyaIi00jgWot2D9QOmmfLC8jINSOzmCLta6Bvz/JSBCqnegV0L80jhxkol5GWNfQ==", "dev": true, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/core": { - "version": "7.24.3", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.3.tgz", - "integrity": "sha512-5FcvN1JHw2sHJChotgx8Ek0lyuh4kCKelgMTTqhYJJtloNvUfpAFMeNQUtdlIaktwrSV9LtCdqwk48wL2wBacQ==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.4.tgz", + "integrity": "sha512-MBVlMXP+kkl5394RBLSxxk/iLTeVGuXTV3cIDXavPpMMqnSnt6apKgan/U8O3USWZCWZT/TbgfEpKa4uMgN4Dg==", "dev": true, "dependencies": { "@ampproject/remapping": "^2.2.0", "@babel/code-frame": "^7.24.2", - "@babel/generator": "^7.24.1", + "@babel/generator": "^7.24.4", "@babel/helper-compilation-targets": "^7.23.6", "@babel/helper-module-transforms": "^7.23.3", - "@babel/helpers": "^7.24.1", - "@babel/parser": "^7.24.1", + "@babel/helpers": "^7.24.4", + "@babel/parser": "^7.24.4", "@babel/template": "^7.24.0", "@babel/traverse": "^7.24.1", "@babel/types": "^7.24.0", @@ -134,9 +158,9 @@ } }, "node_modules/@babel/generator": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.24.1.tgz", - "integrity": "sha512-DfCRfZsBcrPEHUfuBMgbJ1Ut01Y/itOs+hY2nFLgqsqXd52/iSiVq5TITtUasIUgm+IIKdY2/1I7auiQOEeC9A==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.24.4.tgz", + "integrity": "sha512-Xd6+v6SnjWVx/nus+y0l1sxMOTOMBkyL4+BIdbALyatQnAe/SRVjANeDPSCYaX+i1iJmuGSKf3Z+E+V/va1Hvw==", "dev": true, "dependencies": { "@babel/types": "^7.24.0", @@ -198,9 +222,9 @@ } }, "node_modules/@babel/helper-create-class-features-plugin": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.1.tgz", - "integrity": "sha512-1yJa9dX9g//V6fDebXoEfEsxkZHk3Hcbm+zLhyu6qVgYFLvmTALTeV+jNU9e5RnYtioBrGEOdoI2joMSNQ/+aA==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.4.tgz", + "integrity": "sha512-lG75yeuUSVu0pIcbhiYMXBXANHrpUPaOfu7ryAzskCgKUHuAxRQI5ssrtmF0X9UXldPlvT0XM/A4F44OXRt6iQ==", "dev": true, "dependencies": { "@babel/helper-annotate-as-pure": "^7.22.5", @@ -256,9 +280,9 @@ } }, "node_modules/@babel/helper-define-polyfill-provider": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.6.1.tgz", - "integrity": "sha512-o7SDgTJuvx5vLKD6SFvkydkSMBvahDKGiNJzG22IZYXhiqoe9efY7zocICBgzHV4IRg5wdgl2nEL/tulKIEIbA==", + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.6.2.tgz", + "integrity": "sha512-LV76g+C502biUK6AyZ3LK10vDpDyCzZnhZFXkH1L75zHPj68+qc8Zfpx2th+gzwA2MzyK+1g/3EPl62yFnVttQ==", "dev": true, "dependencies": { "@babel/helper-compilation-targets": "^7.22.6", @@ -481,9 +505,9 @@ } }, "node_modules/@babel/helpers": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.1.tgz", - "integrity": "sha512-BpU09QqEe6ZCHuIHFphEFgvNSrubve1FtyMton26ekZ85gRGi6LrTF7zArARp2YvyFxloeiRmtSCq5sjh1WqIg==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.4.tgz", + "integrity": "sha512-FewdlZbSiwaVGlgT1DPANDuCHaDMiOo+D/IDYRFYjHOuv66xMSJ7fQwwODwRNAPkADIO/z1EoF/l2BCWlWABDw==", "dev": true, "dependencies": { "@babel/template": "^7.24.0", @@ -581,9 +605,9 @@ } }, "node_modules/@babel/parser": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.1.tgz", - "integrity": "sha512-Zo9c7N3xdOIQrNip7Lc9wvRPzlRtovHVE4lkz8WEDr7uYh/GMQhSiIgFxGIArRHYdJE5kxtZjAf8rT0xhdLCzg==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.4.tgz", + "integrity": "sha512-zTvEBcghmeBma9QIGunWevvBAp4/Qu9Bdq+2k0Ot4fVMD6v3dsC9WOcRSKk7tRRyBM/53yKMJko9xOatGQAwSg==", "dev": true, "bin": { "parser": "bin/babel-parser.js" @@ -592,6 +616,22 @@ "node": ">=6.0.0" } }, + "node_modules/@babel/plugin-bugfix-firefox-class-in-computed-class-key": { + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-firefox-class-in-computed-class-key/-/plugin-bugfix-firefox-class-in-computed-class-key-7.24.4.tgz", + "integrity": "sha512-qpl6vOOEEzTLLcsuqYYo8yDtrTocmu2xkGvgNebvPjT9DTtfFYGmgDqY+rBYXNlqL4s9qLDn6xkrJv4RxAPiTA==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-plugin-utils": "^7.24.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { "version": "7.24.1", "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.24.1.tgz", @@ -1027,9 +1067,9 @@ } }, "node_modules/@babel/plugin-transform-block-scoping": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.24.1.tgz", - "integrity": "sha512-h71T2QQvDgM2SmT29UYU6ozjMlAt7s7CSs5Hvy8f8cf/GM/Z4a2zMfN+fjVGaieeCrXR3EdQl6C4gQG+OgmbKw==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.24.4.tgz", + "integrity": "sha512-nIFUZIpGKDf9O9ttyRXpHFpKC+X3Y5mtshZONuEUYBomAKoM4y029Jr+uB1bHGPhNmK8YXHevDtKDOLmtRrp6g==", "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.24.0" @@ -1058,12 +1098,12 @@ } }, "node_modules/@babel/plugin-transform-class-static-block": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.24.1.tgz", - "integrity": "sha512-FUHlKCn6J3ERiu8Dv+4eoz7w8+kFLSyeVG4vDAikwADGjUCoHw/JHokyGtr8OR4UjpwPVivyF+h8Q5iv/JmrtA==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.24.4.tgz", + "integrity": "sha512-B8q7Pz870Hz/q9UgP8InNpY01CSLDSCyqX7zcRuv3FcPl87A2G17lASroHWaCtbdIcbYzOZ7kWmXFKbijMSmFg==", "dev": true, "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.24.1", + "@babel/helper-create-class-features-plugin": "^7.24.4", "@babel/helper-plugin-utils": "^7.24.0", "@babel/plugin-syntax-class-static-block": "^7.14.5" }, @@ -1708,13 +1748,13 @@ } }, "node_modules/@babel/plugin-transform-typescript": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.24.1.tgz", - "integrity": "sha512-liYSESjX2fZ7JyBFkYG78nfvHlMKE6IpNdTVnxmlYUR+j5ZLsitFbaAE+eJSK2zPPkNWNw4mXL51rQ8WrvdK0w==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.24.4.tgz", + "integrity": "sha512-79t3CQ8+oBGk/80SQ8MN3Bs3obf83zJ0YZjDmDaEZN8MqhMI760apl5z6a20kFeMXBwJX99VpKT8CKxEBp5H1g==", "dev": true, "dependencies": { "@babel/helper-annotate-as-pure": "^7.22.5", - "@babel/helper-create-class-features-plugin": "^7.24.1", + "@babel/helper-create-class-features-plugin": "^7.24.4", "@babel/helper-plugin-utils": "^7.24.0", "@babel/plugin-syntax-typescript": "^7.24.1" }, @@ -1789,15 +1829,16 @@ } }, "node_modules/@babel/preset-env": { - "version": "7.24.3", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.24.3.tgz", - "integrity": "sha512-fSk430k5c2ff8536JcPvPWK4tZDwehWLGlBp0wrsBUjZVdeQV6lePbwKWZaZfK2vnh/1kQX1PzAJWsnBmVgGJA==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.24.4.tgz", + "integrity": "sha512-7Kl6cSmYkak0FK/FXjSEnLJ1N9T/WA2RkMhu17gZ/dsxKJUuTYNIylahPTzqpLyJN4WhDif8X0XK1R8Wsguo/A==", "dev": true, "dependencies": { - "@babel/compat-data": "^7.24.1", + "@babel/compat-data": "^7.24.4", "@babel/helper-compilation-targets": "^7.23.6", "@babel/helper-plugin-utils": "^7.24.0", "@babel/helper-validator-option": "^7.23.5", + "@babel/plugin-bugfix-firefox-class-in-computed-class-key": "^7.24.4", "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.24.1", "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.24.1", "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": "^7.24.1", @@ -1824,9 +1865,9 @@ "@babel/plugin-transform-async-generator-functions": "^7.24.3", "@babel/plugin-transform-async-to-generator": "^7.24.1", "@babel/plugin-transform-block-scoped-functions": "^7.24.1", - "@babel/plugin-transform-block-scoping": "^7.24.1", + "@babel/plugin-transform-block-scoping": "^7.24.4", "@babel/plugin-transform-class-properties": "^7.24.1", - "@babel/plugin-transform-class-static-block": "^7.24.1", + "@babel/plugin-transform-class-static-block": "^7.24.4", "@babel/plugin-transform-classes": "^7.24.1", "@babel/plugin-transform-computed-properties": "^7.24.1", "@babel/plugin-transform-destructuring": "^7.24.1", @@ -1931,9 +1972,9 @@ "dev": true }, "node_modules/@babel/runtime": { - "version": "7.24.1", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.1.tgz", - "integrity": "sha512-+BIznRzyqBf+2wCTxcKE3wDjfGeCoVE61KSHGpkzqrLi8qxqFwBeUFyId2cxkTmm55fzDGnm0+yCxaxygrLUnQ==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.4.tgz", + "integrity": "sha512-dkxf7+hn8mFBwKjs9bvBlArzLVxVbS8usaPUDd5p2a9JCL9tB8OaOVN1isD4+Xyk4ns89/xeOmbQvgdK7IIVdA==", "dependencies": { "regenerator-runtime": "^0.14.0" }, @@ -2052,6 +2093,14 @@ "axios": "^0.27.2" } }, + "node_modules/@discoveryjs/json-ext": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz", + "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==", + "engines": { + "node": ">=10.0.0" + } + }, "node_modules/@effect/data": { "version": "0.17.1", "resolved": "https://registry.npmjs.org/@effect/data/-/data-0.17.1.tgz", @@ -3413,9 +3462,9 @@ "integrity": "sha512-w+lKW+yRrLhJu620jT3y+5g2mHqnKfepreykvdOcl9/6up8GrQQn+l3FRTsjHTKbkbfQFkuksHpdv2EcpKcJ4Q==" }, "node_modules/@hapi/hapi": { - "version": "21.3.7", - "resolved": "https://registry.npmjs.org/@hapi/hapi/-/hapi-21.3.7.tgz", - "integrity": "sha512-33J0nreMfqkhY7wwRAZRy+9J+7J4QOH1JtICMjIUmxfaOYSJL/d8JJCtg57SX60944bhlCeu7isb7qyr2jT2oA==", + "version": "21.3.9", + "resolved": "https://registry.npmjs.org/@hapi/hapi/-/hapi-21.3.9.tgz", + "integrity": "sha512-AT5m+Rb8iSOFG3zWaiEuTJazf4HDYl5UpRpyxMJ3yR+g8tOEmqDv6FmXrLHShdvDOStAAepHGnr1G7egkFSRdw==", "dependencies": { "@hapi/accept": "^6.0.1", "@hapi/ammo": "^6.0.1", @@ -3590,9 +3639,9 @@ } }, "node_modules/@hapi/wreck": { - "version": "18.0.1", - "resolved": "https://registry.npmjs.org/@hapi/wreck/-/wreck-18.0.1.tgz", - "integrity": "sha512-OLHER70+rZxvDl75xq3xXOfd3e8XIvz8fWY0dqg92UvhZ29zo24vQgfqgHSYhB5ZiuFpSLeriOisAlxAo/1jWg==", + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@hapi/wreck/-/wreck-18.1.0.tgz", + "integrity": "sha512-0z6ZRCmFEfV/MQqkQomJ7sl/hyxvcZM7LtuVqN3vdAO4vM9eBbowl0kaqQj9EJJQab+3Uuh1GxbGIBFy4NfJ4w==", "dependencies": { "@hapi/boom": "^10.0.1", "@hapi/bourne": "^3.0.0", @@ -4053,7 +4102,6 @@ "version": "0.3.5", "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", - "dev": true, "dependencies": { "@jridgewell/set-array": "^1.2.1", "@jridgewell/sourcemap-codec": "^1.4.10", @@ -4067,7 +4115,6 @@ "version": "3.1.2", "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", - "dev": true, "engines": { "node": ">=6.0.0" } @@ -4076,22 +4123,28 @@ "version": "1.2.1", "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", - "dev": true, "engines": { "node": ">=6.0.0" } }, + "node_modules/@jridgewell/source-map": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.6.tgz", + "integrity": "sha512-1ZJTZebgqllO79ue2bm3rIGud/bOe0pP5BjSRCRxxYkEZS8STV7zN84UBbiYu7jy+eCKSnVIUgoWWE/tt+shMQ==", + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25" + } + }, "node_modules/@jridgewell/sourcemap-codec": { "version": "1.4.15", "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", - "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", - "dev": true + "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" }, "node_modules/@jridgewell/trace-mapping": { "version": "0.3.25", "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", - "dev": true, "dependencies": { "@jridgewell/resolve-uri": "^3.1.0", "@jridgewell/sourcemap-codec": "^1.4.14" @@ -4401,29 +4454,27 @@ } }, "node_modules/@nomicfoundation/edr": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr/-/edr-0.3.3.tgz", - "integrity": "sha512-zP+e+3B1nEUx6bW5BPnIzCQbkhmYfdMBJdiVggTqqTfAA82sOkdOG7wsOMcz5qF3fYfx/irNRM1kgc9HVFIbpQ==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr/-/edr-0.3.5.tgz", + "integrity": "sha512-dPSM9DuI1sr71gqWUMgLo8MjHQWO4+WNDm3iWaT6P4vUFJReZX5qwA5X+3UwIPBry8GvNY084u7yWUvB3/8rqA==", "dev": true, "engines": { "node": ">= 18" }, "optionalDependencies": { - "@nomicfoundation/edr-darwin-arm64": "0.3.3", - "@nomicfoundation/edr-darwin-x64": "0.3.3", - "@nomicfoundation/edr-linux-arm64-gnu": "0.3.3", - "@nomicfoundation/edr-linux-arm64-musl": "0.3.3", - "@nomicfoundation/edr-linux-x64-gnu": "0.3.3", - "@nomicfoundation/edr-linux-x64-musl": "0.3.3", - "@nomicfoundation/edr-win32-arm64-msvc": "0.3.3", - "@nomicfoundation/edr-win32-ia32-msvc": "0.3.3", - "@nomicfoundation/edr-win32-x64-msvc": "0.3.3" + "@nomicfoundation/edr-darwin-arm64": "0.3.5", + "@nomicfoundation/edr-darwin-x64": "0.3.5", + "@nomicfoundation/edr-linux-arm64-gnu": "0.3.5", + "@nomicfoundation/edr-linux-arm64-musl": "0.3.5", + "@nomicfoundation/edr-linux-x64-gnu": "0.3.5", + "@nomicfoundation/edr-linux-x64-musl": "0.3.5", + "@nomicfoundation/edr-win32-x64-msvc": "0.3.5" } }, "node_modules/@nomicfoundation/edr-darwin-arm64": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-darwin-arm64/-/edr-darwin-arm64-0.3.3.tgz", - "integrity": "sha512-E9VGsUD+1Ga4mn/5ooHsMi8JEfhZbKP6CXN/BhJ8kXbIC10NqTD1RuhCKGRtYq4vqH/3Nfq25Xg8E8RWOF4KBQ==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-darwin-arm64/-/edr-darwin-arm64-0.3.5.tgz", + "integrity": "sha512-gIXUIiPMUy6roLHpNlxf15DumU7/YhffUf7XIB+WUjMecaySfTGyZsTGnCMJZqrDyiYqWPyPKwCV/2u/jqFAUg==", "cpu": [ "arm64" ], @@ -4437,9 +4488,9 @@ } }, "node_modules/@nomicfoundation/edr-darwin-x64": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-darwin-x64/-/edr-darwin-x64-0.3.3.tgz", - "integrity": "sha512-vkZXZ1ydPg+Ijb2iyqENA+KCkxGTCUWG5itCSliiA0Li2YE7ujDMGhheEpFp1WVlZadviz0bfk1rZXbCqlirpg==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-darwin-x64/-/edr-darwin-x64-0.3.5.tgz", + "integrity": "sha512-0MrpOCXUK8gmplpYZ2Cy0holHEylvWoNeecFcrP2WJ5DLQzrB23U5JU2MvUzOJ7aL76Za1VXNBWi/UeTWdHM+w==", "cpu": [ "x64" ], @@ -4453,9 +4504,9 @@ } }, "node_modules/@nomicfoundation/edr-linux-arm64-gnu": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-arm64-gnu/-/edr-linux-arm64-gnu-0.3.3.tgz", - "integrity": "sha512-gdIg0Yj1qqS9wVuywc5B/+DqKylfUGB6/CQn/shMqwAfsAVAVpchkhy66PR+REEx7fh/GkNctxLlENXPeLzDiA==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-arm64-gnu/-/edr-linux-arm64-gnu-0.3.5.tgz", + "integrity": "sha512-aw9f7AZMiY1dZFNePJGKho2k+nEgFgzUAyyukiKfSqUIMXoFXMf1U3Ujv848czrSq9c5XGcdDa2xnEf3daU3xg==", "cpu": [ "arm64" ], @@ -4469,9 +4520,9 @@ } }, "node_modules/@nomicfoundation/edr-linux-arm64-musl": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-arm64-musl/-/edr-linux-arm64-musl-0.3.3.tgz", - "integrity": "sha512-AXZ08MFvhNeBZbOBNmz1SJ/DMrMOE2mHEJtaNnsctlxIunjxfrWww4q+WXB34jbr9iaVYYlPsaWe5sueuw6s3Q==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-arm64-musl/-/edr-linux-arm64-musl-0.3.5.tgz", + "integrity": "sha512-cVFRQjyABBlsbDj+XTczYBfrCHprZ6YNzN8gGGSqAh+UGIJkAIRomK6ar27GyJLNx3HkgbuDoi/9kA0zOo/95w==", "cpu": [ "arm64" ], @@ -4485,9 +4536,9 @@ } }, "node_modules/@nomicfoundation/edr-linux-x64-gnu": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-x64-gnu/-/edr-linux-x64-gnu-0.3.3.tgz", - "integrity": "sha512-xElOs1U+E6lBLtv1mnJ+E8nr2MxZgKiLo8bZAgBboy9odYtmkDVwhMjtsFKSuZbGxFtsSyGRT4cXw3JAbtUDeA==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-x64-gnu/-/edr-linux-x64-gnu-0.3.5.tgz", + "integrity": "sha512-CjOg85DfR1Vt0fQWn5U0qi26DATK9tVzo3YOZEyI0JBsnqvk43fUTPv3uUAWBrPIRg5O5kOc9xG13hSpCBBxBg==", "cpu": [ "x64" ], @@ -4501,9 +4552,9 @@ } }, "node_modules/@nomicfoundation/edr-linux-x64-musl": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-x64-musl/-/edr-linux-x64-musl-0.3.3.tgz", - "integrity": "sha512-2Fe6gwm1RAGQ/PfMYiaSba2OrFp8zzYWh+am9lYObOFjV9D+A1zhIzfy0UC74glPks5eV8eY4pBPrVR042m2Nw==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-linux-x64-musl/-/edr-linux-x64-musl-0.3.5.tgz", + "integrity": "sha512-hvX8bBGpBydAVevzK8jsu2FlqVZK1RrCyTX6wGHnltgMuBaoGLHYtNHiFpteOaJw2byYMiORc2bvj+98LhJ0Ew==", "cpu": [ "x64" ], @@ -4516,42 +4567,10 @@ "node": ">= 18" } }, - "node_modules/@nomicfoundation/edr-win32-arm64-msvc": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-win32-arm64-msvc/-/edr-win32-arm64-msvc-0.3.3.tgz", - "integrity": "sha512-8NHyxIsFrl0ufSQ/ErqF2lKIa/gz1gaaa1a2vKkDEqvqCUcPhBTYhA5NHgTPhLETFTnCFr0z+YbctFCyjh4qrA==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/edr-win32-ia32-msvc": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-win32-ia32-msvc/-/edr-win32-ia32-msvc-0.3.3.tgz", - "integrity": "sha512-0F6hM0kGia4dQVb/kauho9JcP1ozWisY2/She+ISR5ceuhzmAwQJluM0g+0TYDME0LtxBxiMPq/yPiZMQeq31w==", - "cpu": [ - "ia32" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">= 18" - } - }, "node_modules/@nomicfoundation/edr-win32-x64-msvc": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-win32-x64-msvc/-/edr-win32-x64-msvc-0.3.3.tgz", - "integrity": "sha512-d75q1uaMb6z9i+GQZoblbOfFBvlBnWc+5rB13UWRkCOJSnoYwyFWhGJx5GeM59gC7aIblc5VD9qOAhHuvM9N+w==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@nomicfoundation/edr-win32-x64-msvc/-/edr-win32-x64-msvc-0.3.5.tgz", + "integrity": "sha512-IJXjW13DY5UPsx/eG5DGfXtJ7Ydwrvw/BTZ2Y93lRLHzszVpSmeVmlxjZP5IW2afTSgMLaAAsqNw4NhppRGN8A==", "cpu": [ "x64" ], @@ -4831,9 +4850,9 @@ } }, "node_modules/@nomicfoundation/hardhat-verify": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/@nomicfoundation/hardhat-verify/-/hardhat-verify-2.0.5.tgz", - "integrity": "sha512-Tg4zu8RkWpyADSFIgF4FlJIUEI4VkxcvELsmbJn2OokbvH2SnUrqKmw0BBfDrtvP0hhmx8wsnrRKP5DV/oTyTA==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@nomicfoundation/hardhat-verify/-/hardhat-verify-2.0.6.tgz", + "integrity": "sha512-oKUI5fl8QC8jysE2LUBHE6rObzEmccJcc4b43Ov7LFMlCBZJE27qoqGIsg/++wX7L8Jdga+bkejPxl8NvsecpQ==", "dev": true, "peer": true, "dependencies": { @@ -5933,23 +5952,23 @@ "peer": true }, "node_modules/@polkadot/api": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/api/-/api-10.12.4.tgz", - "integrity": "sha512-bCWF1ciMqvy2XusHRk2AGKgOmod2dk/4WqQu43F8OSUXuazDOXeYJgJTv/oDznU6xQASW7awntp3JpSvsxviaA==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/api/-/api-10.13.1.tgz", + "integrity": "sha512-YrKWR4TQR5CDyGkF0mloEUo7OsUA+bdtENpJGOtNavzOQUDEbxFE0PVzokzZfVfHhHX2CojPVmtzmmLxztyJkg==", "peer": true, "dependencies": { - "@polkadot/api-augment": "10.12.4", - "@polkadot/api-base": "10.12.4", - "@polkadot/api-derive": "10.12.4", + "@polkadot/api-augment": "10.13.1", + "@polkadot/api-base": "10.13.1", + "@polkadot/api-derive": "10.13.1", "@polkadot/keyring": "^12.6.2", - "@polkadot/rpc-augment": "10.12.4", - "@polkadot/rpc-core": "10.12.4", - "@polkadot/rpc-provider": "10.12.4", - "@polkadot/types": "10.12.4", - "@polkadot/types-augment": "10.12.4", - "@polkadot/types-codec": "10.12.4", - "@polkadot/types-create": "10.12.4", - "@polkadot/types-known": "10.12.4", + "@polkadot/rpc-augment": "10.13.1", + "@polkadot/rpc-core": "10.13.1", + "@polkadot/rpc-provider": "10.13.1", + "@polkadot/types": "10.13.1", + "@polkadot/types-augment": "10.13.1", + "@polkadot/types-codec": "10.13.1", + "@polkadot/types-create": "10.13.1", + "@polkadot/types-known": "10.13.1", "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "eventemitter3": "^5.0.1", @@ -5961,16 +5980,16 @@ } }, "node_modules/@polkadot/api-augment": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/api-augment/-/api-augment-10.12.4.tgz", - "integrity": "sha512-ZKKeA8OnB1kkqBlvMhTw7QpPsRxpf/OE2UGhuCabQmU+MysYaWTPGssqAFEBqUZ+iyvTk83s+ssoMlXxdIhblA==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/api-augment/-/api-augment-10.13.1.tgz", + "integrity": "sha512-IAKaCp19QxgOG4HKk9RAgUgC/VNVqymZ2GXfMNOZWImZhxRIbrK+raH5vN2MbWwtVHpjxyXvGsd1RRhnohI33A==", "peer": true, "dependencies": { - "@polkadot/api-base": "10.12.4", - "@polkadot/rpc-augment": "10.12.4", - "@polkadot/types": "10.12.4", - "@polkadot/types-augment": "10.12.4", - "@polkadot/types-codec": "10.12.4", + "@polkadot/api-base": "10.13.1", + "@polkadot/rpc-augment": "10.13.1", + "@polkadot/types": "10.13.1", + "@polkadot/types-augment": "10.13.1", + "@polkadot/types-codec": "10.13.1", "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, @@ -6041,13 +6060,13 @@ "peer": true }, "node_modules/@polkadot/api-base": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/api-base/-/api-base-10.12.4.tgz", - "integrity": "sha512-e9s5rW9KgR+xs3sTI3B38KKQnd+D0WZ3PyNm66Q9aqIZDgDmpe9LIdmKfrqsX/rH74132Fq90mt3aN//DpwgBg==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/api-base/-/api-base-10.13.1.tgz", + "integrity": "sha512-Okrw5hjtEjqSMOG08J6qqEwlUQujTVClvY1/eZkzKwNzPelWrtV6vqfyJklB7zVhenlxfxqhZKKcY7zWSW/q5Q==", "peer": true, "dependencies": { - "@polkadot/rpc-core": "10.12.4", - "@polkadot/types": "10.12.4", + "@polkadot/rpc-core": "10.13.1", + "@polkadot/types": "10.13.1", "@polkadot/util": "^12.6.2", "rxjs": "^7.8.1", "tslib": "^2.6.2" @@ -6119,17 +6138,17 @@ "peer": true }, "node_modules/@polkadot/api-derive": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/api-derive/-/api-derive-10.12.4.tgz", - "integrity": "sha512-V5DogVPWoMw8U6V5hCkxDZP2qpashLUruyWVDcGhQmMb0f5d5PG/dPlZ3CzvAars6G2ypJ8ciSNKDdApP5JWaQ==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/api-derive/-/api-derive-10.13.1.tgz", + "integrity": "sha512-ef0H0GeCZ4q5Om+c61eLLLL29UxFC2/u/k8V1K2JOIU+2wD5LF7sjAoV09CBMKKHfkLenRckVk2ukm4rBqFRpg==", "peer": true, "dependencies": { - "@polkadot/api": "10.12.4", - "@polkadot/api-augment": "10.12.4", - "@polkadot/api-base": "10.12.4", - "@polkadot/rpc-core": "10.12.4", - "@polkadot/types": "10.12.4", - "@polkadot/types-codec": "10.12.4", + "@polkadot/api": "10.13.1", + "@polkadot/api-augment": "10.13.1", + "@polkadot/api-base": "10.13.1", + "@polkadot/rpc-core": "10.13.1", + "@polkadot/types": "10.13.1", + "@polkadot/types-codec": "10.13.1", "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "rxjs": "^7.8.1", @@ -7090,14 +7109,14 @@ "peer": true }, "node_modules/@polkadot/rpc-augment": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/rpc-augment/-/rpc-augment-10.12.4.tgz", - "integrity": "sha512-GELqgtpoxmvFdXREYhrTGAFJ+xnQp8IYHFFtixfLM3SeV/F5FF0T7c1jSJ4PlEgK1tYg/KQ/DLl21fF7aWaInA==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/rpc-augment/-/rpc-augment-10.13.1.tgz", + "integrity": "sha512-iLsWUW4Jcx3DOdVrSHtN0biwxlHuTs4QN2hjJV0gd0jo7W08SXhWabZIf9mDmvUJIbR7Vk+9amzvegjRyIf5+A==", "peer": true, "dependencies": { - "@polkadot/rpc-core": "10.12.4", - "@polkadot/types": "10.12.4", - "@polkadot/types-codec": "10.12.4", + "@polkadot/rpc-core": "10.13.1", + "@polkadot/types": "10.13.1", + "@polkadot/types-codec": "10.13.1", "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, @@ -7168,14 +7187,14 @@ "peer": true }, "node_modules/@polkadot/rpc-core": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/rpc-core/-/rpc-core-10.12.4.tgz", - "integrity": "sha512-OtOW3AQyvDR+0G7VylfwEyE5XnYhHrcRtGULT9NzjZTVHnDFghNIYoDcu6ucHBuMsvx5mbyaXsRtWDDZdr4trw==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/rpc-core/-/rpc-core-10.13.1.tgz", + "integrity": "sha512-eoejSHa+/tzHm0vwic62/aptTGbph8vaBpbvLIK7gd00+rT813ROz5ckB1CqQBFB23nHRLuzzX/toY8ID3xrKw==", "peer": true, "dependencies": { - "@polkadot/rpc-augment": "10.12.4", - "@polkadot/rpc-provider": "10.12.4", - "@polkadot/types": "10.12.4", + "@polkadot/rpc-augment": "10.13.1", + "@polkadot/rpc-provider": "10.13.1", + "@polkadot/types": "10.13.1", "@polkadot/util": "^12.6.2", "rxjs": "^7.8.1", "tslib": "^2.6.2" @@ -7247,14 +7266,14 @@ "peer": true }, "node_modules/@polkadot/rpc-provider": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/rpc-provider/-/rpc-provider-10.12.4.tgz", - "integrity": "sha512-awXLK28nt6BvOwoTnOVPtz+Qu5sx40Al1yb5lzKG6jYFQrEmqrENufHNOCLU3Uspfqmc6eJmNluZOmVtJKDCPg==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/rpc-provider/-/rpc-provider-10.13.1.tgz", + "integrity": "sha512-oJ7tatVXYJ0L7NpNiGd69D558HG5y5ZDmH2Bp9Dd4kFTQIiV8A39SlWwWUPCjSsen9lqSvvprNLnG/VHTpenbw==", "peer": true, "dependencies": { "@polkadot/keyring": "^12.6.2", - "@polkadot/types": "10.12.4", - "@polkadot/types-support": "10.12.4", + "@polkadot/types": "10.13.1", + "@polkadot/types-support": "10.13.1", "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "@polkadot/x-fetch": "^12.6.2", @@ -7486,15 +7505,15 @@ "peer": true }, "node_modules/@polkadot/types": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/types/-/types-10.12.4.tgz", - "integrity": "sha512-KJfxAdOyA/ZmGzRpRWojZx6hOU4iFHiwmerAZQzxELMCUCSsAd4joiXWQX7leSrlJCvvk8/VecnXGTqRe8jtGw==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/types/-/types-10.13.1.tgz", + "integrity": "sha512-Hfvg1ZgJlYyzGSAVrDIpp3vullgxrjOlh/CSThd/PI4TTN1qHoPSFm2hs77k3mKkOzg+LrWsLE0P/LP2XddYcw==", "peer": true, "dependencies": { "@polkadot/keyring": "^12.6.2", - "@polkadot/types-augment": "10.12.4", - "@polkadot/types-codec": "10.12.4", - "@polkadot/types-create": "10.12.4", + "@polkadot/types-augment": "10.13.1", + "@polkadot/types-codec": "10.13.1", + "@polkadot/types-create": "10.13.1", "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "rxjs": "^7.8.1", @@ -7505,13 +7524,13 @@ } }, "node_modules/@polkadot/types-augment": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/types-augment/-/types-augment-10.12.4.tgz", - "integrity": "sha512-BS7uMd5WzbpcXimYcbwQGJFjsZikVW1XXPS3FHAkcdPOKm1qWZ/r3V18XH9G4DKj0O0s4VrdVTl0nMcOZurKKg==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/types-augment/-/types-augment-10.13.1.tgz", + "integrity": "sha512-TcrLhf95FNFin61qmVgOgayzQB/RqVsSg9thAso1Fh6pX4HSbvI35aGPBAn3SkA6R+9/TmtECirpSNLtIGFn0g==", "peer": true, "dependencies": { - "@polkadot/types": "10.12.4", - "@polkadot/types-codec": "10.12.4", + "@polkadot/types": "10.13.1", + "@polkadot/types-codec": "10.13.1", "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, @@ -7582,9 +7601,9 @@ "peer": true }, "node_modules/@polkadot/types-codec": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/types-codec/-/types-codec-10.12.4.tgz", - "integrity": "sha512-8SEwgQT+JfmI62C9MZisA/1oQFuQW1OySvZFZlSqkaoRooK+JMl7Sp9fnRhCuiHMiz08YO4lX16O+aAu0/bmmw==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/types-codec/-/types-codec-10.13.1.tgz", + "integrity": "sha512-AiQ2Vv2lbZVxEdRCN8XSERiWlOWa2cTDLnpAId78EnCtx4HLKYQSd+Jk9Y4BgO35R79mchK4iG+w6gZ+ukG2bg==", "peer": true, "dependencies": { "@polkadot/util": "^12.6.2", @@ -7658,12 +7677,12 @@ "peer": true }, "node_modules/@polkadot/types-create": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/types-create/-/types-create-10.12.4.tgz", - "integrity": "sha512-K3a6q+q+as/FfxrbXgFdgK8aqrsUgAkH5c0KQS+nt6xMs+Yf2ctpqiLPOjOEVEw8kHRpYtjx1db8Namegk51ig==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/types-create/-/types-create-10.13.1.tgz", + "integrity": "sha512-Usn1jqrz35SXgCDAqSXy7mnD6j4RvB4wyzTAZipFA6DGmhwyxxIgOzlWQWDb+1PtPKo9vtMzen5IJ+7w5chIeA==", "peer": true, "dependencies": { - "@polkadot/types-codec": "10.12.4", + "@polkadot/types-codec": "10.13.1", "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, @@ -7734,15 +7753,15 @@ "peer": true }, "node_modules/@polkadot/types-known": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/types-known/-/types-known-10.12.4.tgz", - "integrity": "sha512-fiS26ep9QwHIUn/N0X9R3DIFP8ar4cEG/oJyxs5uBNtIEiAZdWucEZAZFxJnNp6Lib0PGYaz9T9ph0+UbnKKEg==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/types-known/-/types-known-10.13.1.tgz", + "integrity": "sha512-uHjDW05EavOT5JeU8RbiFWTgPilZ+odsCcuEYIJGmK+es3lk/Qsdns9Zb7U7NJl7eJ6OWmRtyrWsLs+bU+jjIQ==", "peer": true, "dependencies": { "@polkadot/networks": "^12.6.2", - "@polkadot/types": "10.12.4", - "@polkadot/types-codec": "10.12.4", - "@polkadot/types-create": "10.12.4", + "@polkadot/types": "10.13.1", + "@polkadot/types-codec": "10.13.1", + "@polkadot/types-create": "10.13.1", "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, @@ -7813,9 +7832,9 @@ "peer": true }, "node_modules/@polkadot/types-support": { - "version": "10.12.4", - "resolved": "https://registry.npmjs.org/@polkadot/types-support/-/types-support-10.12.4.tgz", - "integrity": "sha512-uK0AoxzbuFEwlR3eoTKdWuZxAKYOn2B67Xo+swwRL0/VTZvEc6mGnFUd1RfVM+cWKfH3eqwKQCYhjvFRlOkA8g==", + "version": "10.13.1", + "resolved": "https://registry.npmjs.org/@polkadot/types-support/-/types-support-10.13.1.tgz", + "integrity": "sha512-4gEPfz36XRQIY7inKq0HXNVVhR6HvXtm7yrEmuBuhM86LE0lQQBkISUSgR358bdn2OFSLMxMoRNoh3kcDvdGDQ==", "peer": true, "dependencies": { "@polkadot/util": "^12.6.2", @@ -8822,9 +8841,9 @@ "peer": true }, "node_modules/@substrate/connect-known-chains": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@substrate/connect-known-chains/-/connect-known-chains-1.1.2.tgz", - "integrity": "sha512-XvyemTVqon+6EF2G7QL0fEXxjuz3nUNFgFV0TSWhSVpPb+Sfs+vfipbEZxGNouxvjCoJdr6CF0rwgGsrrKOnAA==", + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/@substrate/connect-known-chains/-/connect-known-chains-1.1.4.tgz", + "integrity": "sha512-iT+BdKqvKl/uBLd8BAJysFM1BaMZXRkaXBP2B7V7ob/EyNs5h0EMhTVbO6MJxV/IEOg5OKsyl6FUqQK7pKnqyw==", "optional": true, "peer": true }, @@ -9232,10 +9251,9 @@ } }, "node_modules/@types/eslint": { - "version": "8.56.7", - "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.7.tgz", - "integrity": "sha512-SjDvI/x3zsZnOkYZ3lCt9lOZWZLB2jIlNKz+LBgCtDurK0JZcwucxYHn1w2BJkD34dgX9Tjnak0txtq4WTggEA==", - "dev": true, + "version": "8.56.10", + "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.10.tgz", + "integrity": "sha512-Shavhk87gCtY2fhXDctcfS3e6FdxWkCx1iUZ9eEUbh7rTqlZT0/IzOkCOVt0fCjcFuZ9FPYfuezTBImfHCDBGQ==", "dependencies": { "@types/estree": "*", "@types/json-schema": "*" @@ -9250,11 +9268,28 @@ "@types/eslint": "*" } }, + "node_modules/@types/eslint-scope": { + "version": "3.7.7", + "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.7.tgz", + "integrity": "sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==", + "dependencies": { + "@types/eslint": "*", + "@types/estree": "*" + } + }, "node_modules/@types/estree": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", - "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", - "dev": true + "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==" + }, + "node_modules/@types/eventemitter3": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/@types/eventemitter3/-/eventemitter3-2.0.2.tgz", + "integrity": "sha512-nLbSkHNDMVCyINVOtmDq9lTv+PDzeypazRMoqYDKyLPzrbLLiSHFSZLifMU1PxFHRvLJuyDlr/GU0j60eEyeaA==", + "deprecated": "This is a stub types definition for EventEmitter3 (https://github.com/primus/eventemitter3). EventEmitter3 provides its own type definitions, so you don't need @types/eventemitter3 installed!", + "dependencies": { + "eventemitter3": "*" + } }, "node_modules/@types/express": { "version": "4.17.21", @@ -9268,9 +9303,9 @@ } }, "node_modules/@types/express-serve-static-core": { - "version": "4.17.43", - "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.43.tgz", - "integrity": "sha512-oaYtiBirUOPQGSWNGPWnzyAFJ0BP3cwvN4oWZQY+zUBwpVIGsKUkpBpSztp74drYcjavs7SKFZ4DX1V2QeN8rg==", + "version": "4.19.0", + "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.19.0.tgz", + "integrity": "sha512-bGyep3JqPCRry1wq+O5n7oiBgGWmeIJXPjXXCo8EK0u8duZGSYar7cGqd3ML2JUsLGeB7fmc06KYo9fLGWqPvQ==", "dependencies": { "@types/node": "*", "@types/qs": "*", @@ -9384,8 +9419,7 @@ "node_modules/@types/json-schema": { "version": "7.0.15", "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", - "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", - "dev": true + "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==" }, "node_modules/@types/json-stable-stringify": { "version": "1.0.36", @@ -9474,9 +9508,9 @@ } }, "node_modules/@types/node": { - "version": "20.12.2", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.12.2.tgz", - "integrity": "sha512-zQ0NYO87hyN6Xrclcqp7f8ZbXNbRfoGWNcMvHTPQp9UUrwI0mI7XBz+cu7/W6/VClYo2g63B0cjull/srU7LgQ==", + "version": "20.12.7", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.12.7.tgz", + "integrity": "sha512-wq0cICSkRLVaf3UGLMGItu/PtdY7oaXaI/RVU+xliKVOtRna3PRY57ZDfztpDL0n11vfymMUnXv8QwYCO7L1wg==", "dependencies": { "undici-types": "~5.26.4" } @@ -9505,9 +9539,9 @@ } }, "node_modules/@types/pg": { - "version": "8.11.4", - "resolved": "https://registry.npmjs.org/@types/pg/-/pg-8.11.4.tgz", - "integrity": "sha512-yw3Bwbda6vO+NvI1Ue/YKOwtl31AYvvd/e73O3V4ZkNzuGpTDndLSyc0dQRB2xrQqDePd20pEGIfqSp/GH3pRw==", + "version": "8.11.5", + "resolved": "https://registry.npmjs.org/@types/pg/-/pg-8.11.5.tgz", + "integrity": "sha512-2xMjVviMxneZHDHX5p5S6tsRRs7TpDHeeK7kTTMe/kAC/mRRNjWHjZg0rkiY+e17jXSZV3zJYDxXV8Cy72/Vuw==", "dev": true, "dependencies": { "@types/node": "*", @@ -9522,9 +9556,9 @@ "dev": true }, "node_modules/@types/qs": { - "version": "6.9.14", - "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.14.tgz", - "integrity": "sha512-5khscbd3SwWMhFqylJBLQ0zIu7c1K6Vz0uBIt915BI3zV0q1nfjRQD3RqSBcPaO6PHEF4ov/t9y89fSiyThlPA==" + "version": "6.9.15", + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.15.tgz", + "integrity": "sha512-uXHQKES6DQKKCLh441Xv/dwxOq1TVS3JPUMlEqoEglvlhR6Mxnlew/Xq/LRVHpLyk7iK3zODe1qYHIMltO7XGg==" }, "node_modules/@types/range-parser": { "version": "1.2.7", @@ -9563,13 +9597,13 @@ } }, "node_modules/@types/serve-static": { - "version": "1.15.5", - "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.5.tgz", - "integrity": "sha512-PDRk21MnK70hja/YF8AHfC7yIsiQHn1rcXx7ijCFBX/k+XQJhQT/gw3xekXKJvx+5SXaMMS8oqQy09Mzvz2TuQ==", + "version": "1.15.7", + "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.7.tgz", + "integrity": "sha512-W8Ym+h8nhuRwaKPaDw34QUkwsGi6Rc4yYqvKFo5rm2FUEhCFbzVWrxXUxuKK8TASjWsysJY0nsmNCGhCOIsrOw==", "dependencies": { "@types/http-errors": "*", - "@types/mime": "*", - "@types/node": "*" + "@types/node": "*", + "@types/send": "*" } }, "node_modules/@types/stack-utils": { @@ -9587,6 +9621,11 @@ "@types/serve-static": "*" } }, + "node_modules/@types/uuid": { + "version": "8.3.4", + "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-8.3.4.tgz", + "integrity": "sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw==" + }, "node_modules/@types/websocket": { "version": "1.0.10", "resolved": "https://registry.npmjs.org/@types/websocket/-/websocket-1.0.10.tgz", @@ -10167,6 +10206,188 @@ "@walletconnect/window-getters": "^1.0.0" } }, + "node_modules/@webassemblyjs/ast": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.12.1.tgz", + "integrity": "sha512-EKfMUOPRRUTy5UII4qJDGPpqfwjOmZ5jeGFwid9mnoqIFK+e0vqoi1qH56JpmZSzEL53jKnNzScdmftJyG5xWg==", + "dependencies": { + "@webassemblyjs/helper-numbers": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6" + } + }, + "node_modules/@webassemblyjs/floating-point-hex-parser": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.6.tgz", + "integrity": "sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==" + }, + "node_modules/@webassemblyjs/helper-api-error": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.6.tgz", + "integrity": "sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==" + }, + "node_modules/@webassemblyjs/helper-buffer": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.12.1.tgz", + "integrity": "sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw==" + }, + "node_modules/@webassemblyjs/helper-numbers": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.6.tgz", + "integrity": "sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==", + "dependencies": { + "@webassemblyjs/floating-point-hex-parser": "1.11.6", + "@webassemblyjs/helper-api-error": "1.11.6", + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@webassemblyjs/helper-wasm-bytecode": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.6.tgz", + "integrity": "sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==" + }, + "node_modules/@webassemblyjs/helper-wasm-section": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.12.1.tgz", + "integrity": "sha512-Jif4vfB6FJlUlSbgEMHUyk1j234GTNG9dBJ4XJdOySoj518Xj0oGsNi59cUQF4RRMS9ouBUxDDdyBVfPTypa5g==", + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-buffer": "1.12.1", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/wasm-gen": "1.12.1" + } + }, + "node_modules/@webassemblyjs/ieee754": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.6.tgz", + "integrity": "sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==", + "dependencies": { + "@xtuc/ieee754": "^1.2.0" + } + }, + "node_modules/@webassemblyjs/leb128": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.6.tgz", + "integrity": "sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==", + "dependencies": { + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@webassemblyjs/utf8": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.6.tgz", + "integrity": "sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==" + }, + "node_modules/@webassemblyjs/wasm-edit": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.12.1.tgz", + "integrity": "sha512-1DuwbVvADvS5mGnXbE+c9NfA8QRcZ6iKquqjjmR10k6o+zzsRVesil54DKexiowcFCPdr/Q0qaMgB01+SQ1u6g==", + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-buffer": "1.12.1", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/helper-wasm-section": "1.12.1", + "@webassemblyjs/wasm-gen": "1.12.1", + "@webassemblyjs/wasm-opt": "1.12.1", + "@webassemblyjs/wasm-parser": "1.12.1", + "@webassemblyjs/wast-printer": "1.12.1" + } + }, + "node_modules/@webassemblyjs/wasm-gen": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.12.1.tgz", + "integrity": "sha512-TDq4Ojh9fcohAw6OIMXqiIcTq5KUXTGRkVxbSo1hQnSy6lAM5GSdfwWeSxpAo0YzgsgF182E/U0mDNhuA0tW7w==", + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" + } + }, + "node_modules/@webassemblyjs/wasm-opt": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.12.1.tgz", + "integrity": "sha512-Jg99j/2gG2iaz3hijw857AVYekZe2SAskcqlWIZXjji5WStnOpVoat3gQfT/Q5tb2djnCjBtMocY/Su1GfxPBg==", + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-buffer": "1.12.1", + "@webassemblyjs/wasm-gen": "1.12.1", + "@webassemblyjs/wasm-parser": "1.12.1" + } + }, + "node_modules/@webassemblyjs/wasm-parser": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.12.1.tgz", + "integrity": "sha512-xikIi7c2FHXysxXe3COrVUPSheuBtpcfhbpFj4gmu7KRLYOzANztwUU0IbsqvMqzuNK2+glRGWCEqZo1WCLyAQ==", + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-api-error": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" + } + }, + "node_modules/@webassemblyjs/wast-printer": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.12.1.tgz", + "integrity": "sha512-+X4WAlOisVWQMikjbcvY2e0rwPsKQ9F688lksZhBcPycBBuii3O7m8FACbDMWDojpAqvjIncrG8J0XHKyQfVeA==", + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@webpack-cli/configtest": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/@webpack-cli/configtest/-/configtest-2.1.1.tgz", + "integrity": "sha512-wy0mglZpDSiSS0XHrVR+BAdId2+yxPSoJW8fsna3ZpYSlufjvxnP4YbKTCBZnNIcGN4r6ZPXV55X4mYExOfLmw==", + "engines": { + "node": ">=14.15.0" + }, + "peerDependencies": { + "webpack": "5.x.x", + "webpack-cli": "5.x.x" + } + }, + "node_modules/@webpack-cli/info": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/@webpack-cli/info/-/info-2.0.2.tgz", + "integrity": "sha512-zLHQdI/Qs1UyT5UBdWNqsARasIA+AaF8t+4u2aS2nEpBQh2mWIVb8qAklq0eUENnC5mOItrIB4LiS9xMtph18A==", + "engines": { + "node": ">=14.15.0" + }, + "peerDependencies": { + "webpack": "5.x.x", + "webpack-cli": "5.x.x" + } + }, + "node_modules/@webpack-cli/serve": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@webpack-cli/serve/-/serve-2.0.5.tgz", + "integrity": "sha512-lqaoKnRYBdo1UgDX8uF24AfGMifWK19TxPmM5FHc2vAGxrJ/qtyUyFBWoY1tISZdelsQ5fBcOusifo5o5wSJxQ==", + "engines": { + "node": ">=14.15.0" + }, + "peerDependencies": { + "webpack": "5.x.x", + "webpack-cli": "5.x.x" + }, + "peerDependenciesMeta": { + "webpack-dev-server": { + "optional": true + } + } + }, + "node_modules/@xtuc/ieee754": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", + "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==" + }, + "node_modules/@xtuc/long": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==" + }, "node_modules/@yao-pkg/pkg": { "version": "5.11.5", "resolved": "https://registry.npmjs.org/@yao-pkg/pkg/-/pkg-5.11.5.tgz", @@ -10419,7 +10640,6 @@ "version": "8.11.3", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", - "dev": true, "bin": { "acorn": "bin/acorn" }, @@ -10427,6 +10647,14 @@ "node": ">=0.4.0" } }, + "node_modules/acorn-import-assertions": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.9.0.tgz", + "integrity": "sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==", + "peerDependencies": { + "acorn": "^8" + } + }, "node_modules/acorn-jsx": { "version": "5.3.2", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", @@ -10508,6 +10736,14 @@ "url": "https://github.com/sponsors/epoberezkin" } }, + "node_modules/ajv-keywords": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", + "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", + "peerDependencies": { + "ajv": "^6.9.1" + } + }, "node_modules/algo-msgpack-with-bigint": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/algo-msgpack-with-bigint/-/algo-msgpack-with-bigint-2.1.1.tgz", @@ -11053,13 +11289,13 @@ } }, "node_modules/babel-plugin-polyfill-corejs2": { - "version": "0.4.10", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.10.tgz", - "integrity": "sha512-rpIuu//y5OX6jVU+a5BCn1R5RSZYWAl2Nar76iwaOdycqb6JPxediskWFMMl7stfwNJR4b7eiQvh5fB5TEQJTQ==", + "version": "0.4.11", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.11.tgz", + "integrity": "sha512-sMEJ27L0gRHShOh5G54uAAPaiCOygY/5ratXuiyb2G46FmlSpc9eFCzYVyDiPxfNbwzA7mYahmjQc5q+CZQ09Q==", "dev": true, "dependencies": { "@babel/compat-data": "^7.22.6", - "@babel/helper-define-polyfill-provider": "^0.6.1", + "@babel/helper-define-polyfill-provider": "^0.6.2", "semver": "^6.3.1" }, "peerDependencies": { @@ -11089,12 +11325,12 @@ } }, "node_modules/babel-plugin-polyfill-regenerator": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.6.1.tgz", - "integrity": "sha512-JfTApdE++cgcTWjsiCQlLyFBMbTUft9ja17saCc93lgV33h4tuCVj7tlvu//qpLwaG+3yEz7/KhahGrUMkVq9g==", + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.6.2.tgz", + "integrity": "sha512-2R25rQZWP63nGwaAswvDazbPXfrM3HwVoBXK6HcqeKrSrL/JqcC/rDcf95l4r7LXLyxDXc8uQDa064GubtCABg==", "dev": true, "dependencies": { - "@babel/helper-define-polyfill-provider": "^0.6.1" + "@babel/helper-define-polyfill-provider": "^0.6.2" }, "peerDependencies": { "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" @@ -11161,6 +11397,27 @@ "safe-buffer": "^5.0.1" } }, + "node_modules/base58check": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/base58check/-/base58check-2.0.0.tgz", + "integrity": "sha512-sTzsDAOC9+i2Ukr3p1Ie2DWpD117ua+vBJRDnpsSlScGwImeeiTg/IatwcFLsz9K9wEGoBLVd5ahNZzrZ/jZyg==", + "dependencies": { + "bs58": "^3.0.0" + } + }, + "node_modules/base58check/node_modules/base-x": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/base-x/-/base-x-1.1.0.tgz", + "integrity": "sha512-c0WLeG3K5OlL4Skz2/LVdS+MjggByKhowxQpG+JpCLA48s/bGwIDyzA1naFjywtNvp/37fLK0p0FpjTNNLLUXQ==" + }, + "node_modules/base58check/node_modules/bs58": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/bs58/-/bs58-3.1.0.tgz", + "integrity": "sha512-9C2bRFTGy3meqO65O9jLvVTyawvhLVp4h2ECm5KlRPuV5KPDNJZcJIj3gl+aA0ENXcYrUSLCkPAeqbTcI2uWyQ==", + "dependencies": { + "base-x": "^1.1.0" + } + }, "node_modules/base64-js": { "version": "1.5.1", "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", @@ -11393,7 +11650,6 @@ "version": "4.23.0", "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.0.tgz", "integrity": "sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ==", - "dev": true, "funding": [ { "type": "opencollective", @@ -11486,8 +11742,7 @@ "node_modules/buffer-from": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", - "dev": true + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" }, "node_modules/buffer-to-arraybuffer": { "version": "0.0.5", @@ -11512,9 +11767,9 @@ } }, "node_modules/builtins": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz", - "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.1.0.tgz", + "integrity": "sha512-SW9lzGTLvWTP1AY8xeAMZimqDrIaSdLQUcVr9DMef51niJ022Ri87SwRRKYm4A6iHfkPaiVUu/Duw2Wc4J7kKg==", "dev": true, "dependencies": { "semver": "^7.0.0" @@ -11622,10 +11877,9 @@ } }, "node_modules/caniuse-lite": { - "version": "1.0.30001603", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001603.tgz", - "integrity": "sha512-iL2iSS0eDILMb9n5yKQoTBim9jMZ0Yrk8g0N9K7UzYyWnfIKzXBZD5ngpM37ZcL/cv0Mli8XtVMRYMQAfFpi5Q==", - "dev": true, + "version": "1.0.30001612", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001612.tgz", + "integrity": "sha512-lFgnZ07UhaCcsSZgWW0K5j4e69dK1u/ltrL9lTUiFOwNHs12S3UMIEYgBV0Z6C6hRDev7iRnMzzYmKabYdXF9g==", "funding": [ { "type": "opencollective", @@ -11775,6 +12029,14 @@ "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==" }, + "node_modules/chrome-trace-event": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz", + "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==", + "engines": { + "node": ">=6.0" + } + }, "node_modules/ci-info": { "version": "3.9.0", "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.9.0.tgz", @@ -11991,6 +12253,19 @@ "node": ">=0.8" } }, + "node_modules/clone-deep": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", + "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", + "dependencies": { + "is-plain-object": "^2.0.4", + "kind-of": "^6.0.2", + "shallow-clone": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, "node_modules/clone-response": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.3.tgz", @@ -12034,6 +12309,11 @@ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, + "node_modules/colorette": { + "version": "2.0.20", + "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz", + "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==" + }, "node_modules/colors": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", @@ -12319,9 +12599,9 @@ "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" }, "node_modules/core-js-compat": { - "version": "3.36.1", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.36.1.tgz", - "integrity": "sha512-Dk997v9ZCt3X/npqzyGdTlq6t7lDBhZwGvV94PKzDArjp7BTRm7WlDAXYd/OWdeFHO8OChQYRJNJvUCqCbrtKA==", + "version": "3.37.0", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.37.0.tgz", + "integrity": "sha512-vYq4L+T8aS5UuFg4UwDhc7YNRWVeVZwltad9C/jV3R2LgVOpS9BDr7l/WL6BN0dbV3k1XejPTHqqEzJgsa0frA==", "dev": true, "dependencies": { "browserslist": "^4.23.0" @@ -12950,9 +13230,9 @@ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" }, "node_modules/ejs": { - "version": "3.1.9", - "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.9.tgz", - "integrity": "sha512-rC+QVNMJWv+MtPgkt0y+0rVEIdbtxVADApW9JXrUVlzHetgcyczP/E7DJmWJ4fJCZF2cPcBk0laWO9ZHMG3DmQ==", + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.10.tgz", + "integrity": "sha512-UeJmFfOrAQS8OJWPZ4qtgHyWExa088/MtK5UEyoJGFH67cDEXkZSviOiKRCZ4Xij0zxI3JECgYs3oKx+AizQBA==", "dev": true, "dependencies": { "jake": "^10.8.5" @@ -12965,10 +13245,9 @@ } }, "node_modules/electron-to-chromium": { - "version": "1.4.723", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.723.tgz", - "integrity": "sha512-rxFVtrMGMFROr4qqU6n95rUi9IlfIm+lIAt+hOToy/9r6CDv0XiEcQdC3VP71y1pE5CFTzKV0RvxOGYCPWWHPw==", - "dev": true + "version": "1.4.747", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.747.tgz", + "integrity": "sha512-+FnSWZIAvFHbsNVmUxhEqWiaOiPMcfum1GQzlWCg/wLigVtshOsjXHyEFfmt6cFK6+HkS3QOJBv6/3OPumbBfw==" }, "node_modules/elliptic": { "version": "6.5.5", @@ -13017,6 +13296,18 @@ "once": "^1.4.0" } }, + "node_modules/enhanced-resolve": { + "version": "5.16.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.16.0.tgz", + "integrity": "sha512-O+QWCviPNSSLAD9Ucn8Awv+poAkqn3T1XY5/N7kR7rQO9yfSGWkYZDwpJ+iKF7B8rxaQKWngSqACpgzeapSyoA==", + "dependencies": { + "graceful-fs": "^4.2.4", + "tapable": "^2.2.0" + }, + "engines": { + "node": ">=10.13.0" + } + }, "node_modules/enquirer": { "version": "2.3.6", "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", @@ -13038,6 +13329,17 @@ "node": ">=6" } }, + "node_modules/envinfo": { + "version": "7.12.0", + "resolved": "https://registry.npmjs.org/envinfo/-/envinfo-7.12.0.tgz", + "integrity": "sha512-Iw9rQJBGpJRd3rwXm9ft/JiGoAZmLxxJZELYDQoPRZ4USVhkKtIcNBPw6U+/K2mBpaqM25JSV6Yl4Az9vO2wJg==", + "bin": { + "envinfo": "dist/cli.js" + }, + "engines": { + "node": ">=4" + } + }, "node_modules/error-ex": { "version": "1.3.2", "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", @@ -13151,6 +13453,11 @@ "node": ">= 0.4" } }, + "node_modules/es-module-lexer": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.5.0.tgz", + "integrity": "sha512-pqrTKmwEIgafsYZAGw9kszYzmagcE/n4dbgwGWLEXg7J4QFJVQRBld8j3Q3GNez79jzxZshq0bcT962QHOghjw==" + }, "node_modules/es-object-atoms": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", @@ -13970,8 +14277,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", - "dev": true, - "peer": true, "dependencies": { "estraverse": "^5.2.0" }, @@ -13983,7 +14288,6 @@ "version": "5.3.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", - "dev": true, "engines": { "node": ">=4.0" } @@ -14218,11 +14522,11 @@ } }, "node_modules/ethereum-bloom-filters": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/ethereum-bloom-filters/-/ethereum-bloom-filters-1.0.10.tgz", - "integrity": "sha512-rxJ5OFN3RwjQxDcFP2Z5+Q9ho4eIdEmSc2ht0fCu8Se9nbXjZ7/031uXoUYJ87KHCOdVeiUuwSnoS7hmYAGVHA==", + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/ethereum-bloom-filters/-/ethereum-bloom-filters-1.1.0.tgz", + "integrity": "sha512-J1gDRkLpuGNvWYzWslBQR9cDV4nd4kfvVTE/Wy4Kkm4yb3EYRSlyi0eB/inTsSTTVyA0+HyzHgbr95Fn/Z1fSw==", "dependencies": { - "js-sha3": "^0.8.0" + "@noble/hashes": "^1.4.0" } }, "node_modules/ethereum-cryptography": { @@ -14476,6 +14780,14 @@ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.4.tgz", "integrity": "sha512-rlaVLnVxtxvoyLsQQFBx53YmXHDxRIzzTLbdfxqi4yocpSjAxXwkU0cScM5JgSKMqEhrZpnvQ2D9gjylR0AimQ==" }, + "node_modules/events": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", + "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", + "engines": { + "node": ">=0.8.x" + } + }, "node_modules/evp_bytestokey": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", @@ -14629,9 +14941,9 @@ ] }, "node_modules/fast-check": { - "version": "3.17.1", - "resolved": "https://registry.npmjs.org/fast-check/-/fast-check-3.17.1.tgz", - "integrity": "sha512-jIKXJVe6ZO0SpwEgVtEVujTf8TwjI9wMXFJCjsDHUB3RroUbXBgF4kOSz3A7MW0UR26aqsoB8i9O2mjtjERAiA==", + "version": "3.17.2", + "resolved": "https://registry.npmjs.org/fast-check/-/fast-check-3.17.2.tgz", + "integrity": "sha512-+3DPTxtxABLgmmVpYxrash3DHoq0cMa1jjLYNp3qqokKKhqVEaS4lbnaDKqWU5Dd6C2pEudPPBAEEQ9nUou9OQ==", "dev": true, "funding": [ { @@ -14706,6 +15018,14 @@ "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz", "integrity": "sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA==" }, + "node_modules/fastest-levenshtein": { + "version": "1.0.16", + "resolved": "https://registry.npmjs.org/fastest-levenshtein/-/fastest-levenshtein-1.0.16.tgz", + "integrity": "sha512-eRnCtTTtGZFpQCwhJiUOuxPQWRXVKYDn0b2PeHfXL6/Zi53SLAzAHfVhVWK2AryC/WH05kGfxhFIPvTF0SXQzg==", + "engines": { + "node": ">= 4.9.1" + } + }, "node_modules/fastq": { "version": "1.17.1", "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", @@ -14871,7 +15191,6 @@ "version": "4.1.0", "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dev": true, "dependencies": { "locate-path": "^5.0.0", "path-exists": "^4.0.0" @@ -14884,7 +15203,6 @@ "version": "5.0.2", "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", - "dev": true, "bin": { "flat": "cli.js" } @@ -15390,6 +15708,11 @@ "node": ">=10.13.0" } }, + "node_modules/glob-to-regexp": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", + "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==" + }, "node_modules/global": { "version": "4.4.0", "resolved": "https://registry.npmjs.org/global/-/global-4.4.0.tgz", @@ -15608,14 +15931,14 @@ } }, "node_modules/hardhat": { - "version": "2.22.2", - "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.22.2.tgz", - "integrity": "sha512-0xZ7MdCZ5sJem4MrvpQWLR3R3zGDoHw5lsR+pBFimqwagimIOn3bWuZv69KA+veXClwI1s/zpqgwPwiFrd4Dxw==", + "version": "2.22.3", + "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.22.3.tgz", + "integrity": "sha512-k8JV2ECWNchD6ahkg2BR5wKVxY0OiKot7fuxiIpRK0frRqyOljcR2vKwgWSLw6YIeDcNNA4xybj7Og7NSxr2hA==", "dev": true, "dependencies": { "@ethersproject/abi": "^5.1.2", "@metamask/eth-sig-util": "^4.0.0", - "@nomicfoundation/edr": "^0.3.1", + "@nomicfoundation/edr": "^0.3.5", "@nomicfoundation/ethereumjs-common": "4.0.4", "@nomicfoundation/ethereumjs-tx": "5.0.4", "@nomicfoundation/ethereumjs-util": "9.0.4", @@ -16482,7 +16805,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", - "dev": true, "dependencies": { "pkg-dir": "^4.2.0", "resolve-cwd": "^3.0.0" @@ -16722,7 +17044,6 @@ "version": "2.13.1", "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", - "dev": true, "dependencies": { "hasown": "^2.0.0" }, @@ -16929,6 +17250,17 @@ "node": ">=8" } }, + "node_modules/is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dependencies": { + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/is-regex": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", @@ -17117,6 +17449,14 @@ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" }, + "node_modules/isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/isstream": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", @@ -17376,9 +17716,9 @@ } }, "node_modules/jest-circus/node_modules/dedent": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.1.tgz", - "integrity": "sha512-+LxW+KLWxu3HW3M2w2ympwtqPrqYRzU8fqi6Fhd18fBALe15blJPI/I4+UHveMVG6lJqB4JNd4UG0S5cnVHwIg==", + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.3.tgz", + "integrity": "sha512-NHQtfOOW68WD8lgypbLA5oT+Bt0xXJhiYvoR6SmmNXZfpzOGXwdKWmcwG8N7PwVVWV3eF/68nmD9BaJSsTBhyQ==", "dev": true, "peerDependencies": { "babel-plugin-macros": "^3.1.0" @@ -17969,8 +18309,7 @@ "node_modules/json-parse-even-better-errors": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", - "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", - "dev": true + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" }, "node_modules/json-rpc-engine": { "version": "6.1.0", @@ -18193,8 +18532,6 @@ "version": "6.0.3", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", - "dev": true, - "peer": true, "engines": { "node": ">=0.10.0" } @@ -18257,11 +18594,18 @@ "node": "^12.20.0 || ^14.13.1 || >=16.0.0" } }, + "node_modules/loader-runner": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz", + "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==", + "engines": { + "node": ">=6.11.5" + } + }, "node_modules/locate-path": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dev": true, "dependencies": { "p-locate": "^4.1.0" }, @@ -18477,8 +18821,7 @@ "node_modules/merge-stream": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", - "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", - "dev": true + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==" }, "node_modules/merge2": { "version": "1.4.1", @@ -18570,6 +18913,15 @@ "dom-walk": "^0.1.0" } }, + "node_modules/mina-signer": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/mina-signer/-/mina-signer-2.1.1.tgz", + "integrity": "sha512-bfdNTQg0Ka0xMR+V3q56GxOzV4Q/c7NL6nhCHTY+akJkul0qt9QZdfeow+XByde2JbnM3ZI502q1foKLZKQgog==", + "dependencies": { + "blakejs": "^1.2.1", + "js-sha256": "^0.9.0" + } + }, "node_modules/minimalistic-assert": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", @@ -19109,9 +19461,9 @@ } }, "node_modules/node-abi": { - "version": "3.57.0", - "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.57.0.tgz", - "integrity": "sha512-Dp+A9JWxRaKuHP35H77I4kCKesDy5HUDEmScia2FyncMTOXASMyg251F5PhFoDA5uqBrDDffiLpbqnrZmNXW+g==", + "version": "3.62.0", + "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.62.0.tgz", + "integrity": "sha512-CPMcGa+y33xuL1E0TcNIu4YyaZCxnnvkVaEXrsosR3FxN+fV8xvb7Mzpb7IgKler10qeMkE6+Dp8qJhpzdq35g==", "dev": true, "dependencies": { "semver": "^7.3.5" @@ -19197,8 +19549,7 @@ "node_modules/node-releases": { "version": "2.0.14", "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", - "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", - "dev": true + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==" }, "node_modules/nofilter": { "version": "3.1.0", @@ -19736,7 +20087,6 @@ "version": "4.1.0", "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dev": true, "dependencies": { "p-limit": "^2.2.0" }, @@ -19748,7 +20098,6 @@ "version": "2.3.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dev": true, "dependencies": { "p-try": "^2.0.0" }, @@ -19778,7 +20127,6 @@ "version": "2.2.0", "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", - "dev": true, "engines": { "node": ">=6" } @@ -19859,7 +20207,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true, "engines": { "node": ">=8" } @@ -19884,8 +20231,7 @@ "node_modules/path-parse": { "version": "1.0.7", "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", - "dev": true + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" }, "node_modules/path-scurry": { "version": "1.10.2", @@ -19970,11 +20316,11 @@ "integrity": "sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow==" }, "node_modules/pg": { - "version": "8.11.4", - "resolved": "https://registry.npmjs.org/pg/-/pg-8.11.4.tgz", - "integrity": "sha512-pWb7JKPxGk1UFbtq7jQ0m3IfPpb7LLACCEyN8/u9DYEom+Q/BSKy+4TRl4+Hh003AOYhppB/z+QK87/hx/bk0w==", + "version": "8.11.5", + "resolved": "https://registry.npmjs.org/pg/-/pg-8.11.5.tgz", + "integrity": "sha512-jqgNHSKL5cbDjFlHyYsCXmQDrfIX/3RsNwYqpd4N0Kt8niLuNoRNH+aazv6cOd43gPh9Y4DjQCtb+X0MH0Hvnw==", "dependencies": { - "pg-connection-string": "^2.6.3", + "pg-connection-string": "^2.6.4", "pg-pool": "^3.6.2", "pg-protocol": "^1.6.1", "pg-types": "^2.1.0", @@ -20002,9 +20348,9 @@ "optional": true }, "node_modules/pg-connection-string": { - "version": "2.6.3", - "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.6.3.tgz", - "integrity": "sha512-77FxhhKJQH+xJx6tDqkhhMa0nZvv3U1HYLDQgwZxZafVD583++O5LXn5oo5HaQZ0vXwYcZA1koYAJM3JvD6Gtw==" + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.6.4.tgz", + "integrity": "sha512-v+Z7W/0EO707aNMaAEfiGnGL9sxxumwLl2fJvCQtMn9Fxsg+lPpPkdcyBSv/KFgpGdYkMfn+EI1Or2EHjpgLCA==" }, "node_modules/pg-int8": { "version": "1.0.1", @@ -20123,8 +20469,7 @@ "node_modules/picocolors": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", - "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", - "dev": true + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" }, "node_modules/picomatch": { "version": "2.3.1", @@ -20271,7 +20616,6 @@ "version": "4.2.0", "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", - "dev": true, "dependencies": { "find-up": "^4.0.0" }, @@ -20352,9 +20696,9 @@ } }, "node_modules/pony-cause": { - "version": "2.1.10", - "resolved": "https://registry.npmjs.org/pony-cause/-/pony-cause-2.1.10.tgz", - "integrity": "sha512-3IKLNXclQgkU++2fSi93sQ6BznFuxSLB11HdvZQ6JW/spahf/P1pAHBQEahr20rs0htZW0UDkM1HmA+nZkXKsw==", + "version": "2.1.11", + "resolved": "https://registry.npmjs.org/pony-cause/-/pony-cause-2.1.11.tgz", + "integrity": "sha512-M7LhCsdNbNgiLYiP4WjsfLUuFmCfnjdF6jKe2R9NKl4WFN+HZPGHJZ9lnLP7f9ZnKe3U9nuWD0szirmj+migUg==", "engines": { "node": ">=12.0.0" } @@ -20367,6 +20711,18 @@ "node": ">= 0.4" } }, + "node_modules/postgres": { + "version": "3.4.4", + "resolved": "https://registry.npmjs.org/postgres/-/postgres-3.4.4.tgz", + "integrity": "sha512-IbyN+9KslkqcXa8AO9fxpk97PA4pzewvpi2B3Dwy9u4zpV32QicaEdgmF3eSQUzdRk7ttDHQejNgAEr4XoeH4A==", + "engines": { + "node": ">=12" + }, + "funding": { + "type": "individual", + "url": "https://github.com/sponsors/porsager" + } + }, "node_modules/postgres-array": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-3.0.2.tgz", @@ -21167,7 +21523,6 @@ "version": "1.22.8", "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", - "dev": true, "dependencies": { "is-core-module": "^2.13.0", "path-parse": "^1.0.7", @@ -21189,7 +21544,6 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", - "dev": true, "dependencies": { "resolve-from": "^5.0.0" }, @@ -21201,7 +21555,6 @@ "version": "5.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", - "dev": true, "engines": { "node": ">=8" } @@ -21561,6 +21914,23 @@ "optional": true, "peer": true }, + "node_modules/schema-utils": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", + "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", + "dependencies": { + "@types/json-schema": "^7.0.8", + "ajv": "^6.12.5", + "ajv-keywords": "^3.5.2" + }, + "engines": { + "node": ">= 10.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + } + }, "node_modules/scrypt-js": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/scrypt-js/-/scrypt-js-3.0.1.tgz", @@ -21759,6 +22129,17 @@ "node": "*" } }, + "node_modules/shallow-clone": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", + "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", + "dependencies": { + "kind-of": "^6.0.2" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/shebang-command": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", @@ -22024,9 +22405,9 @@ "dev": true }, "node_modules/solidity-coverage": { - "version": "0.8.11", - "resolved": "https://registry.npmjs.org/solidity-coverage/-/solidity-coverage-0.8.11.tgz", - "integrity": "sha512-yy0Yk+olovBbXn0Me8BWULmmv7A69ZKkP5aTOJGOO8u61Tu2zS989erfjtFlUjDnfWtxRAVkd8BsQD704yLWHw==", + "version": "0.8.12", + "resolved": "https://registry.npmjs.org/solidity-coverage/-/solidity-coverage-0.8.12.tgz", + "integrity": "sha512-8cOB1PtjnjFRqOgwFiD8DaUsYJtVJ6+YdXQtSZDrLGf8cdhhh8xzTtGzVTGeBf15kTv0v7lYPJlV/az7zLEPJw==", "dev": true, "peer": true, "dependencies": { @@ -22040,7 +22421,7 @@ "global-modules": "^2.0.0", "globby": "^10.0.1", "jsonschema": "^1.2.4", - "lodash": "^4.17.15", + "lodash": "^4.17.21", "mocha": "^10.2.0", "node-emoji": "^1.10.0", "pify": "^4.0.1", @@ -22626,7 +23007,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "dev": true, "engines": { "node": ">= 0.4" }, @@ -22635,9 +23015,9 @@ } }, "node_modules/swagger-ui-dist": { - "version": "5.13.0", - "resolved": "https://registry.npmjs.org/swagger-ui-dist/-/swagger-ui-dist-5.13.0.tgz", - "integrity": "sha512-uaWhh6j18IIs5tOX0arvIBnVINAzpTXaQXkr7qAk8zoupegJVg0UU/5+S/FgsgVCnzVsJ9d7QLjIxkswEeTg0Q==" + "version": "5.17.0", + "resolved": "https://registry.npmjs.org/swagger-ui-dist/-/swagger-ui-dist-5.17.0.tgz", + "integrity": "sha512-PtEozc87rN6i6rqLYNVTK+1ZAYmCMy6poU6I2MOJXD19BVv6D7U9zwS8geRbtfamCM5yUwWkSNQKWGK58vculg==" }, "node_modules/swagger-ui-express": { "version": "5.0.0", @@ -23093,6 +23473,14 @@ "dev": true, "peer": true }, + "node_modules/tapable": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", + "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", + "engines": { + "node": ">=6" + } + }, "node_modules/tar": { "version": "4.4.19", "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.19.tgz", @@ -23149,6 +23537,105 @@ "mkdirp": "bin/cmd.js" } }, + "node_modules/terser": { + "version": "5.30.4", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.30.4.tgz", + "integrity": "sha512-xRdd0v64a8mFK9bnsKVdoNP9GQIKUAaJPTaqEQDL4w/J8WaW4sWXXoMZ+6SimPkfT5bElreXf8m9HnmPc3E1BQ==", + "dependencies": { + "@jridgewell/source-map": "^0.3.3", + "acorn": "^8.8.2", + "commander": "^2.20.0", + "source-map-support": "~0.5.20" + }, + "bin": { + "terser": "bin/terser" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/terser-webpack-plugin": { + "version": "5.3.10", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz", + "integrity": "sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==", + "dependencies": { + "@jridgewell/trace-mapping": "^0.3.20", + "jest-worker": "^27.4.5", + "schema-utils": "^3.1.1", + "serialize-javascript": "^6.0.1", + "terser": "^5.26.0" + }, + "engines": { + "node": ">= 10.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^5.1.0" + }, + "peerDependenciesMeta": { + "@swc/core": { + "optional": true + }, + "esbuild": { + "optional": true + }, + "uglify-js": { + "optional": true + } + } + }, + "node_modules/terser-webpack-plugin/node_modules/jest-worker": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", + "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", + "dependencies": { + "@types/node": "*", + "merge-stream": "^2.0.0", + "supports-color": "^8.0.0" + }, + "engines": { + "node": ">= 10.13.0" + } + }, + "node_modules/terser-webpack-plugin/node_modules/serialize-javascript": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.2.tgz", + "integrity": "sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==", + "dependencies": { + "randombytes": "^2.1.0" + } + }, + "node_modules/terser-webpack-plugin/node_modules/supports-color": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", + "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/supports-color?sponsor=1" + } + }, + "node_modules/terser/node_modules/commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" + }, + "node_modules/terser/node_modules/source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dependencies": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, "node_modules/test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -23239,9 +23726,9 @@ } }, "node_modules/tinypool": { - "version": "0.8.3", - "resolved": "https://registry.npmjs.org/tinypool/-/tinypool-0.8.3.tgz", - "integrity": "sha512-Ud7uepAklqRH1bvwy22ynrliC7Dljz7Tm8M/0RBUW+YRa4YHhZ6e4PpgE+fu1zr/WqB1kbeuVrdfeuyIBpy4tw==", + "version": "0.8.4", + "resolved": "https://registry.npmjs.org/tinypool/-/tinypool-0.8.4.tgz", + "integrity": "sha512-i11VH5gS6IFeLY3gMBQ00/MmLncVP7JLXOw1vlgkytLmJK7QnEr7NXf0LBdxfmNPAeyetukOk0bOYrJrFGjYJQ==", "dev": true, "engines": { "node": ">=14.0.0" @@ -23759,9 +24246,9 @@ } }, "node_modules/typescript": { - "version": "5.4.3", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.3.tgz", - "integrity": "sha512-KrPd3PKaCLr78MalgiwJnA25Nm8HAmdwN3mYUYZgG/wizIo9EainNVQI9/yDavtVFRN2h3k8uf3GLHuhDMgEHg==", + "version": "5.4.5", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz", + "integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==", "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" @@ -23812,9 +24299,9 @@ } }, "node_modules/undici": { - "version": "5.28.3", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.3.tgz", - "integrity": "sha512-3ItfzbrhDlINjaP0duwnNsKpDQk3acHI3gVJ1z4fmwMK31k5G9OVIAMLSIaP6w4FaGkaAkN6zaQO9LUvZ1t7VA==", + "version": "5.28.4", + "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.4.tgz", + "integrity": "sha512-72RFADWFqKmUb2hmmvNODKL3p9hcB6Gt2DOQMis1SEBaV6a4MH8soBvzg+95CYhCKPFedut2JY9bMfrDl9D23g==", "dev": true, "dependencies": { "@fastify/busboy": "^2.0.0" @@ -23888,7 +24375,6 @@ "version": "1.0.13", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", - "dev": true, "funding": [ { "type": "opencollective", @@ -24066,6 +24552,18 @@ "makeerror": "1.0.12" } }, + "node_modules/watchpack": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.1.tgz", + "integrity": "sha512-8wrBCMtVhqcXP2Sup1ctSkga6uc2Bx0IIvKyT7yTFier5AXHooSI+QyQQAtTb7+E0IUCCKyTFmXqdqgum2XWGg==", + "dependencies": { + "glob-to-regexp": "^0.4.1", + "graceful-fs": "^4.1.2" + }, + "engines": { + "node": ">=10.13.0" + } + }, "node_modules/wcwidth": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", @@ -25781,9 +26279,13 @@ } }, "node_modules/webextension-polyfill": { - "version": "0.10.0", - "resolved": "https://registry.npmjs.org/webextension-polyfill/-/webextension-polyfill-0.10.0.tgz", - "integrity": "sha512-c5s35LgVa5tFaHhrZDnr3FpQpjj1BB+RXhLTYUxGqBVN460HkbM8TBtEqdXWbpTKfzwCcjAZVF7zXCYSKtcp9g==" + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/webextension-polyfill/-/webextension-polyfill-0.11.0.tgz", + "integrity": "sha512-YUBSKQA0iCx2YtM75VFgvvcx1hLKaGGiph6a6UaUdSgk32VT9SzrcDAKBjeGHXoAZTnNBqS5skA4VfoKMXhEBA==", + "dependencies": { + "webpack": "^5.91.0", + "webpack-cli": "^5.1.4" + } }, "node_modules/webextension-polyfill-ts": { "version": "0.25.0", @@ -25804,6 +26306,164 @@ "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" }, + "node_modules/webpack": { + "version": "5.91.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.91.0.tgz", + "integrity": "sha512-rzVwlLeBWHJbmgTC/8TvAcu5vpJNII+MelQpylD4jNERPwpBJOE2lEcko1zJX3QJeLjTTAnQxn/OJ8bjDzVQaw==", + "dependencies": { + "@types/eslint-scope": "^3.7.3", + "@types/estree": "^1.0.5", + "@webassemblyjs/ast": "^1.12.1", + "@webassemblyjs/wasm-edit": "^1.12.1", + "@webassemblyjs/wasm-parser": "^1.12.1", + "acorn": "^8.7.1", + "acorn-import-assertions": "^1.9.0", + "browserslist": "^4.21.10", + "chrome-trace-event": "^1.0.2", + "enhanced-resolve": "^5.16.0", + "es-module-lexer": "^1.2.1", + "eslint-scope": "5.1.1", + "events": "^3.2.0", + "glob-to-regexp": "^0.4.1", + "graceful-fs": "^4.2.11", + "json-parse-even-better-errors": "^2.3.1", + "loader-runner": "^4.2.0", + "mime-types": "^2.1.27", + "neo-async": "^2.6.2", + "schema-utils": "^3.2.0", + "tapable": "^2.1.1", + "terser-webpack-plugin": "^5.3.10", + "watchpack": "^2.4.1", + "webpack-sources": "^3.2.3" + }, + "bin": { + "webpack": "bin/webpack.js" + }, + "engines": { + "node": ">=10.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependenciesMeta": { + "webpack-cli": { + "optional": true + } + } + }, + "node_modules/webpack-cli": { + "version": "5.1.4", + "resolved": "https://registry.npmjs.org/webpack-cli/-/webpack-cli-5.1.4.tgz", + "integrity": "sha512-pIDJHIEI9LR0yxHXQ+Qh95k2EvXpWzZ5l+d+jIo+RdSm9MiHfzazIxwwni/p7+x4eJZuvG1AJwgC4TNQ7NRgsg==", + "dependencies": { + "@discoveryjs/json-ext": "^0.5.0", + "@webpack-cli/configtest": "^2.1.1", + "@webpack-cli/info": "^2.0.2", + "@webpack-cli/serve": "^2.0.5", + "colorette": "^2.0.14", + "commander": "^10.0.1", + "cross-spawn": "^7.0.3", + "envinfo": "^7.7.3", + "fastest-levenshtein": "^1.0.12", + "import-local": "^3.0.2", + "interpret": "^3.1.1", + "rechoir": "^0.8.0", + "webpack-merge": "^5.7.3" + }, + "bin": { + "webpack-cli": "bin/cli.js" + }, + "engines": { + "node": ">=14.15.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "5.x.x" + }, + "peerDependenciesMeta": { + "@webpack-cli/generators": { + "optional": true + }, + "webpack-bundle-analyzer": { + "optional": true + }, + "webpack-dev-server": { + "optional": true + } + } + }, + "node_modules/webpack-cli/node_modules/commander": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-10.0.1.tgz", + "integrity": "sha512-y4Mg2tXshplEbSGzx7amzPwKKOCGuoSRP/CjEdwwk0FOGlUbq6lKuoyDZTNZkmxHdJtp54hdfY/JUrdL7Xfdug==", + "engines": { + "node": ">=14" + } + }, + "node_modules/webpack-cli/node_modules/interpret": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-3.1.1.tgz", + "integrity": "sha512-6xwYfHbajpoF0xLW+iwLkhwgvLoZDfjYfoFNu8ftMoXINzwuymNLd9u/KmwtdT2GbR+/Cz66otEGEVVUHX9QLQ==", + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/webpack-cli/node_modules/rechoir": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.8.0.tgz", + "integrity": "sha512-/vxpCXddiX8NGfGO/mTafwjq4aFa/71pvamip0++IQk3zG8cbCj0fifNPrjjF1XMXUne91jL9OoxmdykoEtifQ==", + "dependencies": { + "resolve": "^1.20.0" + }, + "engines": { + "node": ">= 10.13.0" + } + }, + "node_modules/webpack-merge": { + "version": "5.10.0", + "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-5.10.0.tgz", + "integrity": "sha512-+4zXKdx7UnO+1jaN4l2lHVD+mFvnlZQP/6ljaJVb4SZiwIKeUnrT5l0gkT8z+n4hKpC+jpOv6O9R+gLtag7pSA==", + "dependencies": { + "clone-deep": "^4.0.1", + "flat": "^5.0.2", + "wildcard": "^2.0.0" + }, + "engines": { + "node": ">=10.0.0" + } + }, + "node_modules/webpack-sources": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz", + "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==", + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/webpack/node_modules/eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/webpack/node_modules/estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "engines": { + "node": ">=4.0" + } + }, "node_modules/websocket": { "version": "1.0.34", "resolved": "https://registry.npmjs.org/websocket/-/websocket-1.0.34.tgz", @@ -25946,6 +26606,11 @@ "node": ">=8" } }, + "node_modules/wildcard": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/wildcard/-/wildcard-2.0.1.tgz", + "integrity": "sha512-CC1bOL87PIWSBhDcTrdeLo6eGT7mCFtrg0uIJtqJUFyK+eJnzl8A1niH56uu7KMa5XFrtiV+AQuHO3n7DsHnLQ==" + }, "node_modules/word-wrap": { "version": "1.2.5", "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", @@ -26296,7 +26961,7 @@ }, "packages/build-utils/paima-build-utils": { "name": "@paima/build-utils", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "bin": { "paima-build-middleware": "scripts/esbuild.sh", @@ -26338,7 +27003,8 @@ "dependencies": { "@dcspark/cardano-multiplatform-lib-nodejs": "5.2.0", "@dcspark/carp-client": "^3.1.0", - "assert-never": "^1.2.1" + "assert-never": "^1.2.1", + "postgres": "^3.3.5" }, "devDependencies": { "typescript": "^5.3.3" @@ -26418,7 +27084,7 @@ }, "packages/node-sdk/paima-db": { "name": "@paima/db", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { "@pgtyped/runtime": "2.3.0", @@ -26432,10 +27098,10 @@ }, "packages/node-sdk/paima-utils-backend": { "name": "@paima/utils-backend", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { - "@paima/db": "2.2.0", + "@paima/db": "2.3.0", "yaml": "^2.3.1" }, "devDependencies": { @@ -26444,38 +27110,40 @@ }, "packages/node-sdk/publish-wrapper": { "name": "@paima/node-sdk", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { - "@paima/db": "2.2.0", - "@paima/utils-backend": "2.2.0" + "@paima/db": "2.3.0", + "@paima/utils-backend": "2.3.0" }, "devDependencies": {} }, "packages/paima-sdk/paima-concise": { "name": "@paima/concise", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { "ebnf": "^1.9.0", "web3-utils": "1.10.0" }, "devDependencies": { - "@paima/utils": "2.2.0", + "@paima/utils": "2.3.0", "@types/node": "^20.11.0" } }, "packages/paima-sdk/paima-crypto": { "name": "@paima/crypto", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { "@cardano-foundation/cardano-verify-datasignature": "^1.0.11", - "@paima/utils": "2.2.0", + "@paima/utils": "2.3.0", "@polkadot/util": "^10.4.2", "@polkadot/util-crypto": "^10.4.2", "algosdk": "^2.3.0", + "base58check": "^2.0.0", "bech32": "^2.0.0", + "mina-signer": "2.1.1", "tweetnacl": "^1.0.3", "web3": "1.10.0", "web3-utils": "1.10.0" @@ -26484,10 +27152,10 @@ }, "packages/paima-sdk/paima-executors": { "name": "@paima/executors", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { - "@paima/prando": "2.2.0" + "@paima/prando": "2.3.0" }, "devDependencies": { "typescript": "^5.3.3" @@ -26495,14 +27163,14 @@ }, "packages/paima-sdk/paima-mw-core": { "name": "@paima/mw-core", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { "@metamask/providers": "^10.2.1", - "@paima/concise": "2.2.0", - "@paima/prando": "2.2.0", - "@paima/providers": "2.2.0", - "@paima/utils": "2.2.0", + "@paima/concise": "2.3.0", + "@paima/prando": "2.3.0", + "@paima/providers": "2.3.0", + "@paima/utils": "2.3.0", "@perawallet/connect": "^1.2.3", "@polkadot/extension-dapp": "^0.44.9", "algosdk": "^2.3.0", @@ -26518,7 +27186,7 @@ }, "packages/paima-sdk/paima-prando": { "name": "@paima/prando", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "devDependencies": { "typescript": "^5.3.3" @@ -26526,13 +27194,14 @@ }, "packages/paima-sdk/paima-providers": { "name": "@paima/providers", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { + "@aurowallet/mina-provider": "^1.0.2", "@ethersproject/abstract-signer": "^5.7.0", "@metamask/providers": "^10.2.1", - "@paima/crypto": "2.2.0", - "@paima/utils": "2.2.0", + "@paima/crypto": "2.3.0", + "@paima/utils": "2.3.0", "@perawallet/connect": "^1.2.3", "@polkadot/extension-dapp": "^0.44.9", "assert-never": "^1.2.1", @@ -26543,22 +27212,22 @@ }, "packages/paima-sdk/paima-sdk": { "name": "@paima/sdk", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { - "@paima/concise": "2.2.0", - "@paima/crypto": "2.2.0", - "@paima/executors": "2.2.0", - "@paima/mw-core": "2.2.0", - "@paima/prando": "2.2.0", - "@paima/providers": "2.2.0", - "@paima/utils": "2.2.0" + "@paima/concise": "2.3.0", + "@paima/crypto": "2.3.0", + "@paima/executors": "2.3.0", + "@paima/mw-core": "2.3.0", + "@paima/prando": "2.3.0", + "@paima/providers": "2.3.0", + "@paima/utils": "2.3.0" }, "devDependencies": {} }, "packages/paima-sdk/paima-utils": { "name": "@paima/utils", - "version": "2.2.0", + "version": "2.3.0", "license": "See license file", "dependencies": { "@metamask/eth-json-rpc-middleware": "^12.0.0", diff --git a/packages/batcher/address-validator/src/index.ts b/packages/batcher/address-validator/src/index.ts index dd1821bbf..52caa57e2 100644 --- a/packages/batcher/address-validator/src/index.ts +++ b/packages/batcher/address-validator/src/index.ts @@ -85,6 +85,8 @@ class PaimaAddressValidator { return await CryptoManager.Polkadot().verifyAddress(address); case AddressType.ALGORAND: return await CryptoManager.Algorand().verifyAddress(address); + case AddressType.MINA: + return await CryptoManager.Mina().verifyAddress(address); case AddressType.UNKNOWN: return false; default: @@ -130,6 +132,12 @@ class PaimaAddressValidator { message, input.userSignature ); + case AddressType.MINA: + return await CryptoManager.Mina().verifySignature( + input.userAddress, + message, + input.userSignature + ); case AddressType.UNKNOWN: return false; default: diff --git a/packages/batcher/utils/src/index.ts b/packages/batcher/utils/src/index.ts index 21d0f0cbf..4a6a722fd 100644 --- a/packages/batcher/utils/src/index.ts +++ b/packages/batcher/utils/src/index.ts @@ -56,6 +56,7 @@ export const SUPPORTED_CHAIN_NAMES: string[] = [ addressTypeName(AddressType.POLKADOT), addressTypeName(AddressType.CARDANO), addressTypeName(AddressType.ALGORAND), + addressTypeName(AddressType.MINA), ]; const POLLING_INTERVAL = 10000; @@ -70,6 +71,8 @@ export function addressTypeName(addressType: AddressType): string { return 'Astar / Polkadot'; case AddressType.ALGORAND: return 'Algorand'; + case AddressType.MINA: + return 'Mina'; case AddressType.UNKNOWN: return 'Unknown address type'; default: diff --git a/packages/engine/paima-funnel/package.json b/packages/engine/paima-funnel/package.json index d1f33c654..f59aa0d18 100644 --- a/packages/engine/paima-funnel/package.json +++ b/packages/engine/paima-funnel/package.json @@ -19,6 +19,7 @@ "dependencies": { "assert-never": "^1.2.1", "@dcspark/carp-client": "^3.1.0", - "@dcspark/cardano-multiplatform-lib-nodejs": "5.2.0" + "@dcspark/cardano-multiplatform-lib-nodejs": "5.2.0", + "pg": "^8.11.3" } } diff --git a/packages/engine/paima-funnel/src/cde/minaGeneric.ts b/packages/engine/paima-funnel/src/cde/minaGeneric.ts new file mode 100644 index 000000000..b78647197 --- /dev/null +++ b/packages/engine/paima-funnel/src/cde/minaGeneric.ts @@ -0,0 +1,376 @@ +import type { + CdeMinaActionGenericDatum, + CdeMinaEventGenericDatum, + ChainDataExtensionMinaActionGeneric, + ChainDataExtensionMinaEventGeneric, +} from '@paima/sm'; +import { ChainDataExtensionDatumType } from '@paima/utils'; +import pg from 'pg'; + +export async function getEventCdeData(args: { + pg: pg.Client; + extension: ChainDataExtensionMinaEventGeneric; + fromTimestamp: number; + toTimestamp: number; + getBlockNumber: (minaTimestamp: number) => number; + network: string; + isPresync: boolean; + cursor?: string; + limit?: number; + fromBlockHeight?: number; +}): Promise<(CdeMinaActionGenericDatum | CdeMinaEventGenericDatum)[]> { + return getCdeData( + getEventsQuery, + ChainDataExtensionDatumType.MinaEventGeneric, + args.pg, + args.extension, + args.fromTimestamp, + args.toTimestamp, + args.getBlockNumber, + args.network, + args.isPresync, + args.cursor, + args.limit, + args.fromBlockHeight + ); +} + +export async function getActionCdeData(args: { + pg: pg.Client; + extension: ChainDataExtensionMinaActionGeneric; + fromTimestamp: number; + toTimestamp: number; + getBlockNumber: (minaTimestamp: number) => number; + network: string; + isPresync: boolean; + cursor?: string; + limit?: number; + fromBlockHeight?: number; +}): Promise<(CdeMinaActionGenericDatum | CdeMinaEventGenericDatum)[]> { + return getCdeData( + getActionsQuery, + ChainDataExtensionDatumType.MinaActionGeneric, + args.pg, + args.extension, + args.fromTimestamp, + args.toTimestamp, + args.getBlockNumber, + args.network, + args.isPresync, + args.cursor, + args.limit, + args.fromBlockHeight + ); +} + +export async function getCdeData( + query: typeof getEventsQuery | typeof getActionsQuery, + cdeDatumType: + | ChainDataExtensionDatumType.MinaActionGeneric + | ChainDataExtensionDatumType.MinaEventGeneric, + pg: pg.Client, + extension: ChainDataExtensionMinaEventGeneric | ChainDataExtensionMinaActionGeneric, + fromTimestamp: number, + toTimestamp: number, + getBlockNumber: (minaTimestamp: number) => number, + network: string, + isPresync: boolean, + cursor?: string, + limit?: number, + fromBlockHeight?: number +): Promise<(CdeMinaActionGenericDatum | CdeMinaEventGenericDatum)[]> { + const result = [] as (CdeMinaActionGenericDatum | CdeMinaEventGenericDatum)[]; + + while (true) { + const unmapped = await query( + pg, + extension.address, + toTimestamp.toString(), + fromTimestamp.toString(), + cursor, + limit?.toString(), + fromBlockHeight?.toString() + ); + + const grouped = groupByTx(unmapped.rows); + + const events = grouped.flatMap(perBlock => + perBlock.eventsData.map(txEvent => ({ + cdeId: extension.cdeId, + cdeDatumType, + blockNumber: getBlockNumber(Number.parseInt(perBlock.blockInfo.timestamp, 10)), + payload: txEvent, + network, + scheduledPrefix: extension.scheduledPrefix, + paginationCursor: { cursor: txEvent.txHash, finished: false }, + })) + ); + + if (events.length > 0) { + const last = events[events.length - 1]; + + cursor = last.paginationCursor.cursor; + } + + events.forEach(element => { + result.push(element); + }); + + if (events.length === 0 || isPresync) { + break; + } + } + + return result; +} + +function groupByTx(events: PerBlock[]) { + const grouped = [] as { + blockInfo: { + height: number; + timestamp: string; + }; + eventsData: { data: string[][]; txHash: string }[]; + }[]; + + for (const block of events) { + const eventData = [] as { data: string[][]; txHash: string }[]; + + for (const blockEvent of block.events) { + if ( + eventData[eventData.length - 1] && + blockEvent.hash == eventData[eventData.length - 1].txHash + ) { + eventData[eventData.length - 1].data.push(blockEvent.data); + } else { + eventData.push({ txHash: blockEvent.hash, data: [blockEvent.data] }); + } + } + + grouped.push({ + blockInfo: { height: block.height, timestamp: block.timestamp }, + eventsData: eventData, + }); + } + + return grouped; +} + +function canonicalChainCTE(toTimestamp?: string, fromTimestamp?: string, fromBlockHeight?: string) { + return ` + canonical_chain AS ( + SELECT + id, state_hash, height, global_slot_since_genesis, timestamp + FROM + blocks b + WHERE + 1=1 + ${fromTimestamp ? `AND b.timestamp::decimal >= ${fromTimestamp}::decimal` : ``} + ${toTimestamp ? `AND b.timestamp::decimal <= ${toTimestamp}::decimal` : ``} + ${fromBlockHeight ? `AND b.height::decimal >= ${fromBlockHeight}::decimal` : ``} + ORDER BY height + ) + `; +} + +function accountIdentifierCTE(address: string) { + return ` + account_identifier AS ( + SELECT + id AS requesting_zkapp_account_identifier_id + FROM + account_identifiers ai + WHERE + ai.public_key_id = (SELECT id FROM public_keys WHERE value = '${address}') + )`; +} + +function blocksAccessedCTE() { + return ` + blocks_accessed AS + ( + SELECT + requesting_zkapp_account_identifier_id, + block_id, + account_identifier_id, + zkapp_id, + id AS account_access_id, + state_hash, + height, + global_slot_since_genesis, + timestamp + FROM + account_identifier ai + INNER JOIN accounts_accessed aa ON ai.requesting_zkapp_account_identifier_id = aa.account_identifier_id + INNER JOIN canonical_chain b ON aa.block_id = b.id + )`; +} + +function emittedZkAppCommandsCTE(after?: string) { + return ` + emitted_zkapp_commands AS ( + SELECT + blocks_accessed.*, + zkcu.id AS zkapp_account_update_id, + zkapp_fee_payer_body_id, + zkapp_account_updates_ids, + authorization_kind, + status, + memo, + hash, + body_id, + events_id, + actions_id + FROM + blocks_accessed + INNER JOIN blocks_zkapp_commands bzkc ON blocks_accessed.block_id = bzkc.block_id + INNER JOIN zkapp_commands zkc ON bzkc.zkapp_command_id = zkc.id + INNER JOIN zkapp_account_update zkcu ON zkcu.id = ANY(zkc.zkapp_account_updates_ids) + INNER JOIN zkapp_account_update_body zkcu_body ON zkcu_body.id = zkcu.body_id + AND zkcu_body.account_identifier_id = requesting_zkapp_account_identifier_id + ${after ? `AND zkc.id > (SELECT id FROM zkapp_commands WHERE zkapp_commands.hash = '${after}')` : ``} + WHERE + bzkc.status <> 'failed' + )`; +} + +function emittedEventsCTE() { + return ` + emitted_events AS ( + SELECT + *, + zke.id AS zkapp_event_id, + zke.element_ids AS zkapp_event_element_ids, + zkfa.id AS zkapp_event_array_id + FROM + emitted_zkapp_commands + INNER JOIN zkapp_events zke ON zke.id = events_id + INNER JOIN zkapp_field_array zkfa ON zkfa.id = ANY(zke.element_ids) + INNER JOIN zkapp_field zkf ON zkf.id = ANY(zkfa.element_ids) + ) + `; +} + +function emittedActionsCTE() { + return ` + emitted_actions AS ( + SELECT + *, + zke.id AS zkapp_event_id, + zke.element_ids AS zkapp_event_element_ids, + zkfa.id AS zkapp_event_array_id + FROM + emitted_zkapp_commands + INNER JOIN zkapp_events zke ON zke.id = actions_id + INNER JOIN zkapp_field_array zkfa ON zkfa.id = ANY(zke.element_ids) + INNER JOIN zkapp_field zkf ON zkf.id = ANY(zkfa.element_ids) + ) + `; +} + +function emittedActionStateCTE() { + return ` + emitted_action_state AS ( + SELECT + emitted_actions.* + FROM + emitted_actions + INNER JOIN zkapp_accounts zkacc ON zkacc.id = emitted_actions.zkapp_id + INNER JOIN zkapp_action_states zks ON zks.id = zkacc.action_state_id + )`; +} + +type PerBlock = { + timestamp: string; + height: number; + + events: { + hash: string; + data: string[]; + }[]; +}; + +export function getEventsQuery( + db_client: pg.Client, + address: string, + toTimestamp?: string, + fromTimestamp?: string, + after?: string, + limit?: string, + fromBlockHeight?: string +) { + let query = ` + WITH + ${canonicalChainCTE(toTimestamp, fromTimestamp, fromBlockHeight)}, + ${accountIdentifierCTE(address)}, + ${blocksAccessedCTE()}, + ${emittedZkAppCommandsCTE(after)}, + ${emittedEventsCTE()}, + grouped_events AS ( + SELECT + MAX(timestamp) timestamp, + MAX(hash) hash, + JSON_AGG(field) events_data, + MAX(height) height + FROM emitted_events + GROUP BY ( + zkapp_account_update_id, + zkapp_event_array_id + ) + ORDER BY height + ) + SELECT + MAX(timestamp) timestamp, + height, + JSON_AGG(JSON_BUILD_OBJECT('hash', hash, 'data', events_data)) events + FROM grouped_events + GROUP BY height + ORDER BY height + ${limit ? `LIMIT ${limit}` : ``} + `; + + return db_client.query(query); +} + +export function getActionsQuery( + db_client: pg.Client, + address: string, + toTimestamp?: string, + fromTimestamp?: string, + after?: string, + limit?: string, + fromBlockHeight?: string +) { + const query = ` + WITH + ${canonicalChainCTE(toTimestamp, fromTimestamp, fromBlockHeight)}, + ${accountIdentifierCTE(address)}, + ${blocksAccessedCTE()}, + ${emittedZkAppCommandsCTE(after)}, + ${emittedActionsCTE()}, + ${emittedActionStateCTE()}, + grouped_events AS ( + SELECT + MAX(timestamp) timestamp, + MAX(hash) hash, + JSON_AGG(field) actions_data, + MAX(height) height + FROM emitted_actions + GROUP BY ( + zkapp_account_update_id, + zkapp_event_array_id + ) + ORDER BY height + ) + SELECT + MAX(timestamp) timestamp, + height, + JSON_AGG(JSON_BUILD_OBJECT('hash', hash, 'data', actions_data)) events + FROM grouped_events + GROUP BY height + ORDER BY height + ${limit ? `LIMIT ${limit}` : ``} + `; + + return db_client.query(query); +} diff --git a/packages/engine/paima-funnel/src/cde/reading.ts b/packages/engine/paima-funnel/src/cde/reading.ts index 0f53e4b1a..7cc43a4ab 100644 --- a/packages/engine/paima-funnel/src/cde/reading.ts +++ b/packages/engine/paima-funnel/src/cde/reading.ts @@ -58,13 +58,14 @@ async function getSpecificCdeData( return await getCdeErc1155Data(extension, fromBlock, toBlock, network); case ChainDataExtensionType.ERC6551Registry: return await getCdeErc6551RegistryData(extension, fromBlock, toBlock, network); + // these are not used by the block funnel case ChainDataExtensionType.CardanoPool: case ChainDataExtensionType.CardanoProjectedNFT: case ChainDataExtensionType.CardanoAssetUtxo: case ChainDataExtensionType.CardanoTransfer: case ChainDataExtensionType.CardanoMintBurn: - // this is used by the block funnel, which can't get information for this - // extension + case ChainDataExtensionType.MinaEventGeneric: + case ChainDataExtensionType.MinaActionGeneric: return []; default: assertNever(extension); diff --git a/packages/engine/paima-funnel/src/funnels/FunnelCache.ts b/packages/engine/paima-funnel/src/funnels/FunnelCache.ts index 161ebdf22..f8e0effcd 100644 --- a/packages/engine/paima-funnel/src/funnels/FunnelCache.ts +++ b/packages/engine/paima-funnel/src/funnels/FunnelCache.ts @@ -1,4 +1,5 @@ import type { ChainData } from '@paima/sm'; +import pg from 'pg'; export interface FunnelCacheEntry { /** @@ -13,6 +14,7 @@ export type CacheMapType = { [RpcCacheEntry.SYMBOL]?: RpcCacheEntry; [CarpFunnelCacheEntry.SYMBOL]?: CarpFunnelCacheEntry; [EvmFunnelCacheEntry.SYMBOL]?: EvmFunnelCacheEntry; + [MinaFunnelCacheEntry.SYMBOL]?: MinaFunnelCacheEntry; }; export class FunnelCacheManager { public cacheEntries: CacheMapType = {}; @@ -178,3 +180,59 @@ export class EvmFunnelCacheEntry implements FunnelCacheEntry { this.cachedData = {}; }; } + +export type MinaFunnelCacheEntryState = { + startingSlotTimestamp: number; + lastPoint: { timestamp: number } | undefined; + pg: pg.Client; + cursors: + | { + [cdeId: number]: { cursor: string; finished: boolean }; + } + | undefined; +}; + +export class MinaFunnelCacheEntry implements FunnelCacheEntry { + private state: MinaFunnelCacheEntryState | null = null; + public static readonly SYMBOL = Symbol('MinaFunnelStartingSlot'); + + public updateStartingTimestamp(startingSlotTimestamp: number, pg: pg.Client): void { + this.state = { + startingSlotTimestamp, + lastPoint: this.state?.lastPoint, + cursors: this.state?.cursors, + pg, + }; + } + + public updateLastPoint(timestamp: number): void { + if (this.state) { + this.state.lastPoint = { timestamp }; + } + } + + public updateCursor(cdeId: number, presyncCursor: { cursor: string; finished: boolean }): void { + if (this.state) { + if (!this.state.cursors) { + this.state.cursors = {}; + } + + this.state.cursors[cdeId] = presyncCursor; + } + } + + public initialized(): boolean { + return !!this.state; + } + + public getState(): Readonly { + if (!this.state) { + throw new Error('[mina-funnel] Uninitialized cache entry'); + } + return this.state; + } + + clear: FunnelCacheEntry['clear'] = () => { + this.state = null; + }; +} diff --git a/packages/engine/paima-funnel/src/funnels/carp/funnel.ts b/packages/engine/paima-funnel/src/funnels/carp/funnel.ts index 1605a7b50..cc0ddd3a5 100644 --- a/packages/engine/paima-funnel/src/funnels/carp/funnel.ts +++ b/packages/engine/paima-funnel/src/funnels/carp/funnel.ts @@ -30,7 +30,7 @@ import { query } from '@dcspark/carp-client'; import { Routes } from '@dcspark/carp-client'; import { FUNNEL_PRESYNC_FINISHED, InternalEventType } from '@paima/utils'; import { CarpFunnelCacheEntry } from '../FunnelCache.js'; -import { getCardanoEpoch, getCarpCursors } from '@paima/db'; +import { getCardanoEpoch, getPaginationCursors } from '@paima/db'; import type { BlockTxPair } from '@dcspark/carp-client'; const delayForWaitingForFinalityLoop = 1000; @@ -246,7 +246,7 @@ export class CarpFunnel extends BaseFunnel implements ChainFunnel { Promise.all( this.sharedData.extensions .filter(extension => { - if (!('startSlot' in extension)) { + if (extension.network !== this.chainName) { return false; } @@ -456,14 +456,24 @@ export class CarpFunnel extends BaseFunnel implements ChainFunnel { newEntry.updateEpoch(epoch[0].epoch); } - const cursors = await getCarpCursors.run(undefined, dbTx); - - for (const cursor of cursors) { - newEntry.updateCursor(cursor.cde_id, { - cursor: cursor.cursor, - finished: cursor.finished, + const cursors = await getPaginationCursors.run(undefined, dbTx); + + const extensions = sharedData.extensions + .filter(extensions => extensions.network === chainName) + .map(extension => extension.cdeId) + .reduce((set, cdeId) => { + set.add(cdeId); + return set; + }, new Set()); + + cursors + .filter(cursor => extensions.has(cursor.cde_id)) + .forEach(cursor => { + newEntry.updateCursor(cursor.cde_id, { + cursor: cursor.cursor, + finished: cursor.finished, + }); }); - } return newEntry; })(); diff --git a/packages/engine/paima-funnel/src/funnels/mina/funnel.ts b/packages/engine/paima-funnel/src/funnels/mina/funnel.ts new file mode 100644 index 000000000..845acfc4e --- /dev/null +++ b/packages/engine/paima-funnel/src/funnels/mina/funnel.ts @@ -0,0 +1,418 @@ +import { + doLog, + logError, + ChainDataExtensionType, + delay, + ENV, + InternalEventType, +} from '@paima/utils'; +import type { ChainFunnel, ReadPresyncDataFrom } from '@paima/runtime'; +import type { + ChainData, + ChainDataExtensionDatum, + MinaPresyncChainData, + PresyncChainData, +} from '@paima/sm'; +import { composeChainData, groupCdeData } from '../../utils.js'; +import { BaseFunnel } from '../BaseFunnel.js'; +import type { FunnelSharedData } from '../BaseFunnel.js'; +import type { PoolClient } from 'pg'; +import { FUNNEL_PRESYNC_FINISHED, ConfigNetworkType } from '@paima/utils'; +import { getMinaCheckpoint, getPaginationCursors } from '@paima/db'; +import { getActionCdeData, getEventCdeData } from '../../cde/minaGeneric.js'; +import type { MinaConfig } from '@paima/utils'; +import { MinaFunnelCacheEntry } from '../FunnelCache.js'; +import pg from 'pg'; +const { Client } = pg; + +const delayForWaitingForFinalityLoop = 1000; + +async function findMinaConfirmedTimestamp( + db: pg.Client, + confirmationDepth?: number +): Promise { + let row; + if (confirmationDepth) { + row = ( + await db.query(` + WITH RECURSIVE chain AS ( + (SELECT parent_id, id, timestamp, height FROM blocks b WHERE height = (select MAX(height) from blocks) + ORDER BY timestamp ASC + LIMIT 1) + UNION ALL + SELECT b.parent_id, b.id, b.timestamp, b.height FROM blocks b + INNER JOIN chain + ON b.id = chain.parent_id AND chain.id <> chain.parent_id + ) SELECT timestamp FROM chain c + LIMIT 1 + OFFSET ${confirmationDepth}; + `) + ).rows; + } else { + const res = await db.query( + `select timestamp from blocks where chain_status = 'canonical' order by height desc limit 1;` + ); + + row = res.rows; + } + + return Number.parseInt(row[0]['timestamp'], 10); +} + +// mina timestamps are in milliseconds, while evm timestamps are in seconds. +function baseChainTimestampToMina(baseChainTimestamp: number, delay: number): number { + return Math.max((baseChainTimestamp - delay) * 1000, 0); +} + +export class MinaFunnel extends BaseFunnel implements ChainFunnel { + config: MinaConfig; + chainName: string; + + protected constructor( + sharedData: FunnelSharedData, + dbTx: PoolClient, + config: MinaConfig, + chainName: string, + private readonly baseFunnel: ChainFunnel, + private cache: MinaFunnelCacheEntry + ) { + super(sharedData, dbTx); + this.readData.bind(this); + this.readPresyncData.bind(this); + this.getDbTx.bind(this); + this.config = config; + this.chainName = chainName; + } + + public override async readData(blockHeight: number): Promise { + const baseData = await this.baseFunnel.readData(blockHeight); + + if (baseData.length === 0) { + return baseData; + } + + let cachedState = this.cache.getState(); + + const maxBaseTimestamp = baseChainTimestampToMina( + baseData[baseData.length - 1].timestamp, + this.config.delay + ); + + while (true) { + const confirmedTimestamp = await findMinaConfirmedTimestamp( + cachedState.pg, + this.config.confirmationDepth + ); + + if (confirmedTimestamp >= maxBaseTimestamp) { + break; + } + + await delay(delayForWaitingForFinalityLoop); + } + + const lastRoundTimestamp = this.cache.getState().lastPoint?.timestamp; + const fromTimestamp = lastRoundTimestamp + ? lastRoundTimestamp + 1 + : cachedState.startingSlotTimestamp; + + const toTimestamp = maxBaseTimestamp; + + const getBlockNumber = (state: { curr: number }) => (ts: number) => { + while ( + state.curr < baseData.length && + baseChainTimestampToMina(baseData[state.curr].timestamp, this.config.delay) <= ts + ) + state.curr++; + + if (state.curr < baseData.length) { + return baseData[state.curr].blockNumber; + } else { + throw new Error('got event out of the expected range'); + } + }; + + const ungroupedCdeData = await Promise.all( + this.sharedData.extensions.reduce( + (promises, extension) => { + if (extension.cdeType === ChainDataExtensionType.MinaEventGeneric) { + const promise = getEventCdeData({ + pg: cachedState.pg, + extension, + fromTimestamp, + toTimestamp, + getBlockNumber: getBlockNumber({ curr: 0 }), + network: this.chainName, + isPresync: false, + cursor: undefined, + limit: this.config.paginationLimit, + }); + + promises.push(promise); + } + + if (extension.cdeType === ChainDataExtensionType.MinaActionGeneric) { + const promise = getActionCdeData({ + pg: cachedState.pg, + extension, + fromTimestamp, + toTimestamp, + getBlockNumber: getBlockNumber({ curr: 0 }), + network: this.chainName, + isPresync: false, + cursor: undefined, + limit: this.config.paginationLimit, + }); + + promises.push(promise); + } + + return promises; + }, + [] as Promise[] + ) + ); + + const grouped = groupCdeData( + this.chainName, + baseData[0].blockNumber, + baseData[baseData.length - 1].blockNumber, + ungroupedCdeData.filter(data => data.length > 0) + ); + + const composed = composeChainData(baseData, grouped); + + this.cache.updateLastPoint(toTimestamp); + + for (const chainData of composed) { + if (!chainData.internalEvents) { + chainData.internalEvents = []; + } + + chainData.internalEvents.push({ + type: InternalEventType.MinaLastTimestamp, + + timestamp: baseChainTimestampToMina(chainData.timestamp, this.config.delay).toString(), + network: this.chainName, + }); + } + + return composed; + } + + public override async readPresyncData(args: ReadPresyncDataFrom): Promise<{ + [network: string]: PresyncChainData[] | typeof FUNNEL_PRESYNC_FINISHED; + }> { + const basePromise = this.baseFunnel.readPresyncData(args); + + const cache = this.cache.getState(); + + const cursors = cache.cursors; + + if (cursors && Object.values(cursors).every(x => x.finished)) { + const data = await basePromise; + data[this.chainName] = FUNNEL_PRESYNC_FINISHED; + + return data; + } + + const mapCursorPaginatedData = (cdeId: number) => (datums: any) => { + const finished = datums.length === 0 || datums.length < this.config.paginationLimit; + + this.cache.updateCursor(cdeId, { + cursor: datums[datums.length - 1] ? datums[datums.length - 1].paginationCursor.cursor : '', + finished, + }); + + if (datums.length > 0) { + datums[datums.length - 1].paginationCursor.finished = finished; + } + + return datums; + }; + + const startingSlotTimestamp = this.cache.getState().startingSlotTimestamp; + + try { + const [baseData, ungroupedCdeData] = await Promise.all([ + basePromise, + Promise.all( + this.sharedData.extensions + .filter(extension => { + if (extension.network !== this.chainName) { + return false; + } + + if (cursors) { + const cursor = cursors[extension.cdeId]; + + if (!cursor) { + return true; + } + + return !cursor.finished; + } else { + return true; + } + }) + .map(async extension => { + if (extension.cdeType === ChainDataExtensionType.MinaEventGeneric) { + const cursor = cursors && cursors[extension.cdeId]; + + const data = await getEventCdeData({ + pg: cache.pg, + extension, + fromTimestamp: 0, + fromBlockHeight: extension.startBlockHeight, + toTimestamp: startingSlotTimestamp - 1, + // the handler for this cde stores the block height unmodified + // (even if the event is scheduled at the correct height), so + // handle this special case here, to have the events properly + // sorted. + getBlockNumber: _x => ENV.SM_START_BLOCKHEIGHT + 1, + network: this.chainName, + isPresync: true, + cursor: cursor?.cursor, + limit: this.config.paginationLimit, + }).then(mapCursorPaginatedData(extension.cdeId)); + + return { + cdeId: extension.cdeId, + cdeType: extension.cdeType, + data, + }; + } else if (extension.cdeType === ChainDataExtensionType.MinaActionGeneric) { + const cursor = cursors && cursors[extension.cdeId]; + + const data = await getActionCdeData({ + pg: cache.pg, + extension, + fromTimestamp: 0, + fromBlockHeight: extension.startBlockHeight, + toTimestamp: startingSlotTimestamp - 1, + getBlockNumber: _x => ENV.SM_START_BLOCKHEIGHT + 1, + network: this.chainName, + isPresync: true, + cursor: cursor?.cursor, + limit: this.config.paginationLimit, + }).then(mapCursorPaginatedData(extension.cdeId)); + + return { + cdeId: extension.cdeId, + cdeType: extension.cdeType, + data, + }; + } else { + throw new Error(`[mina funnel] unhandled extension: ${extension.cdeType}`); + } + }) + ), + ]); + + const list: MinaPresyncChainData[] = []; + + for (const events of ungroupedCdeData) { + for (const event of events.data || []) { + list.push({ + extensionDatums: [event], + network: this.chainName, + networkType: ConfigNetworkType.MINA, + minaCursor: { + cdeId: event.cdeId, + cursor: event.paginationCursor.cursor, + finished: event.paginationCursor.finished, + }, + }); + } + } + + baseData[this.chainName] = list; + + return baseData; + } catch (err) { + doLog(`[paima-funnel::readPresyncData] Exception occurred while reading blocks: ${err}`); + + throw err; + } + } + + public static async recoverState( + sharedData: FunnelSharedData, + dbTx: PoolClient, + baseFunnel: ChainFunnel, + chainName: string, + config: MinaConfig, + startingBlockHeight: number + ): Promise { + const cacheEntry = (async (): Promise => { + const entry = sharedData.cacheManager.cacheEntries[MinaFunnelCacheEntry.SYMBOL]; + if (entry != null && entry.initialized()) return entry; + + const newEntry = new MinaFunnelCacheEntry(); + sharedData.cacheManager.cacheEntries[MinaFunnelCacheEntry.SYMBOL] = newEntry; + + const pg = new Client({ connectionString: config.archiveConnectionString }); + await pg.connect(); + + const startingBlock = await sharedData.web3.eth.getBlock(startingBlockHeight); + const startingBlockTimestamp = startingBlock.timestamp as number; + + const minaTimestamp = baseChainTimestampToMina(startingBlockTimestamp, config.delay); + + newEntry.updateStartingTimestamp(minaTimestamp, pg); + + const cursors = await getPaginationCursors.run(undefined, dbTx); + + const extensions = sharedData.extensions + .filter(extensions => extensions.network === chainName) + .map(extension => extension.cdeId) + .reduce((set, cdeId) => { + set.add(cdeId); + return set; + }, new Set()); + + cursors + .filter(cursor => extensions.has(cursor.cde_id)) + .forEach(cursor => { + newEntry.updateCursor(cursor.cde_id, { + cursor: cursor.cursor, + finished: cursor.finished, + }); + }); + + const checkpoint = await getMinaCheckpoint.run({ network: chainName }, dbTx); + if (checkpoint.length > 0) { + newEntry.updateLastPoint(Number.parseInt(checkpoint[0].timestamp, 10)); + } + + return newEntry; + })(); + + return new MinaFunnel(sharedData, dbTx, config, chainName, baseFunnel, await cacheEntry); + } +} + +export async function wrapToMinaFunnel( + chainFunnel: ChainFunnel, + sharedData: FunnelSharedData, + dbTx: PoolClient, + startingBlockHeight: number, + chainName: string, + config: MinaConfig +): Promise { + try { + const ebp = await MinaFunnel.recoverState( + sharedData, + dbTx, + chainFunnel, + chainName, + config, + startingBlockHeight + ); + return ebp; + } catch (err) { + doLog('[paima-funnel] Unable to initialize mina cde events processor:'); + logError(err); + throw new Error('[paima-funnel] Unable to initialize mina cde events processor'); + } +} diff --git a/packages/engine/paima-funnel/src/index.ts b/packages/engine/paima-funnel/src/index.ts index dda1527d5..347a278ee 100644 --- a/packages/engine/paima-funnel/src/index.ts +++ b/packages/engine/paima-funnel/src/index.ts @@ -18,6 +18,7 @@ import { wrapToCarpFunnel } from './funnels/carp/funnel.js'; import { wrapToParallelEvmFunnel } from './funnels/parallelEvm/funnel.js'; import { ConfigNetworkType } from '@paima/utils'; import type Web3 from 'web3'; +import { wrapToMinaFunnel } from './funnels/mina/funnel.js'; export class FunnelFactory implements IFunnelFactory { private constructor(public sharedData: FunnelSharedData) {} @@ -93,6 +94,16 @@ export class FunnelFactory implements IFunnelFactory { ); } chainFunnel = await wrapToCarpFunnel(chainFunnel, this.sharedData, dbTx, ENV.START_BLOCKHEIGHT); + for (const [chainName, config] of await GlobalConfig.minaConfig()) { + chainFunnel = await wrapToMinaFunnel( + chainFunnel, + this.sharedData, + dbTx, + ENV.START_BLOCKHEIGHT, + chainName, + config + ); + } chainFunnel = await wrapToEmulatedBlocksFunnel( chainFunnel, this.sharedData, diff --git a/packages/engine/paima-funnel/src/paima-l2-processing.ts b/packages/engine/paima-funnel/src/paima-l2-processing.ts index b7bb917a9..b247b97f0 100644 --- a/packages/engine/paima-funnel/src/paima-l2-processing.ts +++ b/packages/engine/paima-funnel/src/paima-l2-processing.ts @@ -177,6 +177,8 @@ async function validateSubunitSignature( return await CryptoManager.Polkadot().verifySignature(userAddress, message, userSignature); case AddressType.ALGORAND: return await CryptoManager.Algorand().verifySignature(userAddress, message, userSignature); + case AddressType.MINA: + return await CryptoManager.Mina().verifySignature(userAddress, message, userSignature); default: return false; } diff --git a/packages/engine/paima-runtime/src/cde-config/loading.ts b/packages/engine/paima-runtime/src/cde-config/loading.ts index e92d2b721..9df5c5746 100644 --- a/packages/engine/paima-runtime/src/cde-config/loading.ts +++ b/packages/engine/paima-runtime/src/cde-config/loading.ts @@ -19,6 +19,7 @@ import { defaultEvmMainNetworkName, defaultCardanoNetworkName, getErc1155Contract, + defaultMinaNetworkName, } from '@paima/utils'; import type { @@ -43,6 +44,8 @@ import { ChainDataExtensionErc6551RegistryConfig, ChainDataExtensionErc721Config, ChainDataExtensionGenericConfig, + ChainDataExtensionMinaEventGenericConfig, + ChainDataExtensionMinaActionGenericConfig, } from '@paima/sm'; import { loadAbi } from './utils.js'; import assertNever from 'assert-never'; @@ -162,6 +165,18 @@ export function parseCdeConfigFile(configFileData: string): Static { const cdeId = cdeDatum.cdeId; diff --git a/packages/engine/paima-sm/src/cde-processing.ts b/packages/engine/paima-sm/src/cde-processing.ts index dcce614ae..13b29dd79 100644 --- a/packages/engine/paima-sm/src/cde-processing.ts +++ b/packages/engine/paima-sm/src/cde-processing.ts @@ -48,6 +48,10 @@ export async function cdeTransitionFunction( return await processCardanoTransferDatum(cdeDatum, inPresync); case ChainDataExtensionDatumType.CardanoMintBurn: return await processCardanoMintBurnDatum(cdeDatum, inPresync); + case ChainDataExtensionDatumType.MinaEventGeneric: + return await processGenericDatum(cdeDatum, inPresync); + case ChainDataExtensionDatumType.MinaActionGeneric: + return await processGenericDatum(cdeDatum, inPresync); default: assertNever(cdeDatum); } diff --git a/packages/engine/paima-sm/src/delegate-wallet.ts b/packages/engine/paima-sm/src/delegate-wallet.ts index ac64228bb..b8a3e79df 100644 --- a/packages/engine/paima-sm/src/delegate-wallet.ts +++ b/packages/engine/paima-sm/src/delegate-wallet.ts @@ -1,14 +1,13 @@ -import Web3 from 'web3'; import type { PoolClient } from 'pg'; import { PaimaParser } from '@paima/concise'; import { ENV, doLog } from '@paima/utils'; -import type { IVerify } from '@paima/crypto'; import { CryptoManager } from '@paima/crypto'; import type { IGetAddressFromAddressResult } from '@paima/db'; import { addressCache, deleteDelegationTo, + deleteDelegationsFrom, enableManualCache, getAddressFromAddress, getDelegation, @@ -32,7 +31,7 @@ type ParsedDelegateWalletCommand = command: 'migrate'; args: { from: string; to: string; from_signature: string; to_signature: string }; } - | { command: 'cancelDelegations'; args: { to_signature: string } }; + | { command: 'cancelDelegations'; args: { to: string } }; // Delegate Wallet manages cache cleanup. enableManualCache(); @@ -47,7 +46,7 @@ export class DelegateWallet { private static readonly delegationGrammar = ` delegate = &wd|from?|to?|from_signature|to_signature migrate = &wm|from?|to?|from_signature|to_signature - cancelDelegations = &wc|to_signature + cancelDelegations = &wc|to? `; private static readonly parserCommands = { @@ -64,7 +63,7 @@ export class DelegateWallet { to_signature: PaimaParser.NCharsParser(0, 1024), }, cancelDelegations: { - to_signature: PaimaParser.NCharsParser(0, 1024), + to: PaimaParser.OptionalParser('', PaimaParser.WalletAddress()), }, }; @@ -77,9 +76,7 @@ export class DelegateWallet { /* Generate Plaintext Message */ private generateMessage(internalMessage: string = ''): string { - return `${DelegateWallet.DELEGATE_WALLET_PREFIX}${ - DelegateWallet.SEP - }${internalMessage.toLocaleLowerCase()}${DelegateWallet.SEP}${ENV.CONTRACT_ADDRESS}`; + return `${DelegateWallet.DELEGATE_WALLET_PREFIX}${DelegateWallet.SEP}${internalMessage.toLocaleLowerCase()}`; } private validateSender(to: string, from: string, realAddress: string): void { @@ -255,11 +252,26 @@ export class DelegateWallet { } // Cancel Delegations. - // Delete all delegations from where TO=to - private async cmdCancelDelegations(to: string): Promise { - const [toAddress] = await getAddressFromAddress.run({ address: to }, this.DBConn); - if (!toAddress) throw new Error('Invalid Address'); - await deleteDelegationTo.run({ to_id: toAddress.id }, this.DBConn); + // if "to" is provided, delete delegations for "from" -> "to" + // if "to" is not provided, delete all delegations for "from" -> * + private async cmdCancelDelegations(from: string, to: string): Promise { + const [fromAddress] = await getAddressFromAddress.run({ address: from }, this.DBConn); + if (!fromAddress) throw new Error('Invalid Address'); + + if (to) { + const [toAddress] = await getAddressFromAddress.run({ address: to }, this.DBConn); + if (!toAddress) throw new Error('Invalid Address'); + + await deleteDelegationTo.run( + { + to_id: toAddress.id, + from_id: fromAddress.id, + }, + this.DBConn + ); + } else { + await deleteDelegationsFrom.run({ from_id: fromAddress.id }, this.DBConn); + } addressCache.clear(); } @@ -313,11 +325,11 @@ export class DelegateWallet { return true; } case 'cancelDelegations': { - const to = realAddress; - const { to_signature } = parsed.args; - await this.verifySignature(to, this.generateMessage(), to_signature); - await this.cmdCancelDelegations(to.toLocaleLowerCase()); - doLog(`Cancel Delegate 'to' ${to.substring(0, 8)}...`); + const { to } = parsed.args; + await this.cmdCancelDelegations(userAddress.toLocaleLowerCase(), to.toLocaleLowerCase()); + doLog( + `Cancel Delegate ${userAddress.substring(0, 8)}... -> ${to ? to.substring(0, 8) + '...' : '*'}` + ); return true; } default: diff --git a/packages/engine/paima-sm/src/index.ts b/packages/engine/paima-sm/src/index.ts index 0a6ec78f7..9a24626a8 100644 --- a/packages/engine/paima-sm/src/index.ts +++ b/packages/engine/paima-sm/src/index.ts @@ -28,7 +28,8 @@ import { getMainAddress, NO_USER_ID, updateCardanoEpoch, - updateCardanoPaginationCursor, + updatePaginationCursor, + updateMinaCheckpoint, } from '@paima/db'; import Prando from '@paima/prando'; @@ -119,7 +120,7 @@ const SM: GameStateMachineInitializer = { ); } } else if (latestCdeData.networkType === ConfigNetworkType.CARDANO) { - const cdeDataLength = await processCardanoCdeData( + const cdeDataLength = await processPaginatedCdeData( latestCdeData.carpCursor, latestCdeData.extensionDatums, dbTx, @@ -130,6 +131,18 @@ const SM: GameStateMachineInitializer = { `[${latestCdeData.network}] Processed ${cdeDataLength} CDE events in ${latestCdeData.carpCursor.cursor}` ); } + } else if (latestCdeData.networkType === ConfigNetworkType.MINA) { + const cdeDataLength = await processPaginatedCdeData( + latestCdeData.minaCursor, + latestCdeData.extensionDatums, + dbTx, + true + ); + if (cdeDataLength > 0) { + doLog( + `[${latestCdeData.network}] Processed ${cdeDataLength} CDE events in ${latestCdeData.minaCursor.cursor}` + ); + } } }, markPresyncMilestone: async ( @@ -306,34 +319,22 @@ async function processCdeData( }); } -async function processCardanoCdeData( - paginationCursor: - | { cdeId: number; cursor: string; finished: boolean } - | { cdeId: number; slot: number; finished: boolean }, +async function processPaginatedCdeData( + paginationCursor: { cdeId: number; cursor: string; finished: boolean }, cdeData: ChainDataExtensionDatum[] | undefined, dbTx: PoolClient, inPresync: boolean ): Promise { return await processCdeDataBase(cdeData, dbTx, inPresync, async () => { - if ('cursor' in paginationCursor) { - await updateCardanoPaginationCursor.run( - { - cde_id: paginationCursor.cdeId, - cursor: paginationCursor.cursor, - finished: paginationCursor.finished, - }, - dbTx - ); - } else { - await updateCardanoPaginationCursor.run( - { - cde_id: paginationCursor.cdeId, - cursor: paginationCursor.slot.toString(), - finished: paginationCursor.finished, - }, - dbTx - ); - } + await updatePaginationCursor.run( + { + cde_id: paginationCursor.cdeId, + cursor: paginationCursor.cursor, + finished: paginationCursor.finished, + }, + dbTx + ); + return; }); } @@ -414,7 +415,7 @@ async function processUserInputs( // // delegate = &wd|from?|to?|from_signature|to_signature // migrate = &wm|from?|to?|from_signature|to_signature - // cancelDelegate = &wc|to_signature + // cancelDelegate = &wc|to? const delegateWallet = new DelegateWallet(DBConn); if (inputData.inputData.startsWith(DelegateWallet.INTERNAL_COMMAND_PREFIX)) { const status = await delegateWallet.process( @@ -488,6 +489,15 @@ async function processInternalEvents( dbTx ); break; + case InternalEventType.MinaLastTimestamp: + await updateMinaCheckpoint.run( + { + timestamp: event.timestamp, + network: event.network, + }, + dbTx + ); + break; default: assertNever(event); } diff --git a/packages/engine/paima-sm/src/types.ts b/packages/engine/paima-sm/src/types.ts index 7ba427681..01a0234cb 100644 --- a/packages/engine/paima-sm/src/types.ts +++ b/packages/engine/paima-sm/src/types.ts @@ -35,13 +35,18 @@ export interface ChainData { internalEvents?: InternalEvent[]; } -export type InternalEvent = CardanoEpochEvent | EvmLastBlockEvent; +export type InternalEvent = CardanoEpochEvent | EvmLastBlockEvent | MinaLastTimestampEvent; export type CardanoEpochEvent = { type: InternalEventType.CardanoBestEpoch; epoch: number }; export type EvmLastBlockEvent = { type: InternalEventType.EvmLastBlock; block: number; network: string; }; +export type MinaLastTimestampEvent = { + type: InternalEventType.MinaLastTimestamp; + timestamp: string; + network: string; +}; export interface EvmPresyncChainData { network: string; @@ -57,7 +62,14 @@ export interface CardanoPresyncChainData { extensionDatums: ChainDataExtensionDatum[]; } -export type PresyncChainData = EvmPresyncChainData | CardanoPresyncChainData; +export interface MinaPresyncChainData { + network: string; + networkType: ConfigNetworkType.MINA; + minaCursor: { cdeId: number; cursor: string; finished: boolean }; + extensionDatums: ChainDataExtensionDatum[]; +} + +export type PresyncChainData = EvmPresyncChainData | CardanoPresyncChainData | MinaPresyncChainData; interface CdeDatumErc20TransferPayload { from: string; @@ -247,6 +259,17 @@ export interface CdeCardanoMintBurnDatum extends CdeDatumBase { paginationCursor: { cursor: string; finished: boolean }; } +export interface CdeMinaEventGenericDatum extends CdeDatumBase { + cdeDatumType: ChainDataExtensionDatumType.MinaEventGeneric; + paginationCursor: { cursor: string; finished: boolean }; + scheduledPrefix: string; +} +export interface CdeMinaActionGenericDatum extends CdeDatumBase { + cdeDatumType: ChainDataExtensionDatumType.MinaActionGeneric; + paginationCursor: { cursor: string; finished: boolean }; + scheduledPrefix: string; +} + export type ChainDataExtensionDatum = | CdeErc20TransferDatum | CdeErc721MintDatum @@ -259,7 +282,9 @@ export type ChainDataExtensionDatum = | CdeCardanoProjectedNFTDatum | CdeCardanoAssetUtxoDatum | CdeCardanoTransferDatum - | CdeCardanoMintBurnDatum; + | CdeCardanoMintBurnDatum + | CdeMinaEventGenericDatum + | CdeMinaActionGenericDatum; export enum CdeEntryTypeName { Generic = 'generic', @@ -273,6 +298,8 @@ export enum CdeEntryTypeName { CardanoDelayedAsset = 'cardano-delayed-asset', CardanoTransfer = 'cardano-transfer', CardanoMintBurn = 'cardano-mint-burn', + MinaEventGeneric = 'mina-event-generic', + MinaActionGeneric = 'mina-action-generic', } const EvmAddress = Type.Transform(Type.RegExp('0x[0-9a-fA-F]{40}')) @@ -462,6 +489,38 @@ export type ChainDataExtensionCardanoMintBurn = ChainDataExtensionBase & cdeType: ChainDataExtensionType.CardanoMintBurn; }; +export const ChainDataExtensionMinaEventGenericConfig = Type.Object({ + type: Type.Literal(CdeEntryTypeName.MinaEventGeneric), + address: Type.String(), + scheduledPrefix: Type.String(), + startBlockHeight: Type.Number(), + name: Type.String(), +}); + +export type TChainDataExtensionMinaEventGenericConfig = Static< + typeof ChainDataExtensionGenericConfig +>; +export type ChainDataExtensionMinaEventGeneric = ChainDataExtensionBase & + Static & { + cdeType: ChainDataExtensionType.MinaEventGeneric; + }; + +export const ChainDataExtensionMinaActionGenericConfig = Type.Object({ + type: Type.Literal(CdeEntryTypeName.MinaActionGeneric), + address: Type.String(), + scheduledPrefix: Type.String(), + startBlockHeight: Type.Number(), + name: Type.String(), +}); + +export type TChainDataExtensionMinaActionGenericConfig = Static< + typeof ChainDataExtensionGenericConfig +>; +export type ChainDataExtensionMinaActionGeneric = ChainDataExtensionBase & + Static & { + cdeType: ChainDataExtensionType.MinaActionGeneric; + }; + export const CdeConfig = Type.Object({ extensions: Type.Array( Type.Intersect([ @@ -477,6 +536,8 @@ export const CdeConfig = Type.Object({ ChainDataExtensionCardanoDelayedAssetConfig, ChainDataExtensionCardanoTransferConfig, ChainDataExtensionCardanoMintBurnConfig, + ChainDataExtensionMinaEventGenericConfig, + ChainDataExtensionMinaActionGenericConfig, ]), Type.Partial(Type.Object({ network: Type.String() })), ]) @@ -509,6 +570,8 @@ export type ChainDataExtension = ( | ChainDataExtensionCardanoDelayedAsset | ChainDataExtensionCardanoTransfer | ChainDataExtensionCardanoMintBurn + | ChainDataExtensionMinaEventGeneric + | ChainDataExtensionMinaActionGeneric ) & { network: string | undefined }; export type GameStateTransitionFunctionRouter = ( diff --git a/packages/node-sdk/paima-db/migrations/up.sql b/packages/node-sdk/paima-db/migrations/up.sql index 62a3722b5..e406877ae 100644 --- a/packages/node-sdk/paima-db/migrations/up.sql +++ b/packages/node-sdk/paima-db/migrations/up.sql @@ -218,7 +218,7 @@ CREATE TABLE cde_cardano_asset_utxos ( PRIMARY KEY(cde_id,tx_id,output_index,cip14_fingerprint) ); -CREATE TABLE cde_tracking_cardano_pagination ( +CREATE TABLE cde_tracking_cursor_pagination ( cde_id INTEGER PRIMARY KEY, cursor TEXT NOT NULL, finished BOOLEAN NOT NULL @@ -242,6 +242,12 @@ CREATE TABLE cde_cardano_mint_burn( PRIMARY KEY (cde_id, tx_id) ); +CREATE TABLE mina_checkpoint ( + timestamp TEXT NOT NULL, + network TEXT NOT NULL, + PRIMARY KEY (network) +); + CREATE TABLE achievement_progress( wallet TEXT NOT NULL, name TEXT NOT NULL, diff --git a/packages/node-sdk/paima-db/src/index.ts b/packages/node-sdk/paima-db/src/index.ts index 563af261a..311a9c28a 100644 --- a/packages/node-sdk/paima-db/src/index.ts +++ b/packages/node-sdk/paima-db/src/index.ts @@ -53,11 +53,13 @@ export { cdeSpendCardanoAssetUtxo, ICdeCardanoAssetUtxosByAddressParams, } from './sql/cde-cardano-asset-utxos.queries.js'; -export * from './sql/cde-cardano-tracking-pagination.queries.js'; -export type * from './sql/cde-cardano-tracking-pagination.queries.js'; +export * from './sql/cde-cursor-tracking-pagination.queries.js'; +export type * from './sql/cde-cursor-tracking-pagination.queries.js'; export * from './sql/cde-cardano-transfer.queries.js'; export type * from './sql/cde-cardano-transfer.queries.js'; export { cdeCardanoMintBurnInsert } from './sql/cde-cardano-mint-burn.queries.js'; +export type * from './sql/mina-checkpoints.queries.js'; +export * from './sql/mina-checkpoints.queries.js'; export { tx, diff --git a/packages/node-sdk/paima-db/src/paima-tables.ts b/packages/node-sdk/paima-db/src/paima-tables.ts index 4a5844074..32a7f5e03 100644 --- a/packages/node-sdk/paima-db/src/paima-tables.ts +++ b/packages/node-sdk/paima-db/src/paima-tables.ts @@ -118,16 +118,16 @@ const TABLE_DATA_CDE_TRACKING_CARDANO: TableData = { creationQuery: QUERY_CREATE_TABLE_CDE_TRACKING_CARDANO, }; -const QUERY_CREATE_TABLE_CDE_TRACKING_CARDANO_PAGINATION = ` -CREATE TABLE cde_tracking_cardano_pagination ( +const QUERY_CREATE_TABLE_CDE_TRACKING_CURSOR_PAGINATION = ` +CREATE TABLE cde_tracking_cursor_pagination ( cde_id INTEGER PRIMARY KEY, cursor TEXT NOT NULL, finished BOOLEAN NOT NULL ); `; -const TABLE_DATA_CDE_TRACKING_CARDANO_PAGINATION: TableData = { - tableName: 'cde_tracking_cardano_pagination', +const TABLE_DATA_CDE_TRACKING_CURSOR_PAGINATION: TableData = { + tableName: 'cde_tracking_cursor_pagination', primaryKeyColumns: ['cde_id'], columnData: packTuples([ ['cde_id', 'integer', 'NO', ''], @@ -135,7 +135,7 @@ const TABLE_DATA_CDE_TRACKING_CARDANO_PAGINATION: TableData = { ['finished', 'boolean', 'NO', ''], ]), serialColumns: [], - creationQuery: QUERY_CREATE_TABLE_CDE_TRACKING_CARDANO_PAGINATION, + creationQuery: QUERY_CREATE_TABLE_CDE_TRACKING_CURSOR_PAGINATION, }; const QUERY_CREATE_TABLE_CDE = ` @@ -576,6 +576,25 @@ const TABLE_DATA_DELEGATIONS: TableData = { creationQuery: QUERY_CREATE_TABLE_DELEGATIONS, }; +const QUERY_CREATE_TABLE_MINA_CHECKPOINT = ` +CREATE TABLE mina_checkpoint ( + timestamp TEXT NOT NULL, + network TEXT NOT NULL, + PRIMARY KEY (network) +); +`; + +const TABLE_DATA_MINA_CHECKPOINT: TableData = { + tableName: 'mina_checkpoint', + primaryKeyColumns: ['network'], + columnData: packTuples([ + ['timestamp', 'text', 'NO', ''], + ['network', 'text', 'NO', ''], + ]), + serialColumns: [], + creationQuery: QUERY_CREATE_TABLE_MINA_CHECKPOINT, +}; + const QUERY_CREATE_TABLE_ACHIEVEMENT_PROGRESS = ` CREATE TABLE achievement_progress( wallet TEXT NOT NULL, @@ -685,8 +704,9 @@ export const TABLES: TableData[] = [ TABLE_DATA_ADDRESSES, TABLE_DATA_DELEGATIONS, TABLE_DATA_CARDANO_LAST_EPOCH, - TABLE_DATA_CDE_TRACKING_CARDANO_PAGINATION, + TABLE_DATA_CDE_TRACKING_CURSOR_PAGINATION, TABLE_DATA_CDE_CARDANO_TRANSFER, TABLE_DATA_CDE_CARDANO_MINT_BURN, + TABLE_DATA_MINA_CHECKPOINT, TABLE_DATA_ACHIEVEMENT_PROGRESS, ]; diff --git a/packages/node-sdk/paima-db/src/sql/cde-cardano-tracking-pagination.queries.ts b/packages/node-sdk/paima-db/src/sql/cde-cardano-tracking-pagination.queries.ts deleted file mode 100644 index 5e5d5a524..000000000 --- a/packages/node-sdk/paima-db/src/sql/cde-cardano-tracking-pagination.queries.ts +++ /dev/null @@ -1,67 +0,0 @@ -/** Types generated for queries found in "src/sql/cde-cardano-tracking-pagination.sql" */ -import { PreparedQuery } from '@pgtyped/runtime'; - -/** 'GetCarpCursors' parameters type */ -export type IGetCarpCursorsParams = void; - -/** 'GetCarpCursors' return type */ -export interface IGetCarpCursorsResult { - cde_id: number; - cursor: string; - finished: boolean; -} - -/** 'GetCarpCursors' query type */ -export interface IGetCarpCursorsQuery { - params: IGetCarpCursorsParams; - result: IGetCarpCursorsResult; -} - -const getCarpCursorsIR: any = {"usedParamSet":{},"params":[],"statement":"select * from cde_tracking_cardano_pagination"}; - -/** - * Query generated from SQL: - * ``` - * select * from cde_tracking_cardano_pagination - * ``` - */ -export const getCarpCursors = new PreparedQuery(getCarpCursorsIR); - - -/** 'UpdateCardanoPaginationCursor' parameters type */ -export interface IUpdateCardanoPaginationCursorParams { - cde_id: number; - cursor: string; - finished: boolean; -} - -/** 'UpdateCardanoPaginationCursor' return type */ -export type IUpdateCardanoPaginationCursorResult = void; - -/** 'UpdateCardanoPaginationCursor' query type */ -export interface IUpdateCardanoPaginationCursorQuery { - params: IUpdateCardanoPaginationCursorParams; - result: IUpdateCardanoPaginationCursorResult; -} - -const updateCardanoPaginationCursorIR: any = {"usedParamSet":{"cde_id":true,"cursor":true,"finished":true},"params":[{"name":"cde_id","required":true,"transform":{"type":"scalar"},"locs":[{"a":89,"b":96}]},{"name":"cursor","required":true,"transform":{"type":"scalar"},"locs":[{"a":101,"b":108},{"a":170,"b":177}]},{"name":"finished","required":true,"transform":{"type":"scalar"},"locs":[{"a":113,"b":122},{"a":191,"b":200}]}],"statement":"INSERT INTO cde_tracking_cardano_pagination(\n cde_id,\n cursor,\n finished\n) VALUES (\n :cde_id!,\n :cursor!,\n :finished!\n)\nON CONFLICT (cde_id)\nDO UPDATE SET cursor = :cursor!, finished = :finished!"}; - -/** - * Query generated from SQL: - * ``` - * INSERT INTO cde_tracking_cardano_pagination( - * cde_id, - * cursor, - * finished - * ) VALUES ( - * :cde_id!, - * :cursor!, - * :finished! - * ) - * ON CONFLICT (cde_id) - * DO UPDATE SET cursor = :cursor!, finished = :finished! - * ``` - */ -export const updateCardanoPaginationCursor = new PreparedQuery(updateCardanoPaginationCursorIR); - - diff --git a/packages/node-sdk/paima-db/src/sql/cde-cardano-tracking-pagination.sql b/packages/node-sdk/paima-db/src/sql/cde-cardano-tracking-pagination.sql deleted file mode 100644 index 31307a50b..000000000 --- a/packages/node-sdk/paima-db/src/sql/cde-cardano-tracking-pagination.sql +++ /dev/null @@ -1,15 +0,0 @@ -/* @name getCarpCursors */ -select * from cde_tracking_cardano_pagination; - -/* @name updateCardanoPaginationCursor */ -INSERT INTO cde_tracking_cardano_pagination( - cde_id, - cursor, - finished -) VALUES ( - :cde_id!, - :cursor!, - :finished! -) -ON CONFLICT (cde_id) -DO UPDATE SET cursor = :cursor!, finished = :finished!; \ No newline at end of file diff --git a/packages/node-sdk/paima-db/src/sql/cde-cursor-tracking-pagination.queries.ts b/packages/node-sdk/paima-db/src/sql/cde-cursor-tracking-pagination.queries.ts new file mode 100644 index 000000000..de0533d8e --- /dev/null +++ b/packages/node-sdk/paima-db/src/sql/cde-cursor-tracking-pagination.queries.ts @@ -0,0 +1,67 @@ +/** Types generated for queries found in "src/sql/cde-cursor-tracking-pagination.sql" */ +import { PreparedQuery } from '@pgtyped/runtime'; + +/** 'GetPaginationCursors' parameters type */ +export type IGetPaginationCursorsParams = void; + +/** 'GetPaginationCursors' return type */ +export interface IGetPaginationCursorsResult { + cde_id: number; + cursor: string; + finished: boolean; +} + +/** 'GetPaginationCursors' query type */ +export interface IGetPaginationCursorsQuery { + params: IGetPaginationCursorsParams; + result: IGetPaginationCursorsResult; +} + +const getPaginationCursorsIR: any = {"usedParamSet":{},"params":[],"statement":"select * from cde_tracking_cursor_pagination"}; + +/** + * Query generated from SQL: + * ``` + * select * from cde_tracking_cursor_pagination + * ``` + */ +export const getPaginationCursors = new PreparedQuery(getPaginationCursorsIR); + + +/** 'UpdatePaginationCursor' parameters type */ +export interface IUpdatePaginationCursorParams { + cde_id: number; + cursor: string; + finished: boolean; +} + +/** 'UpdatePaginationCursor' return type */ +export type IUpdatePaginationCursorResult = void; + +/** 'UpdatePaginationCursor' query type */ +export interface IUpdatePaginationCursorQuery { + params: IUpdatePaginationCursorParams; + result: IUpdatePaginationCursorResult; +} + +const updatePaginationCursorIR: any = {"usedParamSet":{"cde_id":true,"cursor":true,"finished":true},"params":[{"name":"cde_id","required":true,"transform":{"type":"scalar"},"locs":[{"a":88,"b":95}]},{"name":"cursor","required":true,"transform":{"type":"scalar"},"locs":[{"a":100,"b":107},{"a":169,"b":176}]},{"name":"finished","required":true,"transform":{"type":"scalar"},"locs":[{"a":112,"b":121},{"a":190,"b":199}]}],"statement":"INSERT INTO cde_tracking_cursor_pagination(\n cde_id,\n cursor,\n finished\n) VALUES (\n :cde_id!,\n :cursor!,\n :finished!\n)\nON CONFLICT (cde_id)\nDO UPDATE SET cursor = :cursor!, finished = :finished!"}; + +/** + * Query generated from SQL: + * ``` + * INSERT INTO cde_tracking_cursor_pagination( + * cde_id, + * cursor, + * finished + * ) VALUES ( + * :cde_id!, + * :cursor!, + * :finished! + * ) + * ON CONFLICT (cde_id) + * DO UPDATE SET cursor = :cursor!, finished = :finished! + * ``` + */ +export const updatePaginationCursor = new PreparedQuery(updatePaginationCursorIR); + + diff --git a/packages/node-sdk/paima-db/src/sql/cde-cursor-tracking-pagination.sql b/packages/node-sdk/paima-db/src/sql/cde-cursor-tracking-pagination.sql new file mode 100644 index 000000000..9e25d295d --- /dev/null +++ b/packages/node-sdk/paima-db/src/sql/cde-cursor-tracking-pagination.sql @@ -0,0 +1,15 @@ +/* @name getPaginationCursors */ +select * from cde_tracking_cursor_pagination; + +/* @name updatePaginationCursor */ +INSERT INTO cde_tracking_cursor_pagination( + cde_id, + cursor, + finished +) VALUES ( + :cde_id!, + :cursor!, + :finished! +) +ON CONFLICT (cde_id) +DO UPDATE SET cursor = :cursor!, finished = :finished!; \ No newline at end of file diff --git a/packages/node-sdk/paima-db/src/sql/mina-checkpoints.queries.ts b/packages/node-sdk/paima-db/src/sql/mina-checkpoints.queries.ts new file mode 100644 index 000000000..0c61c3d68 --- /dev/null +++ b/packages/node-sdk/paima-db/src/sql/mina-checkpoints.queries.ts @@ -0,0 +1,64 @@ +/** Types generated for queries found in "src/sql/mina-checkpoints.sql" */ +import { PreparedQuery } from '@pgtyped/runtime'; + +/** 'UpdateMinaCheckpoint' parameters type */ +export interface IUpdateMinaCheckpointParams { + network: string; + timestamp: string; +} + +/** 'UpdateMinaCheckpoint' return type */ +export type IUpdateMinaCheckpointResult = void; + +/** 'UpdateMinaCheckpoint' query type */ +export interface IUpdateMinaCheckpointQuery { + params: IUpdateMinaCheckpointParams; + result: IUpdateMinaCheckpointResult; +} + +const updateMinaCheckpointIR: any = {"usedParamSet":{"timestamp":true,"network":true},"params":[{"name":"timestamp","required":true,"transform":{"type":"scalar"},"locs":[{"a":71,"b":81},{"a":149,"b":159}]},{"name":"network","required":true,"transform":{"type":"scalar"},"locs":[{"a":88,"b":96}]}],"statement":"INSERT INTO mina_checkpoint(\n timestamp,\n network\n) VALUES (\n :timestamp!,\n :network!\n) \nON CONFLICT (network) DO\nUPDATE SET timestamp = :timestamp!"}; + +/** + * Query generated from SQL: + * ``` + * INSERT INTO mina_checkpoint( + * timestamp, + * network + * ) VALUES ( + * :timestamp!, + * :network! + * ) + * ON CONFLICT (network) DO + * UPDATE SET timestamp = :timestamp! + * ``` + */ +export const updateMinaCheckpoint = new PreparedQuery(updateMinaCheckpointIR); + + +/** 'GetMinaCheckpoint' parameters type */ +export interface IGetMinaCheckpointParams { + network: string; +} + +/** 'GetMinaCheckpoint' return type */ +export interface IGetMinaCheckpointResult { + timestamp: string; +} + +/** 'GetMinaCheckpoint' query type */ +export interface IGetMinaCheckpointQuery { + params: IGetMinaCheckpointParams; + result: IGetMinaCheckpointResult; +} + +const getMinaCheckpointIR: any = {"usedParamSet":{"network":true},"params":[{"name":"network","required":true,"transform":{"type":"scalar"},"locs":[{"a":54,"b":62}]}],"statement":"SELECT timestamp FROM mina_checkpoint WHERE network = :network! LIMIT 1"}; + +/** + * Query generated from SQL: + * ``` + * SELECT timestamp FROM mina_checkpoint WHERE network = :network! LIMIT 1 + * ``` + */ +export const getMinaCheckpoint = new PreparedQuery(getMinaCheckpointIR); + + diff --git a/packages/node-sdk/paima-db/src/sql/mina-checkpoints.sql b/packages/node-sdk/paima-db/src/sql/mina-checkpoints.sql new file mode 100644 index 000000000..da8f6e9e1 --- /dev/null +++ b/packages/node-sdk/paima-db/src/sql/mina-checkpoints.sql @@ -0,0 +1,13 @@ +/* @name updateMinaCheckpoint */ +INSERT INTO mina_checkpoint( + timestamp, + network +) VALUES ( + :timestamp!, + :network! +) +ON CONFLICT (network) DO +UPDATE SET timestamp = :timestamp!; + +/* @name getMinaCheckpoint */ +SELECT timestamp FROM mina_checkpoint WHERE network = :network! LIMIT 1; diff --git a/packages/node-sdk/paima-db/src/sql/wallet-delegation.queries.ts b/packages/node-sdk/paima-db/src/sql/wallet-delegation.queries.ts index 96133a2f8..61a33011a 100644 --- a/packages/node-sdk/paima-db/src/sql/wallet-delegation.queries.ts +++ b/packages/node-sdk/paima-db/src/sql/wallet-delegation.queries.ts @@ -320,6 +320,7 @@ export const deleteDelegationsFrom = new PreparedQuery(deleteDelegationToIR); diff --git a/packages/node-sdk/paima-db/src/sql/wallet-delegation.sql b/packages/node-sdk/paima-db/src/sql/wallet-delegation.sql index ca20cd613..b563da902 100644 --- a/packages/node-sdk/paima-db/src/sql/wallet-delegation.sql +++ b/packages/node-sdk/paima-db/src/sql/wallet-delegation.sql @@ -47,7 +47,8 @@ WHERE from_id = :from_id!; /* @name deleteDelegationTo */ DELETE FROM delegations -WHERE to_id = :to_id!; +WHERE to_id = :to_id! +and from_id = :from_id!; /* @name deleteAddress */ DELETE FROM addresses diff --git a/packages/paima-sdk/paima-crypto/package.json b/packages/paima-sdk/paima-crypto/package.json index 66d619745..91af1a8d1 100644 --- a/packages/paima-sdk/paima-crypto/package.json +++ b/packages/paima-sdk/paima-crypto/package.json @@ -33,6 +33,8 @@ "@polkadot/util": "^10.4.2", "@polkadot/util-crypto": "^10.4.2", "bech32": "^2.0.0", - "@paima/utils": "2.3.0" + "@paima/utils": "2.3.0", + "mina-signer": "^2.1.1", + "base58check": "^2.0.0" } } diff --git a/packages/paima-sdk/paima-crypto/src/index.ts b/packages/paima-sdk/paima-crypto/src/index.ts index 8ca11ded7..e2a0f9f52 100644 --- a/packages/paima-sdk/paima-crypto/src/index.ts +++ b/packages/paima-sdk/paima-crypto/src/index.ts @@ -2,6 +2,7 @@ import { AlgorandCrypto } from './algorand.js'; import { CardanoCrypto } from './cardano.js'; import { EvmCrypto } from './evm.js'; import { PolkadotCrypto } from './polkadot.js'; +import { MinaCrypto } from './mina.js'; export { AlgorandCrypto, CardanoCrypto, EvmCrypto, PolkadotCrypto }; export type * from './IVerify.js'; @@ -13,6 +14,7 @@ export class CryptoManager { private static cardano: CardanoCrypto | undefined; private static evm: EvmCrypto | undefined; private static polkadot: PolkadotCrypto | undefined; + private static mina: MinaCrypto | undefined; static Algorand(): AlgorandCrypto { if (CryptoManager.algorand == null) { @@ -41,4 +43,11 @@ export class CryptoManager { } return CryptoManager.polkadot; } + + static Mina(): MinaCrypto { + if (CryptoManager.mina == null) { + CryptoManager.mina = new MinaCrypto(); + } + return CryptoManager.mina; + } } diff --git a/packages/paima-sdk/paima-crypto/src/mina.ts b/packages/paima-sdk/paima-crypto/src/mina.ts new file mode 100644 index 000000000..9b7285c92 --- /dev/null +++ b/packages/paima-sdk/paima-crypto/src/mina.ts @@ -0,0 +1,44 @@ +import { doLog } from '@paima/utils'; +import type { IVerify } from './IVerify.js'; +const base58check = require('base58check'); + +export class MinaCrypto implements IVerify { + verifyAddress = async (address: string): Promise => { + try { + base58check.decode(address); + } catch (e) { + return false; + } + + return true; + }; + verifySignature = async ( + userAddress: string, + message: string, + sigStruct: string + ): Promise => { + try { + const [field, scalar, network, ...remainder] = sigStruct.split(';'); + if (!field || !scalar || !network || remainder.length > 0) { + return false; + } + + const Client = require('mina-signer'); + + const signerClient = new Client({ network }); + + const verifyBody = { + data: message, + publicKey: userAddress, + signature: { field, scalar }, + }; + + const verifyResult = signerClient.verifyMessage(verifyBody); + + return verifyResult; + } catch (err) { + doLog('[address-validator] error verifying mina signature:', err); + return false; + } + }; +} diff --git a/packages/paima-sdk/paima-mw-core/src/delegate-wallet/index.ts b/packages/paima-sdk/paima-mw-core/src/delegate-wallet/index.ts index 0a8922c3d..7464baebf 100644 --- a/packages/paima-sdk/paima-mw-core/src/delegate-wallet/index.ts +++ b/packages/paima-sdk/paima-mw-core/src/delegate-wallet/index.ts @@ -1,7 +1,7 @@ /* * delegate = &wd|from?|to?|from_signature|to_signature * migrate = &wm|from?|to?|from_signature|to_signature - * cancelDelegations = &wc|to_signature + * cancelDelegations = &wc|to? */ import { builder } from '@paima/concise'; @@ -16,6 +16,7 @@ import { PolkadotConnector, AlgorandConnector, WalletMode, + MinaConnector, } from '@paima/providers'; import { AddressType, ENV } from '@paima/utils'; import { paimaEndpoints } from '../index.js'; @@ -78,14 +79,14 @@ export async function walletConnectMigrate( } export async function walletConnectCancelDelegations( - to_signature: string + to: string | null ): Promise | FailedResult> { const errorFxn = buildEndpointErrorFxn('delegate-wallet-cancel'); - // walletConnect = &wc|to_signature + // walletConnect = &wc|to? const conciseBuilder = builder.initialize(); conciseBuilder.setPrefix('&wc'); - conciseBuilder.addValue({ value: to_signature }); + conciseBuilder.addValue({ value: to ?? '' }); try { const result = await postConciseData(conciseBuilder.build(), errorFxn); if (!result.success) { @@ -104,9 +105,7 @@ export class WalletConnectHelper { private static readonly SEP = ':'; public buildMessageToSign(subMessage: string): string { - return `${WalletConnectHelper.DELEGATE_WALLET_PREFIX}${ - WalletConnectHelper.SEP - }${subMessage.toLocaleLowerCase()}${WalletConnectHelper.SEP}${ENV.CONTRACT_ADDRESS}`; + return `${WalletConnectHelper.DELEGATE_WALLET_PREFIX}${WalletConnectHelper.SEP}${subMessage.toLocaleLowerCase()}`; } private getProvider(walletType: AddressType): IProvider { @@ -124,6 +123,9 @@ export class WalletConnectHelper { case AddressType.ALGORAND: provider = AlgorandConnector.instance().getProvider(); break; + case AddressType.MINA: + provider = MinaConnector.instance().getProvider(); + break; } if (!provider) throw new Error('Cannot get provider ' + walletType); return provider; @@ -160,6 +162,9 @@ export class WalletConnectHelper { case AddressType.ALGORAND: loginInfo = { mode: WalletMode.Algorand }; break; + case AddressType.MINA: + loginInfo = { mode: WalletMode.Mina }; + break; case AddressType.UNKNOWN: throw new Error('AddressTypes cannot be Unknown.'); default: diff --git a/packages/paima-sdk/paima-mw-core/src/errors.ts b/packages/paima-sdk/paima-mw-core/src/errors.ts index baf4dba19..0ea3a5d1b 100644 --- a/packages/paima-sdk/paima-mw-core/src/errors.ts +++ b/packages/paima-sdk/paima-mw-core/src/errors.ts @@ -42,6 +42,7 @@ export const enum PaimaMiddlewareErrorCode { POLKADOT_WALLET_NOT_INSTALLED, POLKADOT_LOGIN, ALGORAND_LOGIN, + MINA_LOGIN, // Input posting related: ERROR_POSTING_TO_CHAIN = 2_000, ERROR_POSTING_TO_BATCHER, @@ -102,6 +103,7 @@ export const PAIMA_MIDDLEWARE_ERROR_MESSAGES: Record>>> { + const errorFxn = buildEndpointErrorFxn('minaLoginWrapper'); + + const gameInfo = { + gameName: getGameName(), + gameChainId: undefined, // Not needed because of batcher + }; + const loginResult = await connectInjected( + 'minaLoginWrapper', + errorFxn, + PaimaMiddlewareErrorCode.MINA_LOGIN, + loginInfo, + MinaConnector.instance(), + gameInfo + ); + if (loginResult.success === false) { + return loginResult; + } + return { + success: true, + result: loginResult.result, + }; +} diff --git a/packages/paima-sdk/paima-mw-core/src/wallets/wallet-modes.ts b/packages/paima-sdk/paima-mw-core/src/wallets/wallet-modes.ts index d7317d45c..b576c4c31 100644 --- a/packages/paima-sdk/paima-mw-core/src/wallets/wallet-modes.ts +++ b/packages/paima-sdk/paima-mw-core/src/wallets/wallet-modes.ts @@ -10,6 +10,7 @@ import type { EthersApi, InjectionPreference, WalletMode, + MinaApi, } from '@paima/providers'; import { WalletNotFound, UnsupportedWallet, connectInjectedWallet } from '@paima/providers'; import type { EndpointErrorFxn } from '../errors.js'; @@ -37,6 +38,7 @@ export type LoginInfoMap = { [WalletMode.Cardano]: BaseLoginInfo; [WalletMode.Polkadot]: BaseLoginInfo; [WalletMode.Algorand]: BaseLoginInfo; + [WalletMode.Mina]: BaseLoginInfo; }; type ToUnion = { diff --git a/packages/paima-sdk/paima-mw-core/src/wallets/wallets.ts b/packages/paima-sdk/paima-mw-core/src/wallets/wallets.ts index 1c2e39080..0e6cfef59 100644 --- a/packages/paima-sdk/paima-mw-core/src/wallets/wallets.ts +++ b/packages/paima-sdk/paima-mw-core/src/wallets/wallets.ts @@ -9,6 +9,7 @@ import { ethersLoginWrapper } from './evm/ethers.js'; import type { IProvider } from '@paima/providers'; import { WalletMode } from '@paima/providers'; import { PostingMode, addLogin, setDefaultProvider, setPostingMode } from '../state.js'; +import { minaLoginWrapper } from './mina.js'; export async function specificWalletLogin( loginInfo: LoginInfo, @@ -33,6 +34,9 @@ export async function specificWalletLogin( case WalletMode.Algorand: { return await algorandLoginWrapper(loginInfo); } + case WalletMode.Mina: { + return await minaLoginWrapper(loginInfo); + } default: assertNever(loginInfo, true); return errorFxn(FE_ERR_SPECIFIC_WALLET_NOT_INSTALLED); diff --git a/packages/paima-sdk/paima-providers/package.json b/packages/paima-sdk/paima-providers/package.json index 2185a44a9..354512d47 100644 --- a/packages/paima-sdk/paima-providers/package.json +++ b/packages/paima-sdk/paima-providers/package.json @@ -30,6 +30,7 @@ "@paima/utils": "2.3.0", "@perawallet/connect": "^1.2.3", "@polkadot/extension-dapp": "^0.44.9", + "@aurowallet/mina-provider": "^1.0.2", "bech32": "^2.0.0", "web3": "1.10.0", "web3-utils": "1.10.0", diff --git a/packages/paima-sdk/paima-providers/src/index.ts b/packages/paima-sdk/paima-providers/src/index.ts index d0acb2341..2d071bc19 100644 --- a/packages/paima-sdk/paima-providers/src/index.ts +++ b/packages/paima-sdk/paima-providers/src/index.ts @@ -2,11 +2,13 @@ export * from './algorand.js'; export * from './cardano.js'; export * from './evm/index.js'; export * from './polkadot.js'; +export * from './mina.js'; export * from './errors.js'; export * from './utils.js'; export type * from './algorand.js'; export type * from './cardano.js'; export type * from './evm/index.js'; export type * from './polkadot.js'; +export type * from './mina.js'; export type * from './IProvider.js'; export type * from './utils.js'; diff --git a/packages/paima-sdk/paima-providers/src/mina.ts b/packages/paima-sdk/paima-providers/src/mina.ts new file mode 100644 index 000000000..aaf81f900 --- /dev/null +++ b/packages/paima-sdk/paima-providers/src/mina.ts @@ -0,0 +1,176 @@ +import { AddressType, type UserSignature } from '@paima/utils'; +import { optionToActive } from './IProvider.js'; +import type { + ActiveConnection, + AddressAndType, + ConnectionOption, + GameInfo, + IConnector, + IInjectedConnector, + IProvider, +} from './IProvider.js'; +import { + ProviderApiError, + ProviderNotInitialized, + UnsupportedWallet, + WalletNotFound, +} from './errors.js'; +import { getWindow } from './window.js'; +import AuroMinaApi from '@aurowallet/mina-provider'; + +export type MinaApi = AuroMinaApi; + +type MinaAddress = any; + +declare global { + interface Window { + mina?: Record Promise }>; + } +} + +export class MinaConnector implements IConnector, IInjectedConnector { + private provider: MinaProvider | undefined; + private static INSTANCE: undefined | MinaConnector = undefined; + + static getWalletOptions(): ConnectionOption[] { + const minaApi = getWindow()?.mina; + if (minaApi == null || !minaApi.isAuro) return []; + + return [ + { + metadata: { + name: 'auro', + displayName: 'Auro Wallet', + }, + api: async (): Promise => { + return minaApi as unknown as MinaApi; + }, + }, + ]; + } + + static instance(): MinaConnector { + if (MinaConnector.INSTANCE == null) { + const newInstance = new MinaConnector(); + MinaConnector.INSTANCE = newInstance; + } + return MinaConnector.INSTANCE; + } + + async connectSimple(gameInfo: GameInfo): Promise> { + if (this.provider != null) { + return this.provider; + } + + const options = MinaConnector.getWalletOptions(); + + if (options.length === 0) { + throw new WalletNotFound(`No Mina wallet found`); + } + + return await this.connectExternal(gameInfo, await optionToActive(options[0])); + } + + async connectNamed(gameInfo: GameInfo, name: string): Promise> { + if (this.provider?.getConnection().metadata?.name === name) { + return this.provider; + } + const provider = MinaConnector.getWalletOptions().find(entry => entry.metadata.name === name); + if (provider == null) { + throw new UnsupportedWallet(`MinaProvider: unsupported connection type ${name}`); + } + return await this.connectExternal(gameInfo, await optionToActive(provider)); + } + + connectExternal = async ( + gameInfo: GameInfo, + conn: ActiveConnection + ): Promise => { + if (this.provider?.getConnection().metadata?.name === conn.metadata.name) { + return this.provider; + } + + this.provider = await MinaProvider.init(gameInfo, conn); + + conn.api.on('accountsChanged', accounts => { + if (!accounts || !accounts[0] || accounts[0] !== this.provider?.address) { + this.provider = undefined; + } + }); + + return this.provider; + }; + getProvider = (): undefined | MinaProvider => { + return this.provider; + }; + getOrThrowProvider = (): MinaProvider => { + if (this.provider == null) { + throw new ProviderNotInitialized(`MinaConnector provider isn't initialized yet`); + } + return this.provider; + }; + isConnected = (): boolean => { + return this.provider != null; + }; +} + +export class MinaProvider implements IProvider { + constructor( + private readonly conn: ActiveConnection, + private readonly gameInfo: GameInfo, + readonly address: MinaAddress + ) {} + + static init = async ( + gameInfo: GameInfo, + conn: ActiveConnection + ): Promise => { + const address = await MinaProvider.fetchAddress(conn); + + return new MinaProvider(conn, gameInfo, address); + }; + getConnection = (): ActiveConnection => { + return this.conn; + }; + getAddress = (): AddressAndType => { + return { + type: AddressType.MINA, + address: this.address, + }; + }; + signMessage = async (message: string): Promise => { + // There is no way of choosing the signing account here. At most we could + // monitor the changed events and erroring out if it changed. + const signed = await this.conn.api.signMessage({ message: message }); + + if ('signature' in signed) { + const { signature } = signed; + + const networkKind = await this.conn.api.requestNetwork(); + + // only these two options are used + // https://github.com/aurowallet/auro-wallet-browser-extension/blob/624de322dd99baaa09617bbad4a4a838f0a88edc/src/background/lib/index.js#L17 + // this is part of the hashed message + const network = networkKind.chainId === 'mainnet' ? 'mainnet' : 'testnet'; + + return `${signature.field};${signature.scalar};${network}`; + } else { + throw new ProviderApiError('Failed to sign message'); + } + }; + + static fetchAddress = async (conn: ActiveConnection): Promise => { + try { + const addresses = await conn.api.requestAccounts(); + if ('length' in addresses && addresses.length > 0) { + return addresses[0]; + } else { + throw new ProviderApiError('requestAccounts request failed'); + } + } catch (err) { + console.log('[pickMinaAddress] error calling requestAccounts:', err); + } + + throw new ProviderApiError('[pickMinaAddress] no used or unused addresses'); + }; +} diff --git a/packages/paima-sdk/paima-providers/src/utils.ts b/packages/paima-sdk/paima-providers/src/utils.ts index e86bd077a..5d36215f2 100644 --- a/packages/paima-sdk/paima-providers/src/utils.ts +++ b/packages/paima-sdk/paima-providers/src/utils.ts @@ -10,6 +10,7 @@ import { AlgorandConnector } from './algorand.js'; import { EthersConnector, EvmInjectedConnector } from './evm/index.js'; import { CardanoConnector } from './cardano.js'; import { PolkadotConnector } from './polkadot.js'; +import { MinaConnector } from './mina.js'; export const enum WalletMode { EvmInjected, @@ -17,6 +18,7 @@ export const enum WalletMode { Cardano, Polkadot, Algorand, + Mina, } export const WalletModeMap = { @@ -25,6 +27,7 @@ export const WalletModeMap = { [WalletMode.Cardano]: CardanoConnector.instance(), [WalletMode.Polkadot]: PolkadotConnector.instance(), [WalletMode.Algorand]: AlgorandConnector.instance(), + [WalletMode.Mina]: MinaConnector.instance(), }; type ExtractGeneric = T extends IConnector ? U : never; @@ -43,12 +46,14 @@ export async function allInjectedWallets(gameInfo: GameInfo): Promise<{ [WalletMode.Cardano]: ReturnType; [WalletMode.Polkadot]: Awaited>; [WalletMode.Algorand]: ReturnType; + [WalletMode.Mina]: ReturnType; }> { return { [WalletMode.EvmInjected]: EvmInjectedConnector.getWalletOptions(), [WalletMode.Cardano]: CardanoConnector.getWalletOptions(), [WalletMode.Polkadot]: await PolkadotConnector.getWalletOptions(gameInfo.gameName), [WalletMode.Algorand]: AlgorandConnector.getWalletOptions(), + [WalletMode.Mina]: MinaConnector.getWalletOptions(), }; } export async function connectInjectedWallet( diff --git a/packages/paima-sdk/paima-utils/src/config/loading.ts b/packages/paima-sdk/paima-utils/src/config/loading.ts index 34bd8cb0e..18e68611a 100644 --- a/packages/paima-sdk/paima-utils/src/config/loading.ts +++ b/packages/paima-sdk/paima-utils/src/config/loading.ts @@ -9,6 +9,7 @@ export enum ConfigNetworkType { EVM = 'evm-main', EVM_OTHER = 'evm-other', CARDANO = 'cardano', + MINA = 'mina', } export type EvmConfig = Static; @@ -60,6 +61,15 @@ export const CardanoConfigSchema = Type.Object({ export type CardanoConfig = Static; +export const MinaConfigSchema = Type.Object({ + archiveConnectionString: Type.String(), + delay: Type.Number(), + paginationLimit: Type.Number({ default: 50 }), + confirmationDepth: Type.Optional(Type.Number()), +}); + +export type MinaConfig = Static; + // eslint-disable-next-line @typescript-eslint/explicit-function-return-type export const TaggedEvmConfig = (T: T, MAIN_CONFIG: U) => Type.Union([ @@ -88,9 +98,21 @@ export const TaggedCardanoConfig = (T: T) => Type.Object({ type: Type.Literal(ConfigNetworkType.CARDANO) }), ]); +// eslint-disable-next-line @typescript-eslint/explicit-function-return-type +export const TaggedMinaConfig = (T: T) => + Type.Intersect([ + T ? MinaConfigSchema : Type.Partial(MinaConfigSchema), + Type.Object({ type: Type.Literal(ConfigNetworkType.MINA) }), + ]); + // eslint-disable-next-line @typescript-eslint/explicit-function-return-type export const TaggedConfig = (T: T) => - Type.Union([TaggedEvmMainConfig(T), TaggedEvmOtherConfig(T), TaggedCardanoConfig(T)]); + Type.Union([ + TaggedEvmMainConfig(T), + TaggedEvmOtherConfig(T), + TaggedCardanoConfig(T), + TaggedMinaConfig(T), + ]); // eslint-disable-next-line @typescript-eslint/explicit-function-return-type export const BaseConfig = (T: T) => Type.Record(Type.String(), TaggedConfig(T)); @@ -109,10 +131,17 @@ const cardanoConfigDefaults = { paginationLimits: 50, }; +const minaConfigDefaults = { + // lightnet defaults + confirmationDepth: 30, + delay: 30 * 40, +}; + // used as a placeholder name for the ENV fallback mechanism // will need to be removed afterwards export const defaultEvmMainNetworkName = 'evm'; export const defaultCardanoNetworkName = 'cardano'; +export const defaultMinaNetworkName = 'mina'; export async function loadConfig(): Promise | undefined> { let configFileData: string; @@ -170,6 +199,9 @@ export async function loadConfig(): Promise; @@ -58,4 +64,12 @@ export class GlobalConfig { .filter(key => instance[key].type === ConfigNetworkType.EVM_OTHER) .map(key => [key, instance[key] as EvmConfig]); } + + public static async minaConfig(): Promise<[string, MinaConfig][]> { + const instance = await GlobalConfig.getInstance(); + + return Object.keys(instance) + .filter(key => instance[key].type === ConfigNetworkType.MINA) + .map(key => [key, instance[key] as MinaConfig]); + } } diff --git a/packages/paima-sdk/paima-utils/src/constants.ts b/packages/paima-sdk/paima-utils/src/constants.ts index 523b6cf7e..831c575ce 100644 --- a/packages/paima-sdk/paima-utils/src/constants.ts +++ b/packages/paima-sdk/paima-utils/src/constants.ts @@ -5,6 +5,7 @@ export const enum AddressType { CARDANO = 2, POLKADOT = 3, ALGORAND = 4, + MINA = 5, } export const DEFAULT_FUNNEL_TIMEOUT = 5000; @@ -24,6 +25,8 @@ export const enum ChainDataExtensionType { CardanoTransfer = 10, CardanoMintBurn = 11, ERC1155 = 12, + MinaEventGeneric = 13, + MinaActionGeneric = 14, } export const enum ChainDataExtensionDatumType { @@ -39,6 +42,8 @@ export const enum ChainDataExtensionDatumType { CardanoTransfer, CardanoMintBurn, Erc1155Transfer, + MinaEventGeneric, + MinaActionGeneric, } export const FUNNEL_PRESYNC_FINISHED = 'finished'; @@ -46,4 +51,5 @@ export const FUNNEL_PRESYNC_FINISHED = 'finished'; export const enum InternalEventType { CardanoBestEpoch, EvmLastBlock, + MinaLastTimestamp, } diff --git a/packages/paima-sdk/paima-utils/src/index.ts b/packages/paima-sdk/paima-utils/src/index.ts index 8c3d1671c..4b0c7b820 100644 --- a/packages/paima-sdk/paima-utils/src/index.ts +++ b/packages/paima-sdk/paima-utils/src/index.ts @@ -10,9 +10,11 @@ import { GlobalConfig } from './config/singleton.js'; import { EvmConfig, CardanoConfig, + MinaConfig, ConfigNetworkType, defaultEvmMainNetworkName, defaultCardanoNetworkName, + defaultMinaNetworkName, } from './config/loading.js'; export * from './config.js'; @@ -34,9 +36,11 @@ export { GlobalConfig, EvmConfig, CardanoConfig, + MinaConfig, ConfigNetworkType, defaultEvmMainNetworkName, defaultCardanoNetworkName, + defaultMinaNetworkName, }; export const DEFAULT_GAS_PRICE = '61000000000' as const; diff --git a/packages/paima-sdk/paima-utils/src/types.ts b/packages/paima-sdk/paima-utils/src/types.ts index 9c0afe528..730d811ae 100644 --- a/packages/paima-sdk/paima-utils/src/types.ts +++ b/packages/paima-sdk/paima-utils/src/types.ts @@ -9,9 +9,15 @@ export type ETHAddress = string; export type CardanoAddress = string; export type PolkadotAddress = string; export type AlgorandAddress = string; +export type MinaAddress = string; // eslint-disable-next-line @typescript-eslint/no-duplicate-type-constituents -- the overlapping types is on purpose for readability -export type WalletAddress = ETHAddress | CardanoAddress | PolkadotAddress | AlgorandAddress; +export type WalletAddress = + | ETHAddress + | CardanoAddress + | PolkadotAddress + | AlgorandAddress + | MinaAddress; export type ContractAddress = ETHAddress;