├── .env.example ├── .gitignore ├── .prettierrc ├── README.md ├── image.png ├── package-lock.json ├── package.json ├── scripts ├── main.ts └── score.ts ├── src ├── captcha │ └── index.ts ├── email │ └── index.ts ├── galxe │ ├── index.ts │ └── query.ts ├── logger │ └── index.ts ├── requests │ └── curl.ts ├── twitter │ └── index.ts ├── utils │ └── common.ts └── wallet │ └── index.ts ├── tsconfig.json └── twitter.txt /.env.example: -------------------------------------------------------------------------------- 1 | MNEMONIC="your-mnemonic" 2 | 3 | PROXY_IP="http://127.0.0.1:7890" # 代理 ip,不需要可不填 4 | 5 | #### CONFIG 6 | # 填一个即可,建议用 CAPSOLVER 7 | TWO_CAPTCHA_CLIENT_KEY="" # https://2captcha.com/ 8 | CAPSOLVER_CLIENT_KEY="" # https://capsolver.com/ 9 | CAPMONSTER_CLIENT_KEY="" # https://capmonster.cloud/ 10 | 11 | # 输出日志路径 12 | LOGGER_OUTPUT_NAME="output.log" 13 | 14 | #### GALXE 15 | GALXE_COLLECT="" 16 | GALXE_CAMPAIGNS_INDEXES="" 17 | 18 | # 填 1 会读取 twitter.txt 的 auth_token 以及自动绑定 galxe 账号,不需要填 0 19 | # twitter.txt 每行一个 auth_token,会根据当前遍历的下标获取对应行数的 auth_token 20 | NEED_TWITTER=0 21 | 22 | # 派生路径遍历下标 23 | START_PATH_INDEX=0 24 | MAX_PATH_INDEX=1000 25 | 26 | SPACE_NAME="MapleStoryUniverse" 27 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .env 2 | *.log 3 | dist/ 4 | node_modules/ 5 | *.txt -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "printWidth": 120, 3 | "tabWidth": 2, 4 | "useTabs": false, 5 | "singleQuote": true, 6 | "semi": false, 7 | "trailingComma": "none", 8 | "endOfLine": "auto", 9 | "bracketSameLine": false 10 | } 11 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Galxe Task Automation 2 | 3 | 后面已完成如下功能,后续会加入更多交互: 4 | 5 | - EVM 地址登录 6 | - 创建 GalxeID 账号 7 | - 绑定邮箱:1secmail 8 | - 绑定推特 - auth_token 9 | - 绑定 Taproot 地址 10 | - 完成任务 11 | - 章节奖励领取 12 | - Geetest 自动验证:2captcha(现在经常报错)、capsolver(推荐) 13 | - 批量查询地址 space 分数 14 | 15 | ## 支持任务 16 | 17 | - 校验任务 18 | - 问卷任务 19 | - 推特任务(点赞、转发、发推 @ 好友、关注) 20 | - 浏览任务 21 | - 关注银河 space 任务 22 | 23 | ## 配置参数 24 | 25 | GALXE_COLLECT:银河合集 id,可以通过 URL 获取。如 https://app.galxe.com/quest/Babylon/GCyyntz73L 则为 GCyyntz73L。 26 | 27 | GALXE_CAMPAIGNS_INDEXES:执行任务下标,从 0 开始计算,`:`分隔活动、任务组、任务,`,` 分隔不同任务。 28 | 29 | SPACE_NAME:通过 space url 获取,如 https://app.galxe.com/quest/MapleStoryUniverse 则为 MapleStoryUniverse。 30 | 31 | ``` 32 | # 可测试任务的活动 33 | # 问卷+浏览 34 | GALXE_COLLECT="GC4Uwtd8Hr" 35 | GALXE_CAMPAIGNS_INDEXES="0:0:2,3,4" 36 | 37 | # 推特 38 | GALXE_COLLECT="GCzuatdz2R" 39 | GALXE_CAMPAIGNS_INDEXES="0:2:0,1" 40 | 41 | # 关注 space 42 | GALXE_COLLECT="GCBxytgdNB" 43 | GALXE_CAMPAIGNS_INDEXES="3:0:0" 44 | ``` 45 | 46 | ![](image.png) 47 | 48 | ## 运行 49 | 50 | 复制 `.env.example` 改名为 `.env`,填写相关配置参数,运行过程会遍历助记词对应的派生地址,然后逐步完成任务。 51 | 52 | ```bash 53 | npm i 54 | npm run start # 执行银河任务 55 | npm run space-score # 批量查询地址 space 分数 56 | ``` 57 | 58 | ## 后续规划 59 | 60 | 会持续做好银河相关任务的迭代和优化:如 奥德赛、dc、多活动领取等,开源脚本完善之后会升级成可视化的银河自动化平台。 61 | 62 | ### 感谢关注: [@Kunsect](https://x.com/kunsect7) 63 | -------------------------------------------------------------------------------- /image.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Kunsect/galxe-task-automation/079fbf43a00b9f568ee07fcfd9eec525a0726bab/image.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "galxe-public", 3 | "lockfileVersion": 3, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "devDependencies": { 8 | "@types/bip39": "^3.0.0", 9 | "@types/node": "^20.14.2", 10 | "bip32": "^4.0.0", 11 | "bip39": "^3.1.0", 12 | "bitcoinjs-lib": "^6.1.5", 13 | "bitcoinjs-message": "^2.2.0", 14 | "crypto": "^1.0.1", 15 | "dotenv": "^16.4.5", 16 | "ecpair": "^2.1.0", 17 | "ethers": "^6.13.1", 18 | "node-libcurl": "^4.0.0", 19 | "querystring": "^0.2.1", 20 | "tiny-secp256k1": "^2.2.3", 21 | "ts-node": "^10.9.2", 22 | "typescript": "^5.4.5", 23 | "winston": "^3.13.0" 24 | } 25 | }, 26 | "node_modules/@adraffy/ens-normalize": { 27 | "version": "1.10.1", 28 | "resolved": "https://registry.npmjs.org/@adraffy/ens-normalize/-/ens-normalize-1.10.1.tgz", 29 | "integrity": "sha512-96Z2IP3mYmF1Xg2cDm8f1gWGf/HUVedQ3FMifV4kG/PQ4yEP51xDtRAEfhVNt5f/uzpNkZHwWQuUcu6D6K+Ekw==", 30 | "dev": true 31 | }, 32 | "node_modules/@colors/colors": { 33 | "version": "1.6.0", 34 | "resolved": "https://registry.npmjs.org/@colors/colors/-/colors-1.6.0.tgz", 35 | "integrity": "sha512-Ir+AOibqzrIsL6ajt3Rz3LskB7OiMVHqltZmspbW/TJuTVuyOMirVqAkjfY6JISiLHgyNqicAC8AyHHGzNd/dA==", 36 | "dev": true, 37 | "engines": { 38 | "node": ">=0.1.90" 39 | } 40 | }, 41 | "node_modules/@cspotcode/source-map-support": { 42 | "version": "0.8.1", 43 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 44 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 45 | "dev": true, 46 | "dependencies": { 47 | "@jridgewell/trace-mapping": "0.3.9" 48 | }, 49 | "engines": { 50 | "node": ">=12" 51 | } 52 | }, 53 | "node_modules/@dabh/diagnostics": { 54 | "version": "2.0.3", 55 | "resolved": "https://registry.npmjs.org/@dabh/diagnostics/-/diagnostics-2.0.3.tgz", 56 | "integrity": "sha512-hrlQOIi7hAfzsMqlGSFyVucrx38O+j6wiGOf//H2ecvIEqYN4ADBSS2iLMh5UFyDunCNniUIPk/q3riFv45xRA==", 57 | "dev": true, 58 | "dependencies": { 59 | "colorspace": "1.1.x", 60 | "enabled": "2.0.x", 61 | "kuler": "^2.0.0" 62 | } 63 | }, 64 | "node_modules/@isaacs/cliui": { 65 | "version": "8.0.2", 66 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", 67 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", 68 | "dev": true, 69 | "dependencies": { 70 | "string-width": "^5.1.2", 71 | "string-width-cjs": "npm:string-width@^4.2.0", 72 | "strip-ansi": "^7.0.1", 73 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", 74 | "wrap-ansi": "^8.1.0", 75 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" 76 | }, 77 | "engines": { 78 | "node": ">=12" 79 | } 80 | }, 81 | "node_modules/@jridgewell/resolve-uri": { 82 | "version": "3.1.2", 83 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 84 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 85 | "dev": true, 86 | "engines": { 87 | "node": ">=6.0.0" 88 | } 89 | }, 90 | "node_modules/@jridgewell/sourcemap-codec": { 91 | "version": "1.4.15", 92 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 93 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 94 | "dev": true 95 | }, 96 | "node_modules/@jridgewell/trace-mapping": { 97 | "version": "0.3.9", 98 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 99 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 100 | "dev": true, 101 | "dependencies": { 102 | "@jridgewell/resolve-uri": "^3.0.3", 103 | "@jridgewell/sourcemap-codec": "^1.4.10" 104 | } 105 | }, 106 | "node_modules/@mapbox/node-pre-gyp": { 107 | "version": "1.0.11", 108 | "resolved": "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.11.tgz", 109 | "integrity": "sha512-Yhlar6v9WQgUp/He7BdgzOz8lqMQ8sU+jkCq7Wx8Myc5YFJLbEe7lgui/V7G1qB1DJykHSGwreceSaD60Y0PUQ==", 110 | "dev": true, 111 | "dependencies": { 112 | "detect-libc": "^2.0.0", 113 | "https-proxy-agent": "^5.0.0", 114 | "make-dir": "^3.1.0", 115 | "node-fetch": "^2.6.7", 116 | "nopt": "^5.0.0", 117 | "npmlog": "^5.0.1", 118 | "rimraf": "^3.0.2", 119 | "semver": "^7.3.5", 120 | "tar": "^6.1.11" 121 | }, 122 | "bin": { 123 | "node-pre-gyp": "bin/node-pre-gyp" 124 | } 125 | }, 126 | "node_modules/@mapbox/node-pre-gyp/node_modules/ansi-regex": { 127 | "version": "5.0.1", 128 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 129 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 130 | "dev": true, 131 | "engines": { 132 | "node": ">=8" 133 | } 134 | }, 135 | "node_modules/@mapbox/node-pre-gyp/node_modules/are-we-there-yet": { 136 | "version": "2.0.0", 137 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz", 138 | "integrity": "sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw==", 139 | "deprecated": "This package is no longer supported.", 140 | "dev": true, 141 | "dependencies": { 142 | "delegates": "^1.0.0", 143 | "readable-stream": "^3.6.0" 144 | }, 145 | "engines": { 146 | "node": ">=10" 147 | } 148 | }, 149 | "node_modules/@mapbox/node-pre-gyp/node_modules/brace-expansion": { 150 | "version": "1.1.11", 151 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 152 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 153 | "dev": true, 154 | "dependencies": { 155 | "balanced-match": "^1.0.0", 156 | "concat-map": "0.0.1" 157 | } 158 | }, 159 | "node_modules/@mapbox/node-pre-gyp/node_modules/emoji-regex": { 160 | "version": "8.0.0", 161 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 162 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 163 | "dev": true 164 | }, 165 | "node_modules/@mapbox/node-pre-gyp/node_modules/gauge": { 166 | "version": "3.0.2", 167 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-3.0.2.tgz", 168 | "integrity": "sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q==", 169 | "deprecated": "This package is no longer supported.", 170 | "dev": true, 171 | "dependencies": { 172 | "aproba": "^1.0.3 || ^2.0.0", 173 | "color-support": "^1.1.2", 174 | "console-control-strings": "^1.0.0", 175 | "has-unicode": "^2.0.1", 176 | "object-assign": "^4.1.1", 177 | "signal-exit": "^3.0.0", 178 | "string-width": "^4.2.3", 179 | "strip-ansi": "^6.0.1", 180 | "wide-align": "^1.1.2" 181 | }, 182 | "engines": { 183 | "node": ">=10" 184 | } 185 | }, 186 | "node_modules/@mapbox/node-pre-gyp/node_modules/glob": { 187 | "version": "7.2.3", 188 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 189 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 190 | "deprecated": "Glob versions prior to v9 are no longer supported", 191 | "dev": true, 192 | "dependencies": { 193 | "fs.realpath": "^1.0.0", 194 | "inflight": "^1.0.4", 195 | "inherits": "2", 196 | "minimatch": "^3.1.1", 197 | "once": "^1.3.0", 198 | "path-is-absolute": "^1.0.0" 199 | }, 200 | "engines": { 201 | "node": "*" 202 | }, 203 | "funding": { 204 | "url": "https://github.com/sponsors/isaacs" 205 | } 206 | }, 207 | "node_modules/@mapbox/node-pre-gyp/node_modules/minimatch": { 208 | "version": "3.1.2", 209 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 210 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 211 | "dev": true, 212 | "dependencies": { 213 | "brace-expansion": "^1.1.7" 214 | }, 215 | "engines": { 216 | "node": "*" 217 | } 218 | }, 219 | "node_modules/@mapbox/node-pre-gyp/node_modules/npmlog": { 220 | "version": "5.0.1", 221 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-5.0.1.tgz", 222 | "integrity": "sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw==", 223 | "deprecated": "This package is no longer supported.", 224 | "dev": true, 225 | "dependencies": { 226 | "are-we-there-yet": "^2.0.0", 227 | "console-control-strings": "^1.1.0", 228 | "gauge": "^3.0.0", 229 | "set-blocking": "^2.0.0" 230 | } 231 | }, 232 | "node_modules/@mapbox/node-pre-gyp/node_modules/rimraf": { 233 | "version": "3.0.2", 234 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 235 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 236 | "deprecated": "Rimraf versions prior to v4 are no longer supported", 237 | "dev": true, 238 | "dependencies": { 239 | "glob": "^7.1.3" 240 | }, 241 | "bin": { 242 | "rimraf": "bin.js" 243 | }, 244 | "funding": { 245 | "url": "https://github.com/sponsors/isaacs" 246 | } 247 | }, 248 | "node_modules/@mapbox/node-pre-gyp/node_modules/signal-exit": { 249 | "version": "3.0.7", 250 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 251 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 252 | "dev": true 253 | }, 254 | "node_modules/@mapbox/node-pre-gyp/node_modules/string-width": { 255 | "version": "4.2.3", 256 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 257 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 258 | "dev": true, 259 | "dependencies": { 260 | "emoji-regex": "^8.0.0", 261 | "is-fullwidth-code-point": "^3.0.0", 262 | "strip-ansi": "^6.0.1" 263 | }, 264 | "engines": { 265 | "node": ">=8" 266 | } 267 | }, 268 | "node_modules/@mapbox/node-pre-gyp/node_modules/strip-ansi": { 269 | "version": "6.0.1", 270 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 271 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 272 | "dev": true, 273 | "dependencies": { 274 | "ansi-regex": "^5.0.1" 275 | }, 276 | "engines": { 277 | "node": ">=8" 278 | } 279 | }, 280 | "node_modules/@noble/curves": { 281 | "version": "1.2.0", 282 | "resolved": "https://registry.npmjs.org/@noble/curves/-/curves-1.2.0.tgz", 283 | "integrity": "sha512-oYclrNgRaM9SsBUBVbb8M6DTV7ZHRTKugureoYEncY5c65HOmRzvSiTE3y5CYaPYJA/GVkrhXEoF0M3Ya9PMnw==", 284 | "dev": true, 285 | "dependencies": { 286 | "@noble/hashes": "1.3.2" 287 | }, 288 | "funding": { 289 | "url": "https://paulmillr.com/funding/" 290 | } 291 | }, 292 | "node_modules/@noble/curves/node_modules/@noble/hashes": { 293 | "version": "1.3.2", 294 | "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.3.2.tgz", 295 | "integrity": "sha512-MVC8EAQp7MvEcm30KWENFjgR+Mkmf+D189XJTkFIlwohU5hcBbn1ZkKq7KVTi2Hme3PMGF390DaL52beVrIihQ==", 296 | "dev": true, 297 | "engines": { 298 | "node": ">= 16" 299 | }, 300 | "funding": { 301 | "url": "https://paulmillr.com/funding/" 302 | } 303 | }, 304 | "node_modules/@noble/hashes": { 305 | "version": "1.4.0", 306 | "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.4.0.tgz", 307 | "integrity": "sha512-V1JJ1WTRUqHHrOSh597hURcMqVKVGL/ea3kv0gSnEdsEZ0/+VyPghM1lMNGc00z7CIQorSvbKpuJkxvuHbvdbg==", 308 | "dev": true, 309 | "engines": { 310 | "node": ">= 16" 311 | }, 312 | "funding": { 313 | "url": "https://paulmillr.com/funding/" 314 | } 315 | }, 316 | "node_modules/@npmcli/agent": { 317 | "version": "2.2.2", 318 | "resolved": "https://registry.npmjs.org/@npmcli/agent/-/agent-2.2.2.tgz", 319 | "integrity": "sha512-OrcNPXdpSl9UX7qPVRWbmWMCSXrcDa2M9DvrbOTj7ao1S4PlqVFYv9/yLKMkrJKZ/V5A/kDBC690or307i26Og==", 320 | "dev": true, 321 | "dependencies": { 322 | "agent-base": "^7.1.0", 323 | "http-proxy-agent": "^7.0.0", 324 | "https-proxy-agent": "^7.0.1", 325 | "lru-cache": "^10.0.1", 326 | "socks-proxy-agent": "^8.0.3" 327 | }, 328 | "engines": { 329 | "node": "^16.14.0 || >=18.0.0" 330 | } 331 | }, 332 | "node_modules/@npmcli/agent/node_modules/agent-base": { 333 | "version": "7.1.1", 334 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", 335 | "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", 336 | "dev": true, 337 | "dependencies": { 338 | "debug": "^4.3.4" 339 | }, 340 | "engines": { 341 | "node": ">= 14" 342 | } 343 | }, 344 | "node_modules/@npmcli/agent/node_modules/https-proxy-agent": { 345 | "version": "7.0.5", 346 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.5.tgz", 347 | "integrity": "sha512-1e4Wqeblerz+tMKPIq2EMGiiWW1dIjZOksyHWSUm1rmuvw/how9hBHZ38lAGj5ID4Ik6EdkOw7NmWPy6LAwalw==", 348 | "dev": true, 349 | "dependencies": { 350 | "agent-base": "^7.0.2", 351 | "debug": "4" 352 | }, 353 | "engines": { 354 | "node": ">= 14" 355 | } 356 | }, 357 | "node_modules/@npmcli/fs": { 358 | "version": "3.1.1", 359 | "resolved": "https://registry.npmjs.org/@npmcli/fs/-/fs-3.1.1.tgz", 360 | "integrity": "sha512-q9CRWjpHCMIh5sVyefoD1cA7PkvILqCZsnSOEUUivORLjxCO/Irmue2DprETiNgEqktDBZaM1Bi+jrarx1XdCg==", 361 | "dev": true, 362 | "dependencies": { 363 | "semver": "^7.3.5" 364 | }, 365 | "engines": { 366 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 367 | } 368 | }, 369 | "node_modules/@pkgjs/parseargs": { 370 | "version": "0.11.0", 371 | "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", 372 | "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", 373 | "dev": true, 374 | "optional": true, 375 | "engines": { 376 | "node": ">=14" 377 | } 378 | }, 379 | "node_modules/@scure/base": { 380 | "version": "1.1.7", 381 | "resolved": "https://registry.npmjs.org/@scure/base/-/base-1.1.7.tgz", 382 | "integrity": "sha512-PPNYBslrLNNUQ/Yad37MHYsNQtK67EhWb6WtSvNLLPo7SdVZgkUjD6Dg+5On7zNwmskf8OX7I7Nx5oN+MIWE0g==", 383 | "dev": true, 384 | "funding": { 385 | "url": "https://paulmillr.com/funding/" 386 | } 387 | }, 388 | "node_modules/@tsconfig/node10": { 389 | "version": "1.0.11", 390 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.11.tgz", 391 | "integrity": "sha512-DcRjDCujK/kCk/cUe8Xz8ZSpm8mS3mNNpta+jGCA6USEDfktlNvm1+IuZ9eTcDbNk41BHwpHHeW+N1lKCz4zOw==", 392 | "dev": true 393 | }, 394 | "node_modules/@tsconfig/node12": { 395 | "version": "1.0.11", 396 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 397 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 398 | "dev": true 399 | }, 400 | "node_modules/@tsconfig/node14": { 401 | "version": "1.0.3", 402 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 403 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 404 | "dev": true 405 | }, 406 | "node_modules/@tsconfig/node16": { 407 | "version": "1.0.4", 408 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz", 409 | "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==", 410 | "dev": true 411 | }, 412 | "node_modules/@types/bip39": { 413 | "version": "3.0.0", 414 | "resolved": "https://registry.npmjs.org/@types/bip39/-/bip39-3.0.0.tgz", 415 | "integrity": "sha512-6CqBtChR2JHspepOd8Y2x2BYyq8GBN8hfrbBrbaj7s7j07kMaghvUPnsVTIYbr2c1yV0Pu50wBbVD56KSdalKQ==", 416 | "deprecated": "This is a stub types definition. bip39 provides its own type definitions, so you do not need this installed.", 417 | "dev": true, 418 | "dependencies": { 419 | "bip39": "*" 420 | } 421 | }, 422 | "node_modules/@types/node": { 423 | "version": "20.14.10", 424 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.10.tgz", 425 | "integrity": "sha512-MdiXf+nDuMvY0gJKxyfZ7/6UFsETO7mGKF54MVD/ekJS6HdFtpZFBgrh6Pseu64XTb2MLyFPlbW6hj8HYRQNOQ==", 426 | "dev": true, 427 | "dependencies": { 428 | "undici-types": "~5.26.4" 429 | } 430 | }, 431 | "node_modules/@types/triple-beam": { 432 | "version": "1.3.5", 433 | "resolved": "https://registry.npmjs.org/@types/triple-beam/-/triple-beam-1.3.5.tgz", 434 | "integrity": "sha512-6WaYesThRMCl19iryMYP7/x2OVgCtbIVflDGFpWnb9irXI3UjYE4AzmYuiUKY1AJstGijoY+MgUszMgRxIYTYw==", 435 | "dev": true 436 | }, 437 | "node_modules/abbrev": { 438 | "version": "1.1.1", 439 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 440 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 441 | "dev": true 442 | }, 443 | "node_modules/acorn": { 444 | "version": "8.12.1", 445 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", 446 | "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", 447 | "dev": true, 448 | "bin": { 449 | "acorn": "bin/acorn" 450 | }, 451 | "engines": { 452 | "node": ">=0.4.0" 453 | } 454 | }, 455 | "node_modules/acorn-walk": { 456 | "version": "8.3.3", 457 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.3.tgz", 458 | "integrity": "sha512-MxXdReSRhGO7VlFe1bRG/oI7/mdLV9B9JJT0N8vZOhF7gFRR5l3M8W9G8JxmKV+JC5mGqJ0QvqfSOLsCPa4nUw==", 459 | "dev": true, 460 | "dependencies": { 461 | "acorn": "^8.11.0" 462 | }, 463 | "engines": { 464 | "node": ">=0.4.0" 465 | } 466 | }, 467 | "node_modules/aes-js": { 468 | "version": "4.0.0-beta.5", 469 | "resolved": "https://registry.npmjs.org/aes-js/-/aes-js-4.0.0-beta.5.tgz", 470 | "integrity": "sha512-G965FqalsNyrPqgEGON7nIx1e/OVENSgiEIzyC63haUMuvNnwIgIjMs52hlTCKhkBny7A2ORNlfY9Zu+jmGk1Q==", 471 | "dev": true 472 | }, 473 | "node_modules/agent-base": { 474 | "version": "6.0.2", 475 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 476 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 477 | "dev": true, 478 | "dependencies": { 479 | "debug": "4" 480 | }, 481 | "engines": { 482 | "node": ">= 6.0.0" 483 | } 484 | }, 485 | "node_modules/aggregate-error": { 486 | "version": "3.1.0", 487 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 488 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 489 | "dev": true, 490 | "dependencies": { 491 | "clean-stack": "^2.0.0", 492 | "indent-string": "^4.0.0" 493 | }, 494 | "engines": { 495 | "node": ">=8" 496 | } 497 | }, 498 | "node_modules/ansi-regex": { 499 | "version": "6.0.1", 500 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 501 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 502 | "dev": true, 503 | "engines": { 504 | "node": ">=12" 505 | }, 506 | "funding": { 507 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 508 | } 509 | }, 510 | "node_modules/ansi-styles": { 511 | "version": "6.2.1", 512 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", 513 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", 514 | "dev": true, 515 | "engines": { 516 | "node": ">=12" 517 | }, 518 | "funding": { 519 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 520 | } 521 | }, 522 | "node_modules/aproba": { 523 | "version": "2.0.0", 524 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz", 525 | "integrity": "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==", 526 | "dev": true 527 | }, 528 | "node_modules/are-we-there-yet": { 529 | "version": "4.0.2", 530 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-4.0.2.tgz", 531 | "integrity": "sha512-ncSWAawFhKMJDTdoAeOV+jyW1VCMj5QIAwULIBV0SSR7B/RLPPEQiknKcg/RIIZlUQrxELpsxMiTUoAQ4sIUyg==", 532 | "deprecated": "This package is no longer supported.", 533 | "dev": true, 534 | "engines": { 535 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 536 | } 537 | }, 538 | "node_modules/arg": { 539 | "version": "4.1.3", 540 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 541 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 542 | "dev": true 543 | }, 544 | "node_modules/async": { 545 | "version": "3.2.5", 546 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.5.tgz", 547 | "integrity": "sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg==", 548 | "dev": true 549 | }, 550 | "node_modules/balanced-match": { 551 | "version": "1.0.2", 552 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 553 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 554 | "dev": true 555 | }, 556 | "node_modules/base-x": { 557 | "version": "4.0.0", 558 | "resolved": "https://registry.npmjs.org/base-x/-/base-x-4.0.0.tgz", 559 | "integrity": "sha512-FuwxlW4H5kh37X/oW59pwTzzTKRzfrrQwhmyspRM7swOEZcHtDZSCt45U6oKgtuFE+WYPblePMVIPR4RZrh/hw==", 560 | "dev": true 561 | }, 562 | "node_modules/bech32": { 563 | "version": "2.0.0", 564 | "resolved": "https://registry.npmjs.org/bech32/-/bech32-2.0.0.tgz", 565 | "integrity": "sha512-LcknSilhIGatDAsY1ak2I8VtGaHNhgMSYVxFrGLXv+xLHytaKZKcaUJJUE7qmBr7h33o5YQwP55pMI0xmkpJwg==", 566 | "dev": true 567 | }, 568 | "node_modules/bindings": { 569 | "version": "1.5.0", 570 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", 571 | "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", 572 | "dev": true, 573 | "dependencies": { 574 | "file-uri-to-path": "1.0.0" 575 | } 576 | }, 577 | "node_modules/bip174": { 578 | "version": "2.1.1", 579 | "resolved": "https://registry.npmjs.org/bip174/-/bip174-2.1.1.tgz", 580 | "integrity": "sha512-mdFV5+/v0XyNYXjBS6CQPLo9ekCx4gtKZFnJm5PMto7Fs9hTTDpkkzOB7/FtluRI6JbUUAu+snTYfJRgHLZbZQ==", 581 | "dev": true, 582 | "engines": { 583 | "node": ">=8.0.0" 584 | } 585 | }, 586 | "node_modules/bip32": { 587 | "version": "4.0.0", 588 | "resolved": "https://registry.npmjs.org/bip32/-/bip32-4.0.0.tgz", 589 | "integrity": "sha512-aOGy88DDlVUhspIXJN+dVEtclhIsfAUppD43V0j40cPTld3pv/0X/MlrZSZ6jowIaQQzFwP8M6rFU2z2mVYjDQ==", 590 | "dev": true, 591 | "dependencies": { 592 | "@noble/hashes": "^1.2.0", 593 | "@scure/base": "^1.1.1", 594 | "typeforce": "^1.11.5", 595 | "wif": "^2.0.6" 596 | }, 597 | "engines": { 598 | "node": ">=6.0.0" 599 | } 600 | }, 601 | "node_modules/bip39": { 602 | "version": "3.1.0", 603 | "resolved": "https://registry.npmjs.org/bip39/-/bip39-3.1.0.tgz", 604 | "integrity": "sha512-c9kiwdk45Do5GL0vJMe7tS95VjCii65mYAH7DfWl3uW8AVzXKQVUm64i3hzVybBDMp9r7j9iNxR85+ul8MdN/A==", 605 | "dev": true, 606 | "dependencies": { 607 | "@noble/hashes": "^1.2.0" 608 | } 609 | }, 610 | "node_modules/bip66": { 611 | "version": "1.1.5", 612 | "resolved": "https://registry.npmjs.org/bip66/-/bip66-1.1.5.tgz", 613 | "integrity": "sha512-nemMHz95EmS38a26XbbdxIYj5csHd3RMP3H5bwQknX0WYHF01qhpufP42mLOwVICuH2JmhIhXiWs89MfUGL7Xw==", 614 | "dev": true, 615 | "dependencies": { 616 | "safe-buffer": "^5.0.1" 617 | } 618 | }, 619 | "node_modules/bitcoinjs-lib": { 620 | "version": "6.1.6", 621 | "resolved": "https://registry.npmjs.org/bitcoinjs-lib/-/bitcoinjs-lib-6.1.6.tgz", 622 | "integrity": "sha512-Fk8+Vc+e2rMoDU5gXkW9tD+313rhkm5h6N9HfZxXvYU9LedttVvmXKTgd9k5rsQJjkSfsv6XRM8uhJv94SrvcA==", 623 | "dev": true, 624 | "dependencies": { 625 | "@noble/hashes": "^1.2.0", 626 | "bech32": "^2.0.0", 627 | "bip174": "^2.1.1", 628 | "bs58check": "^3.0.1", 629 | "typeforce": "^1.11.3", 630 | "varuint-bitcoin": "^1.1.2" 631 | }, 632 | "engines": { 633 | "node": ">=8.0.0" 634 | } 635 | }, 636 | "node_modules/bitcoinjs-message": { 637 | "version": "2.2.0", 638 | "resolved": "https://registry.npmjs.org/bitcoinjs-message/-/bitcoinjs-message-2.2.0.tgz", 639 | "integrity": "sha512-103Wy3xg8Y9o+pdhGP4M3/mtQQuUWs6sPuOp1mYphSUoSMHjHTlkj32K4zxU8qMH0Ckv23emfkGlFWtoWZ7YFA==", 640 | "dev": true, 641 | "dependencies": { 642 | "bech32": "^1.1.3", 643 | "bs58check": "^2.1.2", 644 | "buffer-equals": "^1.0.3", 645 | "create-hash": "^1.1.2", 646 | "secp256k1": "^3.0.1", 647 | "varuint-bitcoin": "^1.0.1" 648 | }, 649 | "engines": { 650 | "node": ">=0.10" 651 | } 652 | }, 653 | "node_modules/bitcoinjs-message/node_modules/base-x": { 654 | "version": "3.0.10", 655 | "resolved": "https://registry.npmjs.org/base-x/-/base-x-3.0.10.tgz", 656 | "integrity": "sha512-7d0s06rR9rYaIWHkpfLIFICM/tkSVdoPC9qYAQRpxn9DdKNWNsKC0uk++akckyLq16Tx2WIinnZ6WRriAt6njQ==", 657 | "dev": true, 658 | "dependencies": { 659 | "safe-buffer": "^5.0.1" 660 | } 661 | }, 662 | "node_modules/bitcoinjs-message/node_modules/bech32": { 663 | "version": "1.1.4", 664 | "resolved": "https://registry.npmjs.org/bech32/-/bech32-1.1.4.tgz", 665 | "integrity": "sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==", 666 | "dev": true 667 | }, 668 | "node_modules/bitcoinjs-message/node_modules/bs58": { 669 | "version": "4.0.1", 670 | "resolved": "https://registry.npmjs.org/bs58/-/bs58-4.0.1.tgz", 671 | "integrity": "sha512-Ok3Wdf5vOIlBrgCvTq96gBkJw+JUEzdBgyaza5HLtPm7yTHkjRy8+JzNyHF7BHa0bNWOQIp3m5YF0nnFcOIKLw==", 672 | "dev": true, 673 | "dependencies": { 674 | "base-x": "^3.0.2" 675 | } 676 | }, 677 | "node_modules/bitcoinjs-message/node_modules/bs58check": { 678 | "version": "2.1.2", 679 | "resolved": "https://registry.npmjs.org/bs58check/-/bs58check-2.1.2.tgz", 680 | "integrity": "sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA==", 681 | "dev": true, 682 | "dependencies": { 683 | "bs58": "^4.0.0", 684 | "create-hash": "^1.1.0", 685 | "safe-buffer": "^5.1.2" 686 | } 687 | }, 688 | "node_modules/bn.js": { 689 | "version": "4.12.0", 690 | "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", 691 | "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", 692 | "dev": true 693 | }, 694 | "node_modules/brace-expansion": { 695 | "version": "2.0.1", 696 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 697 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 698 | "dev": true, 699 | "dependencies": { 700 | "balanced-match": "^1.0.0" 701 | } 702 | }, 703 | "node_modules/brorand": { 704 | "version": "1.1.0", 705 | "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", 706 | "integrity": "sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w==", 707 | "dev": true 708 | }, 709 | "node_modules/browserify-aes": { 710 | "version": "1.2.0", 711 | "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", 712 | "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", 713 | "dev": true, 714 | "dependencies": { 715 | "buffer-xor": "^1.0.3", 716 | "cipher-base": "^1.0.0", 717 | "create-hash": "^1.1.0", 718 | "evp_bytestokey": "^1.0.3", 719 | "inherits": "^2.0.1", 720 | "safe-buffer": "^5.0.1" 721 | } 722 | }, 723 | "node_modules/bs58": { 724 | "version": "5.0.0", 725 | "resolved": "https://registry.npmjs.org/bs58/-/bs58-5.0.0.tgz", 726 | "integrity": "sha512-r+ihvQJvahgYT50JD05dyJNKlmmSlMoOGwn1lCcEzanPglg7TxYjioQUYehQ9mAR/+hOSd2jRc/Z2y5UxBymvQ==", 727 | "dev": true, 728 | "dependencies": { 729 | "base-x": "^4.0.0" 730 | } 731 | }, 732 | "node_modules/bs58check": { 733 | "version": "3.0.1", 734 | "resolved": "https://registry.npmjs.org/bs58check/-/bs58check-3.0.1.tgz", 735 | "integrity": "sha512-hjuuJvoWEybo7Hn/0xOrczQKKEKD63WguEjlhLExYs2wUBcebDC1jDNK17eEAD2lYfw82d5ASC1d7K3SWszjaQ==", 736 | "dev": true, 737 | "dependencies": { 738 | "@noble/hashes": "^1.2.0", 739 | "bs58": "^5.0.0" 740 | } 741 | }, 742 | "node_modules/buffer-equals": { 743 | "version": "1.0.4", 744 | "resolved": "https://registry.npmjs.org/buffer-equals/-/buffer-equals-1.0.4.tgz", 745 | "integrity": "sha512-99MsCq0j5+RhubVEtKQgKaD6EM+UP3xJgIvQqwJ3SOLDUekzxMX1ylXBng+Wa2sh7mGT0W6RUly8ojjr1Tt6nA==", 746 | "dev": true, 747 | "engines": { 748 | "node": ">=0.10.0" 749 | } 750 | }, 751 | "node_modules/buffer-xor": { 752 | "version": "1.0.3", 753 | "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", 754 | "integrity": "sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ==", 755 | "dev": true 756 | }, 757 | "node_modules/cacache": { 758 | "version": "18.0.3", 759 | "resolved": "https://registry.npmjs.org/cacache/-/cacache-18.0.3.tgz", 760 | "integrity": "sha512-qXCd4rh6I07cnDqh8V48/94Tc/WSfj+o3Gn6NZ0aZovS255bUx8O13uKxRFd2eWG0xgsco7+YItQNPaa5E85hg==", 761 | "dev": true, 762 | "dependencies": { 763 | "@npmcli/fs": "^3.1.0", 764 | "fs-minipass": "^3.0.0", 765 | "glob": "^10.2.2", 766 | "lru-cache": "^10.0.1", 767 | "minipass": "^7.0.3", 768 | "minipass-collect": "^2.0.1", 769 | "minipass-flush": "^1.0.5", 770 | "minipass-pipeline": "^1.2.4", 771 | "p-map": "^4.0.0", 772 | "ssri": "^10.0.0", 773 | "tar": "^6.1.11", 774 | "unique-filename": "^3.0.0" 775 | }, 776 | "engines": { 777 | "node": "^16.14.0 || >=18.0.0" 778 | } 779 | }, 780 | "node_modules/chownr": { 781 | "version": "2.0.0", 782 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", 783 | "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", 784 | "dev": true, 785 | "engines": { 786 | "node": ">=10" 787 | } 788 | }, 789 | "node_modules/cipher-base": { 790 | "version": "1.0.4", 791 | "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", 792 | "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", 793 | "dev": true, 794 | "dependencies": { 795 | "inherits": "^2.0.1", 796 | "safe-buffer": "^5.0.1" 797 | } 798 | }, 799 | "node_modules/clean-stack": { 800 | "version": "2.2.0", 801 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 802 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 803 | "dev": true, 804 | "engines": { 805 | "node": ">=6" 806 | } 807 | }, 808 | "node_modules/color": { 809 | "version": "3.2.1", 810 | "resolved": "https://registry.npmjs.org/color/-/color-3.2.1.tgz", 811 | "integrity": "sha512-aBl7dZI9ENN6fUGC7mWpMTPNHmWUSNan9tuWN6ahh5ZLNk9baLJOnSMlrQkHcrfFgz2/RigjUVAjdx36VcemKA==", 812 | "dev": true, 813 | "dependencies": { 814 | "color-convert": "^1.9.3", 815 | "color-string": "^1.6.0" 816 | } 817 | }, 818 | "node_modules/color-convert": { 819 | "version": "1.9.3", 820 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 821 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 822 | "dev": true, 823 | "dependencies": { 824 | "color-name": "1.1.3" 825 | } 826 | }, 827 | "node_modules/color-name": { 828 | "version": "1.1.3", 829 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 830 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 831 | "dev": true 832 | }, 833 | "node_modules/color-string": { 834 | "version": "1.9.1", 835 | "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.9.1.tgz", 836 | "integrity": "sha512-shrVawQFojnZv6xM40anx4CkoDP+fZsw/ZerEMsW/pyzsRbElpsL/DBVW7q3ExxwusdNXI3lXpuhEZkzs8p5Eg==", 837 | "dev": true, 838 | "dependencies": { 839 | "color-name": "^1.0.0", 840 | "simple-swizzle": "^0.2.2" 841 | } 842 | }, 843 | "node_modules/color-support": { 844 | "version": "1.1.3", 845 | "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", 846 | "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==", 847 | "dev": true, 848 | "bin": { 849 | "color-support": "bin.js" 850 | } 851 | }, 852 | "node_modules/colorspace": { 853 | "version": "1.1.4", 854 | "resolved": "https://registry.npmjs.org/colorspace/-/colorspace-1.1.4.tgz", 855 | "integrity": "sha512-BgvKJiuVu1igBUF2kEjRCZXol6wiiGbY5ipL/oVPwm0BL9sIpMIzM8IK7vwuxIIzOXMV3Ey5w+vxhm0rR/TN8w==", 856 | "dev": true, 857 | "dependencies": { 858 | "color": "^3.1.3", 859 | "text-hex": "1.0.x" 860 | } 861 | }, 862 | "node_modules/concat-map": { 863 | "version": "0.0.1", 864 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 865 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 866 | "dev": true 867 | }, 868 | "node_modules/console-control-strings": { 869 | "version": "1.1.0", 870 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 871 | "integrity": "sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==", 872 | "dev": true 873 | }, 874 | "node_modules/create-hash": { 875 | "version": "1.2.0", 876 | "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", 877 | "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", 878 | "dev": true, 879 | "dependencies": { 880 | "cipher-base": "^1.0.1", 881 | "inherits": "^2.0.1", 882 | "md5.js": "^1.3.4", 883 | "ripemd160": "^2.0.1", 884 | "sha.js": "^2.4.0" 885 | } 886 | }, 887 | "node_modules/create-hmac": { 888 | "version": "1.1.7", 889 | "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", 890 | "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", 891 | "dev": true, 892 | "dependencies": { 893 | "cipher-base": "^1.0.3", 894 | "create-hash": "^1.1.0", 895 | "inherits": "^2.0.1", 896 | "ripemd160": "^2.0.0", 897 | "safe-buffer": "^5.0.1", 898 | "sha.js": "^2.4.8" 899 | } 900 | }, 901 | "node_modules/create-require": { 902 | "version": "1.1.1", 903 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 904 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 905 | "dev": true 906 | }, 907 | "node_modules/cross-spawn": { 908 | "version": "7.0.3", 909 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 910 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 911 | "dev": true, 912 | "dependencies": { 913 | "path-key": "^3.1.0", 914 | "shebang-command": "^2.0.0", 915 | "which": "^2.0.1" 916 | }, 917 | "engines": { 918 | "node": ">= 8" 919 | } 920 | }, 921 | "node_modules/cross-spawn/node_modules/isexe": { 922 | "version": "2.0.0", 923 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 924 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 925 | "dev": true 926 | }, 927 | "node_modules/cross-spawn/node_modules/which": { 928 | "version": "2.0.2", 929 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 930 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 931 | "dev": true, 932 | "dependencies": { 933 | "isexe": "^2.0.0" 934 | }, 935 | "bin": { 936 | "node-which": "bin/node-which" 937 | }, 938 | "engines": { 939 | "node": ">= 8" 940 | } 941 | }, 942 | "node_modules/crypto": { 943 | "version": "1.0.1", 944 | "resolved": "https://registry.npmjs.org/crypto/-/crypto-1.0.1.tgz", 945 | "integrity": "sha512-VxBKmeNcqQdiUQUW2Tzq0t377b54N2bMtXO/qiLa+6eRRmmC4qT3D4OnTGoT/U6O9aklQ/jTwbOtRMTTY8G0Ig==", 946 | "deprecated": "This package is no longer supported. It's now a built-in Node module. If you've depended on crypto, you should switch to the one that's built-in.", 947 | "dev": true 948 | }, 949 | "node_modules/debug": { 950 | "version": "4.3.5", 951 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.5.tgz", 952 | "integrity": "sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==", 953 | "dev": true, 954 | "dependencies": { 955 | "ms": "2.1.2" 956 | }, 957 | "engines": { 958 | "node": ">=6.0" 959 | }, 960 | "peerDependenciesMeta": { 961 | "supports-color": { 962 | "optional": true 963 | } 964 | } 965 | }, 966 | "node_modules/delegates": { 967 | "version": "1.0.0", 968 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 969 | "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==", 970 | "dev": true 971 | }, 972 | "node_modules/detect-libc": { 973 | "version": "2.0.3", 974 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.3.tgz", 975 | "integrity": "sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==", 976 | "dev": true, 977 | "engines": { 978 | "node": ">=8" 979 | } 980 | }, 981 | "node_modules/diff": { 982 | "version": "4.0.2", 983 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 984 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 985 | "dev": true, 986 | "engines": { 987 | "node": ">=0.3.1" 988 | } 989 | }, 990 | "node_modules/dotenv": { 991 | "version": "16.4.5", 992 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.4.5.tgz", 993 | "integrity": "sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==", 994 | "dev": true, 995 | "engines": { 996 | "node": ">=12" 997 | }, 998 | "funding": { 999 | "url": "https://dotenvx.com" 1000 | } 1001 | }, 1002 | "node_modules/drbg.js": { 1003 | "version": "1.0.1", 1004 | "resolved": "https://registry.npmjs.org/drbg.js/-/drbg.js-1.0.1.tgz", 1005 | "integrity": "sha512-F4wZ06PvqxYLFEZKkFxTDcns9oFNk34hvmJSEwdzsxVQ8YI5YaxtACgQatkYgv2VI2CFkUd2Y+xosPQnHv809g==", 1006 | "dev": true, 1007 | "dependencies": { 1008 | "browserify-aes": "^1.0.6", 1009 | "create-hash": "^1.1.2", 1010 | "create-hmac": "^1.1.4" 1011 | }, 1012 | "engines": { 1013 | "node": ">=0.10" 1014 | } 1015 | }, 1016 | "node_modules/eastasianwidth": { 1017 | "version": "0.2.0", 1018 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 1019 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 1020 | "dev": true 1021 | }, 1022 | "node_modules/ecpair": { 1023 | "version": "2.1.0", 1024 | "resolved": "https://registry.npmjs.org/ecpair/-/ecpair-2.1.0.tgz", 1025 | "integrity": "sha512-cL/mh3MtJutFOvFc27GPZE2pWL3a3k4YvzUWEOvilnfZVlH3Jwgx/7d6tlD7/75tNk8TG2m+7Kgtz0SI1tWcqw==", 1026 | "dev": true, 1027 | "dependencies": { 1028 | "randombytes": "^2.1.0", 1029 | "typeforce": "^1.18.0", 1030 | "wif": "^2.0.6" 1031 | }, 1032 | "engines": { 1033 | "node": ">=8.0.0" 1034 | } 1035 | }, 1036 | "node_modules/elliptic": { 1037 | "version": "6.5.5", 1038 | "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.5.tgz", 1039 | "integrity": "sha512-7EjbcmUm17NQFu4Pmgmq2olYMj8nwMnpcddByChSUjArp8F5DQWcIcpriwO4ZToLNAJig0yiyjswfyGNje/ixw==", 1040 | "dev": true, 1041 | "dependencies": { 1042 | "bn.js": "^4.11.9", 1043 | "brorand": "^1.1.0", 1044 | "hash.js": "^1.0.0", 1045 | "hmac-drbg": "^1.0.1", 1046 | "inherits": "^2.0.4", 1047 | "minimalistic-assert": "^1.0.1", 1048 | "minimalistic-crypto-utils": "^1.0.1" 1049 | } 1050 | }, 1051 | "node_modules/emoji-regex": { 1052 | "version": "9.2.2", 1053 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 1054 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 1055 | "dev": true 1056 | }, 1057 | "node_modules/enabled": { 1058 | "version": "2.0.0", 1059 | "resolved": "https://registry.npmjs.org/enabled/-/enabled-2.0.0.tgz", 1060 | "integrity": "sha512-AKrN98kuwOzMIdAizXGI86UFBoo26CL21UM763y1h/GMSJ4/OHU9k2YlsmBpyScFo/wbLzWQJBMCW4+IO3/+OQ==", 1061 | "dev": true 1062 | }, 1063 | "node_modules/encoding": { 1064 | "version": "0.1.13", 1065 | "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz", 1066 | "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==", 1067 | "dev": true, 1068 | "optional": true, 1069 | "dependencies": { 1070 | "iconv-lite": "^0.6.2" 1071 | } 1072 | }, 1073 | "node_modules/env-paths": { 1074 | "version": "2.2.0", 1075 | "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.0.tgz", 1076 | "integrity": "sha512-6u0VYSCo/OW6IoD5WCLLy9JUGARbamfSavcNXry/eu8aHVFei6CD3Sw+VGX5alea1i9pgPHW0mbu6Xj0uBh7gA==", 1077 | "dev": true, 1078 | "engines": { 1079 | "node": ">=6" 1080 | } 1081 | }, 1082 | "node_modules/err-code": { 1083 | "version": "2.0.3", 1084 | "resolved": "https://registry.npmjs.org/err-code/-/err-code-2.0.3.tgz", 1085 | "integrity": "sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA==", 1086 | "dev": true 1087 | }, 1088 | "node_modules/ethers": { 1089 | "version": "6.13.1", 1090 | "resolved": "https://registry.npmjs.org/ethers/-/ethers-6.13.1.tgz", 1091 | "integrity": "sha512-hdJ2HOxg/xx97Lm9HdCWk949BfYqYWpyw4//78SiwOLgASyfrNszfMUNB2joKjvGUdwhHfaiMMFFwacVVoLR9A==", 1092 | "dev": true, 1093 | "funding": [ 1094 | { 1095 | "type": "individual", 1096 | "url": "https://github.com/sponsors/ethers-io/" 1097 | }, 1098 | { 1099 | "type": "individual", 1100 | "url": "https://www.buymeacoffee.com/ricmoo" 1101 | } 1102 | ], 1103 | "dependencies": { 1104 | "@adraffy/ens-normalize": "1.10.1", 1105 | "@noble/curves": "1.2.0", 1106 | "@noble/hashes": "1.3.2", 1107 | "@types/node": "18.15.13", 1108 | "aes-js": "4.0.0-beta.5", 1109 | "tslib": "2.4.0", 1110 | "ws": "8.17.1" 1111 | }, 1112 | "engines": { 1113 | "node": ">=14.0.0" 1114 | } 1115 | }, 1116 | "node_modules/ethers/node_modules/@noble/hashes": { 1117 | "version": "1.3.2", 1118 | "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.3.2.tgz", 1119 | "integrity": "sha512-MVC8EAQp7MvEcm30KWENFjgR+Mkmf+D189XJTkFIlwohU5hcBbn1ZkKq7KVTi2Hme3PMGF390DaL52beVrIihQ==", 1120 | "dev": true, 1121 | "engines": { 1122 | "node": ">= 16" 1123 | }, 1124 | "funding": { 1125 | "url": "https://paulmillr.com/funding/" 1126 | } 1127 | }, 1128 | "node_modules/ethers/node_modules/@types/node": { 1129 | "version": "18.15.13", 1130 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.15.13.tgz", 1131 | "integrity": "sha512-N+0kuo9KgrUQ1Sn/ifDXsvg0TTleP7rIy4zOBGECxAljqvqfqpTfzx0Q1NUedOixRMBfe2Whhb056a42cWs26Q==", 1132 | "dev": true 1133 | }, 1134 | "node_modules/evp_bytestokey": { 1135 | "version": "1.0.3", 1136 | "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", 1137 | "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", 1138 | "dev": true, 1139 | "dependencies": { 1140 | "md5.js": "^1.3.4", 1141 | "safe-buffer": "^5.1.1" 1142 | } 1143 | }, 1144 | "node_modules/exponential-backoff": { 1145 | "version": "3.1.1", 1146 | "resolved": "https://registry.npmjs.org/exponential-backoff/-/exponential-backoff-3.1.1.tgz", 1147 | "integrity": "sha512-dX7e/LHVJ6W3DE1MHWi9S1EYzDESENfLrYohG2G++ovZrYOkm4Knwa0mc1cn84xJOR4KEU0WSchhLbd0UklbHw==", 1148 | "dev": true 1149 | }, 1150 | "node_modules/fecha": { 1151 | "version": "4.2.3", 1152 | "resolved": "https://registry.npmjs.org/fecha/-/fecha-4.2.3.tgz", 1153 | "integrity": "sha512-OP2IUU6HeYKJi3i0z4A19kHMQoLVs4Hc+DPqqxI2h/DPZHTm/vjsfC6P0b4jCMy14XizLBqvndQ+UilD7707Jw==", 1154 | "dev": true 1155 | }, 1156 | "node_modules/file-uri-to-path": { 1157 | "version": "1.0.0", 1158 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", 1159 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", 1160 | "dev": true 1161 | }, 1162 | "node_modules/fn.name": { 1163 | "version": "1.1.0", 1164 | "resolved": "https://registry.npmjs.org/fn.name/-/fn.name-1.1.0.tgz", 1165 | "integrity": "sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw==", 1166 | "dev": true 1167 | }, 1168 | "node_modules/foreground-child": { 1169 | "version": "3.2.1", 1170 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.2.1.tgz", 1171 | "integrity": "sha512-PXUUyLqrR2XCWICfv6ukppP96sdFwWbNEnfEMt7jNsISjMsvaLNinAHNDYyvkyU+SZG2BTSbT5NjG+vZslfGTA==", 1172 | "dev": true, 1173 | "dependencies": { 1174 | "cross-spawn": "^7.0.0", 1175 | "signal-exit": "^4.0.1" 1176 | }, 1177 | "engines": { 1178 | "node": ">=14" 1179 | }, 1180 | "funding": { 1181 | "url": "https://github.com/sponsors/isaacs" 1182 | } 1183 | }, 1184 | "node_modules/fs-minipass": { 1185 | "version": "3.0.3", 1186 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-3.0.3.tgz", 1187 | "integrity": "sha512-XUBA9XClHbnJWSfBzjkm6RvPsyg3sryZt06BEQoXcF7EK/xpGaQYJgQKDJSUH5SGZ76Y7pFx1QBnXz09rU5Fbw==", 1188 | "dev": true, 1189 | "dependencies": { 1190 | "minipass": "^7.0.3" 1191 | }, 1192 | "engines": { 1193 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 1194 | } 1195 | }, 1196 | "node_modules/fs.realpath": { 1197 | "version": "1.0.0", 1198 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1199 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1200 | "dev": true 1201 | }, 1202 | "node_modules/gauge": { 1203 | "version": "5.0.2", 1204 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-5.0.2.tgz", 1205 | "integrity": "sha512-pMaFftXPtiGIHCJHdcUUx9Rby/rFT/Kkt3fIIGCs+9PMDIljSyRiqraTlxNtBReJRDfUefpa263RQ3vnp5G/LQ==", 1206 | "deprecated": "This package is no longer supported.", 1207 | "dev": true, 1208 | "dependencies": { 1209 | "aproba": "^1.0.3 || ^2.0.0", 1210 | "color-support": "^1.1.3", 1211 | "console-control-strings": "^1.1.0", 1212 | "has-unicode": "^2.0.1", 1213 | "signal-exit": "^4.0.1", 1214 | "string-width": "^4.2.3", 1215 | "strip-ansi": "^6.0.1", 1216 | "wide-align": "^1.1.5" 1217 | }, 1218 | "engines": { 1219 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 1220 | } 1221 | }, 1222 | "node_modules/gauge/node_modules/ansi-regex": { 1223 | "version": "5.0.1", 1224 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1225 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1226 | "dev": true, 1227 | "engines": { 1228 | "node": ">=8" 1229 | } 1230 | }, 1231 | "node_modules/gauge/node_modules/emoji-regex": { 1232 | "version": "8.0.0", 1233 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1234 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1235 | "dev": true 1236 | }, 1237 | "node_modules/gauge/node_modules/string-width": { 1238 | "version": "4.2.3", 1239 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1240 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1241 | "dev": true, 1242 | "dependencies": { 1243 | "emoji-regex": "^8.0.0", 1244 | "is-fullwidth-code-point": "^3.0.0", 1245 | "strip-ansi": "^6.0.1" 1246 | }, 1247 | "engines": { 1248 | "node": ">=8" 1249 | } 1250 | }, 1251 | "node_modules/gauge/node_modules/strip-ansi": { 1252 | "version": "6.0.1", 1253 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1254 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1255 | "dev": true, 1256 | "dependencies": { 1257 | "ansi-regex": "^5.0.1" 1258 | }, 1259 | "engines": { 1260 | "node": ">=8" 1261 | } 1262 | }, 1263 | "node_modules/glob": { 1264 | "version": "10.4.5", 1265 | "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", 1266 | "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", 1267 | "dev": true, 1268 | "dependencies": { 1269 | "foreground-child": "^3.1.0", 1270 | "jackspeak": "^3.1.2", 1271 | "minimatch": "^9.0.4", 1272 | "minipass": "^7.1.2", 1273 | "package-json-from-dist": "^1.0.0", 1274 | "path-scurry": "^1.11.1" 1275 | }, 1276 | "bin": { 1277 | "glob": "dist/esm/bin.mjs" 1278 | }, 1279 | "funding": { 1280 | "url": "https://github.com/sponsors/isaacs" 1281 | } 1282 | }, 1283 | "node_modules/graceful-fs": { 1284 | "version": "4.2.11", 1285 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1286 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1287 | "dev": true 1288 | }, 1289 | "node_modules/has-unicode": { 1290 | "version": "2.0.1", 1291 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 1292 | "integrity": "sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==", 1293 | "dev": true 1294 | }, 1295 | "node_modules/hash-base": { 1296 | "version": "3.1.0", 1297 | "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.1.0.tgz", 1298 | "integrity": "sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA==", 1299 | "dev": true, 1300 | "dependencies": { 1301 | "inherits": "^2.0.4", 1302 | "readable-stream": "^3.6.0", 1303 | "safe-buffer": "^5.2.0" 1304 | }, 1305 | "engines": { 1306 | "node": ">=4" 1307 | } 1308 | }, 1309 | "node_modules/hash.js": { 1310 | "version": "1.1.7", 1311 | "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", 1312 | "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", 1313 | "dev": true, 1314 | "dependencies": { 1315 | "inherits": "^2.0.3", 1316 | "minimalistic-assert": "^1.0.1" 1317 | } 1318 | }, 1319 | "node_modules/hmac-drbg": { 1320 | "version": "1.0.1", 1321 | "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", 1322 | "integrity": "sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg==", 1323 | "dev": true, 1324 | "dependencies": { 1325 | "hash.js": "^1.0.3", 1326 | "minimalistic-assert": "^1.0.0", 1327 | "minimalistic-crypto-utils": "^1.0.1" 1328 | } 1329 | }, 1330 | "node_modules/http-cache-semantics": { 1331 | "version": "4.1.1", 1332 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", 1333 | "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==", 1334 | "dev": true 1335 | }, 1336 | "node_modules/http-proxy-agent": { 1337 | "version": "7.0.2", 1338 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", 1339 | "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", 1340 | "dev": true, 1341 | "dependencies": { 1342 | "agent-base": "^7.1.0", 1343 | "debug": "^4.3.4" 1344 | }, 1345 | "engines": { 1346 | "node": ">= 14" 1347 | } 1348 | }, 1349 | "node_modules/http-proxy-agent/node_modules/agent-base": { 1350 | "version": "7.1.1", 1351 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", 1352 | "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", 1353 | "dev": true, 1354 | "dependencies": { 1355 | "debug": "^4.3.4" 1356 | }, 1357 | "engines": { 1358 | "node": ">= 14" 1359 | } 1360 | }, 1361 | "node_modules/https-proxy-agent": { 1362 | "version": "5.0.1", 1363 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 1364 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 1365 | "dev": true, 1366 | "dependencies": { 1367 | "agent-base": "6", 1368 | "debug": "4" 1369 | }, 1370 | "engines": { 1371 | "node": ">= 6" 1372 | } 1373 | }, 1374 | "node_modules/iconv-lite": { 1375 | "version": "0.6.3", 1376 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", 1377 | "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", 1378 | "dev": true, 1379 | "optional": true, 1380 | "dependencies": { 1381 | "safer-buffer": ">= 2.1.2 < 3.0.0" 1382 | }, 1383 | "engines": { 1384 | "node": ">=0.10.0" 1385 | } 1386 | }, 1387 | "node_modules/imurmurhash": { 1388 | "version": "0.1.4", 1389 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1390 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1391 | "dev": true, 1392 | "engines": { 1393 | "node": ">=0.8.19" 1394 | } 1395 | }, 1396 | "node_modules/indent-string": { 1397 | "version": "4.0.0", 1398 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 1399 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 1400 | "dev": true, 1401 | "engines": { 1402 | "node": ">=8" 1403 | } 1404 | }, 1405 | "node_modules/inflight": { 1406 | "version": "1.0.6", 1407 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1408 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1409 | "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", 1410 | "dev": true, 1411 | "dependencies": { 1412 | "once": "^1.3.0", 1413 | "wrappy": "1" 1414 | } 1415 | }, 1416 | "node_modules/inherits": { 1417 | "version": "2.0.4", 1418 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1419 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1420 | "dev": true 1421 | }, 1422 | "node_modules/ip-address": { 1423 | "version": "9.0.5", 1424 | "resolved": "https://registry.npmjs.org/ip-address/-/ip-address-9.0.5.tgz", 1425 | "integrity": "sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==", 1426 | "dev": true, 1427 | "dependencies": { 1428 | "jsbn": "1.1.0", 1429 | "sprintf-js": "^1.1.3" 1430 | }, 1431 | "engines": { 1432 | "node": ">= 12" 1433 | } 1434 | }, 1435 | "node_modules/is-arrayish": { 1436 | "version": "0.3.2", 1437 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", 1438 | "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==", 1439 | "dev": true 1440 | }, 1441 | "node_modules/is-fullwidth-code-point": { 1442 | "version": "3.0.0", 1443 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1444 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1445 | "dev": true, 1446 | "engines": { 1447 | "node": ">=8" 1448 | } 1449 | }, 1450 | "node_modules/is-lambda": { 1451 | "version": "1.0.1", 1452 | "resolved": "https://registry.npmjs.org/is-lambda/-/is-lambda-1.0.1.tgz", 1453 | "integrity": "sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ==", 1454 | "dev": true 1455 | }, 1456 | "node_modules/is-stream": { 1457 | "version": "2.0.1", 1458 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 1459 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 1460 | "dev": true, 1461 | "engines": { 1462 | "node": ">=8" 1463 | }, 1464 | "funding": { 1465 | "url": "https://github.com/sponsors/sindresorhus" 1466 | } 1467 | }, 1468 | "node_modules/isexe": { 1469 | "version": "3.1.1", 1470 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-3.1.1.tgz", 1471 | "integrity": "sha512-LpB/54B+/2J5hqQ7imZHfdU31OlgQqx7ZicVlkm9kzg9/w8GKLEcFfJl/t7DCEDueOyBAD6zCCwTO6Fzs0NoEQ==", 1472 | "dev": true, 1473 | "engines": { 1474 | "node": ">=16" 1475 | } 1476 | }, 1477 | "node_modules/jackspeak": { 1478 | "version": "3.4.2", 1479 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.2.tgz", 1480 | "integrity": "sha512-qH3nOSj8q/8+Eg8LUPOq3C+6HWkpUioIjDsq1+D4zY91oZvpPttw8GwtF1nReRYKXl+1AORyFqtm2f5Q1SB6/Q==", 1481 | "dev": true, 1482 | "dependencies": { 1483 | "@isaacs/cliui": "^8.0.2" 1484 | }, 1485 | "engines": { 1486 | "node": "14 >=14.21 || 16 >=16.20 || >=18" 1487 | }, 1488 | "funding": { 1489 | "url": "https://github.com/sponsors/isaacs" 1490 | }, 1491 | "optionalDependencies": { 1492 | "@pkgjs/parseargs": "^0.11.0" 1493 | } 1494 | }, 1495 | "node_modules/jsbn": { 1496 | "version": "1.1.0", 1497 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz", 1498 | "integrity": "sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A==", 1499 | "dev": true 1500 | }, 1501 | "node_modules/kuler": { 1502 | "version": "2.0.0", 1503 | "resolved": "https://registry.npmjs.org/kuler/-/kuler-2.0.0.tgz", 1504 | "integrity": "sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==", 1505 | "dev": true 1506 | }, 1507 | "node_modules/logform": { 1508 | "version": "2.6.0", 1509 | "resolved": "https://registry.npmjs.org/logform/-/logform-2.6.0.tgz", 1510 | "integrity": "sha512-1ulHeNPp6k/LD8H91o7VYFBng5i1BDE7HoKxVbZiGFidS1Rj65qcywLxX+pVfAPoQJEjRdvKcusKwOupHCVOVQ==", 1511 | "dev": true, 1512 | "dependencies": { 1513 | "@colors/colors": "1.6.0", 1514 | "@types/triple-beam": "^1.3.2", 1515 | "fecha": "^4.2.0", 1516 | "ms": "^2.1.1", 1517 | "safe-stable-stringify": "^2.3.1", 1518 | "triple-beam": "^1.3.0" 1519 | }, 1520 | "engines": { 1521 | "node": ">= 12.0.0" 1522 | } 1523 | }, 1524 | "node_modules/lru-cache": { 1525 | "version": "10.4.2", 1526 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.2.tgz", 1527 | "integrity": "sha512-voV4dDrdVZVNz84n39LFKDaRzfwhdzJ7akpyXfTMxCgRUp07U3lcJUXRlhTKP17rgt09sUzLi5iCitpEAr+6ug==", 1528 | "dev": true, 1529 | "engines": { 1530 | "node": "14 || 16 || 18 || 20 || >=22" 1531 | } 1532 | }, 1533 | "node_modules/make-dir": { 1534 | "version": "3.1.0", 1535 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1536 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1537 | "dev": true, 1538 | "dependencies": { 1539 | "semver": "^6.0.0" 1540 | }, 1541 | "engines": { 1542 | "node": ">=8" 1543 | }, 1544 | "funding": { 1545 | "url": "https://github.com/sponsors/sindresorhus" 1546 | } 1547 | }, 1548 | "node_modules/make-dir/node_modules/semver": { 1549 | "version": "6.3.1", 1550 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 1551 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 1552 | "dev": true, 1553 | "bin": { 1554 | "semver": "bin/semver.js" 1555 | } 1556 | }, 1557 | "node_modules/make-error": { 1558 | "version": "1.3.6", 1559 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1560 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1561 | "dev": true 1562 | }, 1563 | "node_modules/make-fetch-happen": { 1564 | "version": "13.0.1", 1565 | "resolved": "https://registry.npmjs.org/make-fetch-happen/-/make-fetch-happen-13.0.1.tgz", 1566 | "integrity": "sha512-cKTUFc/rbKUd/9meOvgrpJ2WrNzymt6jfRDdwg5UCnVzv9dTpEj9JS5m3wtziXVCjluIXyL8pcaukYqezIzZQA==", 1567 | "dev": true, 1568 | "dependencies": { 1569 | "@npmcli/agent": "^2.0.0", 1570 | "cacache": "^18.0.0", 1571 | "http-cache-semantics": "^4.1.1", 1572 | "is-lambda": "^1.0.1", 1573 | "minipass": "^7.0.2", 1574 | "minipass-fetch": "^3.0.0", 1575 | "minipass-flush": "^1.0.5", 1576 | "minipass-pipeline": "^1.2.4", 1577 | "negotiator": "^0.6.3", 1578 | "proc-log": "^4.2.0", 1579 | "promise-retry": "^2.0.1", 1580 | "ssri": "^10.0.0" 1581 | }, 1582 | "engines": { 1583 | "node": "^16.14.0 || >=18.0.0" 1584 | } 1585 | }, 1586 | "node_modules/make-fetch-happen/node_modules/proc-log": { 1587 | "version": "4.2.0", 1588 | "resolved": "https://registry.npmjs.org/proc-log/-/proc-log-4.2.0.tgz", 1589 | "integrity": "sha512-g8+OnU/L2v+wyiVK+D5fA34J7EH8jZ8DDlvwhRCMxmMj7UCBvxiO1mGeN+36JXIKF4zevU4kRBd8lVgG9vLelA==", 1590 | "dev": true, 1591 | "engines": { 1592 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 1593 | } 1594 | }, 1595 | "node_modules/md5.js": { 1596 | "version": "1.3.5", 1597 | "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", 1598 | "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", 1599 | "dev": true, 1600 | "dependencies": { 1601 | "hash-base": "^3.0.0", 1602 | "inherits": "^2.0.1", 1603 | "safe-buffer": "^5.1.2" 1604 | } 1605 | }, 1606 | "node_modules/minimalistic-assert": { 1607 | "version": "1.0.1", 1608 | "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", 1609 | "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", 1610 | "dev": true 1611 | }, 1612 | "node_modules/minimalistic-crypto-utils": { 1613 | "version": "1.0.1", 1614 | "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", 1615 | "integrity": "sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg==", 1616 | "dev": true 1617 | }, 1618 | "node_modules/minimatch": { 1619 | "version": "9.0.5", 1620 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", 1621 | "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", 1622 | "dev": true, 1623 | "dependencies": { 1624 | "brace-expansion": "^2.0.1" 1625 | }, 1626 | "engines": { 1627 | "node": ">=16 || 14 >=14.17" 1628 | }, 1629 | "funding": { 1630 | "url": "https://github.com/sponsors/isaacs" 1631 | } 1632 | }, 1633 | "node_modules/minipass": { 1634 | "version": "7.1.2", 1635 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", 1636 | "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", 1637 | "dev": true, 1638 | "engines": { 1639 | "node": ">=16 || 14 >=14.17" 1640 | } 1641 | }, 1642 | "node_modules/minipass-collect": { 1643 | "version": "2.0.1", 1644 | "resolved": "https://registry.npmjs.org/minipass-collect/-/minipass-collect-2.0.1.tgz", 1645 | "integrity": "sha512-D7V8PO9oaz7PWGLbCACuI1qEOsq7UKfLotx/C0Aet43fCUB/wfQ7DYeq2oR/svFJGYDHPr38SHATeaj/ZoKHKw==", 1646 | "dev": true, 1647 | "dependencies": { 1648 | "minipass": "^7.0.3" 1649 | }, 1650 | "engines": { 1651 | "node": ">=16 || 14 >=14.17" 1652 | } 1653 | }, 1654 | "node_modules/minipass-fetch": { 1655 | "version": "3.0.5", 1656 | "resolved": "https://registry.npmjs.org/minipass-fetch/-/minipass-fetch-3.0.5.tgz", 1657 | "integrity": "sha512-2N8elDQAtSnFV0Dk7gt15KHsS0Fyz6CbYZ360h0WTYV1Ty46li3rAXVOQj1THMNLdmrD9Vt5pBPtWtVkpwGBqg==", 1658 | "dev": true, 1659 | "dependencies": { 1660 | "minipass": "^7.0.3", 1661 | "minipass-sized": "^1.0.3", 1662 | "minizlib": "^2.1.2" 1663 | }, 1664 | "engines": { 1665 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 1666 | }, 1667 | "optionalDependencies": { 1668 | "encoding": "^0.1.13" 1669 | } 1670 | }, 1671 | "node_modules/minipass-flush": { 1672 | "version": "1.0.5", 1673 | "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz", 1674 | "integrity": "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==", 1675 | "dev": true, 1676 | "dependencies": { 1677 | "minipass": "^3.0.0" 1678 | }, 1679 | "engines": { 1680 | "node": ">= 8" 1681 | } 1682 | }, 1683 | "node_modules/minipass-flush/node_modules/minipass": { 1684 | "version": "3.3.6", 1685 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 1686 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 1687 | "dev": true, 1688 | "dependencies": { 1689 | "yallist": "^4.0.0" 1690 | }, 1691 | "engines": { 1692 | "node": ">=8" 1693 | } 1694 | }, 1695 | "node_modules/minipass-pipeline": { 1696 | "version": "1.2.4", 1697 | "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz", 1698 | "integrity": "sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A==", 1699 | "dev": true, 1700 | "dependencies": { 1701 | "minipass": "^3.0.0" 1702 | }, 1703 | "engines": { 1704 | "node": ">=8" 1705 | } 1706 | }, 1707 | "node_modules/minipass-pipeline/node_modules/minipass": { 1708 | "version": "3.3.6", 1709 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 1710 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 1711 | "dev": true, 1712 | "dependencies": { 1713 | "yallist": "^4.0.0" 1714 | }, 1715 | "engines": { 1716 | "node": ">=8" 1717 | } 1718 | }, 1719 | "node_modules/minipass-sized": { 1720 | "version": "1.0.3", 1721 | "resolved": "https://registry.npmjs.org/minipass-sized/-/minipass-sized-1.0.3.tgz", 1722 | "integrity": "sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g==", 1723 | "dev": true, 1724 | "dependencies": { 1725 | "minipass": "^3.0.0" 1726 | }, 1727 | "engines": { 1728 | "node": ">=8" 1729 | } 1730 | }, 1731 | "node_modules/minipass-sized/node_modules/minipass": { 1732 | "version": "3.3.6", 1733 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 1734 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 1735 | "dev": true, 1736 | "dependencies": { 1737 | "yallist": "^4.0.0" 1738 | }, 1739 | "engines": { 1740 | "node": ">=8" 1741 | } 1742 | }, 1743 | "node_modules/minizlib": { 1744 | "version": "2.1.2", 1745 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", 1746 | "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", 1747 | "dev": true, 1748 | "dependencies": { 1749 | "minipass": "^3.0.0", 1750 | "yallist": "^4.0.0" 1751 | }, 1752 | "engines": { 1753 | "node": ">= 8" 1754 | } 1755 | }, 1756 | "node_modules/minizlib/node_modules/minipass": { 1757 | "version": "3.3.6", 1758 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 1759 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 1760 | "dev": true, 1761 | "dependencies": { 1762 | "yallist": "^4.0.0" 1763 | }, 1764 | "engines": { 1765 | "node": ">=8" 1766 | } 1767 | }, 1768 | "node_modules/mkdirp": { 1769 | "version": "1.0.4", 1770 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1771 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1772 | "dev": true, 1773 | "bin": { 1774 | "mkdirp": "bin/cmd.js" 1775 | }, 1776 | "engines": { 1777 | "node": ">=10" 1778 | } 1779 | }, 1780 | "node_modules/ms": { 1781 | "version": "2.1.2", 1782 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1783 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1784 | "dev": true 1785 | }, 1786 | "node_modules/nan": { 1787 | "version": "2.18.0", 1788 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.18.0.tgz", 1789 | "integrity": "sha512-W7tfG7vMOGtD30sHoZSSc/JVYiyDPEyQVso/Zz+/uQd0B0L46gtC+pHha5FFMRpil6fm/AoEcRWyOVi4+E/f8w==", 1790 | "dev": true 1791 | }, 1792 | "node_modules/negotiator": { 1793 | "version": "0.6.3", 1794 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1795 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1796 | "dev": true, 1797 | "engines": { 1798 | "node": ">= 0.6" 1799 | } 1800 | }, 1801 | "node_modules/node-fetch": { 1802 | "version": "2.7.0", 1803 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", 1804 | "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", 1805 | "dev": true, 1806 | "dependencies": { 1807 | "whatwg-url": "^5.0.0" 1808 | }, 1809 | "engines": { 1810 | "node": "4.x || >=6.0.0" 1811 | }, 1812 | "peerDependencies": { 1813 | "encoding": "^0.1.0" 1814 | }, 1815 | "peerDependenciesMeta": { 1816 | "encoding": { 1817 | "optional": true 1818 | } 1819 | } 1820 | }, 1821 | "node_modules/node-gyp": { 1822 | "version": "10.0.1", 1823 | "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-10.0.1.tgz", 1824 | "integrity": "sha512-gg3/bHehQfZivQVfqIyy8wTdSymF9yTyP4CJifK73imyNMU8AIGQE2pUa7dNWfmMeG9cDVF2eehiRMv0LC1iAg==", 1825 | "dev": true, 1826 | "dependencies": { 1827 | "env-paths": "^2.2.0", 1828 | "exponential-backoff": "^3.1.1", 1829 | "glob": "^10.3.10", 1830 | "graceful-fs": "^4.2.6", 1831 | "make-fetch-happen": "^13.0.0", 1832 | "nopt": "^7.0.0", 1833 | "proc-log": "^3.0.0", 1834 | "semver": "^7.3.5", 1835 | "tar": "^6.1.2", 1836 | "which": "^4.0.0" 1837 | }, 1838 | "bin": { 1839 | "node-gyp": "bin/node-gyp.js" 1840 | }, 1841 | "engines": { 1842 | "node": "^16.14.0 || >=18.0.0" 1843 | } 1844 | }, 1845 | "node_modules/node-gyp/node_modules/abbrev": { 1846 | "version": "2.0.0", 1847 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-2.0.0.tgz", 1848 | "integrity": "sha512-6/mh1E2u2YgEsCHdY0Yx5oW+61gZU+1vXaoiHHrpKeuRNNgFvS+/jrwHiQhB5apAf5oB7UB7E19ol2R2LKH8hQ==", 1849 | "dev": true, 1850 | "engines": { 1851 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 1852 | } 1853 | }, 1854 | "node_modules/node-gyp/node_modules/nopt": { 1855 | "version": "7.2.1", 1856 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-7.2.1.tgz", 1857 | "integrity": "sha512-taM24ViiimT/XntxbPyJQzCG+p4EKOpgD3mxFwW38mGjVUrfERQOeY4EDHjdnptttfHuHQXFx+lTP08Q+mLa/w==", 1858 | "dev": true, 1859 | "dependencies": { 1860 | "abbrev": "^2.0.0" 1861 | }, 1862 | "bin": { 1863 | "nopt": "bin/nopt.js" 1864 | }, 1865 | "engines": { 1866 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 1867 | } 1868 | }, 1869 | "node_modules/node-libcurl": { 1870 | "version": "4.0.0", 1871 | "resolved": "https://registry.npmjs.org/node-libcurl/-/node-libcurl-4.0.0.tgz", 1872 | "integrity": "sha512-v+u+OgSq6ldvf8MrdjieAy/mv8WeTN94nrTomh62zhItF2HH0Ckin/QEqs8+35DWyYrE5nBM2480UtWVXktzbQ==", 1873 | "dev": true, 1874 | "hasInstallScript": true, 1875 | "dependencies": { 1876 | "@mapbox/node-pre-gyp": "1.0.11", 1877 | "env-paths": "2.2.0", 1878 | "nan": "2.18.0", 1879 | "node-gyp": "10.0.1", 1880 | "npmlog": "7.0.1", 1881 | "rimraf": "5.0.5", 1882 | "tslib": "2.6.2" 1883 | }, 1884 | "engines": { 1885 | "node": ">=16.14" 1886 | } 1887 | }, 1888 | "node_modules/node-libcurl/node_modules/tslib": { 1889 | "version": "2.6.2", 1890 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 1891 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 1892 | "dev": true 1893 | }, 1894 | "node_modules/nopt": { 1895 | "version": "5.0.0", 1896 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 1897 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 1898 | "dev": true, 1899 | "dependencies": { 1900 | "abbrev": "1" 1901 | }, 1902 | "bin": { 1903 | "nopt": "bin/nopt.js" 1904 | }, 1905 | "engines": { 1906 | "node": ">=6" 1907 | } 1908 | }, 1909 | "node_modules/npmlog": { 1910 | "version": "7.0.1", 1911 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-7.0.1.tgz", 1912 | "integrity": "sha512-uJ0YFk/mCQpLBt+bxN88AKd+gyqZvZDbtiNxk6Waqcj2aPRyfVx8ITawkyQynxUagInjdYT1+qj4NfA5KJJUxg==", 1913 | "deprecated": "This package is no longer supported.", 1914 | "dev": true, 1915 | "dependencies": { 1916 | "are-we-there-yet": "^4.0.0", 1917 | "console-control-strings": "^1.1.0", 1918 | "gauge": "^5.0.0", 1919 | "set-blocking": "^2.0.0" 1920 | }, 1921 | "engines": { 1922 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 1923 | } 1924 | }, 1925 | "node_modules/object-assign": { 1926 | "version": "4.1.1", 1927 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1928 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1929 | "dev": true, 1930 | "engines": { 1931 | "node": ">=0.10.0" 1932 | } 1933 | }, 1934 | "node_modules/once": { 1935 | "version": "1.4.0", 1936 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1937 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1938 | "dev": true, 1939 | "dependencies": { 1940 | "wrappy": "1" 1941 | } 1942 | }, 1943 | "node_modules/one-time": { 1944 | "version": "1.0.0", 1945 | "resolved": "https://registry.npmjs.org/one-time/-/one-time-1.0.0.tgz", 1946 | "integrity": "sha512-5DXOiRKwuSEcQ/l0kGCF6Q3jcADFv5tSmRaJck/OqkVFcOzutB134KRSfF0xDrL39MNnqxbHBbUUcjZIhTgb2g==", 1947 | "dev": true, 1948 | "dependencies": { 1949 | "fn.name": "1.x.x" 1950 | } 1951 | }, 1952 | "node_modules/p-map": { 1953 | "version": "4.0.0", 1954 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 1955 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 1956 | "dev": true, 1957 | "dependencies": { 1958 | "aggregate-error": "^3.0.0" 1959 | }, 1960 | "engines": { 1961 | "node": ">=10" 1962 | }, 1963 | "funding": { 1964 | "url": "https://github.com/sponsors/sindresorhus" 1965 | } 1966 | }, 1967 | "node_modules/package-json-from-dist": { 1968 | "version": "1.0.0", 1969 | "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.0.tgz", 1970 | "integrity": "sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==", 1971 | "dev": true 1972 | }, 1973 | "node_modules/path-is-absolute": { 1974 | "version": "1.0.1", 1975 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1976 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1977 | "dev": true, 1978 | "engines": { 1979 | "node": ">=0.10.0" 1980 | } 1981 | }, 1982 | "node_modules/path-key": { 1983 | "version": "3.1.1", 1984 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1985 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1986 | "dev": true, 1987 | "engines": { 1988 | "node": ">=8" 1989 | } 1990 | }, 1991 | "node_modules/path-scurry": { 1992 | "version": "1.11.1", 1993 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", 1994 | "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", 1995 | "dev": true, 1996 | "dependencies": { 1997 | "lru-cache": "^10.2.0", 1998 | "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" 1999 | }, 2000 | "engines": { 2001 | "node": ">=16 || 14 >=14.18" 2002 | }, 2003 | "funding": { 2004 | "url": "https://github.com/sponsors/isaacs" 2005 | } 2006 | }, 2007 | "node_modules/proc-log": { 2008 | "version": "3.0.0", 2009 | "resolved": "https://registry.npmjs.org/proc-log/-/proc-log-3.0.0.tgz", 2010 | "integrity": "sha512-++Vn7NS4Xf9NacaU9Xq3URUuqZETPsf8L4j5/ckhaRYsfPeRyzGw+iDjFhV/Jr3uNmTvvddEJFWh5R1gRgUH8A==", 2011 | "dev": true, 2012 | "engines": { 2013 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 2014 | } 2015 | }, 2016 | "node_modules/promise-retry": { 2017 | "version": "2.0.1", 2018 | "resolved": "https://registry.npmjs.org/promise-retry/-/promise-retry-2.0.1.tgz", 2019 | "integrity": "sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g==", 2020 | "dev": true, 2021 | "dependencies": { 2022 | "err-code": "^2.0.2", 2023 | "retry": "^0.12.0" 2024 | }, 2025 | "engines": { 2026 | "node": ">=10" 2027 | } 2028 | }, 2029 | "node_modules/querystring": { 2030 | "version": "0.2.1", 2031 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.1.tgz", 2032 | "integrity": "sha512-wkvS7mL/JMugcup3/rMitHmd9ecIGd2lhFhK9N3UUQ450h66d1r3Y9nvXzQAW1Lq+wyx61k/1pfKS5KuKiyEbg==", 2033 | "deprecated": "The querystring API is considered Legacy. new code should use the URLSearchParams API instead.", 2034 | "dev": true, 2035 | "engines": { 2036 | "node": ">=0.4.x" 2037 | } 2038 | }, 2039 | "node_modules/randombytes": { 2040 | "version": "2.1.0", 2041 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2042 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2043 | "dev": true, 2044 | "dependencies": { 2045 | "safe-buffer": "^5.1.0" 2046 | } 2047 | }, 2048 | "node_modules/readable-stream": { 2049 | "version": "3.6.2", 2050 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 2051 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 2052 | "dev": true, 2053 | "dependencies": { 2054 | "inherits": "^2.0.3", 2055 | "string_decoder": "^1.1.1", 2056 | "util-deprecate": "^1.0.1" 2057 | }, 2058 | "engines": { 2059 | "node": ">= 6" 2060 | } 2061 | }, 2062 | "node_modules/retry": { 2063 | "version": "0.12.0", 2064 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", 2065 | "integrity": "sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==", 2066 | "dev": true, 2067 | "engines": { 2068 | "node": ">= 4" 2069 | } 2070 | }, 2071 | "node_modules/rimraf": { 2072 | "version": "5.0.5", 2073 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.5.tgz", 2074 | "integrity": "sha512-CqDakW+hMe/Bz202FPEymy68P+G50RfMQK+Qo5YUqc9SPipvbGjCGKd0RSKEelbsfQuw3g5NZDSrlZZAJurH1A==", 2075 | "dev": true, 2076 | "dependencies": { 2077 | "glob": "^10.3.7" 2078 | }, 2079 | "bin": { 2080 | "rimraf": "dist/esm/bin.mjs" 2081 | }, 2082 | "engines": { 2083 | "node": ">=14" 2084 | }, 2085 | "funding": { 2086 | "url": "https://github.com/sponsors/isaacs" 2087 | } 2088 | }, 2089 | "node_modules/ripemd160": { 2090 | "version": "2.0.2", 2091 | "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", 2092 | "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", 2093 | "dev": true, 2094 | "dependencies": { 2095 | "hash-base": "^3.0.0", 2096 | "inherits": "^2.0.1" 2097 | } 2098 | }, 2099 | "node_modules/safe-buffer": { 2100 | "version": "5.2.1", 2101 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2102 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 2103 | "dev": true, 2104 | "funding": [ 2105 | { 2106 | "type": "github", 2107 | "url": "https://github.com/sponsors/feross" 2108 | }, 2109 | { 2110 | "type": "patreon", 2111 | "url": "https://www.patreon.com/feross" 2112 | }, 2113 | { 2114 | "type": "consulting", 2115 | "url": "https://feross.org/support" 2116 | } 2117 | ] 2118 | }, 2119 | "node_modules/safe-stable-stringify": { 2120 | "version": "2.4.3", 2121 | "resolved": "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.4.3.tgz", 2122 | "integrity": "sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g==", 2123 | "dev": true, 2124 | "engines": { 2125 | "node": ">=10" 2126 | } 2127 | }, 2128 | "node_modules/safer-buffer": { 2129 | "version": "2.1.2", 2130 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2131 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2132 | "dev": true, 2133 | "optional": true 2134 | }, 2135 | "node_modules/secp256k1": { 2136 | "version": "3.8.0", 2137 | "resolved": "https://registry.npmjs.org/secp256k1/-/secp256k1-3.8.0.tgz", 2138 | "integrity": "sha512-k5ke5avRZbtl9Tqx/SA7CbY3NF6Ro+Sj9cZxezFzuBlLDmyqPiL8hJJ+EmzD8Ig4LUDByHJ3/iPOVoRixs/hmw==", 2139 | "dev": true, 2140 | "hasInstallScript": true, 2141 | "dependencies": { 2142 | "bindings": "^1.5.0", 2143 | "bip66": "^1.1.5", 2144 | "bn.js": "^4.11.8", 2145 | "create-hash": "^1.2.0", 2146 | "drbg.js": "^1.0.1", 2147 | "elliptic": "^6.5.2", 2148 | "nan": "^2.14.0", 2149 | "safe-buffer": "^5.1.2" 2150 | }, 2151 | "engines": { 2152 | "node": ">=4.0.0" 2153 | } 2154 | }, 2155 | "node_modules/semver": { 2156 | "version": "7.6.2", 2157 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", 2158 | "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", 2159 | "dev": true, 2160 | "bin": { 2161 | "semver": "bin/semver.js" 2162 | }, 2163 | "engines": { 2164 | "node": ">=10" 2165 | } 2166 | }, 2167 | "node_modules/set-blocking": { 2168 | "version": "2.0.0", 2169 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2170 | "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==", 2171 | "dev": true 2172 | }, 2173 | "node_modules/sha.js": { 2174 | "version": "2.4.11", 2175 | "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", 2176 | "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", 2177 | "dev": true, 2178 | "dependencies": { 2179 | "inherits": "^2.0.1", 2180 | "safe-buffer": "^5.0.1" 2181 | }, 2182 | "bin": { 2183 | "sha.js": "bin.js" 2184 | } 2185 | }, 2186 | "node_modules/shebang-command": { 2187 | "version": "2.0.0", 2188 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2189 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2190 | "dev": true, 2191 | "dependencies": { 2192 | "shebang-regex": "^3.0.0" 2193 | }, 2194 | "engines": { 2195 | "node": ">=8" 2196 | } 2197 | }, 2198 | "node_modules/shebang-regex": { 2199 | "version": "3.0.0", 2200 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2201 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2202 | "dev": true, 2203 | "engines": { 2204 | "node": ">=8" 2205 | } 2206 | }, 2207 | "node_modules/signal-exit": { 2208 | "version": "4.1.0", 2209 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 2210 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 2211 | "dev": true, 2212 | "engines": { 2213 | "node": ">=14" 2214 | }, 2215 | "funding": { 2216 | "url": "https://github.com/sponsors/isaacs" 2217 | } 2218 | }, 2219 | "node_modules/simple-swizzle": { 2220 | "version": "0.2.2", 2221 | "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", 2222 | "integrity": "sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg==", 2223 | "dev": true, 2224 | "dependencies": { 2225 | "is-arrayish": "^0.3.1" 2226 | } 2227 | }, 2228 | "node_modules/smart-buffer": { 2229 | "version": "4.2.0", 2230 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 2231 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", 2232 | "dev": true, 2233 | "engines": { 2234 | "node": ">= 6.0.0", 2235 | "npm": ">= 3.0.0" 2236 | } 2237 | }, 2238 | "node_modules/socks": { 2239 | "version": "2.8.3", 2240 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.8.3.tgz", 2241 | "integrity": "sha512-l5x7VUUWbjVFbafGLxPWkYsHIhEvmF85tbIeFZWc8ZPtoMyybuEhL7Jye/ooC4/d48FgOjSJXgsF/AJPYCW8Zw==", 2242 | "dev": true, 2243 | "dependencies": { 2244 | "ip-address": "^9.0.5", 2245 | "smart-buffer": "^4.2.0" 2246 | }, 2247 | "engines": { 2248 | "node": ">= 10.0.0", 2249 | "npm": ">= 3.0.0" 2250 | } 2251 | }, 2252 | "node_modules/socks-proxy-agent": { 2253 | "version": "8.0.4", 2254 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-8.0.4.tgz", 2255 | "integrity": "sha512-GNAq/eg8Udq2x0eNiFkr9gRg5bA7PXEWagQdeRX4cPSG+X/8V38v637gim9bjFptMk1QWsCTr0ttrJEiXbNnRw==", 2256 | "dev": true, 2257 | "dependencies": { 2258 | "agent-base": "^7.1.1", 2259 | "debug": "^4.3.4", 2260 | "socks": "^2.8.3" 2261 | }, 2262 | "engines": { 2263 | "node": ">= 14" 2264 | } 2265 | }, 2266 | "node_modules/socks-proxy-agent/node_modules/agent-base": { 2267 | "version": "7.1.1", 2268 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", 2269 | "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", 2270 | "dev": true, 2271 | "dependencies": { 2272 | "debug": "^4.3.4" 2273 | }, 2274 | "engines": { 2275 | "node": ">= 14" 2276 | } 2277 | }, 2278 | "node_modules/sprintf-js": { 2279 | "version": "1.1.3", 2280 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.3.tgz", 2281 | "integrity": "sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==", 2282 | "dev": true 2283 | }, 2284 | "node_modules/ssri": { 2285 | "version": "10.0.6", 2286 | "resolved": "https://registry.npmjs.org/ssri/-/ssri-10.0.6.tgz", 2287 | "integrity": "sha512-MGrFH9Z4NP9Iyhqn16sDtBpRRNJ0Y2hNa6D65h736fVSaPCHr4DM4sWUNvVaSuC+0OBGhwsrydQwmgfg5LncqQ==", 2288 | "dev": true, 2289 | "dependencies": { 2290 | "minipass": "^7.0.3" 2291 | }, 2292 | "engines": { 2293 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 2294 | } 2295 | }, 2296 | "node_modules/stack-trace": { 2297 | "version": "0.0.10", 2298 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 2299 | "integrity": "sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg==", 2300 | "dev": true, 2301 | "engines": { 2302 | "node": "*" 2303 | } 2304 | }, 2305 | "node_modules/string_decoder": { 2306 | "version": "1.3.0", 2307 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 2308 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 2309 | "dev": true, 2310 | "dependencies": { 2311 | "safe-buffer": "~5.2.0" 2312 | } 2313 | }, 2314 | "node_modules/string-width": { 2315 | "version": "5.1.2", 2316 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", 2317 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", 2318 | "dev": true, 2319 | "dependencies": { 2320 | "eastasianwidth": "^0.2.0", 2321 | "emoji-regex": "^9.2.2", 2322 | "strip-ansi": "^7.0.1" 2323 | }, 2324 | "engines": { 2325 | "node": ">=12" 2326 | }, 2327 | "funding": { 2328 | "url": "https://github.com/sponsors/sindresorhus" 2329 | } 2330 | }, 2331 | "node_modules/string-width-cjs": { 2332 | "name": "string-width", 2333 | "version": "4.2.3", 2334 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2335 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2336 | "dev": true, 2337 | "dependencies": { 2338 | "emoji-regex": "^8.0.0", 2339 | "is-fullwidth-code-point": "^3.0.0", 2340 | "strip-ansi": "^6.0.1" 2341 | }, 2342 | "engines": { 2343 | "node": ">=8" 2344 | } 2345 | }, 2346 | "node_modules/string-width-cjs/node_modules/ansi-regex": { 2347 | "version": "5.0.1", 2348 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2349 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2350 | "dev": true, 2351 | "engines": { 2352 | "node": ">=8" 2353 | } 2354 | }, 2355 | "node_modules/string-width-cjs/node_modules/emoji-regex": { 2356 | "version": "8.0.0", 2357 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2358 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2359 | "dev": true 2360 | }, 2361 | "node_modules/string-width-cjs/node_modules/strip-ansi": { 2362 | "version": "6.0.1", 2363 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2364 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2365 | "dev": true, 2366 | "dependencies": { 2367 | "ansi-regex": "^5.0.1" 2368 | }, 2369 | "engines": { 2370 | "node": ">=8" 2371 | } 2372 | }, 2373 | "node_modules/strip-ansi": { 2374 | "version": "7.1.0", 2375 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 2376 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 2377 | "dev": true, 2378 | "dependencies": { 2379 | "ansi-regex": "^6.0.1" 2380 | }, 2381 | "engines": { 2382 | "node": ">=12" 2383 | }, 2384 | "funding": { 2385 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 2386 | } 2387 | }, 2388 | "node_modules/strip-ansi-cjs": { 2389 | "name": "strip-ansi", 2390 | "version": "6.0.1", 2391 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2392 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2393 | "dev": true, 2394 | "dependencies": { 2395 | "ansi-regex": "^5.0.1" 2396 | }, 2397 | "engines": { 2398 | "node": ">=8" 2399 | } 2400 | }, 2401 | "node_modules/strip-ansi-cjs/node_modules/ansi-regex": { 2402 | "version": "5.0.1", 2403 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2404 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2405 | "dev": true, 2406 | "engines": { 2407 | "node": ">=8" 2408 | } 2409 | }, 2410 | "node_modules/tar": { 2411 | "version": "6.2.1", 2412 | "resolved": "https://registry.npmjs.org/tar/-/tar-6.2.1.tgz", 2413 | "integrity": "sha512-DZ4yORTwrbTj/7MZYq2w+/ZFdI6OZ/f9SFHR+71gIVUZhOQPHzVCLpvRnPgyaMpfWxxk/4ONva3GQSyNIKRv6A==", 2414 | "dev": true, 2415 | "dependencies": { 2416 | "chownr": "^2.0.0", 2417 | "fs-minipass": "^2.0.0", 2418 | "minipass": "^5.0.0", 2419 | "minizlib": "^2.1.1", 2420 | "mkdirp": "^1.0.3", 2421 | "yallist": "^4.0.0" 2422 | }, 2423 | "engines": { 2424 | "node": ">=10" 2425 | } 2426 | }, 2427 | "node_modules/tar/node_modules/fs-minipass": { 2428 | "version": "2.1.0", 2429 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", 2430 | "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", 2431 | "dev": true, 2432 | "dependencies": { 2433 | "minipass": "^3.0.0" 2434 | }, 2435 | "engines": { 2436 | "node": ">= 8" 2437 | } 2438 | }, 2439 | "node_modules/tar/node_modules/fs-minipass/node_modules/minipass": { 2440 | "version": "3.3.6", 2441 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 2442 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 2443 | "dev": true, 2444 | "dependencies": { 2445 | "yallist": "^4.0.0" 2446 | }, 2447 | "engines": { 2448 | "node": ">=8" 2449 | } 2450 | }, 2451 | "node_modules/tar/node_modules/minipass": { 2452 | "version": "5.0.0", 2453 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", 2454 | "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==", 2455 | "dev": true, 2456 | "engines": { 2457 | "node": ">=8" 2458 | } 2459 | }, 2460 | "node_modules/text-hex": { 2461 | "version": "1.0.0", 2462 | "resolved": "https://registry.npmjs.org/text-hex/-/text-hex-1.0.0.tgz", 2463 | "integrity": "sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg==", 2464 | "dev": true 2465 | }, 2466 | "node_modules/tiny-secp256k1": { 2467 | "version": "2.2.3", 2468 | "resolved": "https://registry.npmjs.org/tiny-secp256k1/-/tiny-secp256k1-2.2.3.tgz", 2469 | "integrity": "sha512-SGcL07SxcPN2nGKHTCvRMkQLYPSoeFcvArUSCYtjVARiFAWU44cCIqYS0mYAU6nY7XfvwURuTIGo2Omt3ZQr0Q==", 2470 | "dev": true, 2471 | "dependencies": { 2472 | "uint8array-tools": "0.0.7" 2473 | }, 2474 | "engines": { 2475 | "node": ">=14.0.0" 2476 | } 2477 | }, 2478 | "node_modules/tr46": { 2479 | "version": "0.0.3", 2480 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 2481 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", 2482 | "dev": true 2483 | }, 2484 | "node_modules/triple-beam": { 2485 | "version": "1.4.1", 2486 | "resolved": "https://registry.npmjs.org/triple-beam/-/triple-beam-1.4.1.tgz", 2487 | "integrity": "sha512-aZbgViZrg1QNcG+LULa7nhZpJTZSLm/mXnHXnbAbjmN5aSa0y7V+wvv6+4WaBtpISJzThKy+PIPxc1Nq1EJ9mg==", 2488 | "dev": true, 2489 | "engines": { 2490 | "node": ">= 14.0.0" 2491 | } 2492 | }, 2493 | "node_modules/ts-node": { 2494 | "version": "10.9.2", 2495 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.2.tgz", 2496 | "integrity": "sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ==", 2497 | "dev": true, 2498 | "dependencies": { 2499 | "@cspotcode/source-map-support": "^0.8.0", 2500 | "@tsconfig/node10": "^1.0.7", 2501 | "@tsconfig/node12": "^1.0.7", 2502 | "@tsconfig/node14": "^1.0.0", 2503 | "@tsconfig/node16": "^1.0.2", 2504 | "acorn": "^8.4.1", 2505 | "acorn-walk": "^8.1.1", 2506 | "arg": "^4.1.0", 2507 | "create-require": "^1.1.0", 2508 | "diff": "^4.0.1", 2509 | "make-error": "^1.1.1", 2510 | "v8-compile-cache-lib": "^3.0.1", 2511 | "yn": "3.1.1" 2512 | }, 2513 | "bin": { 2514 | "ts-node": "dist/bin.js", 2515 | "ts-node-cwd": "dist/bin-cwd.js", 2516 | "ts-node-esm": "dist/bin-esm.js", 2517 | "ts-node-script": "dist/bin-script.js", 2518 | "ts-node-transpile-only": "dist/bin-transpile.js", 2519 | "ts-script": "dist/bin-script-deprecated.js" 2520 | }, 2521 | "peerDependencies": { 2522 | "@swc/core": ">=1.2.50", 2523 | "@swc/wasm": ">=1.2.50", 2524 | "@types/node": "*", 2525 | "typescript": ">=2.7" 2526 | }, 2527 | "peerDependenciesMeta": { 2528 | "@swc/core": { 2529 | "optional": true 2530 | }, 2531 | "@swc/wasm": { 2532 | "optional": true 2533 | } 2534 | } 2535 | }, 2536 | "node_modules/tslib": { 2537 | "version": "2.4.0", 2538 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", 2539 | "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==", 2540 | "dev": true 2541 | }, 2542 | "node_modules/typeforce": { 2543 | "version": "1.18.0", 2544 | "resolved": "https://registry.npmjs.org/typeforce/-/typeforce-1.18.0.tgz", 2545 | "integrity": "sha512-7uc1O8h1M1g0rArakJdf0uLRSSgFcYexrVoKo+bzJd32gd4gDy2L/Z+8/FjPnU9ydY3pEnVPtr9FyscYY60K1g==", 2546 | "dev": true 2547 | }, 2548 | "node_modules/typescript": { 2549 | "version": "5.5.3", 2550 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.3.tgz", 2551 | "integrity": "sha512-/hreyEujaB0w76zKo6717l3L0o/qEUtRgdvUBvlkhoWeOVMjMuHNHk0BRBzikzuGDqNmPQbg5ifMEqsHLiIUcQ==", 2552 | "dev": true, 2553 | "bin": { 2554 | "tsc": "bin/tsc", 2555 | "tsserver": "bin/tsserver" 2556 | }, 2557 | "engines": { 2558 | "node": ">=14.17" 2559 | } 2560 | }, 2561 | "node_modules/uint8array-tools": { 2562 | "version": "0.0.7", 2563 | "resolved": "https://registry.npmjs.org/uint8array-tools/-/uint8array-tools-0.0.7.tgz", 2564 | "integrity": "sha512-vrrNZJiusLWoFWBqz5Y5KMCgP9W9hnjZHzZiZRT8oNAkq3d5Z5Oe76jAvVVSRh4U8GGR90N2X1dWtrhvx6L8UQ==", 2565 | "dev": true, 2566 | "engines": { 2567 | "node": ">=14.0.0" 2568 | } 2569 | }, 2570 | "node_modules/undici-types": { 2571 | "version": "5.26.5", 2572 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 2573 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 2574 | "dev": true 2575 | }, 2576 | "node_modules/unique-filename": { 2577 | "version": "3.0.0", 2578 | "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-3.0.0.tgz", 2579 | "integrity": "sha512-afXhuC55wkAmZ0P18QsVE6kp8JaxrEokN2HGIoIVv2ijHQd419H0+6EigAFcIzXeMIkcIkNBpB3L/DXB3cTS/g==", 2580 | "dev": true, 2581 | "dependencies": { 2582 | "unique-slug": "^4.0.0" 2583 | }, 2584 | "engines": { 2585 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 2586 | } 2587 | }, 2588 | "node_modules/unique-slug": { 2589 | "version": "4.0.0", 2590 | "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-4.0.0.tgz", 2591 | "integrity": "sha512-WrcA6AyEfqDX5bWige/4NQfPZMtASNVxdmWR76WESYQVAACSgWcR6e9i0mofqqBxYFtL4oAxPIptY73/0YE1DQ==", 2592 | "dev": true, 2593 | "dependencies": { 2594 | "imurmurhash": "^0.1.4" 2595 | }, 2596 | "engines": { 2597 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0" 2598 | } 2599 | }, 2600 | "node_modules/util-deprecate": { 2601 | "version": "1.0.2", 2602 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2603 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 2604 | "dev": true 2605 | }, 2606 | "node_modules/v8-compile-cache-lib": { 2607 | "version": "3.0.1", 2608 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 2609 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 2610 | "dev": true 2611 | }, 2612 | "node_modules/varuint-bitcoin": { 2613 | "version": "1.1.2", 2614 | "resolved": "https://registry.npmjs.org/varuint-bitcoin/-/varuint-bitcoin-1.1.2.tgz", 2615 | "integrity": "sha512-4EVb+w4rx+YfVM32HQX42AbbT7/1f5zwAYhIujKXKk8NQK+JfRVl3pqT3hjNn/L+RstigmGGKVwHA/P0wgITZw==", 2616 | "dev": true, 2617 | "dependencies": { 2618 | "safe-buffer": "^5.1.1" 2619 | } 2620 | }, 2621 | "node_modules/webidl-conversions": { 2622 | "version": "3.0.1", 2623 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 2624 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", 2625 | "dev": true 2626 | }, 2627 | "node_modules/whatwg-url": { 2628 | "version": "5.0.0", 2629 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 2630 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 2631 | "dev": true, 2632 | "dependencies": { 2633 | "tr46": "~0.0.3", 2634 | "webidl-conversions": "^3.0.0" 2635 | } 2636 | }, 2637 | "node_modules/which": { 2638 | "version": "4.0.0", 2639 | "resolved": "https://registry.npmjs.org/which/-/which-4.0.0.tgz", 2640 | "integrity": "sha512-GlaYyEb07DPxYCKhKzplCWBJtvxZcZMrL+4UkrTSJHHPyZU4mYYTv3qaOe77H7EODLSSopAUFAc6W8U4yqvscg==", 2641 | "dev": true, 2642 | "dependencies": { 2643 | "isexe": "^3.1.1" 2644 | }, 2645 | "bin": { 2646 | "node-which": "bin/which.js" 2647 | }, 2648 | "engines": { 2649 | "node": "^16.13.0 || >=18.0.0" 2650 | } 2651 | }, 2652 | "node_modules/wide-align": { 2653 | "version": "1.1.5", 2654 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz", 2655 | "integrity": "sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==", 2656 | "dev": true, 2657 | "dependencies": { 2658 | "string-width": "^1.0.2 || 2 || 3 || 4" 2659 | } 2660 | }, 2661 | "node_modules/wide-align/node_modules/ansi-regex": { 2662 | "version": "5.0.1", 2663 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2664 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2665 | "dev": true, 2666 | "engines": { 2667 | "node": ">=8" 2668 | } 2669 | }, 2670 | "node_modules/wide-align/node_modules/emoji-regex": { 2671 | "version": "8.0.0", 2672 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2673 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2674 | "dev": true 2675 | }, 2676 | "node_modules/wide-align/node_modules/string-width": { 2677 | "version": "4.2.3", 2678 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2679 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2680 | "dev": true, 2681 | "dependencies": { 2682 | "emoji-regex": "^8.0.0", 2683 | "is-fullwidth-code-point": "^3.0.0", 2684 | "strip-ansi": "^6.0.1" 2685 | }, 2686 | "engines": { 2687 | "node": ">=8" 2688 | } 2689 | }, 2690 | "node_modules/wide-align/node_modules/strip-ansi": { 2691 | "version": "6.0.1", 2692 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2693 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2694 | "dev": true, 2695 | "dependencies": { 2696 | "ansi-regex": "^5.0.1" 2697 | }, 2698 | "engines": { 2699 | "node": ">=8" 2700 | } 2701 | }, 2702 | "node_modules/wif": { 2703 | "version": "2.0.6", 2704 | "resolved": "https://registry.npmjs.org/wif/-/wif-2.0.6.tgz", 2705 | "integrity": "sha512-HIanZn1zmduSF+BQhkE+YXIbEiH0xPr1012QbFEGB0xsKqJii0/SqJjyn8dFv6y36kOznMgMB+LGcbZTJ1xACQ==", 2706 | "dev": true, 2707 | "dependencies": { 2708 | "bs58check": "<3.0.0" 2709 | } 2710 | }, 2711 | "node_modules/wif/node_modules/base-x": { 2712 | "version": "3.0.10", 2713 | "resolved": "https://registry.npmjs.org/base-x/-/base-x-3.0.10.tgz", 2714 | "integrity": "sha512-7d0s06rR9rYaIWHkpfLIFICM/tkSVdoPC9qYAQRpxn9DdKNWNsKC0uk++akckyLq16Tx2WIinnZ6WRriAt6njQ==", 2715 | "dev": true, 2716 | "dependencies": { 2717 | "safe-buffer": "^5.0.1" 2718 | } 2719 | }, 2720 | "node_modules/wif/node_modules/bs58": { 2721 | "version": "4.0.1", 2722 | "resolved": "https://registry.npmjs.org/bs58/-/bs58-4.0.1.tgz", 2723 | "integrity": "sha512-Ok3Wdf5vOIlBrgCvTq96gBkJw+JUEzdBgyaza5HLtPm7yTHkjRy8+JzNyHF7BHa0bNWOQIp3m5YF0nnFcOIKLw==", 2724 | "dev": true, 2725 | "dependencies": { 2726 | "base-x": "^3.0.2" 2727 | } 2728 | }, 2729 | "node_modules/wif/node_modules/bs58check": { 2730 | "version": "2.1.2", 2731 | "resolved": "https://registry.npmjs.org/bs58check/-/bs58check-2.1.2.tgz", 2732 | "integrity": "sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA==", 2733 | "dev": true, 2734 | "dependencies": { 2735 | "bs58": "^4.0.0", 2736 | "create-hash": "^1.1.0", 2737 | "safe-buffer": "^5.1.2" 2738 | } 2739 | }, 2740 | "node_modules/winston": { 2741 | "version": "3.13.0", 2742 | "resolved": "https://registry.npmjs.org/winston/-/winston-3.13.0.tgz", 2743 | "integrity": "sha512-rwidmA1w3SE4j0E5MuIufFhyJPBDG7Nu71RkZor1p2+qHvJSZ9GYDA81AyleQcZbh/+V6HjeBdfnTZJm9rSeQQ==", 2744 | "dev": true, 2745 | "dependencies": { 2746 | "@colors/colors": "^1.6.0", 2747 | "@dabh/diagnostics": "^2.0.2", 2748 | "async": "^3.2.3", 2749 | "is-stream": "^2.0.0", 2750 | "logform": "^2.4.0", 2751 | "one-time": "^1.0.0", 2752 | "readable-stream": "^3.4.0", 2753 | "safe-stable-stringify": "^2.3.1", 2754 | "stack-trace": "0.0.x", 2755 | "triple-beam": "^1.3.0", 2756 | "winston-transport": "^4.7.0" 2757 | }, 2758 | "engines": { 2759 | "node": ">= 12.0.0" 2760 | } 2761 | }, 2762 | "node_modules/winston-transport": { 2763 | "version": "4.7.0", 2764 | "resolved": "https://registry.npmjs.org/winston-transport/-/winston-transport-4.7.0.tgz", 2765 | "integrity": "sha512-ajBj65K5I7denzer2IYW6+2bNIVqLGDHqDw3Ow8Ohh+vdW+rv4MZ6eiDvHoKhfJFZ2auyN8byXieDDJ96ViONg==", 2766 | "dev": true, 2767 | "dependencies": { 2768 | "logform": "^2.3.2", 2769 | "readable-stream": "^3.6.0", 2770 | "triple-beam": "^1.3.0" 2771 | }, 2772 | "engines": { 2773 | "node": ">= 12.0.0" 2774 | } 2775 | }, 2776 | "node_modules/wrap-ansi": { 2777 | "version": "8.1.0", 2778 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", 2779 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", 2780 | "dev": true, 2781 | "dependencies": { 2782 | "ansi-styles": "^6.1.0", 2783 | "string-width": "^5.0.1", 2784 | "strip-ansi": "^7.0.1" 2785 | }, 2786 | "engines": { 2787 | "node": ">=12" 2788 | }, 2789 | "funding": { 2790 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2791 | } 2792 | }, 2793 | "node_modules/wrap-ansi-cjs": { 2794 | "name": "wrap-ansi", 2795 | "version": "7.0.0", 2796 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2797 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2798 | "dev": true, 2799 | "dependencies": { 2800 | "ansi-styles": "^4.0.0", 2801 | "string-width": "^4.1.0", 2802 | "strip-ansi": "^6.0.0" 2803 | }, 2804 | "engines": { 2805 | "node": ">=10" 2806 | }, 2807 | "funding": { 2808 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2809 | } 2810 | }, 2811 | "node_modules/wrap-ansi-cjs/node_modules/ansi-regex": { 2812 | "version": "5.0.1", 2813 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2814 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2815 | "dev": true, 2816 | "engines": { 2817 | "node": ">=8" 2818 | } 2819 | }, 2820 | "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { 2821 | "version": "4.3.0", 2822 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2823 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2824 | "dev": true, 2825 | "dependencies": { 2826 | "color-convert": "^2.0.1" 2827 | }, 2828 | "engines": { 2829 | "node": ">=8" 2830 | }, 2831 | "funding": { 2832 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2833 | } 2834 | }, 2835 | "node_modules/wrap-ansi-cjs/node_modules/color-convert": { 2836 | "version": "2.0.1", 2837 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2838 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2839 | "dev": true, 2840 | "dependencies": { 2841 | "color-name": "~1.1.4" 2842 | }, 2843 | "engines": { 2844 | "node": ">=7.0.0" 2845 | } 2846 | }, 2847 | "node_modules/wrap-ansi-cjs/node_modules/color-name": { 2848 | "version": "1.1.4", 2849 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2850 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2851 | "dev": true 2852 | }, 2853 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { 2854 | "version": "8.0.0", 2855 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2856 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2857 | "dev": true 2858 | }, 2859 | "node_modules/wrap-ansi-cjs/node_modules/string-width": { 2860 | "version": "4.2.3", 2861 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2862 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2863 | "dev": true, 2864 | "dependencies": { 2865 | "emoji-regex": "^8.0.0", 2866 | "is-fullwidth-code-point": "^3.0.0", 2867 | "strip-ansi": "^6.0.1" 2868 | }, 2869 | "engines": { 2870 | "node": ">=8" 2871 | } 2872 | }, 2873 | "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": { 2874 | "version": "6.0.1", 2875 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2876 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2877 | "dev": true, 2878 | "dependencies": { 2879 | "ansi-regex": "^5.0.1" 2880 | }, 2881 | "engines": { 2882 | "node": ">=8" 2883 | } 2884 | }, 2885 | "node_modules/wrappy": { 2886 | "version": "1.0.2", 2887 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2888 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 2889 | "dev": true 2890 | }, 2891 | "node_modules/ws": { 2892 | "version": "8.17.1", 2893 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.1.tgz", 2894 | "integrity": "sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==", 2895 | "dev": true, 2896 | "engines": { 2897 | "node": ">=10.0.0" 2898 | }, 2899 | "peerDependencies": { 2900 | "bufferutil": "^4.0.1", 2901 | "utf-8-validate": ">=5.0.2" 2902 | }, 2903 | "peerDependenciesMeta": { 2904 | "bufferutil": { 2905 | "optional": true 2906 | }, 2907 | "utf-8-validate": { 2908 | "optional": true 2909 | } 2910 | } 2911 | }, 2912 | "node_modules/yallist": { 2913 | "version": "4.0.0", 2914 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2915 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2916 | "dev": true 2917 | }, 2918 | "node_modules/yn": { 2919 | "version": "3.1.1", 2920 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 2921 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 2922 | "dev": true, 2923 | "engines": { 2924 | "node": ">=6" 2925 | } 2926 | } 2927 | } 2928 | } 2929 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "author": "SohaDao - Kunsect", 3 | "scripts": { 4 | "start": "ts-node scripts/main.ts", 5 | "space-score": "ts-node scripts/score.ts" 6 | }, 7 | "devDependencies": { 8 | "@types/bip39": "^3.0.0", 9 | "@types/node": "^20.14.2", 10 | "bip32": "^4.0.0", 11 | "bip39": "^3.1.0", 12 | "bitcoinjs-lib": "^6.1.5", 13 | "bitcoinjs-message": "^2.2.0", 14 | "crypto": "^1.0.1", 15 | "dotenv": "^16.4.5", 16 | "ecpair": "^2.1.0", 17 | "ethers": "^6.13.1", 18 | "node-libcurl": "^4.0.0", 19 | "querystring": "^0.2.1", 20 | "tiny-secp256k1": "^2.2.3", 21 | "ts-node": "^10.9.2", 22 | "typescript": "^5.4.5", 23 | "winston": "^3.13.0" 24 | }, 25 | "ts-node": { 26 | "esm": true 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /scripts/main.ts: -------------------------------------------------------------------------------- 1 | import * as fs from 'fs' 2 | import logger from './../src/logger' 3 | import { Galxe } from './../src/galxe' 4 | import { readFileToArray, waittingBetween } from './../src/utils/common' 5 | import 'dotenv/config' 6 | 7 | /** 8 | * 执行 Galxe 任务的主流程 9 | * 10 | * 1. 获取助记词对应派生地址的钱包 11 | * 2. 通过 EVM 地址登录账号 12 | * 3. 校验账号是否注册(没注册的走注册流程) 13 | * 4. 绑定其他类型的钱包地址及邮箱 14 | * 5. 获取任务状态(未领取奖励的会执行) 15 | */ 16 | const main = async () => { 17 | let pathIndex: number = Number(process.env.START_PATH_INDEX) 18 | const maxPathIndex: number = Number(process.env.MAX_PATH_INDEX) 19 | 20 | while (pathIndex < maxPathIndex) { 21 | const galxe = new Galxe(pathIndex) 22 | 23 | try { 24 | await galxe.authLogin() 25 | 26 | await galxe.updateBaseInfo() 27 | 28 | await galxe.startCampaigns() 29 | 30 | logger.info('============== galxe tasks finish! continue next path ==============') 31 | 32 | pathIndex += 1 33 | } catch (err: any) { 34 | logger.error(err.message) 35 | logger.debug('uncatch error,waitting 20s to continue...') 36 | 37 | /** 38 | * twitter 报错处理 39 | * 捕捉到上述错误码的一般为不可用的 twitter 号,需要从列表中剔除并重新绑定 twitter 执行任务 40 | * 41 | * 37: Authorization: Denied by access control: Missing TwitterUserNotSuspended 42 | * 64: Your account is suspended and is not permitted to access this feature 43 | * 141: Authorization: User (uid: 1813038126891200512) is suspended, deactivated or offboarded 44 | * 187: Authorization: Status is a duplicate. (187) 45 | * 1000: get ct0 fail 46 | */ 47 | const needTwitter = Number(process.env.NEED_TWITTER) === 1 48 | if (needTwitter) { 49 | const twitterErrorCode = [32, 37, 64, 141, 187, 326, 1000] 50 | 51 | if (twitterErrorCode.includes(err.code)) { 52 | await galxe.unbindTwitter() 53 | 54 | const filePath = 'twitter.txt' 55 | const twitterAccounts = readFileToArray(filePath) 56 | 57 | let failAccount = null 58 | const filteredTwitterAccounts = twitterAccounts.filter((item: string) => { 59 | const included = item.includes(err.extra) 60 | if (included) failAccount = item 61 | 62 | return !included 63 | }) 64 | 65 | const fileContent = filteredTwitterAccounts.join('\n') 66 | fs.writeFileSync(filePath, fileContent) 67 | 68 | if (failAccount) { 69 | logger.warn(`fail account is: ${failAccount}`) 70 | fs.appendFile('twitter-fail.txt', `${failAccount}\n`, () => {}) 71 | } 72 | } 73 | } 74 | 75 | await waittingBetween(17500, 22500) 76 | } 77 | } 78 | } 79 | 80 | main() 81 | -------------------------------------------------------------------------------- /scripts/score.ts: -------------------------------------------------------------------------------- 1 | import * as fs from 'fs' 2 | import logger from './../src/logger' 3 | import { Galxe } from './../src/galxe' 4 | import { waittingBetween } from './../src/utils/common' 5 | import 'dotenv/config' 6 | import { WalletManager } from '../src/wallet' 7 | 8 | const main = async () => { 9 | let pathIndex: number = Number(process.env.START_PATH_INDEX) 10 | const maxPathIndex: number = Number(process.env.MAX_PATH_INDEX) 11 | 12 | while (pathIndex < maxPathIndex) { 13 | const galxe = new Galxe(pathIndex) 14 | 15 | try { 16 | await galxe.authLogin() 17 | 18 | const userScore = await galxe.getSpaceScore(process.env.SPACE_NAME!) 19 | const wallet = new WalletManager(pathIndex) 20 | 21 | fs.appendFile( 22 | 'score.txt', 23 | `index: ${pathIndex}, privateKey: ${wallet.evmWallet.privateKey}, score: ${userScore.addressLoyaltyPoints.points}, rank: ${userScore.addressLoyaltyPoints.rank}\n`, 24 | () => {} 25 | ) 26 | 27 | pathIndex += 1 28 | } catch (err: any) { 29 | logger.error(err.message) 30 | logger.debug('uncatch error,waitting 20s to continue...') 31 | 32 | await waittingBetween(17500, 22500) 33 | } 34 | } 35 | } 36 | 37 | main() 38 | -------------------------------------------------------------------------------- /src/captcha/index.ts: -------------------------------------------------------------------------------- 1 | import logger from '../logger' 2 | import curl from '../requests/curl' 3 | import { waitting } from '../utils/common' 4 | import 'dotenv/config' 5 | 6 | const CAPSOLVER_API_URL: string = 'https://api.capsolver.com' 7 | const TWO_CAPTCHA_API_URL: string = 'https://api.2captcha.com' 8 | const CAPMONSTER_API_URL: string = 'https://api.capmonster.cloud' 9 | 10 | const GALXE_URL: string = 'https://app.galxe.com/quest' 11 | const GALXE_CAPTCHA_ID: string = '244bcb8b9846215df5af4c624a750db4' 12 | 13 | export interface ICaptchaParams { 14 | captchaOutput: string 15 | genTime: string 16 | lotNumber: string 17 | passToken: string 18 | } 19 | 20 | interface ITaskPayload { 21 | websiteURL: string 22 | [key: string]: any 23 | } 24 | 25 | export class CaptchaDecoder { 26 | apiUrl?: string 27 | clientKey?: string 28 | taskPayload: ITaskPayload = { 29 | websiteURL: GALXE_URL 30 | } 31 | 32 | constructor() { 33 | const { CAPSOLVER_CLIENT_KEY, TWO_CAPTCHA_CLIENT_KEY, CAPMONSTER_CLIENT_KEY } = process.env 34 | 35 | if (CAPSOLVER_CLIENT_KEY) this.initializeCapsolver() 36 | else if (TWO_CAPTCHA_CLIENT_KEY) this.initializeTwoCaptcha() 37 | else if (CAPMONSTER_CLIENT_KEY) this.initializeTwoCaptcha() 38 | } 39 | 40 | private initializeCapsolver() { 41 | const { CAPSOLVER_CLIENT_KEY } = process.env 42 | 43 | this.clientKey = CAPSOLVER_CLIENT_KEY 44 | this.apiUrl = CAPSOLVER_API_URL 45 | this.taskPayload = { 46 | ...this.taskPayload, 47 | type: 'GeetestTaskProxyless', 48 | captchaId: GALXE_CAPTCHA_ID 49 | } 50 | } 51 | 52 | private initializeTwoCaptcha() { 53 | const { TWO_CAPTCHA_CLIENT_KEY } = process.env 54 | 55 | this.clientKey = TWO_CAPTCHA_CLIENT_KEY 56 | this.apiUrl = TWO_CAPTCHA_API_URL 57 | this.taskPayload = { 58 | ...this.taskPayload, 59 | type: 'GeeTestTaskProxyless', 60 | version: 4, 61 | initParameters: { captcha_id: GALXE_CAPTCHA_ID } 62 | } 63 | } 64 | 65 | private initializeCapMonsterCaptcha() { 66 | const { CAPMONSTER_CLIENT_KEY } = process.env 67 | 68 | this.clientKey = CAPMONSTER_CLIENT_KEY 69 | this.apiUrl = CAPMONSTER_API_URL 70 | this.taskPayload = { 71 | ...this.taskPayload, 72 | type: 'GeeTestTaskProxyless', 73 | gt: GALXE_CAPTCHA_ID, 74 | version: 4, 75 | initParameters: { riskType: 'slide' } 76 | } 77 | } 78 | 79 | private async createTask() { 80 | const payload = { 81 | clientKey: this.clientKey, 82 | task: this.taskPayload 83 | } 84 | 85 | const res = await curl.post(`${this.apiUrl}/createTask`, payload) 86 | 87 | return res.data.taskId 88 | } 89 | 90 | private async getTaskResult(taskId: string): Promise { 91 | while (true) { 92 | await waitting(1000) 93 | 94 | const getResultPayload = { clientKey: this.clientKey, taskId } 95 | const resp = await curl.post(`${this.apiUrl}/getTaskResult`, getResultPayload) 96 | const status = resp.data.status 97 | 98 | if (status === 'ready') { 99 | const { captcha_output, gen_time, lot_number, pass_token } = resp.data.solution 100 | 101 | return { 102 | captchaOutput: captcha_output, 103 | genTime: gen_time, 104 | lotNumber: lot_number, 105 | passToken: pass_token 106 | } 107 | } 108 | 109 | if (status === 'failed' || resp.data.errorId) { 110 | console.log('Solve failed! response:', resp.data) 111 | 112 | return null 113 | } 114 | } 115 | } 116 | 117 | async getCaptcha(): Promise { 118 | let res = null 119 | 120 | for (let i = 0; i < 5; i++) { 121 | try { 122 | const taskId = await this.createTask() 123 | if (taskId) res = await this.getTaskResult(taskId) 124 | 125 | if (!res) throw Error('get captcha fail') 126 | else break 127 | } catch (err) { 128 | if (i < 4) logger.warn(`[Captcha] (${i + 1} / 5) will try again.`) 129 | else logger.error(`[Captcha] all trying failed.`) 130 | } 131 | } 132 | 133 | return res 134 | } 135 | } 136 | -------------------------------------------------------------------------------- /src/email/index.ts: -------------------------------------------------------------------------------- 1 | import { waitting } from '../utils/common' 2 | import curl from '../requests/curl' 3 | 4 | const EMAIL_URL: string = 'https://www.1secmail.com/api/v1/' 5 | 6 | /** 7 | * 邮件管理类 8 | * 9 | * 基于 1secmail 的 API 实现:https://www.1secmail.com/api/ 10 | */ 11 | export class EmailManager { 12 | email: string = '' 13 | 14 | async getEmail() { 15 | if (!this.email) { 16 | const res = await curl.get(`${EMAIL_URL}?action=genRandomMailbox`) 17 | 18 | this.email = res.data[0] 19 | } 20 | 21 | return this.email 22 | } 23 | 24 | async getEmailCode(): Promise { 25 | if (!this.email) await this.getEmail() 26 | 27 | const [username, domain] = this.email.split('@') 28 | const mailParams = `login=${username}&domain=${domain}` 29 | 30 | let emailId 31 | for (let i = 0; i < 10; i++) { 32 | await waitting(4000) 33 | 34 | const receivesRes = await curl.get(`${EMAIL_URL}?action=getMessages&${mailParams}`) 35 | 36 | if (receivesRes.data.length) { 37 | emailId = receivesRes.data[0]['id'] 38 | 39 | break 40 | } 41 | } 42 | 43 | if (!emailId) throw Error('uncatch email id') 44 | 45 | const emailRes = await curl.get(`${EMAIL_URL}?action=readMessage&id=${emailId}&${mailParams}`) 46 | 47 | const matches = emailRes.data.body.match(/

(\d{6}) { 105 | if (desc) logger.debug(`requesting ${desc}.`) 106 | 107 | const headers = [...HEADERS, ...(this.authorization ? [this.authorization] : [])] 108 | 109 | const payload = { 110 | operationName, 111 | query, 112 | variables: body 113 | } 114 | 115 | let result = null 116 | for (let i = 0; i < 3; i++) { 117 | if (needCaptcha) { 118 | const captcha: ICaptchaParams | null = await this.captchaDecoder.getCaptcha() 119 | 120 | if ((payload.variables as any).input instanceof Object) { 121 | ;(payload.variables as any).input.captcha = captcha 122 | } 123 | } 124 | 125 | const res = await curl.post(GALXE_URL, payload, headers) 126 | 127 | await waittingBetween(3000, 4500) 128 | 129 | if (res.data.errors) { 130 | console.log(JSON.stringify(payload)) 131 | 132 | const message = res.data.errors[0]['message'] 133 | 134 | // 解码平台 token 有误 135 | if (message.includes('pass_token error')) { 136 | logger.warn(`[captcha] failed to verify recaptcha token, (${i + 1} / 3) will try again, info: ${message}`) 137 | 138 | await waittingBetween(5000, 7000) 139 | } else { 140 | throw Error(`request error, info: ${JSON.stringify(res.data.errors)}`) 141 | } 142 | } else { 143 | if (desc) logger.info(`${desc} completed.`) 144 | 145 | result = res 146 | break 147 | } 148 | } 149 | 150 | return result 151 | } 152 | 153 | private async sendEmailCode(email: string) { 154 | const body = { 155 | input: { email, address: `EVM:${this.address}` } 156 | } 157 | 158 | await this.request('SendVerifyCode', GalxeQuery.sendEmailCode, body, 'send email code', true) 159 | } 160 | 161 | async authLogin() { 162 | const nonce = randomString(17, true) 163 | const issuedAt = new Date().toISOString() 164 | const expiredAt = new Date(Date.now() + 1000 * 60 * 60 * 24 * 7).toISOString() 165 | 166 | const message = `app.galxe.com wants you to sign in with your Ethereum account:\n${this.address}\n\nSign in with Ethereum to the app.\n\nURI: https://app.galxe.com\nVersion: 1\nChain ID: 1\nNonce: ${nonce}\nIssued At: ${issuedAt}\nExpiration Time: ${expiredAt}` 167 | const signature = await this.walletManager.signEvmMessage(message) 168 | 169 | const body = { 170 | input: { 171 | address: this.address, 172 | addressType: 'EVM', 173 | publicKey: '1', 174 | message, 175 | signature 176 | } 177 | } 178 | 179 | const desc = `sign in by evm address: ${this.address}` 180 | 181 | const res = await this.request('SignIn', GalxeQuery.signin, body, desc) 182 | 183 | this.authorization = `Authorization: ${res.data.data.signin}` 184 | 185 | logger.info(`get user authorization success, ${this.authorization}`) 186 | } 187 | 188 | async checkGalxeIdExist(): Promise { 189 | const body = { schema: `EVM:${this.address}` } 190 | const desc = `galxe id exist by evm address: ${this.address}` 191 | 192 | const res = await this.request('GalxeIDExist', GalxeQuery.idExist, body, desc) 193 | 194 | return res.data.data.galxeIdExist 195 | } 196 | 197 | async getUserInfo(): Promise { 198 | const body = { address: `EVM:${this.address}` } 199 | 200 | const desc = 'basic user info' 201 | 202 | const res = await this.request('BasicUserInfo', GalxeQuery.userInfo, body, desc) 203 | 204 | return res.data.data.addressInfo 205 | } 206 | 207 | async createNewAccount() { 208 | const username = randomString(8) 209 | 210 | const body = { 211 | input: { 212 | schema: `EVM:${this.address}`, 213 | socialUsername: username, 214 | username: username 215 | } 216 | } 217 | 218 | await this.request( 219 | 'CreateNewAccount', 220 | 'mutation CreateNewAccount($input: CreateNewAccount!) {\n createNewAccount(input: $input)\n}', 221 | body, 222 | 'create galxe id' 223 | ) 224 | } 225 | 226 | async getCampaignsInfo(id: string) { 227 | const body = { 228 | id, 229 | address: this.address, 230 | withAddress: true 231 | } 232 | 233 | const res = await this.request('CampaignDetailAll', GalxeQuery.campaignsInfo, body, 'campaigns detail') 234 | this.spaceId = res.data.data.campaign.space.id 235 | 236 | return res.data.data.campaign.childrenCampaigns 237 | } 238 | 239 | async submitTask(task: ITask) { 240 | const retryCount = 3 241 | let result = false 242 | 243 | for (let i = 0; i < retryCount; i++) { 244 | await waittingBetween(3000, 5000) 245 | 246 | const taskLabel = `[TASK - ${task.name}]` 247 | 248 | if (task.eligible) { 249 | logger.warn(`${taskLabel} completed, skip next task.`) 250 | 251 | return true 252 | } 253 | 254 | logger.debug(`${taskLabel} waitting to submit task...`) 255 | 256 | const body: any = { 257 | input: { 258 | syncOptions: { 259 | credId: task.id, 260 | address: `EVM:${this.address}` 261 | } 262 | } 263 | } 264 | 265 | // 前置交互 266 | switch (task.credType) { 267 | case 'TWITTER': 268 | if (task.credSource === 'TWITTER_LIKE') await this.tryAppend(task, taskLabel) 269 | 270 | const captcha: ICaptchaParams | null = await this.captchaDecoder.getCaptcha() 271 | body.input.syncOptions = { 272 | ...body.input.syncOptions, 273 | twitter: { 274 | campaignID: task.campaignId, 275 | captcha 276 | } 277 | } 278 | break 279 | 280 | default: 281 | break 282 | } 283 | 284 | // 根据类型进行交互 285 | switch (task.credSource) { 286 | case 'VISIT_LINK': 287 | // 浏览链接 288 | await this.tryAppend(task, taskLabel) 289 | break 290 | 291 | case 'SPACE_USERS': 292 | // 平台关注 293 | await this.followSpace() 294 | break 295 | 296 | case 'QUIZ': 297 | // 问卷 298 | body.input.syncOptions = { 299 | ...body.input.syncOptions, 300 | quiz: { 301 | answers: ['0', 'Vanderbilt', '1', 'San Francisco'] 302 | } 303 | } 304 | break 305 | 306 | default: 307 | break 308 | } 309 | 310 | const res = await this.request('SyncCredentialValue', GalxeQuery.submitTask, body, taskLabel) 311 | const credValue = res.data.data.syncCredentialValue 312 | 313 | // 特殊类型判断返回 314 | if (task.credSource === 'SPACE_USERS' && credValue.value.spaceUsers.follow) credValue.value.allow = true 315 | if (task.credSource === 'QUIZ' && credValue.value.quiz.allow) credValue.value.allow = true 316 | 317 | if (credValue.value.allow) { 318 | result = true 319 | 320 | break 321 | } 322 | 323 | if (credValue.message) { 324 | logger.error(`${taskLabel} complete fail: ${credValue.message}`) 325 | } 326 | 327 | if (i < retryCount - 1) { 328 | console.log(JSON.stringify(credValue)) 329 | logger.warn(`${taskLabel} (${i + 1} / ${retryCount}) will try again.`) 330 | 331 | if (task.credType === 'TWITTER') { 332 | logger.error(`[twitter] ${taskLabel} complete fail: after 55-60s continue...`) 333 | 334 | await waittingBetween(55000, 65000) 335 | } 336 | } else { 337 | logger.error(`${taskLabel} all trying failed.`) 338 | 339 | result = false 340 | } 341 | } 342 | 343 | return result 344 | } 345 | 346 | async claimCampaign(campaign: ICampaign) { 347 | for (let i = 0; i < 5; i++) { 348 | await waittingBetween(3000, 5000) 349 | 350 | const campaignLabel = `[CAMPAIGN - ${campaign.name}]` 351 | 352 | const body = { 353 | input: { 354 | chain: 'ETHEREUM', 355 | campaignID: campaign.id, 356 | address: `EVM:${this.address}`, 357 | mintCount: 1, 358 | signature: '' 359 | } 360 | } 361 | 362 | const res = await this.request('PrepareParticipate', GalxeQuery.claimCampaign, body, campaignLabel, true) 363 | 364 | if (!res.data.data.prepareParticipate.allow) { 365 | const reason = res.data.data.prepareParticipate.disallowReason 366 | logger.error(`${campaignLabel} claim campaign fail: ${reason}`) 367 | 368 | if (reason.includes('empty reward')) break 369 | 370 | if (i < 4) logger.warn(`${campaignLabel} (${i + 1} / 5) campaign will try again.`) 371 | else logger.error(`${campaignLabel} all trying failed.`) 372 | } else { 373 | break 374 | } 375 | } 376 | } 377 | 378 | async bindEmail() { 379 | const email = await this.emailManager.getEmail() 380 | 381 | await this.sendEmailCode(email) 382 | 383 | const code = await this.emailManager.getEmailCode() 384 | 385 | logger.info(`get email info success, email: ${email}, verify code: ${code}`) 386 | 387 | const body = { 388 | input: { 389 | address: `EVM:${this.address}`, 390 | email, 391 | verificationCode: code 392 | } 393 | } 394 | 395 | await this.request('UpdateEmail', GalxeQuery.updateEmail, body, 'bind email') 396 | } 397 | 398 | async bindTwitter() { 399 | const tweetUrl = await this.twitter.createBindTweet(this.userId) 400 | 401 | if (!tweetUrl) logger.error('bind create tweet fail.') 402 | 403 | const body = { 404 | input: { 405 | address: this.address, 406 | tweetURL: tweetUrl 407 | } 408 | } 409 | 410 | await this.request('VerifyTwitterAccount', GalxeQuery.verifyTwitter, body, 'bind twitter') 411 | } 412 | 413 | async unbindTwitter() { 414 | const body = { 415 | input: { 416 | address: `EVM:${this.address}`, 417 | type: 'TWITTER' 418 | } 419 | } 420 | 421 | await this.request('DeleteSocialAccount', GalxeQuery.deleteSocialAccount, body, 'unbind twitter') 422 | } 423 | 424 | async updateBaseInfo() { 425 | const galxeIdExist = await this.checkGalxeIdExist() 426 | 427 | if (!galxeIdExist) { 428 | logger.warn('galxe id not exist, go to create new account.') 429 | 430 | await this.createNewAccount() 431 | } 432 | 433 | const userInfo = await this.getUserInfo() 434 | this.userId = userInfo.id 435 | 436 | if (!userInfo.email) await this.bindEmail() 437 | else logger.warn(`User has already bound an email address, skip the email binding step.`) 438 | 439 | const needTwitter = Number(process.env.NEED_TWITTER) === 1 440 | if (needTwitter) { 441 | if (!userInfo.hasTwitter) await this.bindTwitter() 442 | else logger.warn(`User has already bound twitter, skip the twitter binding step.`) 443 | } else { 444 | logger.warn(`User don't need to bind twitter, skip the twitter binding step.`) 445 | } 446 | } 447 | 448 | async tryAppend(task: ITask, label: string) { 449 | const appendBody = { 450 | input: { 451 | credId: task.id, 452 | campaignId: task.campaignId, 453 | operation: 'APPEND', 454 | items: [`EVM:${this.address}`] 455 | } 456 | } 457 | 458 | await this.request( 459 | 'AddTypedCredentialItems', 460 | GalxeQuery.addTypedCredentialItems, 461 | appendBody, 462 | `[append credential] try append by ${label}`, 463 | true 464 | ) 465 | 466 | await waittingBetween(5000, 8000) 467 | } 468 | 469 | async followSpace() { 470 | const body = { spaceIds: [this.spaceId] } 471 | 472 | await this.request('followSpace', GalxeQuery.followSpace, body, `follow space ${this.spaceId}`) 473 | 474 | await waittingBetween(3000, 5000) 475 | } 476 | 477 | async startCampaigns() { 478 | const { GALXE_COLLECT, GALXE_CAMPAIGNS_INDEXES } = process.env 479 | 480 | if (!GALXE_COLLECT) throw Error('please fill in the GALXE_COLLECT in .env') 481 | 482 | const campaignsRes = await this.getCampaignsInfo(GALXE_COLLECT) 483 | 484 | let campaigns: ICampaign[] = [] 485 | campaignsRes.map((campaign: any) => { 486 | campaigns.push({ 487 | id: campaign.id, 488 | name: campaign.name, 489 | group: campaign['credentialGroups'].map((item: any) => ({ 490 | tasks: item.credentials.map((credential: any) => ({ ...credential, campaignId: campaign.id })), 491 | claimed: item.claimedLoyaltyPoints > 0, 492 | campaignId: campaign.id, 493 | allEligible: false 494 | })), 495 | claimed: 496 | campaign.whitelistInfo.currentPeriodClaimedLoyaltyPoints >= 497 | campaign.whitelistInfo.currentPeriodClaimedLoyaltyPoints && 498 | campaign.claimedLoyaltyPoints >= campaign.loyaltyPoints 499 | }) 500 | }) 501 | 502 | // 根据 .env 的 GALXE_CAMPAIGNS_INDEXES 重新渲染执行任务列表 503 | // 若有 twitter 先完成 twitter 的前置交互 504 | const twitterTasks: ITask[] = [] 505 | if (GALXE_CAMPAIGNS_INDEXES) { 506 | const [campaignIndex, groupIndex, tasksIndexes] = GALXE_CAMPAIGNS_INDEXES.split(':') 507 | const tasksArr = tasksIndexes.split(',').map(Number) 508 | 509 | const selectedCampaign = campaigns[Number(campaignIndex)] 510 | selectedCampaign.group = [selectedCampaign.group[Number(groupIndex)]] 511 | 512 | const selectedTasks = selectedCampaign.group[0]['tasks'].filter((item, index) => tasksArr.includes(index)) 513 | const unselectedTasks = selectedCampaign.group[0]['tasks'].filter((item, index) => !tasksArr.includes(index)) 514 | 515 | selectedTasks.map((task) => { 516 | if (!task.eligible && task.credType === 'TWITTER') twitterTasks.push(task) 517 | }) 518 | 519 | selectedCampaign.group[0]['tasks'] = selectedTasks 520 | selectedCampaign.group[0]['allEligible'] = unselectedTasks.every((task: ITask) => task.eligible) 521 | 522 | campaigns = [selectedCampaign] 523 | } 524 | 525 | if (twitterTasks.length) await this.startTwitterTasks(twitterTasks) 526 | 527 | for (let campaign of campaigns) { 528 | if (campaign.claimed) { 529 | logger.info(`[CAMPAIGN - ${campaign.name}] completed, skip next campaign.`) 530 | 531 | continue 532 | } 533 | 534 | for (let item of campaign.group) { 535 | let tasksResult = [] 536 | 537 | for (let task of item.tasks) { 538 | if (!task.eligible) tasksResult.push(await this.submitTask(task)) 539 | } 540 | 541 | if (item.allEligible && tasksResult.every((result) => result)) await this.claimCampaign(campaign) 542 | } 543 | } 544 | } 545 | 546 | async startTwitterTasks(twitterTasks: ITask[]) { 547 | for (let task of twitterTasks) { 548 | switch (task.credSource) { 549 | case 'TWITTER_FOLLOW': { 550 | // 关注推特 551 | const nameMatch = task.referenceLink!.match(/[?&]screen_name=([^&]+)/) 552 | const name = nameMatch && nameMatch[1] 553 | if (!name) throw Error('tweet name not found.') 554 | 555 | await this.twitter.follow(name) 556 | break 557 | } 558 | 559 | case 'TWITTER_LIKE': { 560 | // 点赞推文 561 | const tweetIdMatch = task.referenceLink!.match(/tweet_id=(\d+)/) 562 | const tweetId = tweetIdMatch && tweetIdMatch[1] 563 | if (!tweetId) throw Error('tweet id not found.') 564 | 565 | await this.twitter.likeTweet(tweetId) 566 | break 567 | } 568 | 569 | case 'TWITTER_RT': { 570 | // 转发推文 571 | const tweetIdMatch = task.referenceLink!.match(/tweet_id=(\d+)/) 572 | const tweetId = tweetIdMatch && tweetIdMatch[1] 573 | if (!tweetId) throw Error('tweet id not found.') 574 | 575 | await this.twitter.reTweet(tweetId) 576 | break 577 | } 578 | 579 | case 'TWITTER_QUOTE': { 580 | // 创建推文并 @ 好友 581 | const tweetUrlMatch = task.description!.match(/\(([^)]+)\)/) 582 | const tweetUrl = tweetUrlMatch && tweetUrlMatch[1] 583 | 584 | await this.twitter.createPost(`@MaplestoryU ${tweetUrl}`) 585 | break 586 | } 587 | 588 | default: 589 | break 590 | } 591 | 592 | await waittingBetween(5000, 8000) 593 | } 594 | } 595 | 596 | async getSpaceScore(name: string) { 597 | const body = { 598 | alias: name, 599 | address: `EVM:${this.address}`, 600 | firstTailoredTask: 10, 601 | afterTailoredTask: '-1' 602 | } 603 | 604 | const res = await this.request('SpaceBasicWithAuthQuery', GalxeQuery.spaceInfo, body, `get space score`) 605 | 606 | return res.data.data.space 607 | } 608 | } 609 | -------------------------------------------------------------------------------- /src/galxe/query.ts: -------------------------------------------------------------------------------- 1 | export const GalxeQuery = { 2 | idExist: 'query GalxeIDExist($schema: String!) {\n galxeIdExist(schema: $schema)\n}', 3 | signin: 'mutation SignIn($input: Auth) {\n signin(input: $input)\n}', 4 | userInfo: `query BasicUserInfo($address: String!) {\n addressInfo(address: $address) {\n id\n username\n avatar\n address\n evmAddressSecondary {\n address\n __typename\n }\n hasEmail\n solanaAddress\n aptosAddress\n seiAddress\n injectiveAddress\n flowAddress\n starknetAddress\n bitcoinAddress\n suiAddress\n stacksAddress\n azeroAddress\n archwayAddress\n bitcoinSignetAddress\n hasEvmAddress\n hasSolanaAddress\n hasAptosAddress\n hasInjectiveAddress\n hasFlowAddress\n hasStarknetAddress\n hasBitcoinAddress\n hasSuiAddress\n hasStacksAddress\n hasAzeroAddress\n hasArchwayAddress\n hasBitcoinSignetAddress\n hasTwitter\n hasGithub\n hasDiscord\n hasTelegram\n hasWorldcoin\n displayEmail\n displayTwitter\n displayGithub\n displayDiscord\n displayTelegram\n displayWorldcoin\n displayNamePref\n email\n twitterUserID\n twitterUserName\n githubUserID\n githubUserName\n discordUserID\n discordUserName\n telegramUserID\n telegramUserName\n worldcoinID\n enableEmailSubs\n subscriptions\n isWhitelisted\n isInvited\n isAdmin\n accessToken\n __typename\n }\n}`, 5 | campaignsInfo: 6 | 'query CampaignDetailAll($id: ID!, $address: String!, $withAddress: Boolean!) {\n campaign(id: $id) {\n ...CampaignForSiblingSlide\n coHostSpaces {\n ...SpaceDetail\n isAdmin(address: $address) @include(if: $withAddress)\n isFollowing @include(if: $withAddress)\n followersCount\n categories\n __typename\n }\n bannerUrl\n ...CampaignDetailFrag\n userParticipants(address: $address, first: 1) @include(if: $withAddress) {\n list {\n status\n premintTo\n __typename\n }\n __typename\n }\n space {\n ...SpaceDetail\n isAdmin(address: $address) @include(if: $withAddress)\n isFollowing @include(if: $withAddress)\n followersCount\n categories\n __typename\n }\n isBookmarked(address: $address) @include(if: $withAddress)\n inWatchList\n claimedLoyaltyPoints(address: $address) @include(if: $withAddress)\n parentCampaign {\n id\n isSequencial\n thumbnail\n __typename\n }\n isSequencial\n numNFTMinted\n childrenCampaigns {\n ...ChildrenCampaignsForCampaignDetailAll\n __typename\n }\n __typename\n }\n}\n\nfragment CampaignForTokenObject on Campaign {\n tokenReward {\n tokenAddress\n tokenSymbol\n tokenDecimal\n tokenLogo\n __typename\n }\n tokenRewardContract {\n id\n chain\n __typename\n }\n __typename\n}\n\nfragment GetImageCommon on Campaign {\n ...CampaignForTokenObject\n id\n type\n thumbnail\n __typename\n}\n\nfragment CampaignForGetImage on Campaign {\n ...GetImageCommon\n nftTemplates {\n image\n __typename\n }\n __typename\n}\n\nfragment CampaignForCheckFinish on Campaign {\n claimedLoyaltyPoints(address: $address)\n whitelistInfo(address: $address) {\n usedCount\n __typename\n }\n __typename\n}\n\nfragment CampaignMedia on Campaign {\n thumbnail\n rewardName\n type\n gamification {\n id\n type\n __typename\n }\n __typename\n}\n\nfragment CampaignForgePage on Campaign {\n id\n numberID\n chain\n spaceStation {\n address\n __typename\n }\n gamification {\n forgeConfig {\n maxNFTCount\n minNFTCount\n requiredNFTs {\n nft {\n category\n __typename\n }\n __typename\n }\n __typename\n }\n __typename\n }\n __typename\n}\n\nfragment CampaignForParticipantsDialog on Campaign {\n id\n name\n type\n rewardType\n chain\n nftHolderSnapshot {\n holderSnapshotBlock\n __typename\n }\n space {\n isAdmin(address: $address)\n __typename\n }\n rewardInfo {\n discordRole {\n guildName\n roleName\n __typename\n }\n __typename\n }\n __typename\n}\n\nfragment CampaignForCampaignParticipantsBox on Campaign {\n ...CampaignForParticipantsDialog\n id\n chain\n space {\n id\n isAdmin(address: $address)\n __typename\n }\n participants {\n participants(first: 10, after: "-1", download: false) {\n list {\n address {\n id\n avatar\n __typename\n }\n __typename\n }\n __typename\n }\n participantsCount\n bountyWinners(first: 10, after: "-1", download: false) {\n list {\n createdTime\n address {\n id\n avatar\n __typename\n }\n __typename\n }\n __typename\n }\n bountyWinnersCount\n __typename\n }\n __typename\n}\n\nfragment NftCoreInfoFrag on NFTCore {\n id\n capable\n chain\n contractAddress\n name\n symbol\n __typename\n}\n\nfragment WhitelistInfoFrag on Campaign {\n id\n whitelistInfo(address: $address) {\n address\n maxCount\n usedCount\n claimedLoyaltyPoints\n currentPeriodClaimedLoyaltyPoints\n currentPeriodMaxLoyaltyPoints\n __typename\n }\n __typename\n}\n\nfragment WhitelistSubgraphFrag on Campaign {\n id\n whitelistSubgraph {\n query\n endpoint\n expression\n variable\n __typename\n }\n __typename\n}\n\nfragment GamificationDetailFrag on Gamification {\n id\n type\n nfts {\n nft {\n id\n animationURL\n category\n powah\n image\n name\n treasureBack\n nftCore {\n ...NftCoreInfoFrag\n __typename\n }\n traits {\n name\n value\n __typename\n }\n __typename\n }\n __typename\n }\n forgeConfig {\n minNFTCount\n maxNFTCount\n requiredNFTs {\n nft {\n category\n powah\n image\n name\n nftCore {\n capable\n contractAddress\n __typename\n }\n __typename\n }\n count\n __typename\n }\n __typename\n }\n __typename\n}\n\nfragment CredForAddressWithoutMetadata on Cred {\n id\n name\n type\n credType\n credSource\n referenceLink\n description\n lastUpdate\n lastSync\n syncStatus\n credContractNFTHolder {\n timestamp\n __typename\n }\n chain\n eligible(address: $address)\n subgraph {\n endpoint\n query\n expression\n __typename\n }\n dimensionConfig\n value {\n gitcoinPassport {\n score\n lastScoreTimestamp\n __typename\n }\n __typename\n }\n __typename\n}\n\nfragment CredentialGroupConditionForVerifyButton on CredentialGroupCondition {\n expression\n eligibleAddress\n __typename\n}\n\nfragment CredentialGroupForAddress on CredentialGroup {\n id\n description\n credentials {\n ...CredForAddressWithoutMetadata\n __typename\n }\n conditionRelation\n conditions {\n expression\n eligible\n ...CredentialGroupConditionForVerifyButton\n __typename\n }\n rewards {\n expression\n eligible\n rewardCount\n rewardType\n __typename\n }\n rewardAttrVals {\n attrName\n attrTitle\n attrVal\n __typename\n }\n claimedLoyaltyPoints\n __typename\n}\n\nfragment ExpressionEntity on ExprEntity {\n cred {\n id\n name\n type\n credType\n credSource\n dimensionConfig\n referenceLink\n description\n lastUpdate\n lastSync\n chain\n eligible(address: $address)\n metadata {\n visitLink {\n link\n __typename\n }\n twitter {\n isAuthentic\n __typename\n }\n worldcoin {\n dimensions {\n values {\n value\n __typename\n }\n __typename\n }\n __typename\n }\n __typename\n }\n commonInfo {\n participateEndTime\n modificationInfo\n __typename\n }\n __typename\n }\n attrs {\n attrName\n operatorSymbol\n targetValue\n __typename\n }\n attrFormula\n eligible\n eligibleAddress\n __typename\n}\n\nfragment ExpressionReward on ExprReward {\n arithmetics {\n ...ExpressionEntity\n __typename\n }\n arithmeticFormula\n rewardType\n rewardCount\n rewardVal\n __typename\n}\n\nfragment SpaceDetail on Space {\n id\n name\n info\n thumbnail\n alias\n status\n links\n isVerified\n discordGuildID\n followersCount\n nftCores(input: {first: 1}) {\n list {\n id\n marketLink\n __typename\n }\n __typename\n }\n __typename\n}\n\nfragment CampaignDetailFrag on Campaign {\n id\n ...CampaignMedia\n ...CampaignForgePage\n ...CampaignForCampaignParticipantsBox\n nftCore {\n ...NftCoreInfoFrag\n __typename\n }\n name\n numberID\n type\n inWatchList\n cap\n info\n useCred\n smartbalancePreCheck(mintCount: 1)\n smartbalanceDeposited\n formula\n status\n seoImage\n creator\n tags\n thumbnail\n gasType\n isPrivate\n createdAt\n requirementInfo\n description\n enableWhitelist\n chain\n startTime\n endTime\n requireEmail\n requireUsername\n blacklistCountryCodes\n whitelistRegions\n rewardType\n distributionType\n rewardName\n claimEndTime\n loyaltyPoints\n tokenRewardContract {\n id\n address\n chain\n __typename\n }\n tokenReward {\n userTokenAmount\n tokenAddress\n depositedTokenAmount\n tokenRewardId\n tokenDecimal\n tokenLogo\n tokenSymbol\n __typename\n }\n nftHolderSnapshot {\n holderSnapshotBlock\n __typename\n }\n spaceStation {\n id\n address\n chain\n __typename\n }\n ...WhitelistInfoFrag\n ...WhitelistSubgraphFrag\n gamification {\n ...GamificationDetailFrag\n __typename\n }\n creds {\n id\n name\n type\n credType\n credSource\n referenceLink\n description\n lastUpdate\n lastSync\n syncStatus\n credContractNFTHolder {\n timestamp\n __typename\n }\n chain\n eligible(address: $address, campaignId: $id)\n subgraph {\n endpoint\n query\n expression\n __typename\n }\n dimensionConfig\n value {\n gitcoinPassport {\n score\n lastScoreTimestamp\n __typename\n }\n __typename\n }\n commonInfo {\n participateEndTime\n modificationInfo\n __typename\n }\n __typename\n }\n credentialGroups(address: $address) {\n ...CredentialGroupForAddress\n __typename\n }\n rewardInfo {\n discordRole {\n guildId\n guildName\n roleId\n roleName\n inviteLink\n __typename\n }\n premint {\n startTime\n endTime\n chain\n price\n totalSupply\n contractAddress\n banner\n __typename\n }\n loyaltyPoints {\n points\n __typename\n }\n loyaltyPointsMysteryBox {\n points\n weight\n __typename\n }\n __typename\n }\n participants {\n participantsCount\n bountyWinnersCount\n __typename\n }\n taskConfig(address: $address) {\n participateCondition {\n conditions {\n ...ExpressionEntity\n __typename\n }\n conditionalFormula\n eligible\n __typename\n }\n requiredInfo {\n socialInfos {\n email\n discordUserID\n twitterUserID\n telegramUserID\n githubUserID\n googleUserID\n worldcoinID\n __typename\n }\n addressInfos {\n address\n evmAddressSecondary\n solanaAddress\n aptosAddress\n seiAddress\n injectiveAddress\n flowAddress\n starknetAddress\n suiAddress\n bitcoinAddress\n stacksAddress\n azeroAddress\n archwayAddress\n __typename\n }\n __typename\n }\n rewardConfigs {\n id\n conditions {\n ...ExpressionEntity\n __typename\n }\n conditionalFormula\n description\n rewards {\n ...ExpressionReward\n __typename\n }\n eligible\n rewardAttrVals {\n attrName\n attrTitle\n attrVal\n __typename\n }\n __typename\n }\n referralConfig {\n id\n conditions {\n ...ExpressionEntity\n __typename\n }\n conditionalFormula\n description\n rewards {\n ...ExpressionReward\n __typename\n }\n eligible\n rewardAttrVals {\n attrName\n attrTitle\n attrVal\n __typename\n }\n __typename\n }\n __typename\n }\n referralCode(address: $address)\n recurringType\n latestRecurringTime\n nftTemplates {\n id\n image\n treasureBack\n __typename\n }\n __typename\n}\n\nfragment CampaignForSiblingSlide on Campaign {\n id\n space {\n id\n alias\n __typename\n }\n parentCampaign {\n id\n thumbnail\n isSequencial\n childrenCampaigns {\n id\n ...CampaignForGetImage\n ...CampaignForCheckFinish\n __typename\n }\n __typename\n }\n __typename\n}\n\nfragment ChildrenCampaignsForCampaignDetailAll on Campaign {\n space {\n ...SpaceDetail\n isAdmin(address: $address) @include(if: $withAddress)\n isFollowing @include(if: $withAddress)\n followersCount\n categories\n __typename\n }\n ...CampaignDetailFrag\n claimedLoyaltyPoints(address: $address) @include(if: $withAddress)\n userParticipants(address: $address, first: 1) @include(if: $withAddress) {\n list {\n status\n __typename\n }\n __typename\n }\n parentCampaign {\n id\n isSequencial\n __typename\n }\n __typename\n}', 7 | submitTask: 8 | 'mutation SyncCredentialValue($input: SyncCredentialValueInput!) {\n syncCredentialValue(input: $input) {\n value {\n address\n spaceUsers {\n follow\n points\n participations\n __typename\n }\n campaignReferral {\n count\n __typename\n }\n gitcoinPassport {\n score\n lastScoreTimestamp\n __typename\n }\n walletBalance {\n balance\n __typename\n }\n multiDimension {\n value\n __typename\n }\n allow\n survey {\n answers\n __typename\n }\n quiz {\n allow\n correct\n __typename\n }\n __typename\n }\n message\n __typename\n }\n}', 9 | claimCampaign: 10 | 'mutation PrepareParticipate($input: PrepareParticipateInput!) {\n prepareParticipate(input: $input) {\n allow\n disallowReason\n signature\n nonce\n mintFuncInfo {\n funcName\n nftCoreAddress\n verifyIDs\n powahs\n cap\n __typename\n }\n extLinkResp {\n success\n data\n error\n __typename\n }\n metaTxResp {\n metaSig2\n autoTaskUrl\n metaSpaceAddr\n forwarderAddr\n metaTxHash\n reqQueueing\n __typename\n }\n solanaTxResp {\n mint\n updateAuthority\n explorerUrl\n signedTx\n verifyID\n __typename\n }\n aptosTxResp {\n signatureExpiredAt\n tokenName\n __typename\n }\n spaceStation\n airdropRewardCampaignTxResp {\n airdropID\n verifyID\n index\n account\n amount\n proof\n __typename\n }\n tokenRewardCampaignTxResp {\n signatureExpiredAt\n verifyID\n __typename\n }\n loyaltyPointsTxResp {\n TotalClaimedPoints\n __typename\n }\n flowTxResp {\n Name\n Description\n Thumbnail\n __typename\n }\n suiTxResp {\n packageId\n tableId\n nftName\n campaignId\n verifyID\n imgUrl\n signatureExpiredAt\n __typename\n }\n __typename\n }\n}', 11 | updateAddress: 12 | 'mutation UpdateUserAddress($input: UpdateUserAddressInput!) {\n updateUserAddress(input: $input) {\n code\n message\n __typename\n }\n}', 13 | updateEmail: 14 | 'mutation UpdateEmail($input: UpdateEmailInput!) {\n updateEmail(input: $input) {\n code\n message\n __typename\n }\n}', 15 | sendEmailCode: 16 | 'mutation SendVerifyCode($input: SendVerificationEmailInput!) {\n sendVerificationCode(input: $input) {\n code\n message\n __typename\n }\n}', 17 | verifyTwitter: 18 | 'mutation VerifyTwitterAccount($input: VerifyTwitterAccountInput!) {\n verifyTwitterAccount(input: $input) {\n address\n twitterUserID\n twitterUserName\n __typename\n }\n}\n', 19 | addTypedCredentialItems: 20 | 'mutation AddTypedCredentialItems($input: MutateTypedCredItemInput!) {\n typedCredentialItems(input: $input) {\n id\n __typename\n }\n}', 21 | deleteSocialAccount: 22 | 'mutation DeleteSocialAccount($input: DeleteSocialAccountInput!) {\n deleteSocialAccount(input: $input) {\n code\n message\n __typename\n }\n}', 23 | followSpace: 'mutation followSpace($spaceIds: [Int!]) {\n followSpace(spaceIds: $spaceIds)\n}', 24 | spaceInfo: 25 | 'query SpaceBasicWithAuthQuery($id: Int, $alias: String, $address: String!, $firstTailoredTask: Int, $afterTailoredTask: String) {\n space(id: $id, alias: $alias) {\n ...SpaceTailoredTasksWithAuth\n id\n isFollowing\n isAdmin(address: $address)\n addressLoyaltyPoints(address: $address) {\n id\n points\n rank\n __typename\n }\n __typename\n }\n}\n\nfragment SpaceTailoredTasksWithAuth on Space {\n tailoredTasks(first: $firstTailoredTask, after: $afterTailoredTask) {\n totalCount\n pageInfo {\n hasNextPage\n __typename\n }\n list {\n id\n spaceId\n title\n description\n link\n tag\n points\n startTime\n claimedPoints(address: $address)\n __typename\n }\n __typename\n }\n __typename\n}' 26 | } 27 | -------------------------------------------------------------------------------- /src/logger/index.ts: -------------------------------------------------------------------------------- 1 | import winston from 'winston' 2 | import 'dotenv/config' 3 | 4 | /** 5 | * 日志类 6 | * 7 | * 参考 winston 文档:https://github.com/winstonjs/winston 8 | */ 9 | class Logger { 10 | logger: winston.Logger 11 | 12 | constructor() { 13 | const { LOGGER_OUTPUT_NAME } = process.env 14 | 15 | this.logger = winston 16 | .createLogger({ 17 | level: 'silly', 18 | format: winston.format.combine( 19 | winston.format.label({ label: 'galxe' }), 20 | winston.format.timestamp({ format: 'MM.DD HH:mm:ss' }), 21 | this.getCustomFormat() 22 | ), 23 | transports: [...(LOGGER_OUTPUT_NAME ? [new winston.transports.File({ filename: LOGGER_OUTPUT_NAME })] : [])] 24 | }) 25 | .add( 26 | new winston.transports.Console({ 27 | format: winston.format.combine( 28 | winston.format.colorize(), 29 | winston.format.label({ label: 'galxe' }), 30 | this.getCustomFormat() 31 | ) 32 | }) 33 | ) 34 | } 35 | 36 | private getCustomFormat = () => 37 | winston.format.printf(({ level, message, label, timestamp }) => { 38 | return `${timestamp} ${level}: ${message}` 39 | }) 40 | 41 | public debug(message: string) { 42 | this.logger.debug(message) 43 | } 44 | 45 | public info(message: string) { 46 | this.logger.info(message) 47 | } 48 | 49 | public warn(message: string) { 50 | this.logger.warn(message) 51 | } 52 | 53 | public error(message: string) { 54 | this.logger.error(message) 55 | } 56 | } 57 | 58 | const logger = new Logger() 59 | 60 | export default logger 61 | -------------------------------------------------------------------------------- /src/requests/curl.ts: -------------------------------------------------------------------------------- 1 | import { Curl } from 'node-libcurl' 2 | import { isJsonString } from '../utils/common' 3 | import querystring from 'querystring' 4 | import 'dotenv/config' 5 | 6 | /** 7 | * Curl 请求类 8 | */ 9 | class CurlInstance { 10 | private createInstance(): Curl { 11 | const curl = new Curl() 12 | 13 | curl.setOpt(Curl.option.SSL_VERIFYHOST, 0) 14 | curl.setOpt(Curl.option.SSL_VERIFYPEER, 0) 15 | curl.setOpt(Curl.option.FOLLOWLOCATION, true) 16 | 17 | const proxyIp = process.env.PROXY_IP 18 | if (proxyIp) curl.setOpt(Curl.option.PROXY, proxyIp) 19 | 20 | return curl 21 | } 22 | 23 | async get(url: string, headers: string[] = [], needClearCookie: boolean = false): Promise { 24 | const curl = this.createInstance() 25 | 26 | curl.setOpt(Curl.option.HTTPHEADER, headers) 27 | 28 | if (needClearCookie) { 29 | curl.setOpt(Curl.option.COOKIEFILE, '') 30 | curl.setOpt(Curl.option.FRESH_CONNECT, true) 31 | curl.setOpt(Curl.option.FORBID_REUSE, true) 32 | } 33 | 34 | return new Promise((resolve, reject) => { 35 | curl.setOpt(Curl.option.URL, url) 36 | curl.setOpt(Curl.option.HTTPGET, true) 37 | 38 | curl.on('end', (statusCode: number, data: string, headers: object) => { 39 | try { 40 | resolve({ statusCode, headers, data: isJsonString(data) ? JSON.parse(data) : data }) 41 | } catch (error) { 42 | reject(`Error parsing response: ${error}`) 43 | } finally { 44 | curl.close() 45 | } 46 | }) 47 | 48 | curl.on('error', (err) => { 49 | console.error('Error:', err) 50 | curl.close() 51 | 52 | reject(err) 53 | }) 54 | 55 | curl.perform() 56 | }) 57 | } 58 | 59 | async post(url: string, payload: any, headers: string[] = []): Promise { 60 | const curl = this.createInstance() 61 | 62 | const isForm = headers.some((header) => header.includes('application/x-www-form-urlencoded')) 63 | 64 | curl.setOpt(Curl.option.HTTPHEADER, headers) 65 | curl.setOpt(Curl.option.POSTFIELDS, isForm ? querystring.stringify(payload) : JSON.stringify(payload)) 66 | 67 | return new Promise((resolve, reject) => { 68 | curl.setOpt(Curl.option.URL, url) 69 | curl.setOpt(Curl.option.POST, true) 70 | 71 | curl.on('end', (statusCode: number, data: string, headers: object) => { 72 | try { 73 | resolve({ statusCode, headers, data: isJsonString(data) ? JSON.parse(data) : data }) 74 | } catch (error) { 75 | reject(`Error parsing response: ${error}`) 76 | } finally { 77 | curl.close() 78 | } 79 | }) 80 | 81 | curl.on('error', (err) => { 82 | console.error('Error:', err) 83 | curl.close() 84 | 85 | reject(err) 86 | }) 87 | 88 | curl.perform() 89 | }) 90 | } 91 | } 92 | 93 | const curl = new CurlInstance() 94 | 95 | export default curl 96 | -------------------------------------------------------------------------------- /src/twitter/index.ts: -------------------------------------------------------------------------------- 1 | import { readFileToArray, waittingBetween } from '../utils/common' 2 | import curl from '../requests/curl' 3 | import logger from '../logger' 4 | import 'dotenv/config' 5 | 6 | const BASE_URL = 'https://x.com' 7 | 8 | export class Twitter { 9 | headers: string[] 10 | authToken: string = '' 11 | initted: boolean = false 12 | 13 | constructor(pathIndex: number) { 14 | const needTwitter = Number(process.env.NEED_TWITTER) === 1 15 | if (needTwitter) { 16 | const twitterAccounts = readFileToArray('twitter.txt') 17 | 18 | if (twitterAccounts.length) { 19 | this.authToken = twitterAccounts[pathIndex] 20 | 21 | logger.info(`the twitter auth token is ${this.authToken}`) 22 | } 23 | } 24 | 25 | this.headers = [ 26 | 'accept: */*', 27 | 'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36', 28 | `Cookie: auth_token=${this.authToken}`, 29 | 'accept-language: en;q=0.9', 30 | 'authorization: Bearer AAAAAAAAAAAAAAAAAAAAANRILgAAAAAAnNwIzUejRCOuH5E6I8xnZz4puTs%3D1Zv7ttfk8LF81IUq16cHjhLTvJu4FA33AGWWjCpTnA', 31 | 'x-twitter-active-user: yes', 32 | 'x-twitter-client-language: en', 33 | 'x-twitter-auth-type: OAuth2Session', 34 | 'origin: https://x.com', 35 | 'sec-ch-ua: "Not/A)Brand";v="8", "Chromium";v="126", "Google Chrome";v="126"', 36 | 'sec-ch-ua-mobile: ?0', 37 | 'sec-ch-ua-platform: "Windows"', 38 | 'sec-fetch-dest: empty', 39 | 'sec-fetch-mode: cors', 40 | 'sec-fetch-site: same-origin' 41 | ] 42 | } 43 | 44 | private async request(queryId: string, action: string, body: object): Promise { 45 | if (!this.initted) await this.getCt0() 46 | 47 | logger.debug(`[twitter] requesting ${action}.`) 48 | 49 | const headers = [...this.headers, 'Content-Type: application/json'] 50 | 51 | const res = await curl.post(`${BASE_URL}/i/api/graphql/${queryId}/${action}`, body, headers) 52 | 53 | await waittingBetween(3000, 4500) 54 | 55 | // 327, 139: already 56 | const errorCode = res.data.errors && res.data.errors[0].code 57 | const alreadyCode = [139, 327] 58 | 59 | if (!errorCode) { 60 | logger.info(`[twitter] ${action} completed.`) 61 | 62 | return res 63 | } 64 | 65 | if (alreadyCode.includes(errorCode)) { 66 | logger.warn(`[twitter] already, code: ${errorCode} - ${res.data.errors[0].message}`) 67 | 68 | return true 69 | } 70 | 71 | throw { 72 | code: res.data.errors[0].code, 73 | data: res.data.errors[0], 74 | message: `[twitter] request ${action} error, info: ${JSON.stringify(res.data.errors)}`, 75 | extra: this.authToken 76 | } 77 | } 78 | 79 | async getCt0() { 80 | const res = await curl.get(`${BASE_URL}/home`, this.headers, true) 81 | 82 | const cookies = res.headers[1]['Set-Cookie'] 83 | const userCookie = cookies.find((cookie: string) => cookie.startsWith('ct0=')) 84 | 85 | const ct0 = userCookie.split(';')[0].split('=')[1] 86 | 87 | if (!ct0) { 88 | throw { 89 | code: 1000, 90 | message: `ct0 not found - auth token: ${this.authToken}`, 91 | extra: this.authToken 92 | } 93 | } 94 | 95 | this.initted = true 96 | this.headers = [ 97 | ...this.headers.map((header) => { 98 | if (header.startsWith('Cookie:')) return `${header}; ct0=${ct0}` 99 | return header 100 | }), 101 | `x-csrf-token: ${ct0}` 102 | ] 103 | } 104 | 105 | async createBindTweet(gid: string): Promise { 106 | if (!this.initted) await this.getCt0() 107 | 108 | const queryId = 'SoVnbfCycZ7fERGCwpZkYA' 109 | const action = 'CreateTweet' 110 | 111 | const payload = { 112 | variables: { 113 | tweet_text: `Verifying my Twitter account for my #GalxeID gid:${gid} @Galxe \n\n galxe.com/id `, 114 | dark_request: false, 115 | media: { media_entities: [], possibly_sensitive: false }, 116 | semantic_annotation_ids: [] 117 | }, 118 | features: { 119 | tweetypie_unmention_optimization_enabled: true, 120 | responsive_web_edit_tweet_api_enabled: true, 121 | graphql_is_translatable_rweb_tweet_is_translatable_enabled: true, 122 | view_counts_everywhere_api_enabled: true, 123 | longform_notetweets_consumption_enabled: true, 124 | responsive_web_twitter_article_tweet_consumption_enabled: false, 125 | tweet_awards_web_tipping_enabled: false, 126 | longform_notetweets_rich_text_read_enabled: true, 127 | longform_notetweets_inline_media_enabled: true, 128 | responsive_web_graphql_exclude_directive_enabled: true, 129 | verified_phone_label_enabled: false, 130 | freedom_of_speech_not_reach_fetch_enabled: true, 131 | standardized_nudges_misinfo: true, 132 | tweet_with_visibility_results_prefer_gql_limited_actions_policy_enabled: true, 133 | responsive_web_media_download_video_enabled: false, 134 | responsive_web_graphql_skip_user_profile_image_extensions_enabled: false, 135 | responsive_web_graphql_timeline_navigation_enabled: true, 136 | responsive_web_enhance_cards_enabled: false 137 | }, 138 | queryId 139 | } 140 | 141 | const res = await this.request(queryId, action, payload) 142 | 143 | const data = res.data.data 144 | 145 | const result = data.create_tweet.tweet_results.result 146 | const restId = result.rest_id 147 | const screenName = result.core.user_results.result.legacy.screen_name 148 | 149 | return `${BASE_URL}/${screenName}/status/${restId}` 150 | } 151 | 152 | async likeTweet(id: string) { 153 | const queryId = 'lI07N6Otwv1PhnEgXILM7A' 154 | const action = 'FavoriteTweet' 155 | 156 | const payload = { 157 | variables: { 158 | tweet_id: id, 159 | dark_request: false 160 | }, 161 | queryId 162 | } 163 | 164 | await this.request(queryId, action, payload) 165 | } 166 | 167 | async reTweet(id: string) { 168 | const queryId = 'ojPdsZsimiJrUGLR1sjUtA' 169 | const action = 'CreateRetweet' 170 | 171 | const payload = { 172 | variables: { 173 | tweet_id: id, 174 | dark_request: false 175 | }, 176 | queryId 177 | } 178 | 179 | return await this.request(queryId, action, payload) 180 | } 181 | 182 | async createPost(text: string) { 183 | const queryId = 'SoVnbfCycZ7fERGCwpZkYA' 184 | const action = 'CreateTweet' 185 | 186 | const payload = { 187 | variables: { 188 | tweet_text: text, 189 | dark_request: false, 190 | media: { media_entities: [], possibly_sensitive: false }, 191 | semantic_annotation_ids: [] 192 | }, 193 | features: { 194 | tweetypie_unmention_optimization_enabled: true, 195 | responsive_web_edit_tweet_api_enabled: true, 196 | graphql_is_translatable_rweb_tweet_is_translatable_enabled: true, 197 | view_counts_everywhere_api_enabled: true, 198 | longform_notetweets_consumption_enabled: true, 199 | responsive_web_twitter_article_tweet_consumption_enabled: false, 200 | tweet_awards_web_tipping_enabled: false, 201 | longform_notetweets_rich_text_read_enabled: true, 202 | longform_notetweets_inline_media_enabled: true, 203 | responsive_web_graphql_exclude_directive_enabled: true, 204 | verified_phone_label_enabled: false, 205 | freedom_of_speech_not_reach_fetch_enabled: true, 206 | standardized_nudges_misinfo: true, 207 | tweet_with_visibility_results_prefer_gql_limited_actions_policy_enabled: true, 208 | responsive_web_media_download_video_enabled: false, 209 | responsive_web_graphql_skip_user_profile_image_extensions_enabled: false, 210 | responsive_web_graphql_timeline_navigation_enabled: true, 211 | responsive_web_enhance_cards_enabled: false 212 | }, 213 | queryId 214 | } 215 | 216 | return await this.request(queryId, action, payload) 217 | } 218 | 219 | async follow(name: string) { 220 | if (!this.initted) await this.getCt0() 221 | 222 | // get user id 223 | const queryId = '9zwVLJ48lmVUk8u_Gh9DmA' 224 | const action = 'ProfileSpotlightsQuery' 225 | const queryParams = encodeURIComponent(JSON.stringify({ screen_name: name })) 226 | 227 | const userRes = await curl.get( 228 | `${BASE_URL}/i/api/graphql/${queryId}/${action}?variables=${queryParams}`, 229 | this.headers 230 | ) 231 | const userId = userRes.data.data.user_result_by_screen_name.result.rest_id 232 | 233 | // follow 234 | const payload = { 235 | include_profile_interstitial_type: '1', 236 | include_blocking: '1', 237 | include_blocked_by: '1', 238 | include_followed_by: '1', 239 | include_want_retweets: '1', 240 | include_mute_edge: '1', 241 | include_can_dm: '1', 242 | include_can_media_tag: '1', 243 | include_ext_has_nft_avatar: '1', 244 | include_ext_is_blue_verified: '1', 245 | include_ext_verified_type: '1', 246 | include_ext_profile_image_shape: '1', 247 | skip_status: '1', 248 | user_id: userId 249 | } 250 | 251 | try { 252 | const headers = [...this.headers, 'Content-Type: application/x-www-form-urlencoded'] 253 | 254 | const res = await curl.post('https://x.com/i/api/1.1/friendships/create.json', payload, headers) 255 | 256 | const statusCode = res.statusCode 257 | 258 | if (statusCode === 200) { 259 | logger.info('twitter follow success') 260 | 261 | return true 262 | } 263 | 264 | logger.error(JSON.stringify(res.data.errors)) 265 | 266 | if (res.data.errors[0].code === 64) { 267 | throw { 268 | code: res.data.errors[0].code, 269 | data: res.data.errors[0], 270 | message: `[twitter] request ${action} error, info: ${JSON.stringify(res.data.errors)}`, 271 | extra: this.authToken 272 | } 273 | } 274 | 275 | return false 276 | } catch (err: any) { 277 | if (err.code === 139) { 278 | logger.warn(`[twitter] ${err.data.message}`) 279 | 280 | return true 281 | } 282 | 283 | throw err 284 | } 285 | } 286 | } 287 | -------------------------------------------------------------------------------- /src/utils/common.ts: -------------------------------------------------------------------------------- 1 | import * as fs from 'fs' 2 | 3 | export const waitting = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms)) 4 | 5 | export const waittingBetween = (minMs: number, maxMs: number) => 6 | new Promise((resolve) => setTimeout(resolve, Math.floor(Math.random() * (maxMs - minMs)) + minMs)) 7 | 8 | export const formatDate = (date: Date, format: string): string => { 9 | const pad = (n: number): string => (n < 10 ? '0' + n : n.toString()) 10 | 11 | return format 12 | .replace('yyyy', date.getFullYear().toString()) 13 | .replace('MM', pad(date.getMonth() + 1)) 14 | .replace('dd', pad(date.getDate())) 15 | .replace('HH', pad(date.getHours())) 16 | .replace('mm', pad(date.getMinutes())) 17 | .replace('ss', pad(date.getSeconds())) 18 | } 19 | 20 | export const randomString = (len: number, needBigWord: boolean = false) => { 21 | let chars = '0123456789abcdefghijklmnopqrstuvwxyz' 22 | if (needBigWord) chars += 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 23 | 24 | const maxPos = chars.length 25 | let str = '' 26 | for (let i = 0; i < len; i++) { 27 | str += chars.charAt(Math.floor(Math.random() * maxPos)) 28 | } 29 | return str 30 | } 31 | 32 | export const isJsonString = (data: any) => { 33 | try { 34 | JSON.parse(data) 35 | return true 36 | } catch (error) { 37 | return false 38 | } 39 | } 40 | 41 | export const readFileToArray = (filePath: string): string[] => { 42 | try { 43 | const data = fs.readFileSync(filePath, 'utf8') 44 | if (!data) return [] 45 | 46 | const lines = data.split('\n') 47 | 48 | return lines.map((line) => line.trim()) 49 | } catch (error) { 50 | console.error('Error reading file:', error) 51 | return [] 52 | } 53 | } 54 | -------------------------------------------------------------------------------- /src/wallet/index.ts: -------------------------------------------------------------------------------- 1 | import * as bitcoinMessage from 'bitcoinjs-message' 2 | import * as bitcoin from 'bitcoinjs-lib' 3 | import * as bip39 from 'bip39' 4 | import * as ecc from 'tiny-secp256k1' 5 | import BIP32Factory, { BIP32Interface } from 'bip32' 6 | import ECPairFactory, { ECPairInterface } from 'ecpair' 7 | import { ethers } from 'ethers' 8 | import 'dotenv/config' 9 | 10 | const MNEMONIC = process.env.MNEMONIC! 11 | 12 | bitcoin.initEccLib(ecc) 13 | const bip32 = BIP32Factory(ecc) 14 | const ECPair = ECPairFactory(ecc) 15 | 16 | export const SIGNET_NETWORK = { 17 | messagePrefix: '\x18Bitcoin Signed Message:\n', 18 | bech32: 'tb', 19 | bip32: { public: 0x045f1cf6, private: 0x045f18bc }, 20 | pubKeyHash: 0x6f, 21 | scriptHash: 0xc4, 22 | wif: 0xef 23 | } 24 | 25 | export interface ITaprootWallet { 26 | address: string 27 | path: string 28 | childNode: BIP32Interface 29 | payment: bitcoin.Payment 30 | internalPubkey: Buffer 31 | tweakedChildNode: bitcoin.Signer 32 | } 33 | 34 | export interface ISegWitWallet { 35 | address: string 36 | keyPair: ECPairInterface 37 | } 38 | 39 | /** 40 | * 钱包管理类 41 | * 42 | * 目前实现了 Evm 和 Taproot Signet 的签名和交易 43 | */ 44 | export class WalletManager { 45 | pathIndex: number 46 | 47 | evmWallet: ethers.Wallet 48 | taprootWallet: ITaprootWallet 49 | 50 | constructor(pathIndex: number) { 51 | this.pathIndex = pathIndex 52 | 53 | this.evmWallet = this.getEvmWallet() 54 | this.taprootWallet = this.getTaprootWallet() 55 | } 56 | 57 | private getEvmWallet(): ethers.Wallet { 58 | const seed = bip39.mnemonicToSeedSync(MNEMONIC) 59 | const path = `m/44'/60'/0'/0/${this.pathIndex}` 60 | 61 | const hdNode = ethers.HDNodeWallet.fromSeed(seed) 62 | const wallet = hdNode.derivePath(path) 63 | 64 | return new ethers.Wallet(wallet.privateKey) 65 | } 66 | 67 | private getTaprootWallet(): ITaprootWallet { 68 | const seed = bip39.mnemonicToSeedSync(MNEMONIC) 69 | const rootKey = bip32.fromSeed(seed, SIGNET_NETWORK) 70 | 71 | const path = `m/86'/1'/0'/0/${this.pathIndex}` 72 | const childNode = rootKey.derivePath(path) 73 | const internalPubkey = childNode.publicKey.subarray(1, 33) 74 | 75 | const payment = bitcoin.payments.p2tr({ 76 | internalPubkey, 77 | network: SIGNET_NETWORK 78 | }) 79 | 80 | const tweakedChildNode = childNode.tweak(bitcoin.crypto.taggedHash('TapTweak', internalPubkey)) 81 | 82 | return { 83 | address: payment.address!, 84 | path, 85 | payment, 86 | childNode, 87 | internalPubkey, 88 | tweakedChildNode 89 | } 90 | } 91 | 92 | async signEvmMessage(message: string | Uint8Array): Promise { 93 | const ethersWallet = new ethers.Wallet(this.evmWallet.privateKey) 94 | 95 | return await ethersWallet.signMessage(message) 96 | } 97 | 98 | async signTaprootMessage(message: string): Promise { 99 | const keyPair = ECPair.fromWIF(this.taprootWallet.childNode.toWIF(), SIGNET_NETWORK) 100 | 101 | const signature = bitcoinMessage.sign(message, keyPair.privateKey as Buffer, keyPair.compressed) 102 | 103 | return Buffer.from(signature).toString('base64') 104 | } 105 | } 106 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es6", 4 | "module": "CommonJS", 5 | "strict": true, 6 | "esModuleInterop": true, 7 | "skipLibCheck": true, 8 | "forceConsistentCasingInFileNames": true 9 | }, 10 | "include": ["./**/*.ts"], 11 | "exclude": ["node_modules"] 12 | } 13 | -------------------------------------------------------------------------------- /twitter.txt: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Kunsect/galxe-task-automation/079fbf43a00b9f568ee07fcfd9eec525a0726bab/twitter.txt --------------------------------------------------------------------------------