From 349beabf38642c2a1fe663f52a0244272dac51fa Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Mon, 13 Nov 2023 20:01:50 +0100 Subject: [PATCH 01/19] Update CI dependencies --- .github/workflows/.pre-commit-config.yaml | 13 ++++++++++--- .github/workflows/main.yaml | 14 +++++++------- .pre-commit-config.yaml | 10 +++++----- 3 files changed, 22 insertions(+), 15 deletions(-) diff --git a/.github/workflows/.pre-commit-config.yaml b/.github/workflows/.pre-commit-config.yaml index ae6a588..f0da0b1 100644 --- a/.github/workflows/.pre-commit-config.yaml +++ b/.github/workflows/.pre-commit-config.yaml @@ -6,6 +6,13 @@ jobs: pre-commit: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 - - uses: actions/setup-python@v2 - - uses: pre-commit/action@v2.0.3 + - name: Checkout + uses: actions/checkout@v4 + + - name: Setup Python 3.10.13 + uses: actions/setup-python@v4 + with: + python-version: 3.10.13 + + - name: Pre-commit checks + uses: pre-commit/action@v3.0.0 diff --git a/.github/workflows/main.yaml b/.github/workflows/main.yaml index 8ff2c7b..b86da2f 100644 --- a/.github/workflows/main.yaml +++ b/.github/workflows/main.yaml @@ -13,27 +13,27 @@ jobs: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - name: Cache Compiler Installations - uses: actions/cache@v2 + uses: actions/cache@v3 with: path: | ~/.vvm key: compiler-cache - name: Setup Node.js - uses: actions/setup-node@v1 + uses: actions/setup-node@v3 with: - node-version: 16 + node-version: 20 - name: Install Hardhat run: npm ci - - name: Setup Python 3.8 - uses: actions/setup-python@v2 + - name: Setup Python 3.10 + uses: actions/setup-python@v4 with: - python-version: 3.8 + python-version: 3.10.13 - name: Install Requirements run: pip install -r requirements.txt diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index b64277d..7d6119c 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -2,25 +2,25 @@ # See https://pre-commit.com/hooks.html for more hooks repos: - repo: https://github.com/pre-commit/pre-commit-hooks - rev: v4.1.0 + rev: v4.5.0 hooks: - id: trailing-whitespace - id: end-of-file-fixer - id: check-yaml - repo: https://github.com/psf/black - rev: 22.3.0 + rev: 23.11.0 hooks: - id: black args: [--line-length=79] - repo: https://github.com/pycqa/flake8 - rev: 4.0.1 + rev: 6.1.0 hooks: - id: flake8 - repo: https://github.com/pycqa/isort - rev: 5.10.1 + rev: 5.12.0 hooks: - id: isort args: ["--profile", "black", --line-length=79] default_language_version: - python: python3.10.4 + python: python3.10 From a70015575b9987a6f64a0f3f814f2be459174662 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Mon, 13 Nov 2023 20:37:08 +0100 Subject: [PATCH 02/19] Dockerfile and pip dependencies --- Dockerfile | 12 + package-lock.json | 3952 ++++++++++++++++++++++++++++----------------- package.json | 4 +- requirements.txt | 16 +- 4 files changed, 2512 insertions(+), 1472 deletions(-) create mode 100644 Dockerfile diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..f93232a --- /dev/null +++ b/Dockerfile @@ -0,0 +1,12 @@ +FROM nikolaik/python-nodejs:python3.10-nodejs20 + +WORKDIR /usr/app +COPY package*.json ./ +RUN npm ci \ + && npm cache clean --force + +COPY requirements.in ./ +RUN pip install -r requirements.in + +COPY . . +CMD ape test diff --git a/package-lock.json b/package-lock.json index befde2b..c056810 100644 --- a/package-lock.json +++ b/package-lock.json @@ -6,94 +6,137 @@ "": { "hasInstallScript": true, "devDependencies": { - "hardhat": "^2.10.1" + "hardhat": "^2.19.0" } }, - "node_modules/@ethereumjs/block": { - "version": "3.6.3", - "resolved": "https://registry.npmjs.org/@ethereumjs/block/-/block-3.6.3.tgz", - "integrity": "sha512-CegDeryc2DVKnDkg5COQrE0bJfw/p0v3GBk2W5/Dj5dOVfEmb50Ux0GLnSPypooLnfqjwFaorGuT9FokWB3GRg==", + "node_modules/@chainsafe/as-sha256": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@chainsafe/as-sha256/-/as-sha256-0.3.1.tgz", + "integrity": "sha512-hldFFYuf49ed7DAakWVXSJODuq3pzJEguD8tQ7h+sGkM18vja+OFoJI9krnGmgzyuZC2ETX0NOIcCTy31v2Mtg==", + "dev": true + }, + "node_modules/@chainsafe/persistent-merkle-tree": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.4.2.tgz", + "integrity": "sha512-lLO3ihKPngXLTus/L7WHKaw9PnNJWizlOF1H9NNzHP6Xvh82vzg9F2bzkXhYIFshMZ2gTCEz8tq6STe7r5NDfQ==", "dev": true, "dependencies": { - "@ethereumjs/common": "^2.6.5", - "@ethereumjs/tx": "^3.5.2", - "ethereumjs-util": "^7.1.5", - "merkle-patricia-tree": "^4.2.4" + "@chainsafe/as-sha256": "^0.3.1" } }, - "node_modules/@ethereumjs/blockchain": { - "version": "5.5.3", - "resolved": "https://registry.npmjs.org/@ethereumjs/blockchain/-/blockchain-5.5.3.tgz", - "integrity": "sha512-bi0wuNJ1gw4ByNCV56H0Z4Q7D+SxUbwyG12Wxzbvqc89PXLRNR20LBcSUZRKpN0+YCPo6m0XZL/JLio3B52LTw==", + "node_modules/@chainsafe/ssz": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.9.4.tgz", + "integrity": "sha512-77Qtg2N1ayqs4Bg/wvnWfg5Bta7iy7IRh8XqXh7oNMeP2HBbBwx8m6yTpA8p0EHItWPEBkgZd5S5/LSlp3GXuQ==", "dev": true, "dependencies": { - "@ethereumjs/block": "^3.6.2", - "@ethereumjs/common": "^2.6.4", - "@ethereumjs/ethash": "^1.1.0", - "debug": "^4.3.3", - "ethereumjs-util": "^7.1.5", - "level-mem": "^5.0.1", - "lru-cache": "^5.1.1", - "semaphore-async-await": "^1.5.1" + "@chainsafe/as-sha256": "^0.3.1", + "@chainsafe/persistent-merkle-tree": "^0.4.2", + "case": "^1.6.3" } }, - "node_modules/@ethereumjs/common": { - "version": "2.6.5", - "resolved": "https://registry.npmjs.org/@ethereumjs/common/-/common-2.6.5.tgz", - "integrity": "sha512-lRyVQOeCDaIVtgfbowla32pzeDv2Obr8oR8Put5RdUBNRGr1VGPGQNGP6elWIpgK3YdpzqTOh4GyUGOureVeeA==", + "node_modules/@ethersproject/abi": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/abi/-/abi-5.7.0.tgz", + "integrity": "sha512-351ktp42TiRcYB3H1OP8yajPeAQstMW/yCFokj/AthP9bLHzQFPlOrxOcwYEDkUAICmOHljvN4K39OMTMUa9RA==", "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], "dependencies": { - "crc-32": "^1.2.0", - "ethereumjs-util": "^7.1.5" + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" } }, - "node_modules/@ethereumjs/ethash": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@ethereumjs/ethash/-/ethash-1.1.0.tgz", - "integrity": "sha512-/U7UOKW6BzpA+Vt+kISAoeDie1vAvY4Zy2KF5JJb+So7+1yKmJeJEHOGSnQIj330e9Zyl3L5Nae6VZyh2TJnAA==", + "node_modules/@ethersproject/abstract-provider": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/abstract-provider/-/abstract-provider-5.7.0.tgz", + "integrity": "sha512-R41c9UkchKCpAqStMYUpdunjo3pkEvZC3FAwZn5S5MGbXoMQOHIdHItezTETxAO5bevtMApSyEhn9+CHcDsWBw==", "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], "dependencies": { - "@ethereumjs/block": "^3.5.0", - "@types/levelup": "^4.3.0", - "buffer-xor": "^2.0.1", - "ethereumjs-util": "^7.1.1", - "miller-rabin": "^4.0.0" + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/networks": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/web": "^5.7.0" } }, - "node_modules/@ethereumjs/tx": { - "version": "3.5.2", - "resolved": "https://registry.npmjs.org/@ethereumjs/tx/-/tx-3.5.2.tgz", - "integrity": "sha512-gQDNJWKrSDGu2w7w0PzVXVBNMzb7wwdDOmOqczmhNjqFxFuIbhVJDwiGEnxFNC2/b8ifcZzY7MLcluizohRzNw==", + "node_modules/@ethersproject/abstract-signer": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/abstract-signer/-/abstract-signer-5.7.0.tgz", + "integrity": "sha512-a16V8bq1/Cz+TGCkE2OPMTOUDLS3grCpdjoJCYNnVBbdYEMSgKrU0+B90s8b6H+ByYTBZN7a3g76jdIJi7UfKQ==", "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], "dependencies": { - "@ethereumjs/common": "^2.6.4", - "ethereumjs-util": "^7.1.5" + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0" } }, - "node_modules/@ethereumjs/vm": { - "version": "5.9.3", - "resolved": "https://registry.npmjs.org/@ethereumjs/vm/-/vm-5.9.3.tgz", - "integrity": "sha512-Ha04TeF8goEglr8eL7hkkYyjhzdZS0PsoRURzYlTF6I0VVId5KjKb0N7MrA8GMgheN+UeTncfTgYx52D/WhEmg==", + "node_modules/@ethersproject/address": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/address/-/address-5.7.0.tgz", + "integrity": "sha512-9wYhYt7aghVGo758POM5nqcOMaE168Q6aRLJZwUmiqSrAungkG74gSSeKEIR7ukixesdRZGPgVqme6vmxs1fkA==", "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], "dependencies": { - "@ethereumjs/block": "^3.6.3", - "@ethereumjs/blockchain": "^5.5.3", - "@ethereumjs/common": "^2.6.5", - "@ethereumjs/tx": "^3.5.2", - "async-eventemitter": "^0.2.4", - "core-js-pure": "^3.0.1", - "debug": "^4.3.3", - "ethereumjs-util": "^7.1.5", - "functional-red-black-tree": "^1.0.1", - "mcl-wasm": "^0.7.1", - "merkle-patricia-tree": "^4.2.4", - "rustbn.js": "~0.2.0" + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/rlp": "^5.7.0" } }, - "node_modules/@ethersproject/abi": { - "version": "5.6.4", - "resolved": "https://registry.npmjs.org/@ethersproject/abi/-/abi-5.6.4.tgz", - "integrity": "sha512-TTeZUlCeIHG6527/2goZA6gW5F8Emoc7MrZDC7hhP84aRGvW3TEdTnZR08Ls88YXM1m2SuK42Osw/jSi3uO8gg==", + "node_modules/@ethersproject/base64": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/base64/-/base64-5.7.0.tgz", + "integrity": "sha512-Dr8tcHt2mEbsZr/mwTPIQAf3Ai0Bks/7gTw9dSqk1mQvhW3XvRlmDJr/4n+wg1JmCl16NZue17CDh8xb/vZ0sQ==", "dev": true, "funding": [ { @@ -106,21 +149,13 @@ } ], "dependencies": { - "@ethersproject/address": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/constants": "^5.6.1", - "@ethersproject/hash": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/strings": "^5.6.1" + "@ethersproject/bytes": "^5.7.0" } }, - "node_modules/@ethersproject/abstract-provider": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-provider/-/abstract-provider-5.6.1.tgz", - "integrity": "sha512-BxlIgogYJtp1FS8Muvj8YfdClk3unZH0vRMVX791Z9INBNT/kuACZ9GzaY1Y4yFq+YSy6/w4gzj3HCRKrK9hsQ==", + "node_modules/@ethersproject/basex": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/basex/-/basex-5.7.0.tgz", + "integrity": "sha512-ywlh43GwZLv2Voc2gQVTKBoVQ1mti3d8HK5aMxsfu/nRDnMmNqaSJ3r3n85HBByT8OpoY96SXM1FogC533T4zw==", "dev": true, "funding": [ { @@ -133,19 +168,14 @@ } ], "dependencies": { - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/networks": "^5.6.3", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/transactions": "^5.6.2", - "@ethersproject/web": "^5.6.1" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/properties": "^5.7.0" } }, - "node_modules/@ethersproject/abstract-signer": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-signer/-/abstract-signer-5.6.2.tgz", - "integrity": "sha512-n1r6lttFBG0t2vNiI3HoWaS/KdOt8xyDjzlP2cuevlWLG6EX0OwcKLyG/Kp/cuwNxdy/ous+R/DEMdTUwWQIjQ==", + "node_modules/@ethersproject/bignumber": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/bignumber/-/bignumber-5.7.0.tgz", + "integrity": "sha512-n1CAdIHRWjSucQO3MC1zPSVgV/6dy/fjL9pMrPP9peL+QxEg9wOsVqwD4+818B6LUEtaXzVHQiuivzRoxPxUGw==", "dev": true, "funding": [ { @@ -158,17 +188,15 @@ } ], "dependencies": { - "@ethersproject/abstract-provider": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "bn.js": "^5.2.1" } }, - "node_modules/@ethersproject/address": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/address/-/address-5.6.1.tgz", - "integrity": "sha512-uOgF0kS5MJv9ZvCz7x6T2EXJSzotiybApn4XlOgoTX0xdtyVIJ7pF+6cGPxiEq/dpBiTfMiw7Yc81JcwhSYA0Q==", + "node_modules/@ethersproject/bytes": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/bytes/-/bytes-5.7.0.tgz", + "integrity": "sha512-nsbxwgFXWh9NyYWo+U8atvmMsSdKJprTcICAkvbBffT75qDocbuggBU0SJiVK2MuTrp0q+xvLkTnGMPK1+uA9A==", "dev": true, "funding": [ { @@ -181,17 +209,13 @@ } ], "dependencies": { - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/rlp": "^5.6.1" + "@ethersproject/logger": "^5.7.0" } }, - "node_modules/@ethersproject/base64": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/base64/-/base64-5.6.1.tgz", - "integrity": "sha512-qB76rjop6a0RIYYMiB4Eh/8n+Hxu2NIZm8S/Q7kNo5pmZfXhHGHmS4MinUainiBC54SCyRnwzL+KZjj8zbsSsw==", + "node_modules/@ethersproject/constants": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/constants/-/constants-5.7.0.tgz", + "integrity": "sha512-DHI+y5dBNvkpYUMiRQyxRBYBefZkJfo70VUkUAsRjcPs47muV9evftfZ0PJVCXYbAiCgght0DtcF9srFQmIgWA==", "dev": true, "funding": [ { @@ -204,13 +228,13 @@ } ], "dependencies": { - "@ethersproject/bytes": "^5.6.1" + "@ethersproject/bignumber": "^5.7.0" } }, - "node_modules/@ethersproject/bignumber": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/bignumber/-/bignumber-5.6.2.tgz", - "integrity": "sha512-v7+EEUbhGqT3XJ9LMPsKvXYHFc8eHxTowFCG/HgJErmq4XHJ2WR7aeyICg3uTOAQ7Icn0GFHAohXEhxQHq4Ubw==", + "node_modules/@ethersproject/contracts": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/contracts/-/contracts-5.7.0.tgz", + "integrity": "sha512-5GJbzEU3X+d33CdfPhcyS+z8MzsTrBGk/sc+G+59+tPa9yFkl6HQ9D6L0QMgNTA9q8dT0XKxxkyp883XsQvbbg==", "dev": true, "funding": [ { @@ -223,15 +247,22 @@ } ], "dependencies": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "bn.js": "^5.2.1" + "@ethersproject/abi": "^5.7.0", + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/transactions": "^5.7.0" } }, - "node_modules/@ethersproject/bytes": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/bytes/-/bytes-5.6.1.tgz", - "integrity": "sha512-NwQt7cKn5+ZE4uDn+X5RAXLp46E1chXoaMmrxAyA0rblpxz8t58lVkrHXoRIn0lz1joQElQ8410GqhTqMOwc6g==", + "node_modules/@ethersproject/hash": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/hash/-/hash-5.7.0.tgz", + "integrity": "sha512-qX5WrQfnah1EFnO5zJv1v46a8HW0+E5xuBBDTwMFZLuVTx0tbU2kkx15NqdjxecrLGatQN9FGQKpb1FKdHCt+g==", "dev": true, "funding": [ { @@ -244,13 +275,21 @@ } ], "dependencies": { - "@ethersproject/logger": "^5.6.0" + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/base64": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" } }, - "node_modules/@ethersproject/constants": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/constants/-/constants-5.6.1.tgz", - "integrity": "sha512-QSq9WVnZbxXYFftrjSjZDUshp6/eKp6qrtdBtUCm0QxCV5z1fG/w3kdlcsjMCQuQHUnAclKoK7XpXMezhRDOLg==", + "node_modules/@ethersproject/hdnode": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/hdnode/-/hdnode-5.7.0.tgz", + "integrity": "sha512-OmyYo9EENBPPf4ERhR7oj6uAtUAhYGqOnIS+jE5pTXvdKBS99ikzq1E7Iv0ZQZ5V36Lqx1qZLeak0Ra16qpeOg==", "dev": true, "funding": [ { @@ -263,13 +302,24 @@ } ], "dependencies": { - "@ethersproject/bignumber": "^5.6.2" - } - }, - "node_modules/@ethersproject/hash": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/hash/-/hash-5.6.1.tgz", - "integrity": "sha512-L1xAHurbaxG8VVul4ankNX5HgQ8PNCTrnVXEiFnE9xoRnaUcgfD12tZINtDinSllxPLCtGwguQxJ5E6keE84pA==", + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/basex": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/pbkdf2": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/sha2": "^5.7.0", + "@ethersproject/signing-key": "^5.7.0", + "@ethersproject/strings": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/wordlists": "^5.7.0" + } + }, + "node_modules/@ethersproject/json-wallets": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/json-wallets/-/json-wallets-5.7.0.tgz", + "integrity": "sha512-8oee5Xgu6+RKgJTkvEMl2wDgSPSAQ9MB/3JYjFV9jlKvcYHUXZC+cQp0njgmxdHkYWn8s6/IqIZYm0YWCjO/0g==", "dev": true, "funding": [ { @@ -282,20 +332,25 @@ } ], "dependencies": { - "@ethersproject/abstract-signer": "^5.6.2", - "@ethersproject/address": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/strings": "^5.6.1" + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/hdnode": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/pbkdf2": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/random": "^5.7.0", + "@ethersproject/strings": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "aes-js": "3.0.0", + "scrypt-js": "3.0.1" } }, "node_modules/@ethersproject/keccak256": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/keccak256/-/keccak256-5.6.1.tgz", - "integrity": "sha512-bB7DQHCTRDooZZdL3lk9wpL0+XuG3XLGHLh3cePnybsO3V0rdCAOQGpn/0R3aODmnTOOkCATJiD2hnL+5bwthA==", + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/keccak256/-/keccak256-5.7.0.tgz", + "integrity": "sha512-2UcPboeL/iW+pSg6vZ6ydF8tCnv3Iu/8tUmLLzWWGzxWKFFqOBQFLo6uLUv6BDrLgCDfN28RJ/wtByx+jZ4KBg==", "dev": true, "funding": [ { @@ -308,14 +363,14 @@ } ], "dependencies": { - "@ethersproject/bytes": "^5.6.1", + "@ethersproject/bytes": "^5.7.0", "js-sha3": "0.8.0" } }, "node_modules/@ethersproject/logger": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/@ethersproject/logger/-/logger-5.6.0.tgz", - "integrity": "sha512-BiBWllUROH9w+P21RzoxJKzqoqpkyM1pRnEKG69bulE9TSQD8SAIvTQqIMZmmCO8pUNkgLP1wndX1gKghSpBmg==", + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/logger/-/logger-5.7.0.tgz", + "integrity": "sha512-0odtFdXu/XHtjQXJYA3u9G0G8btm0ND5Cu8M7i5vhEcE8/HmF4Lbdqanwyv4uQTr2tx6b7fQRmgLrsnpQlmnig==", "dev": true, "funding": [ { @@ -329,9 +384,28 @@ ] }, "node_modules/@ethersproject/networks": { - "version": "5.6.4", - "resolved": "https://registry.npmjs.org/@ethersproject/networks/-/networks-5.6.4.tgz", - "integrity": "sha512-KShHeHPahHI2UlWdtDMn2lJETcbtaJge4k7XSjDR9h79QTd6yQJmv6Cp2ZA4JdqWnhszAOLSuJEd9C0PRw7hSQ==", + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/@ethersproject/networks/-/networks-5.7.1.tgz", + "integrity": "sha512-n/MufjFYv3yFcUyfhnXotyDlNdFb7onmkSy8aQERi2PjNcnWQ66xXxa3XlS8nCcA8aJKJjIIMNJTC7tu80GwpQ==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/logger": "^5.7.0" + } + }, + "node_modules/@ethersproject/pbkdf2": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/pbkdf2/-/pbkdf2-5.7.0.tgz", + "integrity": "sha512-oR/dBRZR6GTyaofd86DehG72hY6NpAjhabkhxgr3X2FpJtJuodEl2auADWBZfhDHgVCbu3/H/Ocq2uC6dpNjjw==", "dev": true, "funding": [ { @@ -344,13 +418,92 @@ } ], "dependencies": { - "@ethersproject/logger": "^5.6.0" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/sha2": "^5.7.0" } }, "node_modules/@ethersproject/properties": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/@ethersproject/properties/-/properties-5.6.0.tgz", - "integrity": "sha512-szoOkHskajKePTJSZ46uHUWWkbv7TzP2ypdEK6jGMqJaEt2sb0jCgfBo0gH0m2HBpRixMuJ6TBRaQCF7a9DoCg==", + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/properties/-/properties-5.7.0.tgz", + "integrity": "sha512-J87jy8suntrAkIZtecpxEPxY//szqr1mlBaYlQ0r4RCaiD2hjheqF9s1LVE8vVuJCXisjIP+JgtK/Do54ej4Sw==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/logger": "^5.7.0" + } + }, + "node_modules/@ethersproject/providers": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/@ethersproject/providers/-/providers-5.7.2.tgz", + "integrity": "sha512-g34EWZ1WWAVgr4aptGlVBF8mhl3VWjv+8hoAnzStu8Ah22VHBsuGzP17eb6xDVRzw895G4W7vvx60lFFur/1Rg==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/base64": "^5.7.0", + "@ethersproject/basex": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/networks": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/random": "^5.7.0", + "@ethersproject/rlp": "^5.7.0", + "@ethersproject/sha2": "^5.7.0", + "@ethersproject/strings": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/web": "^5.7.0", + "bech32": "1.1.4", + "ws": "7.4.6" + } + }, + "node_modules/@ethersproject/providers/node_modules/ws": { + "version": "7.4.6", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.6.tgz", + "integrity": "sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A==", + "dev": true, + "engines": { + "node": ">=8.3.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": "^5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/@ethersproject/random": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/random/-/random-5.7.0.tgz", + "integrity": "sha512-19WjScqRA8IIeWclFme75VMXSBvi4e6InrUNuaR4s5pTF2qNhcGdCUwdxUVGtDDqC00sDLCO93jPQoDUH4HVmQ==", "dev": true, "funding": [ { @@ -363,13 +516,34 @@ } ], "dependencies": { - "@ethersproject/logger": "^5.6.0" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0" } }, "node_modules/@ethersproject/rlp": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/rlp/-/rlp-5.6.1.tgz", - "integrity": "sha512-uYjmcZx+DKlFUk7a5/W9aQVaoEC7+1MOBgNtvNg13+RnuUwT4F0zTovC0tmay5SmRslb29V1B7Y5KCri46WhuQ==", + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/rlp/-/rlp-5.7.0.tgz", + "integrity": "sha512-rBxzX2vK8mVF7b0Tol44t5Tb8gomOHkj5guL+HhzQ1yBh/ydjGnpw6at+X6Iw0Kp3OzzzkcKp8N9r0W4kYSs9w==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0" + } + }, + "node_modules/@ethersproject/sha2": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/sha2/-/sha2-5.7.0.tgz", + "integrity": "sha512-gKlH42riwb3KYp0reLsFTokByAKoJdgFCwI+CCiX/k+Jm2mbNs6oOaCjYQSlI1+XBVejwH2KrmCbMAT/GnRDQw==", "dev": true, "funding": [ { @@ -382,14 +556,15 @@ } ], "dependencies": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "hash.js": "1.1.7" } }, "node_modules/@ethersproject/signing-key": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/signing-key/-/signing-key-5.6.2.tgz", - "integrity": "sha512-jVbu0RuP7EFpw82vHcL+GP35+KaNruVAZM90GxgQnGqB6crhBqW/ozBfFvdeImtmb4qPko0uxXjn8l9jpn0cwQ==", + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/signing-key/-/signing-key-5.7.0.tgz", + "integrity": "sha512-MZdy2nL3wO0u7gkB4nA/pEf8lu1TlFswPNmy8AiYkfKTdO6eXBJyUdmHO/ehm/htHw9K/qF8ujnTyUAD+Ry54Q==", "dev": true, "funding": [ { @@ -402,18 +577,42 @@ } ], "dependencies": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", "bn.js": "^5.2.1", "elliptic": "6.5.4", "hash.js": "1.1.7" } }, + "node_modules/@ethersproject/solidity": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/solidity/-/solidity-5.7.0.tgz", + "integrity": "sha512-HmabMd2Dt/raavyaGukF4XxizWKhKQ24DoLtdNbBmNKUOPqwjsKQSdV9GQtj9CBEea9DlzETlVER1gYeXXBGaA==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/sha2": "^5.7.0", + "@ethersproject/strings": "^5.7.0" + } + }, "node_modules/@ethersproject/strings": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/strings/-/strings-5.6.1.tgz", - "integrity": "sha512-2X1Lgk6Jyfg26MUnsHiT456U9ijxKUybz8IM1Vih+NJxYtXhmvKBcHOmvGqpFSVJ0nQ4ZCoIViR8XlRw1v/+Cw==", + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/strings/-/strings-5.7.0.tgz", + "integrity": "sha512-/9nu+lj0YswRNSH0NXYqrh8775XNyEdUQAuf3f+SmOrnVewcJ5SBNAjF7lpgehKi4abvNNXyf+HX86czCdJ8Mg==", "dev": true, "funding": [ { @@ -426,15 +625,15 @@ } ], "dependencies": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/constants": "^5.6.1", - "@ethersproject/logger": "^5.6.0" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/logger": "^5.7.0" } }, "node_modules/@ethersproject/transactions": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/transactions/-/transactions-5.6.2.tgz", - "integrity": "sha512-BuV63IRPHmJvthNkkt9G70Ullx6AcM+SDc+a8Aw/8Yew6YwT51TcBKEp1P4oOQ/bP25I18JJr7rcFRgFtU9B2Q==", + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/transactions/-/transactions-5.7.0.tgz", + "integrity": "sha512-kmcNicCp1lp8qanMTC3RIikGgoJ80ztTyvtsFvCYpSCfkjhD0jZ2LOrnbcuxuToLIUYYf+4XwD1rP+B/erDIhQ==", "dev": true, "funding": [ { @@ -447,21 +646,98 @@ } ], "dependencies": { - "@ethersproject/address": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/constants": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/rlp": "^5.6.1", - "@ethersproject/signing-key": "^5.6.2" + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/rlp": "^5.7.0", + "@ethersproject/signing-key": "^5.7.0" + } + }, + "node_modules/@ethersproject/units": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/units/-/units-5.7.0.tgz", + "integrity": "sha512-pD3xLMy3SJu9kG5xDGI7+xhTEmGXlEqXU4OfNapmfnxLVY4EMSSRp7j1k7eezutBPH7RBN/7QPnwR7hzNlEFeg==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/logger": "^5.7.0" + } + }, + "node_modules/@ethersproject/wallet": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/wallet/-/wallet-5.7.0.tgz", + "integrity": "sha512-MhmXlJXEJFBFVKrDLB4ZdDzxcBxQ3rLyCkhNqVu3CDYvR97E+8r01UgrI+TI99Le+aYm/in/0vp86guJuM7FCA==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/hdnode": "^5.7.0", + "@ethersproject/json-wallets": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/random": "^5.7.0", + "@ethersproject/signing-key": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/wordlists": "^5.7.0" } }, "node_modules/@ethersproject/web": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/web/-/web-5.6.1.tgz", - "integrity": "sha512-/vSyzaQlNXkO1WV+RneYKqCJwualcUdx/Z3gseVovZP0wIlOFcCE1hkRhKBH8ImKbGQbMl9EAAyJFrJu7V0aqA==", + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/@ethersproject/web/-/web-5.7.1.tgz", + "integrity": "sha512-Gueu8lSvyjBWL4cYsWsjh6MtMwM0+H4HvqFPZfB6dV8ctbP9zFAO73VG1cMWae0FLPCtz0peKPpZY8/ugJJX2w==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], + "dependencies": { + "@ethersproject/base64": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" + } + }, + "node_modules/@ethersproject/wordlists": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/wordlists/-/wordlists-5.7.0.tgz", + "integrity": "sha512-S2TFNJNfHWVHNE6cNDjbVlZ6MgE17MIxMbMg2zv3wn+3XSJGosL1m9ZVv3GXCf/2ymSsQ+hRI5IzoMJTG6aoVA==", "dev": true, "funding": [ { @@ -474,11 +750,20 @@ } ], "dependencies": { - "@ethersproject/base64": "^5.6.1", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/strings": "^5.6.1" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" + } + }, + "node_modules/@fastify/busboy": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.0.tgz", + "integrity": "sha512-+KpH+QxZU7O4675t3mnkQKcZZg56u+K/Ct2K+N2AZYNVK8kyeo/bI18tI8aPm3tvNNRyTWfj6s5tnGNlcbQRsA==", + "dev": true, + "engines": { + "node": ">=14" } }, "node_modules/@metamask/eth-sig-util": { @@ -574,54 +859,646 @@ } ] }, - "node_modules/@scure/base": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@scure/base/-/base-1.1.1.tgz", - "integrity": "sha512-ZxOhsSyxYwLJj3pLZCefNitxsj093tb2vq90mp2txoYeBqbcjDjqFhyM8eUjq/uFm6zJ+mUuqxlS2FkuSY1MTA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ] - }, - "node_modules/@scure/bip32": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@scure/bip32/-/bip32-1.1.0.tgz", - "integrity": "sha512-ftTW3kKX54YXLCxH6BB7oEEoJfoE2pIgw7MINKAs5PsS6nqKPuKk1haTF/EuHmYqG330t5GSrdmtRuHaY1a62Q==", + "node_modules/@nomicfoundation/ethereumjs-block": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-block/-/ethereumjs-block-5.0.2.tgz", + "integrity": "sha512-hSe6CuHI4SsSiWWjHDIzWhSiAVpzMUcDRpWYzN0T9l8/Rz7xNn3elwVOJ/tAyS0LqL6vitUD78Uk7lQDXZun7Q==", "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], "dependencies": { - "@noble/hashes": "~1.1.1", - "@noble/secp256k1": "~1.6.0", - "@scure/base": "~1.1.0" + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "ethereum-cryptography": "0.1.3", + "ethers": "^5.7.1" + }, + "engines": { + "node": ">=14" } }, - "node_modules/@scure/bip39": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@scure/bip39/-/bip39-1.1.0.tgz", - "integrity": "sha512-pwrPOS16VeTKg98dYXQyIjJEcWfz7/1YJIwxUEPFfQPtc86Ym/1sVgQ2RLoD43AazMk2l/unK4ITySSpW2+82w==", + "node_modules/@nomicfoundation/ethereumjs-block/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], "dependencies": { - "@noble/hashes": "~1.1.1", - "@scure/base": "~1.1.0" - } - }, - "node_modules/@sentry/core": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/core/-/core-5.30.0.tgz", + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-blockchain": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-blockchain/-/ethereumjs-blockchain-7.0.2.tgz", + "integrity": "sha512-8UUsSXJs+MFfIIAKdh3cG16iNmWzWC/91P40sazNvrqhhdR/RtGDlFk2iFTGbBAZPs2+klZVzhRX8m2wvuvz3w==", + "dev": true, + "dependencies": { + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-ethash": "3.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "abstract-level": "^1.0.3", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "level": "^8.0.0", + "lru-cache": "^5.1.1", + "memory-level": "^1.0.0" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-blockchain/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-common": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-common/-/ethereumjs-common-4.0.2.tgz", + "integrity": "sha512-I2WGP3HMGsOoycSdOTSqIaES0ughQTueOsddJ36aYVpI3SN8YSusgRFLwzDJwRFVIYDKx/iJz0sQ5kBHVgdDwg==", + "dev": true, + "dependencies": { + "@nomicfoundation/ethereumjs-util": "9.0.2", + "crc-32": "^1.2.0" + } + }, + "node_modules/@nomicfoundation/ethereumjs-ethash": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-ethash/-/ethereumjs-ethash-3.0.2.tgz", + "integrity": "sha512-8PfoOQCcIcO9Pylq0Buijuq/O73tmMVURK0OqdjhwqcGHYC2PwhbajDh7GZ55ekB0Px197ajK3PQhpKoiI/UPg==", + "dev": true, + "dependencies": { + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "abstract-level": "^1.0.3", + "bigint-crypto-utils": "^3.0.23", + "ethereum-cryptography": "0.1.3" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-ethash/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-evm": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-evm/-/ethereumjs-evm-2.0.2.tgz", + "integrity": "sha512-rBLcUaUfANJxyOx9HIdMX6uXGin6lANCulIm/pjMgRqfiCRMZie3WKYxTSd8ZE/d+qT+zTedBF4+VHTdTSePmQ==", + "dev": true, + "dependencies": { + "@ethersproject/providers": "^5.7.1", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "mcl-wasm": "^0.7.1", + "rustbn.js": "~0.2.0" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-evm/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-rlp": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-rlp/-/ethereumjs-rlp-5.0.2.tgz", + "integrity": "sha512-QwmemBc+MMsHJ1P1QvPl8R8p2aPvvVcKBbvHnQOKBpBztEo0omN0eaob6FeZS/e3y9NSe+mfu3nNFBHszqkjTA==", + "dev": true, + "bin": { + "rlp": "bin/rlp" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-statemanager": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-statemanager/-/ethereumjs-statemanager-2.0.2.tgz", + "integrity": "sha512-dlKy5dIXLuDubx8Z74sipciZnJTRSV/uHG48RSijhgm1V7eXYFC567xgKtsKiVZB1ViTP9iFL4B6Je0xD6X2OA==", + "dev": true, + "dependencies": { + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "ethers": "^5.7.1", + "js-sdsl": "^4.1.4" + } + }, + "node_modules/@nomicfoundation/ethereumjs-statemanager/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-trie": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-trie/-/ethereumjs-trie-6.0.2.tgz", + "integrity": "sha512-yw8vg9hBeLYk4YNg5MrSJ5H55TLOv2FSWUTROtDtTMMmDGROsAu+0tBjiNGTnKRi400M6cEzoFfa89Fc5k8NTQ==", + "dev": true, + "dependencies": { + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "@types/readable-stream": "^2.3.13", + "ethereum-cryptography": "0.1.3", + "readable-stream": "^3.6.0" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-trie/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-tx": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-tx/-/ethereumjs-tx-5.0.2.tgz", + "integrity": "sha512-T+l4/MmTp7VhJeNloMkM+lPU3YMUaXdcXgTGCf8+ZFvV9NYZTRLFekRwlG6/JMmVfIfbrW+dRRJ9A6H5Q/Z64g==", + "dev": true, + "dependencies": { + "@chainsafe/ssz": "^0.9.2", + "@ethersproject/providers": "^5.7.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "ethereum-cryptography": "0.1.3" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-tx/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-util": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-util/-/ethereumjs-util-9.0.2.tgz", + "integrity": "sha512-4Wu9D3LykbSBWZo8nJCnzVIYGvGCuyiYLIJa9XXNVt1q1jUzHdB+sJvx95VGCpPkCT+IbLecW6yfzy3E1bQrwQ==", + "dev": true, + "dependencies": { + "@chainsafe/ssz": "^0.10.0", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "ethereum-cryptography": "0.1.3" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-util/node_modules/@chainsafe/persistent-merkle-tree": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.5.0.tgz", + "integrity": "sha512-l0V1b5clxA3iwQLXP40zYjyZYospQLZXzBVIhhr9kDg/1qHZfzzHw0jj4VPBijfYCArZDlPkRi1wZaV2POKeuw==", + "dev": true, + "dependencies": { + "@chainsafe/as-sha256": "^0.3.1" + } + }, + "node_modules/@nomicfoundation/ethereumjs-util/node_modules/@chainsafe/ssz": { + "version": "0.10.2", + "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.10.2.tgz", + "integrity": "sha512-/NL3Lh8K+0q7A3LsiFq09YXS9fPE+ead2rr7vM2QK8PLzrNsw3uqrif9bpRX5UxgeRjM+vYi+boCM3+GM4ovXg==", + "dev": true, + "dependencies": { + "@chainsafe/as-sha256": "^0.3.1", + "@chainsafe/persistent-merkle-tree": "^0.5.0" + } + }, + "node_modules/@nomicfoundation/ethereumjs-util/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/ethereumjs-vm": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-vm/-/ethereumjs-vm-7.0.2.tgz", + "integrity": "sha512-Bj3KZT64j54Tcwr7Qm/0jkeZXJMfdcAtRBedou+Hx0dPOSIgqaIr0vvLwP65TpHbak2DmAq+KJbW2KNtIoFwvA==", + "dev": true, + "dependencies": { + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-blockchain": "7.0.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-evm": "2.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-statemanager": "2.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "mcl-wasm": "^0.7.1", + "rustbn.js": "~0.2.0" + }, + "engines": { + "node": ">=14" + } + }, + "node_modules/@nomicfoundation/ethereumjs-vm/node_modules/ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "dependencies": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer/-/solidity-analyzer-0.1.1.tgz", + "integrity": "sha512-1LMtXj1puAxyFusBgUIy5pZk3073cNXYnXUpuNKFghHbIit/xZgbk0AokpUADbNm3gyD6bFWl3LRFh3dhVdREg==", + "dev": true, + "engines": { + "node": ">= 12" + }, + "optionalDependencies": { + "@nomicfoundation/solidity-analyzer-darwin-arm64": "0.1.1", + "@nomicfoundation/solidity-analyzer-darwin-x64": "0.1.1", + "@nomicfoundation/solidity-analyzer-freebsd-x64": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-arm64-musl": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-x64-gnu": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-x64-musl": "0.1.1", + "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": "0.1.1", + "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": "0.1.1", + "@nomicfoundation/solidity-analyzer-win32-x64-msvc": "0.1.1" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-darwin-arm64": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-arm64/-/solidity-analyzer-darwin-arm64-0.1.1.tgz", + "integrity": "sha512-KcTodaQw8ivDZyF+D76FokN/HdpgGpfjc/gFCImdLUyqB6eSWVaZPazMbeAjmfhx3R0zm/NYVzxwAokFKgrc0w==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-darwin-x64": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-x64/-/solidity-analyzer-darwin-x64-0.1.1.tgz", + "integrity": "sha512-XhQG4BaJE6cIbjAVtzGOGbK3sn1BO9W29uhk9J8y8fZF1DYz0Doj8QDMfpMu+A6TjPDs61lbsmeYodIDnfveSA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-freebsd-x64": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-freebsd-x64/-/solidity-analyzer-freebsd-x64-0.1.1.tgz", + "integrity": "sha512-GHF1VKRdHW3G8CndkwdaeLkVBi5A9u2jwtlS7SLhBc8b5U/GcoL39Q+1CSO3hYqePNP+eV5YI7Zgm0ea6kMHoA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-linux-arm64-gnu": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-gnu/-/solidity-analyzer-linux-arm64-gnu-0.1.1.tgz", + "integrity": "sha512-g4Cv2fO37ZsUENQ2vwPnZc2zRenHyAxHcyBjKcjaSmmkKrFr64yvzeNO8S3GBFCo90rfochLs99wFVGT/0owpg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-linux-arm64-musl": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-musl/-/solidity-analyzer-linux-arm64-musl-0.1.1.tgz", + "integrity": "sha512-WJ3CE5Oek25OGE3WwzK7oaopY8xMw9Lhb0mlYuJl/maZVo+WtP36XoQTb7bW/i8aAdHW5Z+BqrHMux23pvxG3w==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-linux-x64-gnu": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-gnu/-/solidity-analyzer-linux-x64-gnu-0.1.1.tgz", + "integrity": "sha512-5WN7leSr5fkUBBjE4f3wKENUy9HQStu7HmWqbtknfXkkil+eNWiBV275IOlpXku7v3uLsXTOKpnnGHJYI2qsdA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-linux-x64-musl": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-musl/-/solidity-analyzer-linux-x64-musl-0.1.1.tgz", + "integrity": "sha512-KdYMkJOq0SYPQMmErv/63CwGwMm5XHenEna9X9aB8mQmhDBrYrlAOSsIPgFCUSL0hjxE3xHP65/EPXR/InD2+w==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-win32-arm64-msvc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-arm64-msvc/-/solidity-analyzer-win32-arm64-msvc-0.1.1.tgz", + "integrity": "sha512-VFZASBfl4qiBYwW5xeY20exWhmv6ww9sWu/krWSesv3q5hA0o1JuzmPHR4LPN6SUZj5vcqci0O6JOL8BPw+APg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-win32-ia32-msvc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-ia32-msvc/-/solidity-analyzer-win32-ia32-msvc-0.1.1.tgz", + "integrity": "sha512-JnFkYuyCSA70j6Si6cS1A9Gh1aHTEb8kOTBApp/c7NRTFGNMH8eaInKlyuuiIbvYFhlXW4LicqyYuWNNq9hkpQ==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nomicfoundation/solidity-analyzer-win32-x64-msvc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-x64-msvc/-/solidity-analyzer-win32-x64-msvc-0.1.1.tgz", + "integrity": "sha512-HrVJr6+WjIXGnw3Q9u6KQcbZCtk0caVWhCdFADySvRyUxJ8PnzlaP+MhwNE8oyT8OZ6ejHBRrrgjSqDCFXGirw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@scure/base": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@scure/base/-/base-1.1.1.tgz", + "integrity": "sha512-ZxOhsSyxYwLJj3pLZCefNitxsj093tb2vq90mp2txoYeBqbcjDjqFhyM8eUjq/uFm6zJ+mUuqxlS2FkuSY1MTA==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + ] + }, + "node_modules/@scure/bip32": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@scure/bip32/-/bip32-1.1.0.tgz", + "integrity": "sha512-ftTW3kKX54YXLCxH6BB7oEEoJfoE2pIgw7MINKAs5PsS6nqKPuKk1haTF/EuHmYqG330t5GSrdmtRuHaY1a62Q==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + ], + "dependencies": { + "@noble/hashes": "~1.1.1", + "@noble/secp256k1": "~1.6.0", + "@scure/base": "~1.1.0" + } + }, + "node_modules/@scure/bip39": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@scure/bip39/-/bip39-1.1.0.tgz", + "integrity": "sha512-pwrPOS16VeTKg98dYXQyIjJEcWfz7/1YJIwxUEPFfQPtc86Ym/1sVgQ2RLoD43AazMk2l/unK4ITySSpW2+82w==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + ], + "dependencies": { + "@noble/hashes": "~1.1.1", + "@scure/base": "~1.1.0" + } + }, + "node_modules/@sentry/core": { + "version": "5.30.0", + "resolved": "https://registry.npmjs.org/@sentry/core/-/core-5.30.0.tgz", "integrity": "sha512-TmfrII8w1PQZSZgPpUESqjB+jC6MvZJZdLtE/0hZ+SrnKhW3x5WlYLvTXZpcWePYBku7rl2wn1RZu6uT0qCTeg==", "dev": true, "dependencies": { @@ -721,44 +1598,12 @@ "node": ">=6" } }, - "node_modules/@solidity-parser/parser": { - "version": "0.14.3", - "resolved": "https://registry.npmjs.org/@solidity-parser/parser/-/parser-0.14.3.tgz", - "integrity": "sha512-29g2SZ29HtsqA58pLCtopI1P/cPy5/UAzlcAXO6T/CNJimG6yA8kx4NaseMyJULiC+TEs02Y9/yeHzClqoA0hw==", - "dev": true, - "dependencies": { - "antlr4ts": "^0.5.0-alpha.4" - } - }, - "node_modules/@types/abstract-leveldown": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@types/abstract-leveldown/-/abstract-leveldown-7.2.0.tgz", - "integrity": "sha512-q5veSX6zjUy/DlDhR4Y4cU0k2Ar+DT2LUraP00T19WLmTO6Se1djepCCaqU6nQrwcJ5Hyo/CWqxTzrrFg8eqbQ==", - "dev": true - }, "node_modules/@types/bn.js": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-5.1.0.tgz", - "integrity": "sha512-QSSVYj7pYFN49kW77o2s9xTCwZ8F2xLbjLLSEVh8D2F4JUhZtPAGOFLTD+ffqksBx/u4cE/KImFjyhqCjn/LIA==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/level-errors": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/level-errors/-/level-errors-3.0.0.tgz", - "integrity": "sha512-/lMtoq/Cf/2DVOm6zE6ORyOM+3ZVm/BvzEZVxUhf6bgh8ZHglXlBqxbxSlJeVp8FCbD3IVvk/VbsaNmDjrQvqQ==", - "dev": true - }, - "node_modules/@types/levelup": { - "version": "4.3.3", - "resolved": "https://registry.npmjs.org/@types/levelup/-/levelup-4.3.3.tgz", - "integrity": "sha512-K+OTIjJcZHVlZQN1HmU64VtrC0jC3dXWQozuEIR9zVvltIk90zaGPM2AgT+fIkChpzHhFE3YnvFLCbLtzAmexA==", + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-5.1.5.tgz", + "integrity": "sha512-V46N0zwKRF5Q00AZ6hWtN0T8gGmDUaUzLWQvHFo5yThtVwK/VCenFY3wXVbOvNfajEpsTfQM4IN9k/d6gUVX3A==", "dev": true, "dependencies": { - "@types/abstract-leveldown": "*", - "@types/level-errors": "*", "@types/node": "*" } }, @@ -783,6 +1628,22 @@ "@types/node": "*" } }, + "node_modules/@types/readable-stream": { + "version": "2.3.15", + "resolved": "https://registry.npmjs.org/@types/readable-stream/-/readable-stream-2.3.15.tgz", + "integrity": "sha512-oM5JSKQCcICF1wvGgmecmHldZ48OZamtMxcGGVICOJA8o8cahXC1zEVAif8iwoc5j8etxFaRFnf095+CDsuoFQ==", + "dev": true, + "dependencies": { + "@types/node": "*", + "safe-buffer": "~5.1.1" + } + }, + "node_modules/@types/readable-stream/node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + }, "node_modules/@types/secp256k1": { "version": "4.0.3", "resolved": "https://registry.npmjs.org/@types/secp256k1/-/secp256k1-4.0.3.tgz", @@ -798,32 +1659,22 @@ "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", "dev": true }, - "node_modules/abort-controller": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", - "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", - "dev": true, - "dependencies": { - "event-target-shim": "^5.0.0" - }, - "engines": { - "node": ">=6.5" - } - }, - "node_modules/abstract-leveldown": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/abstract-leveldown/-/abstract-leveldown-6.3.0.tgz", - "integrity": "sha512-TU5nlYgta8YrBMNpc9FwQzRbiXsj49gsALsXadbGHt9CROPzX5fB0rWDR5mtdpOOKa5XqRFpbj1QroPAoPzVjQ==", + "node_modules/abstract-level": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/abstract-level/-/abstract-level-1.0.3.tgz", + "integrity": "sha512-t6jv+xHy+VYwc4xqZMn2Pa9DjcdzvzZmQGRjTFc8spIbRGHgBrEKbPq+rYXc7CCo0lxgYvSgKVg9qZAhpVQSjA==", "dev": true, "dependencies": { - "buffer": "^5.5.0", - "immediate": "^3.2.3", - "level-concat-iterator": "~2.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" + "buffer": "^6.0.3", + "catering": "^2.1.0", + "is-buffer": "^2.0.5", + "level-supports": "^4.0.0", + "level-transcoder": "^1.0.1", + "module-error": "^1.0.1", + "queue-microtask": "^1.2.3" }, "engines": { - "node": ">=6" + "node": ">=12" } }, "node_modules/adm-zip": { @@ -835,6 +1686,12 @@ "node": ">=0.3.0" } }, + "node_modules/aes-js": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/aes-js/-/aes-js-3.0.0.tgz", + "integrity": "sha512-H7wUZRn8WpTq9jocdxQ2c8x2sKo9ZVmzfRE13GiNJXfp7NcKYEdvl3vspKjXox6RIG2VtaRe4JFvxG4rqp2Zuw==", + "dev": true + }, "node_modules/agent-base": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", @@ -905,12 +1762,6 @@ "node": ">=4" } }, - "node_modules/antlr4ts": { - "version": "0.5.0-alpha.4", - "resolved": "https://registry.npmjs.org/antlr4ts/-/antlr4ts-0.5.0-alpha.4.tgz", - "integrity": "sha512-WPQDt1B74OfPv/IMS2ekXAKkTZIHl88uMetg6q3OTqgFxZ/dxDXI0EWLyZid/1Pe6hTftyg5N7gel5wNAGxXyQ==", - "dev": true - }, "node_modules/anymatch": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", @@ -930,24 +1781,6 @@ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", "dev": true }, - "node_modules/async": { - "version": "2.6.4", - "resolved": "https://registry.npmjs.org/async/-/async-2.6.4.tgz", - "integrity": "sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA==", - "dev": true, - "dependencies": { - "lodash": "^4.17.14" - } - }, - "node_modules/async-eventemitter": { - "version": "0.2.4", - "resolved": "https://registry.npmjs.org/async-eventemitter/-/async-eventemitter-0.2.4.tgz", - "integrity": "sha512-pd20BwL7Yt1zwDFy+8MX8F1+WCT8aQeKj0kQnTrH9WaeRETlRamVhD0JtRPmrV4GfOJ2F9CvdQkZeZhnh2TuHw==", - "dev": true, - "dependencies": { - "async": "^2.4.0" - } - }, "node_modules/balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -983,6 +1816,21 @@ } ] }, + "node_modules/bech32": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/bech32/-/bech32-1.1.4.tgz", + "integrity": "sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==", + "dev": true + }, + "node_modules/bigint-crypto-utils": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/bigint-crypto-utils/-/bigint-crypto-utils-3.3.0.tgz", + "integrity": "sha512-jOTSb+drvEDxEq6OuUybOAv/xxoh3cuYRUIPyu8sSHQNKM303UQ2R1DAo45o1AkcIXw6fzbaFI1+xGGdaXs2lg==", + "dev": true, + "engines": { + "node": ">=14.0.0" + } + }, "node_modules/binary-extensions": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", @@ -1032,6 +1880,18 @@ "integrity": "sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w==", "dev": true }, + "node_modules/browser-level": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browser-level/-/browser-level-1.0.1.tgz", + "integrity": "sha512-XECYKJ+Dbzw0lbydyQuJzwNXtOpbMSq737qxJN11sIRTErOMShvDpbzTlgju7orJKvx4epULolZAuJGLzCmWRQ==", + "dev": true, + "dependencies": { + "abstract-level": "^1.0.2", + "catering": "^2.1.1", + "module-error": "^1.0.2", + "run-parallel-limit": "^1.1.0" + } + }, "node_modules/browser-stdout": { "version": "1.3.1", "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", @@ -1079,9 +1939,9 @@ } }, "node_modules/buffer": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", - "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", + "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", "dev": true, "funding": [ { @@ -1099,7 +1959,7 @@ ], "dependencies": { "base64-js": "^1.3.1", - "ieee754": "^1.1.13" + "ieee754": "^1.2.1" } }, "node_modules/buffer-from": { @@ -1108,15 +1968,6 @@ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", "dev": true }, - "node_modules/buffer-xor": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-2.0.2.tgz", - "integrity": "sha512-eHslX0bin3GB+Lx2p7lEYRShRewuNZL3fUl4qlVJGGiwoPGftmt8JQgk2Y9Ji5/01TnVDo33E5b5O3vUB1HdqQ==", - "dev": true, - "dependencies": { - "safe-buffer": "^5.1.1" - } - }, "node_modules/bytes": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", @@ -1126,19 +1977,6 @@ "node": ">= 0.8" } }, - "node_modules/call-bind": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", - "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", - "dev": true, - "dependencies": { - "function-bind": "^1.1.1", - "get-intrinsic": "^1.0.2" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/camelcase": { "version": "6.3.0", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", @@ -1151,6 +1989,24 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/case": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/case/-/case-1.6.3.tgz", + "integrity": "sha512-mzDSXIPaFwVDvZAHqZ9VlbyF4yyXRuX6IvB06WvPYkqJVO24kX1PPhv9bfpKNFZyxYFmmgo03HUiD8iklmJYRQ==", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/catering": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/catering/-/catering-2.1.1.tgz", + "integrity": "sha512-K7Qy8O9p76sL3/3m7/zLKbRkyOlSZAgzEaLhyj2mXS8PsCud2Eo4hAb8aLtZqHh0QGqLcb9dlJSu6lHRVENm1w==", + "dev": true, + "engines": { + "node": ">=6" + } + }, "node_modules/chalk": { "version": "2.4.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", @@ -1208,6 +2064,23 @@ "safe-buffer": "^5.0.1" } }, + "node_modules/classic-level": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/classic-level/-/classic-level-1.3.0.tgz", + "integrity": "sha512-iwFAJQYtqRTRM0F6L8h4JCt00ZSGdOyqh7yVrhhjrOpFhmBjNlRUey64MCiyo6UmQHMJ+No3c81nujPv+n9yrg==", + "dev": true, + "hasInstallScript": true, + "dependencies": { + "abstract-level": "^1.0.2", + "catering": "^2.1.0", + "module-error": "^1.0.1", + "napi-macros": "^2.2.2", + "node-gyp-build": "^4.3.0" + }, + "engines": { + "node": ">=12" + } + }, "node_modules/clean-stack": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", @@ -1270,17 +2143,6 @@ "node": ">= 0.6" } }, - "node_modules/core-js-pure": { - "version": "3.23.5", - "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.23.5.tgz", - "integrity": "sha512-8t78LdpKSuCq4pJYCYk8hl7XEkAX+BP16yRIwL3AanTksxuEf7CM83vRyctmiEL8NDZ3jpUcv56fk9/zG3aIuw==", - "dev": true, - "hasInstallScript": true, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/core-js" - } - }, "node_modules/crc-32": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", @@ -1349,35 +2211,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/deferred-leveldown": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/deferred-leveldown/-/deferred-leveldown-5.3.0.tgz", - "integrity": "sha512-a59VOT+oDy7vtAbLRCZwWgxu2BaCfd5Hk7wxJd48ei7I+nsg8Orlb9CLG0PMZienk9BSUKgeAqkO2+Lw+1+Ukw==", - "dev": true, - "dependencies": { - "abstract-leveldown": "~6.2.1", - "inherits": "^2.0.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/deferred-leveldown/node_modules/abstract-leveldown": { - "version": "6.2.3", - "resolved": "https://registry.npmjs.org/abstract-leveldown/-/abstract-leveldown-6.2.3.tgz", - "integrity": "sha512-BsLm5vFMRUrrLeCcRc+G0t2qOaTzpoJQLOubq2XM72eNpjF5UdU5o/5NvlNhx95XHcAvcl8OMXr4mlg/fRgUXQ==", - "dev": true, - "dependencies": { - "buffer": "^5.5.0", - "immediate": "^3.2.3", - "level-concat-iterator": "~2.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" - }, - "engines": { - "node": ">=6" - } - }, "node_modules/depd": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", @@ -1423,21 +2256,6 @@ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, - "node_modules/encoding-down": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/encoding-down/-/encoding-down-6.3.0.tgz", - "integrity": "sha512-QKrV0iKR6MZVJV08QY0wp1e7vF6QbhnbQhb07bwpEyuz4uZiZgPlEGdkCROuFkUwdxlFaiPIhjyarH1ee/3vhw==", - "dev": true, - "dependencies": { - "abstract-leveldown": "^6.2.1", - "inherits": "^2.0.3", - "level-codec": "^9.0.0", - "level-errors": "^2.0.0" - }, - "engines": { - "node": ">=6" - } - }, "node_modules/enquirer": { "version": "2.3.6", "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", @@ -1459,18 +2277,6 @@ "node": ">=6" } }, - "node_modules/errno": { - "version": "0.1.8", - "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.8.tgz", - "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==", - "dev": true, - "dependencies": { - "prr": "~1.0.1" - }, - "bin": { - "errno": "cli.js" - } - }, "node_modules/escalade": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", @@ -1564,43 +2370,52 @@ "rlp": "^2.2.3" } }, - "node_modules/ethereumjs-util": { - "version": "7.1.5", - "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-7.1.5.tgz", - "integrity": "sha512-SDl5kKrQAudFBUe5OJM9Ac6WmMyYmXX/6sTmLZ3ffG2eY6ZIGBes3pEDxNN6V72WyOw4CPD5RomKdsa8DAAwLg==", - "dev": true, - "dependencies": { - "@types/bn.js": "^5.1.0", - "bn.js": "^5.1.2", - "create-hash": "^1.1.2", - "ethereum-cryptography": "^0.1.3", - "rlp": "^2.2.4" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/ethereumjs-util/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "node_modules/ethers": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/ethers/-/ethers-5.7.2.tgz", + "integrity": "sha512-wswUsmWo1aOK8rR7DIKiWSw9DbLWe6x98Jrn8wcTflTVvaXhAMaB5zGAXy0GYQEQp9iO1iSHWVyARQm11zUtyg==", "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" + }, + { + "type": "individual", + "url": "https://www.buymeacoffee.com/ricmoo" + } + ], "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" + "@ethersproject/abi": "5.7.0", + "@ethersproject/abstract-provider": "5.7.0", + "@ethersproject/abstract-signer": "5.7.0", + "@ethersproject/address": "5.7.0", + "@ethersproject/base64": "5.7.0", + "@ethersproject/basex": "5.7.0", + "@ethersproject/bignumber": "5.7.0", + "@ethersproject/bytes": "5.7.0", + "@ethersproject/constants": "5.7.0", + "@ethersproject/contracts": "5.7.0", + "@ethersproject/hash": "5.7.0", + "@ethersproject/hdnode": "5.7.0", + "@ethersproject/json-wallets": "5.7.0", + "@ethersproject/keccak256": "5.7.0", + "@ethersproject/logger": "5.7.0", + "@ethersproject/networks": "5.7.1", + "@ethersproject/pbkdf2": "5.7.0", + "@ethersproject/properties": "5.7.0", + "@ethersproject/providers": "5.7.2", + "@ethersproject/random": "5.7.0", + "@ethersproject/rlp": "5.7.0", + "@ethersproject/sha2": "5.7.0", + "@ethersproject/signing-key": "5.7.0", + "@ethersproject/solidity": "5.7.0", + "@ethersproject/strings": "5.7.0", + "@ethersproject/transactions": "5.7.0", + "@ethersproject/units": "5.7.0", + "@ethersproject/wallet": "5.7.0", + "@ethersproject/web": "5.7.1", + "@ethersproject/wordlists": "5.7.0" } }, "node_modules/ethjs-util": { @@ -1617,15 +2432,6 @@ "npm": ">=3" } }, - "node_modules/event-target-shim": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", - "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", - "dev": true, - "engines": { - "node": ">=6" - } - }, "node_modules/evp_bytestokey": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", @@ -1729,12 +2535,6 @@ "node": "^8.16.0 || ^10.6.0 || >=11.0.0" } }, - "node_modules/function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", - "dev": true - }, "node_modules/functional-red-black-tree": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", @@ -1750,20 +2550,6 @@ "node": "6.* || 8.* || >= 10.*" } }, - "node_modules/get-intrinsic": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz", - "integrity": "sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA==", - "dev": true, - "dependencies": { - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/glob": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", @@ -1803,23 +2589,27 @@ "dev": true }, "node_modules/hardhat": { - "version": "2.10.1", - "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.10.1.tgz", - "integrity": "sha512-0FN9TyCtn7Lt25SB2ei2G7nA2rZjP+RN6MvFOm+zYwherxLZNo6RbD8nDz88eCbhRapevmXqOiL2nM8INKsjmA==", + "version": "2.19.0", + "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.19.0.tgz", + "integrity": "sha512-kMpwovOEfrFRQXEopCP+JTcKVwSYVj8rnXE0LynxDqnh06yvyKCQknmXL6IVYTHQL6Csysc/yNbCHQbjSeJGpA==", "dev": true, "dependencies": { - "@ethereumjs/block": "^3.6.2", - "@ethereumjs/blockchain": "^5.5.2", - "@ethereumjs/common": "^2.6.4", - "@ethereumjs/tx": "^3.5.1", - "@ethereumjs/vm": "^5.9.0", "@ethersproject/abi": "^5.1.2", "@metamask/eth-sig-util": "^4.0.0", + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-blockchain": "7.0.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-evm": "2.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-statemanager": "2.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "@nomicfoundation/ethereumjs-vm": "7.0.2", + "@nomicfoundation/solidity-analyzer": "^0.1.0", "@sentry/node": "^5.18.1", - "@solidity-parser/parser": "^0.14.2", "@types/bn.js": "^5.1.0", "@types/lru-cache": "^5.1.0", - "abort-controller": "^3.0.0", "adm-zip": "^0.4.16", "aggregate-error": "^3.0.0", "ansi-escapes": "^4.3.0", @@ -1831,37 +2621,30 @@ "env-paths": "^2.2.0", "ethereum-cryptography": "^1.0.3", "ethereumjs-abi": "^0.6.8", - "ethereumjs-util": "^7.1.4", "find-up": "^2.1.0", "fp-ts": "1.19.3", "fs-extra": "^7.0.1", "glob": "7.2.0", "immutable": "^4.0.0-rc.12", "io-ts": "1.10.4", + "keccak": "^3.0.2", "lodash": "^4.17.11", - "merkle-patricia-tree": "^4.2.4", "mnemonist": "^0.38.0", "mocha": "^10.0.0", "p-map": "^4.0.0", - "qs": "^6.7.0", "raw-body": "^2.4.1", "resolve": "1.17.0", "semver": "^6.3.0", - "slash": "^3.0.0", "solc": "0.7.3", "source-map-support": "^0.5.13", "stacktrace-parser": "^0.1.10", - "true-case-path": "^2.2.1", "tsort": "0.0.1", - "undici": "^5.4.0", + "undici": "^5.14.0", "uuid": "^8.3.2", "ws": "^7.4.6" }, "bin": { - "hardhat": "internal/cli/cli.js" - }, - "engines": { - "node": "^14.0.0 || ^16.0.0 || ^18.0.0" + "hardhat": "internal/cli/bootstrap.js" }, "peerDependencies": { "ts-node": "*", @@ -1876,18 +2659,6 @@ } } }, - "node_modules/has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dev": true, - "dependencies": { - "function-bind": "^1.1.1" - }, - "engines": { - "node": ">= 0.4.0" - } - }, "node_modules/has-flag": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", @@ -1897,18 +2668,6 @@ "node": ">=4" } }, - "node_modules/has-symbols": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", - "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", - "dev": true, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/hash-base": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.1.0.tgz", @@ -2014,12 +2773,6 @@ } ] }, - "node_modules/immediate": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.3.0.tgz", - "integrity": "sha512-HR7EVodfFUdQCTIeySw+WDRFJlPcLOJbXfwwZ7Oom6tjsvZ3bOkCDJHehQC3nxJrv7+f9XecwazynjU8e4Vw3Q==", - "dev": true - }, "node_modules/immutable": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.1.0.tgz", @@ -2072,6 +2825,29 @@ "node": ">=8" } }, + "node_modules/is-buffer": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", + "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "engines": { + "node": ">=4" + } + }, "node_modules/is-extglob": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", @@ -2142,6 +2918,16 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/js-sdsl": { + "version": "4.4.2", + "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.4.2.tgz", + "integrity": "sha512-dwXFwByc/ajSV6m5bcKAPwe4yDDF6D614pxmIi5odytzxRlwqF6nwoiCek80Ixc7Cvma5awClxrzFtxCQvcM8w==", + "dev": true, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/js-sdsl" + } + }, "node_modules/js-sha3": { "version": "0.8.0", "resolved": "https://registry.npmjs.org/js-sha3/-/js-sha3-0.8.0.tgz", @@ -2193,119 +2979,43 @@ "graceful-fs": "^4.1.9" } }, - "node_modules/level-codec": { - "version": "9.0.2", - "resolved": "https://registry.npmjs.org/level-codec/-/level-codec-9.0.2.tgz", - "integrity": "sha512-UyIwNb1lJBChJnGfjmO0OR+ezh2iVu1Kas3nvBS/BzGnx79dv6g7unpKIDNPMhfdTEGoc7mC8uAu51XEtX+FHQ==", - "dev": true, - "dependencies": { - "buffer": "^5.6.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/level-concat-iterator": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/level-concat-iterator/-/level-concat-iterator-2.0.1.tgz", - "integrity": "sha512-OTKKOqeav2QWcERMJR7IS9CUo1sHnke2C0gkSmcR7QuEtFNLLzHQAvnMw8ykvEcv0Qtkg0p7FOwP1v9e5Smdcw==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/level-errors": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/level-errors/-/level-errors-2.0.1.tgz", - "integrity": "sha512-UVprBJXite4gPS+3VznfgDSU8PTRuVX0NXwoWW50KLxd2yw4Y1t2JUR5In1itQnudZqRMT9DlAM3Q//9NCjCFw==", - "dev": true, - "dependencies": { - "errno": "~0.1.1" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/level-iterator-stream": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/level-iterator-stream/-/level-iterator-stream-4.0.2.tgz", - "integrity": "sha512-ZSthfEqzGSOMWoUGhTXdX9jv26d32XJuHz/5YnuHZzH6wldfWMOVwI9TBtKcya4BKTyTt3XVA0A3cF3q5CY30Q==", - "dev": true, - "dependencies": { - "inherits": "^2.0.4", - "readable-stream": "^3.4.0", - "xtend": "^4.0.2" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/level-mem": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/level-mem/-/level-mem-5.0.1.tgz", - "integrity": "sha512-qd+qUJHXsGSFoHTziptAKXoLX87QjR7v2KMbqncDXPxQuCdsQlzmyX+gwrEHhlzn08vkf8TyipYyMmiC6Gobzg==", + "node_modules/level": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/level/-/level-8.0.0.tgz", + "integrity": "sha512-ypf0jjAk2BWI33yzEaaotpq7fkOPALKAgDBxggO6Q9HGX2MRXn0wbP1Jn/tJv1gtL867+YOjOB49WaUF3UoJNQ==", "dev": true, "dependencies": { - "level-packager": "^5.0.3", - "memdown": "^5.0.0" + "browser-level": "^1.0.1", + "classic-level": "^1.2.0" }, "engines": { - "node": ">=6" - } - }, - "node_modules/level-packager": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/level-packager/-/level-packager-5.1.1.tgz", - "integrity": "sha512-HMwMaQPlTC1IlcwT3+swhqf/NUO+ZhXVz6TY1zZIIZlIR0YSn8GtAAWmIvKjNY16ZkEg/JcpAuQskxsXqC0yOQ==", - "dev": true, - "dependencies": { - "encoding-down": "^6.3.0", - "levelup": "^4.3.2" + "node": ">=12" }, - "engines": { - "node": ">=6" + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/level" } }, "node_modules/level-supports": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/level-supports/-/level-supports-1.0.1.tgz", - "integrity": "sha512-rXM7GYnW8gsl1vedTJIbzOrRv85c/2uCMpiiCzO2fndd06U/kUXEEU9evYn4zFggBOg36IsBW8LzqIpETwwQzg==", - "dev": true, - "dependencies": { - "xtend": "^4.0.2" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/level-ws": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/level-ws/-/level-ws-2.0.0.tgz", - "integrity": "sha512-1iv7VXx0G9ec1isqQZ7y5LmoZo/ewAsyDHNA8EFDW5hqH2Kqovm33nSFkSdnLLAK+I5FlT+lo5Cw9itGe+CpQA==", + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/level-supports/-/level-supports-4.0.1.tgz", + "integrity": "sha512-PbXpve8rKeNcZ9C1mUicC9auIYFyGpkV9/i6g76tLgANwWhtG2v7I4xNBUlkn3lE2/dZF3Pi0ygYGtLc4RXXdA==", "dev": true, - "dependencies": { - "inherits": "^2.0.3", - "readable-stream": "^3.1.0", - "xtend": "^4.0.1" - }, "engines": { - "node": ">=6" + "node": ">=12" } }, - "node_modules/levelup": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/levelup/-/levelup-4.4.0.tgz", - "integrity": "sha512-94++VFO3qN95cM/d6eBXvd894oJE0w3cInq9USsyQzzoJxmiYzPAocNcuGCPGGjoXqDVJcr3C1jzt1TSjyaiLQ==", + "node_modules/level-transcoder": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/level-transcoder/-/level-transcoder-1.0.1.tgz", + "integrity": "sha512-t7bFwFtsQeD8cl8NIoQ2iwxA0CL/9IFw7/9gAjOonH0PWTTiRfY7Hq+Ejbsxh86tXobDQ6IOiddjNYIfOBs06w==", "dev": true, "dependencies": { - "deferred-leveldown": "~5.3.0", - "level-errors": "~2.0.0", - "level-iterator-stream": "~4.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" + "buffer": "^6.0.3", + "module-error": "^1.0.1" }, "engines": { - "node": ">=6" + "node": ">=12" } }, "node_modules/locate-path": { @@ -2428,12 +3138,6 @@ "yallist": "^3.0.2" } }, - "node_modules/ltgt": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/ltgt/-/ltgt-2.2.1.tgz", - "integrity": "sha512-AI2r85+4MquTw9ZYqabu4nMwy9Oftlfa/e/52t9IjtfG+mGBbTNdAoZ3RQKLHR6r0wQnwZnPIEh/Ya6XTWAKNA==", - "dev": true - }, "node_modules/mcl-wasm": { "version": "0.7.9", "resolved": "https://registry.npmjs.org/mcl-wasm/-/mcl-wasm-0.7.9.tgz", @@ -2454,45 +3158,20 @@ "safe-buffer": "^5.1.2" } }, - "node_modules/memdown": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/memdown/-/memdown-5.1.0.tgz", - "integrity": "sha512-B3J+UizMRAlEArDjWHTMmadet+UKwHd3UjMgGBkZcKAxAYVPS9o0Yeiha4qvz7iGiL2Sb3igUft6p7nbFWctpw==", - "dev": true, - "dependencies": { - "abstract-leveldown": "~6.2.1", - "functional-red-black-tree": "~1.0.1", - "immediate": "~3.2.3", - "inherits": "~2.0.1", - "ltgt": "~2.2.0", - "safe-buffer": "~5.2.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/memdown/node_modules/abstract-leveldown": { - "version": "6.2.3", - "resolved": "https://registry.npmjs.org/abstract-leveldown/-/abstract-leveldown-6.2.3.tgz", - "integrity": "sha512-BsLm5vFMRUrrLeCcRc+G0t2qOaTzpoJQLOubq2XM72eNpjF5UdU5o/5NvlNhx95XHcAvcl8OMXr4mlg/fRgUXQ==", + "node_modules/memory-level": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/memory-level/-/memory-level-1.0.0.tgz", + "integrity": "sha512-UXzwewuWeHBz5krr7EvehKcmLFNoXxGcvuYhC41tRnkrTbJohtS7kVn9akmgirtRygg+f7Yjsfi8Uu5SGSQ4Og==", "dev": true, "dependencies": { - "buffer": "^5.5.0", - "immediate": "^3.2.3", - "level-concat-iterator": "~2.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" + "abstract-level": "^1.0.0", + "functional-red-black-tree": "^1.0.1", + "module-error": "^1.0.1" }, "engines": { - "node": ">=6" + "node": ">=12" } }, - "node_modules/memdown/node_modules/immediate": { - "version": "3.2.3", - "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.2.3.tgz", - "integrity": "sha512-RrGCXRm/fRVqMIhqXrGEX9rRADavPiDFSoMb/k64i9XMk8uH4r/Omi5Ctierj6XzNecwDbO4WuFbDD1zmpl3Tg==", - "dev": true - }, "node_modules/memorystream": { "version": "0.3.1", "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", @@ -2502,39 +3181,6 @@ "node": ">= 0.10.0" } }, - "node_modules/merkle-patricia-tree": { - "version": "4.2.4", - "resolved": "https://registry.npmjs.org/merkle-patricia-tree/-/merkle-patricia-tree-4.2.4.tgz", - "integrity": "sha512-eHbf/BG6eGNsqqfbLED9rIqbsF4+sykEaBn6OLNs71tjclbMcMOk1tEPmJKcNcNCLkvbpY/lwyOlizWsqPNo8w==", - "dev": true, - "dependencies": { - "@types/levelup": "^4.3.0", - "ethereumjs-util": "^7.1.4", - "level-mem": "^5.0.1", - "level-ws": "^2.0.0", - "readable-stream": "^3.6.0", - "semaphore-async-await": "^1.5.1" - } - }, - "node_modules/miller-rabin": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", - "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", - "dev": true, - "dependencies": { - "bn.js": "^4.0.0", - "brorand": "^1.0.1" - }, - "bin": { - "miller-rabin": "bin/miller-rabin" - } - }, - "node_modules/miller-rabin/node_modules/bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - }, "node_modules/minimalistic-assert": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", @@ -2751,6 +3397,15 @@ "url": "https://github.com/chalk/supports-color?sponsor=1" } }, + "node_modules/module-error": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/module-error/-/module-error-1.0.2.tgz", + "integrity": "sha512-0yuvsqSCv8LbaOKhnsQ/T5JhyFlCYLPXK3U2sgV10zoKQwzs/MyfuQUOZQ1V/6OCOJsK/TRgNVrPuPDqtdMFtA==", + "dev": true, + "engines": { + "node": ">=10" + } + }, "node_modules/ms": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", @@ -2769,6 +3424,12 @@ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" } }, + "node_modules/napi-macros": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/napi-macros/-/napi-macros-2.2.2.tgz", + "integrity": "sha512-hmEVtAGYzVQpCKdbQea4skABsdXW4RUh5t5mJ2zzqowJS2OyXZTU1KhDVFhx+NlWZ4ap9mqR9TcDO3LTTttd+g==", + "dev": true + }, "node_modules/node-addon-api": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-2.0.2.tgz", @@ -2795,15 +3456,6 @@ "node": ">=0.10.0" } }, - "node_modules/object-inspect": { - "version": "1.12.2", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", - "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", - "dev": true, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/obliterator": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/obliterator/-/obliterator-2.0.4.tgz", @@ -2928,26 +3580,25 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, - "node_modules/prr": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", - "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==", - "dev": true - }, - "node_modules/qs": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", - "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", + "node_modules/queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", "dev": true, - "dependencies": { - "side-channel": "^1.0.4" - }, - "engines": { - "node": ">=0.6" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] }, "node_modules/randombytes": { "version": "2.1.0", @@ -3063,6 +3714,29 @@ "rlp": "bin/rlp" } }, + "node_modules/run-parallel-limit": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/run-parallel-limit/-/run-parallel-limit-1.1.0.tgz", + "integrity": "sha512-jJA7irRNM91jaKc3Hcl1npHsFLOXOoTkPCUL1JEa1R82O2miplXXRaGdjW/KM/98YQWDhJLiSs793CnXfblJUw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "queue-microtask": "^1.2.2" + } + }, "node_modules/rustbn.js": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/rustbn.js/-/rustbn.js-0.2.0.tgz", @@ -3116,15 +3790,6 @@ "node": ">=10.0.0" } }, - "node_modules/semaphore-async-await": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/semaphore-async-await/-/semaphore-async-await-1.5.1.tgz", - "integrity": "sha512-b/ptP11hETwYWpeilHXXQiV5UJNJl7ZWWooKRE5eBIYWoom6dZ0SluCIdCtKycsMtZgKWE01/qAw6jblw1YVhg==", - "dev": true, - "engines": { - "node": ">=4.1" - } - }, "node_modules/semver": { "version": "6.3.0", "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", @@ -3168,29 +3833,6 @@ "sha.js": "bin.js" } }, - "node_modules/side-channel": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", - "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.0", - "get-intrinsic": "^1.0.2", - "object-inspect": "^1.9.0" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/slash": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", - "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", - "dev": true, - "engines": { - "node": ">=8" - } - }, "node_modules/solc": { "version": "0.7.3", "resolved": "https://registry.npmjs.org/solc/-/solc-0.7.3.tgz", @@ -3399,12 +4041,6 @@ "node": ">=0.6" } }, - "node_modules/true-case-path": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/true-case-path/-/true-case-path-2.2.1.tgz", - "integrity": "sha512-0z3j8R7MCjy10kc/g+qg7Ln3alJTodw9aDuVWZa3uiWqfuBMKeAeP2ocWcxoyM3D73yz3Jt/Pu4qPr4wHSdB/Q==", - "dev": true - }, "node_modules/tslib": { "version": "1.14.1", "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", @@ -3442,12 +4078,15 @@ } }, "node_modules/undici": { - "version": "5.8.0", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.8.0.tgz", - "integrity": "sha512-1F7Vtcez5w/LwH2G2tGnFIihuWUlc58YidwLiCv+jR2Z50x0tNXpRRw7eOIJ+GvqCqIkg9SB7NWAJ/T9TLfv8Q==", + "version": "5.27.2", + "resolved": "https://registry.npmjs.org/undici/-/undici-5.27.2.tgz", + "integrity": "sha512-iS857PdOEy/y3wlM3yRp+6SNQQ6xU0mmZcwRSriqk+et/cwWAtwmIGf6WkoDN2EK/AMdCO/dfXzIwi+rFMrjjQ==", "dev": true, + "dependencies": { + "@fastify/busboy": "^2.0.0" + }, "engines": { - "node": ">=12.18" + "node": ">=14.0" } }, "node_modules/universalify": { @@ -3566,15 +4205,6 @@ } } }, - "node_modules/xtend": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", - "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", - "dev": true, - "engines": { - "node": ">=0.4" - } - }, "node_modules/y18n": { "version": "5.0.8", "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", @@ -3646,325 +4276,855 @@ } }, "dependencies": { - "@ethereumjs/block": { - "version": "3.6.3", - "resolved": "https://registry.npmjs.org/@ethereumjs/block/-/block-3.6.3.tgz", - "integrity": "sha512-CegDeryc2DVKnDkg5COQrE0bJfw/p0v3GBk2W5/Dj5dOVfEmb50Ux0GLnSPypooLnfqjwFaorGuT9FokWB3GRg==", + "@chainsafe/as-sha256": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@chainsafe/as-sha256/-/as-sha256-0.3.1.tgz", + "integrity": "sha512-hldFFYuf49ed7DAakWVXSJODuq3pzJEguD8tQ7h+sGkM18vja+OFoJI9krnGmgzyuZC2ETX0NOIcCTy31v2Mtg==", + "dev": true + }, + "@chainsafe/persistent-merkle-tree": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.4.2.tgz", + "integrity": "sha512-lLO3ihKPngXLTus/L7WHKaw9PnNJWizlOF1H9NNzHP6Xvh82vzg9F2bzkXhYIFshMZ2gTCEz8tq6STe7r5NDfQ==", "dev": true, "requires": { - "@ethereumjs/common": "^2.6.5", - "@ethereumjs/tx": "^3.5.2", - "ethereumjs-util": "^7.1.5", - "merkle-patricia-tree": "^4.2.4" + "@chainsafe/as-sha256": "^0.3.1" } }, - "@ethereumjs/blockchain": { - "version": "5.5.3", - "resolved": "https://registry.npmjs.org/@ethereumjs/blockchain/-/blockchain-5.5.3.tgz", - "integrity": "sha512-bi0wuNJ1gw4ByNCV56H0Z4Q7D+SxUbwyG12Wxzbvqc89PXLRNR20LBcSUZRKpN0+YCPo6m0XZL/JLio3B52LTw==", + "@chainsafe/ssz": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.9.4.tgz", + "integrity": "sha512-77Qtg2N1ayqs4Bg/wvnWfg5Bta7iy7IRh8XqXh7oNMeP2HBbBwx8m6yTpA8p0EHItWPEBkgZd5S5/LSlp3GXuQ==", "dev": true, "requires": { - "@ethereumjs/block": "^3.6.2", - "@ethereumjs/common": "^2.6.4", - "@ethereumjs/ethash": "^1.1.0", - "debug": "^4.3.3", - "ethereumjs-util": "^7.1.5", - "level-mem": "^5.0.1", - "lru-cache": "^5.1.1", - "semaphore-async-await": "^1.5.1" + "@chainsafe/as-sha256": "^0.3.1", + "@chainsafe/persistent-merkle-tree": "^0.4.2", + "case": "^1.6.3" } }, - "@ethereumjs/common": { - "version": "2.6.5", - "resolved": "https://registry.npmjs.org/@ethereumjs/common/-/common-2.6.5.tgz", - "integrity": "sha512-lRyVQOeCDaIVtgfbowla32pzeDv2Obr8oR8Put5RdUBNRGr1VGPGQNGP6elWIpgK3YdpzqTOh4GyUGOureVeeA==", + "@ethersproject/abi": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/abi/-/abi-5.7.0.tgz", + "integrity": "sha512-351ktp42TiRcYB3H1OP8yajPeAQstMW/yCFokj/AthP9bLHzQFPlOrxOcwYEDkUAICmOHljvN4K39OMTMUa9RA==", "dev": true, "requires": { - "crc-32": "^1.2.0", - "ethereumjs-util": "^7.1.5" + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" } }, - "@ethereumjs/ethash": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@ethereumjs/ethash/-/ethash-1.1.0.tgz", - "integrity": "sha512-/U7UOKW6BzpA+Vt+kISAoeDie1vAvY4Zy2KF5JJb+So7+1yKmJeJEHOGSnQIj330e9Zyl3L5Nae6VZyh2TJnAA==", + "@ethersproject/abstract-provider": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/abstract-provider/-/abstract-provider-5.7.0.tgz", + "integrity": "sha512-R41c9UkchKCpAqStMYUpdunjo3pkEvZC3FAwZn5S5MGbXoMQOHIdHItezTETxAO5bevtMApSyEhn9+CHcDsWBw==", "dev": true, "requires": { - "@ethereumjs/block": "^3.5.0", - "@types/levelup": "^4.3.0", - "buffer-xor": "^2.0.1", - "ethereumjs-util": "^7.1.1", - "miller-rabin": "^4.0.0" + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/networks": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/web": "^5.7.0" } }, - "@ethereumjs/tx": { - "version": "3.5.2", - "resolved": "https://registry.npmjs.org/@ethereumjs/tx/-/tx-3.5.2.tgz", - "integrity": "sha512-gQDNJWKrSDGu2w7w0PzVXVBNMzb7wwdDOmOqczmhNjqFxFuIbhVJDwiGEnxFNC2/b8ifcZzY7MLcluizohRzNw==", + "@ethersproject/abstract-signer": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/abstract-signer/-/abstract-signer-5.7.0.tgz", + "integrity": "sha512-a16V8bq1/Cz+TGCkE2OPMTOUDLS3grCpdjoJCYNnVBbdYEMSgKrU0+B90s8b6H+ByYTBZN7a3g76jdIJi7UfKQ==", "dev": true, "requires": { - "@ethereumjs/common": "^2.6.4", - "ethereumjs-util": "^7.1.5" + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0" } }, - "@ethereumjs/vm": { - "version": "5.9.3", - "resolved": "https://registry.npmjs.org/@ethereumjs/vm/-/vm-5.9.3.tgz", - "integrity": "sha512-Ha04TeF8goEglr8eL7hkkYyjhzdZS0PsoRURzYlTF6I0VVId5KjKb0N7MrA8GMgheN+UeTncfTgYx52D/WhEmg==", + "@ethersproject/address": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/address/-/address-5.7.0.tgz", + "integrity": "sha512-9wYhYt7aghVGo758POM5nqcOMaE168Q6aRLJZwUmiqSrAungkG74gSSeKEIR7ukixesdRZGPgVqme6vmxs1fkA==", "dev": true, "requires": { - "@ethereumjs/block": "^3.6.3", - "@ethereumjs/blockchain": "^5.5.3", - "@ethereumjs/common": "^2.6.5", - "@ethereumjs/tx": "^3.5.2", - "async-eventemitter": "^0.2.4", - "core-js-pure": "^3.0.1", - "debug": "^4.3.3", - "ethereumjs-util": "^7.1.5", - "functional-red-black-tree": "^1.0.1", - "mcl-wasm": "^0.7.1", - "merkle-patricia-tree": "^4.2.4", - "rustbn.js": "~0.2.0" + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/rlp": "^5.7.0" } }, - "@ethersproject/abi": { - "version": "5.6.4", - "resolved": "https://registry.npmjs.org/@ethersproject/abi/-/abi-5.6.4.tgz", - "integrity": "sha512-TTeZUlCeIHG6527/2goZA6gW5F8Emoc7MrZDC7hhP84aRGvW3TEdTnZR08Ls88YXM1m2SuK42Osw/jSi3uO8gg==", + "@ethersproject/base64": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/base64/-/base64-5.7.0.tgz", + "integrity": "sha512-Dr8tcHt2mEbsZr/mwTPIQAf3Ai0Bks/7gTw9dSqk1mQvhW3XvRlmDJr/4n+wg1JmCl16NZue17CDh8xb/vZ0sQ==", "dev": true, "requires": { - "@ethersproject/address": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/constants": "^5.6.1", - "@ethersproject/hash": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/strings": "^5.6.1" + "@ethersproject/bytes": "^5.7.0" } }, - "@ethersproject/abstract-provider": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-provider/-/abstract-provider-5.6.1.tgz", - "integrity": "sha512-BxlIgogYJtp1FS8Muvj8YfdClk3unZH0vRMVX791Z9INBNT/kuACZ9GzaY1Y4yFq+YSy6/w4gzj3HCRKrK9hsQ==", + "@ethersproject/basex": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/basex/-/basex-5.7.0.tgz", + "integrity": "sha512-ywlh43GwZLv2Voc2gQVTKBoVQ1mti3d8HK5aMxsfu/nRDnMmNqaSJ3r3n85HBByT8OpoY96SXM1FogC533T4zw==", "dev": true, "requires": { - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/networks": "^5.6.3", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/transactions": "^5.6.2", - "@ethersproject/web": "^5.6.1" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/properties": "^5.7.0" } }, - "@ethersproject/abstract-signer": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-signer/-/abstract-signer-5.6.2.tgz", - "integrity": "sha512-n1r6lttFBG0t2vNiI3HoWaS/KdOt8xyDjzlP2cuevlWLG6EX0OwcKLyG/Kp/cuwNxdy/ous+R/DEMdTUwWQIjQ==", + "@ethersproject/bignumber": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/bignumber/-/bignumber-5.7.0.tgz", + "integrity": "sha512-n1CAdIHRWjSucQO3MC1zPSVgV/6dy/fjL9pMrPP9peL+QxEg9wOsVqwD4+818B6LUEtaXzVHQiuivzRoxPxUGw==", "dev": true, "requires": { - "@ethersproject/abstract-provider": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "bn.js": "^5.2.1" } }, - "@ethersproject/address": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/address/-/address-5.6.1.tgz", - "integrity": "sha512-uOgF0kS5MJv9ZvCz7x6T2EXJSzotiybApn4XlOgoTX0xdtyVIJ7pF+6cGPxiEq/dpBiTfMiw7Yc81JcwhSYA0Q==", + "@ethersproject/bytes": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/bytes/-/bytes-5.7.0.tgz", + "integrity": "sha512-nsbxwgFXWh9NyYWo+U8atvmMsSdKJprTcICAkvbBffT75qDocbuggBU0SJiVK2MuTrp0q+xvLkTnGMPK1+uA9A==", "dev": true, "requires": { - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/rlp": "^5.6.1" + "@ethersproject/logger": "^5.7.0" } }, - "@ethersproject/base64": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/base64/-/base64-5.6.1.tgz", - "integrity": "sha512-qB76rjop6a0RIYYMiB4Eh/8n+Hxu2NIZm8S/Q7kNo5pmZfXhHGHmS4MinUainiBC54SCyRnwzL+KZjj8zbsSsw==", + "@ethersproject/constants": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/constants/-/constants-5.7.0.tgz", + "integrity": "sha512-DHI+y5dBNvkpYUMiRQyxRBYBefZkJfo70VUkUAsRjcPs47muV9evftfZ0PJVCXYbAiCgght0DtcF9srFQmIgWA==", "dev": true, "requires": { - "@ethersproject/bytes": "^5.6.1" + "@ethersproject/bignumber": "^5.7.0" } }, - "@ethersproject/bignumber": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/bignumber/-/bignumber-5.6.2.tgz", - "integrity": "sha512-v7+EEUbhGqT3XJ9LMPsKvXYHFc8eHxTowFCG/HgJErmq4XHJ2WR7aeyICg3uTOAQ7Icn0GFHAohXEhxQHq4Ubw==", + "@ethersproject/contracts": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/contracts/-/contracts-5.7.0.tgz", + "integrity": "sha512-5GJbzEU3X+d33CdfPhcyS+z8MzsTrBGk/sc+G+59+tPa9yFkl6HQ9D6L0QMgNTA9q8dT0XKxxkyp883XsQvbbg==", "dev": true, "requires": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "bn.js": "^5.2.1" + "@ethersproject/abi": "^5.7.0", + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/transactions": "^5.7.0" } }, - "@ethersproject/bytes": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/bytes/-/bytes-5.6.1.tgz", - "integrity": "sha512-NwQt7cKn5+ZE4uDn+X5RAXLp46E1chXoaMmrxAyA0rblpxz8t58lVkrHXoRIn0lz1joQElQ8410GqhTqMOwc6g==", + "@ethersproject/hash": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/hash/-/hash-5.7.0.tgz", + "integrity": "sha512-qX5WrQfnah1EFnO5zJv1v46a8HW0+E5xuBBDTwMFZLuVTx0tbU2kkx15NqdjxecrLGatQN9FGQKpb1FKdHCt+g==", + "dev": true, + "requires": { + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/base64": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" + } + }, + "@ethersproject/hdnode": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/hdnode/-/hdnode-5.7.0.tgz", + "integrity": "sha512-OmyYo9EENBPPf4ERhR7oj6uAtUAhYGqOnIS+jE5pTXvdKBS99ikzq1E7Iv0ZQZ5V36Lqx1qZLeak0Ra16qpeOg==", + "dev": true, + "requires": { + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/basex": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/pbkdf2": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/sha2": "^5.7.0", + "@ethersproject/signing-key": "^5.7.0", + "@ethersproject/strings": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/wordlists": "^5.7.0" + } + }, + "@ethersproject/json-wallets": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/json-wallets/-/json-wallets-5.7.0.tgz", + "integrity": "sha512-8oee5Xgu6+RKgJTkvEMl2wDgSPSAQ9MB/3JYjFV9jlKvcYHUXZC+cQp0njgmxdHkYWn8s6/IqIZYm0YWCjO/0g==", + "dev": true, + "requires": { + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/hdnode": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/pbkdf2": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/random": "^5.7.0", + "@ethersproject/strings": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "aes-js": "3.0.0", + "scrypt-js": "3.0.1" + } + }, + "@ethersproject/keccak256": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/keccak256/-/keccak256-5.7.0.tgz", + "integrity": "sha512-2UcPboeL/iW+pSg6vZ6ydF8tCnv3Iu/8tUmLLzWWGzxWKFFqOBQFLo6uLUv6BDrLgCDfN28RJ/wtByx+jZ4KBg==", "dev": true, "requires": { - "@ethersproject/logger": "^5.6.0" + "@ethersproject/bytes": "^5.7.0", + "js-sha3": "0.8.0" } }, - "@ethersproject/constants": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/constants/-/constants-5.6.1.tgz", - "integrity": "sha512-QSq9WVnZbxXYFftrjSjZDUshp6/eKp6qrtdBtUCm0QxCV5z1fG/w3kdlcsjMCQuQHUnAclKoK7XpXMezhRDOLg==", + "@ethersproject/logger": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/logger/-/logger-5.7.0.tgz", + "integrity": "sha512-0odtFdXu/XHtjQXJYA3u9G0G8btm0ND5Cu8M7i5vhEcE8/HmF4Lbdqanwyv4uQTr2tx6b7fQRmgLrsnpQlmnig==", + "dev": true + }, + "@ethersproject/networks": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/@ethersproject/networks/-/networks-5.7.1.tgz", + "integrity": "sha512-n/MufjFYv3yFcUyfhnXotyDlNdFb7onmkSy8aQERi2PjNcnWQ66xXxa3XlS8nCcA8aJKJjIIMNJTC7tu80GwpQ==", "dev": true, "requires": { - "@ethersproject/bignumber": "^5.6.2" + "@ethersproject/logger": "^5.7.0" } }, - "@ethersproject/hash": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/hash/-/hash-5.6.1.tgz", - "integrity": "sha512-L1xAHurbaxG8VVul4ankNX5HgQ8PNCTrnVXEiFnE9xoRnaUcgfD12tZINtDinSllxPLCtGwguQxJ5E6keE84pA==", + "@ethersproject/pbkdf2": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/pbkdf2/-/pbkdf2-5.7.0.tgz", + "integrity": "sha512-oR/dBRZR6GTyaofd86DehG72hY6NpAjhabkhxgr3X2FpJtJuodEl2auADWBZfhDHgVCbu3/H/Ocq2uC6dpNjjw==", "dev": true, "requires": { - "@ethersproject/abstract-signer": "^5.6.2", - "@ethersproject/address": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/strings": "^5.6.1" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/sha2": "^5.7.0" } }, - "@ethersproject/keccak256": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/keccak256/-/keccak256-5.6.1.tgz", - "integrity": "sha512-bB7DQHCTRDooZZdL3lk9wpL0+XuG3XLGHLh3cePnybsO3V0rdCAOQGpn/0R3aODmnTOOkCATJiD2hnL+5bwthA==", + "@ethersproject/properties": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/properties/-/properties-5.7.0.tgz", + "integrity": "sha512-J87jy8suntrAkIZtecpxEPxY//szqr1mlBaYlQ0r4RCaiD2hjheqF9s1LVE8vVuJCXisjIP+JgtK/Do54ej4Sw==", + "dev": true, + "requires": { + "@ethersproject/logger": "^5.7.0" + } + }, + "@ethersproject/providers": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/@ethersproject/providers/-/providers-5.7.2.tgz", + "integrity": "sha512-g34EWZ1WWAVgr4aptGlVBF8mhl3VWjv+8hoAnzStu8Ah22VHBsuGzP17eb6xDVRzw895G4W7vvx60lFFur/1Rg==", + "dev": true, + "requires": { + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/base64": "^5.7.0", + "@ethersproject/basex": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/networks": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/random": "^5.7.0", + "@ethersproject/rlp": "^5.7.0", + "@ethersproject/sha2": "^5.7.0", + "@ethersproject/strings": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/web": "^5.7.0", + "bech32": "1.1.4", + "ws": "7.4.6" + }, + "dependencies": { + "ws": { + "version": "7.4.6", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.6.tgz", + "integrity": "sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A==", + "dev": true, + "requires": {} + } + } + }, + "@ethersproject/random": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/random/-/random-5.7.0.tgz", + "integrity": "sha512-19WjScqRA8IIeWclFme75VMXSBvi4e6InrUNuaR4s5pTF2qNhcGdCUwdxUVGtDDqC00sDLCO93jPQoDUH4HVmQ==", "dev": true, "requires": { - "@ethersproject/bytes": "^5.6.1", - "js-sha3": "0.8.0" + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0" } }, - "@ethersproject/logger": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/@ethersproject/logger/-/logger-5.6.0.tgz", - "integrity": "sha512-BiBWllUROH9w+P21RzoxJKzqoqpkyM1pRnEKG69bulE9TSQD8SAIvTQqIMZmmCO8pUNkgLP1wndX1gKghSpBmg==", + "@ethersproject/rlp": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/rlp/-/rlp-5.7.0.tgz", + "integrity": "sha512-rBxzX2vK8mVF7b0Tol44t5Tb8gomOHkj5guL+HhzQ1yBh/ydjGnpw6at+X6Iw0Kp3OzzzkcKp8N9r0W4kYSs9w==", + "dev": true, + "requires": { + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0" + } + }, + "@ethersproject/sha2": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/sha2/-/sha2-5.7.0.tgz", + "integrity": "sha512-gKlH42riwb3KYp0reLsFTokByAKoJdgFCwI+CCiX/k+Jm2mbNs6oOaCjYQSlI1+XBVejwH2KrmCbMAT/GnRDQw==", + "dev": true, + "requires": { + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "hash.js": "1.1.7" + } + }, + "@ethersproject/signing-key": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/signing-key/-/signing-key-5.7.0.tgz", + "integrity": "sha512-MZdy2nL3wO0u7gkB4nA/pEf8lu1TlFswPNmy8AiYkfKTdO6eXBJyUdmHO/ehm/htHw9K/qF8ujnTyUAD+Ry54Q==", + "dev": true, + "requires": { + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "bn.js": "^5.2.1", + "elliptic": "6.5.4", + "hash.js": "1.1.7" + } + }, + "@ethersproject/solidity": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/solidity/-/solidity-5.7.0.tgz", + "integrity": "sha512-HmabMd2Dt/raavyaGukF4XxizWKhKQ24DoLtdNbBmNKUOPqwjsKQSdV9GQtj9CBEea9DlzETlVER1gYeXXBGaA==", + "dev": true, + "requires": { + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/sha2": "^5.7.0", + "@ethersproject/strings": "^5.7.0" + } + }, + "@ethersproject/strings": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/strings/-/strings-5.7.0.tgz", + "integrity": "sha512-/9nu+lj0YswRNSH0NXYqrh8775XNyEdUQAuf3f+SmOrnVewcJ5SBNAjF7lpgehKi4abvNNXyf+HX86czCdJ8Mg==", + "dev": true, + "requires": { + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/logger": "^5.7.0" + } + }, + "@ethersproject/transactions": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/transactions/-/transactions-5.7.0.tgz", + "integrity": "sha512-kmcNicCp1lp8qanMTC3RIikGgoJ80ztTyvtsFvCYpSCfkjhD0jZ2LOrnbcuxuToLIUYYf+4XwD1rP+B/erDIhQ==", + "dev": true, + "requires": { + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/rlp": "^5.7.0", + "@ethersproject/signing-key": "^5.7.0" + } + }, + "@ethersproject/units": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/units/-/units-5.7.0.tgz", + "integrity": "sha512-pD3xLMy3SJu9kG5xDGI7+xhTEmGXlEqXU4OfNapmfnxLVY4EMSSRp7j1k7eezutBPH7RBN/7QPnwR7hzNlEFeg==", + "dev": true, + "requires": { + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/constants": "^5.7.0", + "@ethersproject/logger": "^5.7.0" + } + }, + "@ethersproject/wallet": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/wallet/-/wallet-5.7.0.tgz", + "integrity": "sha512-MhmXlJXEJFBFVKrDLB4ZdDzxcBxQ3rLyCkhNqVu3CDYvR97E+8r01UgrI+TI99Le+aYm/in/0vp86guJuM7FCA==", + "dev": true, + "requires": { + "@ethersproject/abstract-provider": "^5.7.0", + "@ethersproject/abstract-signer": "^5.7.0", + "@ethersproject/address": "^5.7.0", + "@ethersproject/bignumber": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/hdnode": "^5.7.0", + "@ethersproject/json-wallets": "^5.7.0", + "@ethersproject/keccak256": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/random": "^5.7.0", + "@ethersproject/signing-key": "^5.7.0", + "@ethersproject/transactions": "^5.7.0", + "@ethersproject/wordlists": "^5.7.0" + } + }, + "@ethersproject/web": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/@ethersproject/web/-/web-5.7.1.tgz", + "integrity": "sha512-Gueu8lSvyjBWL4cYsWsjh6MtMwM0+H4HvqFPZfB6dV8ctbP9zFAO73VG1cMWae0FLPCtz0peKPpZY8/ugJJX2w==", + "dev": true, + "requires": { + "@ethersproject/base64": "^5.7.0", + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" + } + }, + "@ethersproject/wordlists": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/@ethersproject/wordlists/-/wordlists-5.7.0.tgz", + "integrity": "sha512-S2TFNJNfHWVHNE6cNDjbVlZ6MgE17MIxMbMg2zv3wn+3XSJGosL1m9ZVv3GXCf/2ymSsQ+hRI5IzoMJTG6aoVA==", + "dev": true, + "requires": { + "@ethersproject/bytes": "^5.7.0", + "@ethersproject/hash": "^5.7.0", + "@ethersproject/logger": "^5.7.0", + "@ethersproject/properties": "^5.7.0", + "@ethersproject/strings": "^5.7.0" + } + }, + "@fastify/busboy": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.0.tgz", + "integrity": "sha512-+KpH+QxZU7O4675t3mnkQKcZZg56u+K/Ct2K+N2AZYNVK8kyeo/bI18tI8aPm3tvNNRyTWfj6s5tnGNlcbQRsA==", "dev": true }, - "@ethersproject/networks": { - "version": "5.6.4", - "resolved": "https://registry.npmjs.org/@ethersproject/networks/-/networks-5.6.4.tgz", - "integrity": "sha512-KShHeHPahHI2UlWdtDMn2lJETcbtaJge4k7XSjDR9h79QTd6yQJmv6Cp2ZA4JdqWnhszAOLSuJEd9C0PRw7hSQ==", + "@metamask/eth-sig-util": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/@metamask/eth-sig-util/-/eth-sig-util-4.0.1.tgz", + "integrity": "sha512-tghyZKLHZjcdlDqCA3gNZmLeR0XvOE9U1qoQO9ohyAZT6Pya+H9vkBPcsyXytmYLNgVoin7CKCmweo/R43V+tQ==", + "dev": true, + "requires": { + "ethereumjs-abi": "^0.6.8", + "ethereumjs-util": "^6.2.1", + "ethjs-util": "^0.1.6", + "tweetnacl": "^1.0.3", + "tweetnacl-util": "^0.15.1" + }, + "dependencies": { + "@types/bn.js": { + "version": "4.11.6", + "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-4.11.6.tgz", + "integrity": "sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg==", + "dev": true, + "requires": { + "@types/node": "*" + } + }, + "bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", + "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", + "dev": true + }, + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + }, + "ethereumjs-util": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz", + "integrity": "sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw==", + "dev": true, + "requires": { + "@types/bn.js": "^4.11.3", + "bn.js": "^4.11.0", + "create-hash": "^1.1.2", + "elliptic": "^6.5.2", + "ethereum-cryptography": "^0.1.3", + "ethjs-util": "0.1.6", + "rlp": "^2.2.3" + } + } + } + }, + "@noble/hashes": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.1.2.tgz", + "integrity": "sha512-KYRCASVTv6aeUi1tsF8/vpyR7zpfs3FUzy2Jqm+MU+LmUKhQ0y2FpfwqkCcxSg2ua4GALJd8k2R76WxwZGbQpA==", + "dev": true + }, + "@noble/secp256k1": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/@noble/secp256k1/-/secp256k1-1.6.3.tgz", + "integrity": "sha512-T04e4iTurVy7I8Sw4+c5OSN9/RkPlo1uKxAomtxQNLq8j1uPAqnsqG1bqvY3Jv7c13gyr6dui0zmh/I3+f/JaQ==", + "dev": true + }, + "@nomicfoundation/ethereumjs-block": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-block/-/ethereumjs-block-5.0.2.tgz", + "integrity": "sha512-hSe6CuHI4SsSiWWjHDIzWhSiAVpzMUcDRpWYzN0T9l8/Rz7xNn3elwVOJ/tAyS0LqL6vitUD78Uk7lQDXZun7Q==", + "dev": true, + "requires": { + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "ethereum-cryptography": "0.1.3", + "ethers": "^5.7.1" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + } + } + }, + "@nomicfoundation/ethereumjs-blockchain": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-blockchain/-/ethereumjs-blockchain-7.0.2.tgz", + "integrity": "sha512-8UUsSXJs+MFfIIAKdh3cG16iNmWzWC/91P40sazNvrqhhdR/RtGDlFk2iFTGbBAZPs2+klZVzhRX8m2wvuvz3w==", + "dev": true, + "requires": { + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-ethash": "3.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "abstract-level": "^1.0.3", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "level": "^8.0.0", + "lru-cache": "^5.1.1", + "memory-level": "^1.0.0" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + } + } + }, + "@nomicfoundation/ethereumjs-common": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-common/-/ethereumjs-common-4.0.2.tgz", + "integrity": "sha512-I2WGP3HMGsOoycSdOTSqIaES0ughQTueOsddJ36aYVpI3SN8YSusgRFLwzDJwRFVIYDKx/iJz0sQ5kBHVgdDwg==", "dev": true, "requires": { - "@ethersproject/logger": "^5.6.0" + "@nomicfoundation/ethereumjs-util": "9.0.2", + "crc-32": "^1.2.0" } }, - "@ethersproject/properties": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/@ethersproject/properties/-/properties-5.6.0.tgz", - "integrity": "sha512-szoOkHskajKePTJSZ46uHUWWkbv7TzP2ypdEK6jGMqJaEt2sb0jCgfBo0gH0m2HBpRixMuJ6TBRaQCF7a9DoCg==", + "@nomicfoundation/ethereumjs-ethash": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-ethash/-/ethereumjs-ethash-3.0.2.tgz", + "integrity": "sha512-8PfoOQCcIcO9Pylq0Buijuq/O73tmMVURK0OqdjhwqcGHYC2PwhbajDh7GZ55ekB0Px197ajK3PQhpKoiI/UPg==", "dev": true, "requires": { - "@ethersproject/logger": "^5.6.0" + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "abstract-level": "^1.0.3", + "bigint-crypto-utils": "^3.0.23", + "ethereum-cryptography": "0.1.3" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + } } }, - "@ethersproject/rlp": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/rlp/-/rlp-5.6.1.tgz", - "integrity": "sha512-uYjmcZx+DKlFUk7a5/W9aQVaoEC7+1MOBgNtvNg13+RnuUwT4F0zTovC0tmay5SmRslb29V1B7Y5KCri46WhuQ==", + "@nomicfoundation/ethereumjs-evm": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-evm/-/ethereumjs-evm-2.0.2.tgz", + "integrity": "sha512-rBLcUaUfANJxyOx9HIdMX6uXGin6lANCulIm/pjMgRqfiCRMZie3WKYxTSd8ZE/d+qT+zTedBF4+VHTdTSePmQ==", "dev": true, "requires": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0" + "@ethersproject/providers": "^5.7.1", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "mcl-wasm": "^0.7.1", + "rustbn.js": "~0.2.0" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + } } }, - "@ethersproject/signing-key": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/signing-key/-/signing-key-5.6.2.tgz", - "integrity": "sha512-jVbu0RuP7EFpw82vHcL+GP35+KaNruVAZM90GxgQnGqB6crhBqW/ozBfFvdeImtmb4qPko0uxXjn8l9jpn0cwQ==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "bn.js": "^5.2.1", - "elliptic": "6.5.4", - "hash.js": "1.1.7" - } + "@nomicfoundation/ethereumjs-rlp": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-rlp/-/ethereumjs-rlp-5.0.2.tgz", + "integrity": "sha512-QwmemBc+MMsHJ1P1QvPl8R8p2aPvvVcKBbvHnQOKBpBztEo0omN0eaob6FeZS/e3y9NSe+mfu3nNFBHszqkjTA==", + "dev": true }, - "@ethersproject/strings": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/strings/-/strings-5.6.1.tgz", - "integrity": "sha512-2X1Lgk6Jyfg26MUnsHiT456U9ijxKUybz8IM1Vih+NJxYtXhmvKBcHOmvGqpFSVJ0nQ4ZCoIViR8XlRw1v/+Cw==", + "@nomicfoundation/ethereumjs-statemanager": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-statemanager/-/ethereumjs-statemanager-2.0.2.tgz", + "integrity": "sha512-dlKy5dIXLuDubx8Z74sipciZnJTRSV/uHG48RSijhgm1V7eXYFC567xgKtsKiVZB1ViTP9iFL4B6Je0xD6X2OA==", "dev": true, "requires": { - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/constants": "^5.6.1", - "@ethersproject/logger": "^5.6.0" + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "ethers": "^5.7.1", + "js-sdsl": "^4.1.4" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + } } }, - "@ethersproject/transactions": { - "version": "5.6.2", - "resolved": "https://registry.npmjs.org/@ethersproject/transactions/-/transactions-5.6.2.tgz", - "integrity": "sha512-BuV63IRPHmJvthNkkt9G70Ullx6AcM+SDc+a8Aw/8Yew6YwT51TcBKEp1P4oOQ/bP25I18JJr7rcFRgFtU9B2Q==", + "@nomicfoundation/ethereumjs-trie": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-trie/-/ethereumjs-trie-6.0.2.tgz", + "integrity": "sha512-yw8vg9hBeLYk4YNg5MrSJ5H55TLOv2FSWUTROtDtTMMmDGROsAu+0tBjiNGTnKRi400M6cEzoFfa89Fc5k8NTQ==", "dev": true, "requires": { - "@ethersproject/address": "^5.6.1", - "@ethersproject/bignumber": "^5.6.2", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/constants": "^5.6.1", - "@ethersproject/keccak256": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/rlp": "^5.6.1", - "@ethersproject/signing-key": "^5.6.2" + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "@types/readable-stream": "^2.3.13", + "ethereum-cryptography": "0.1.3", + "readable-stream": "^3.6.0" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + } } }, - "@ethersproject/web": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/@ethersproject/web/-/web-5.6.1.tgz", - "integrity": "sha512-/vSyzaQlNXkO1WV+RneYKqCJwualcUdx/Z3gseVovZP0wIlOFcCE1hkRhKBH8ImKbGQbMl9EAAyJFrJu7V0aqA==", + "@nomicfoundation/ethereumjs-tx": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-tx/-/ethereumjs-tx-5.0.2.tgz", + "integrity": "sha512-T+l4/MmTp7VhJeNloMkM+lPU3YMUaXdcXgTGCf8+ZFvV9NYZTRLFekRwlG6/JMmVfIfbrW+dRRJ9A6H5Q/Z64g==", "dev": true, "requires": { - "@ethersproject/base64": "^5.6.1", - "@ethersproject/bytes": "^5.6.1", - "@ethersproject/logger": "^5.6.0", - "@ethersproject/properties": "^5.6.0", - "@ethersproject/strings": "^5.6.1" + "@chainsafe/ssz": "^0.9.2", + "@ethersproject/providers": "^5.7.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "ethereum-cryptography": "0.1.3" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", + "dev": true, + "requires": { + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" + } + } } }, - "@metamask/eth-sig-util": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/@metamask/eth-sig-util/-/eth-sig-util-4.0.1.tgz", - "integrity": "sha512-tghyZKLHZjcdlDqCA3gNZmLeR0XvOE9U1qoQO9ohyAZT6Pya+H9vkBPcsyXytmYLNgVoin7CKCmweo/R43V+tQ==", + "@nomicfoundation/ethereumjs-util": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-util/-/ethereumjs-util-9.0.2.tgz", + "integrity": "sha512-4Wu9D3LykbSBWZo8nJCnzVIYGvGCuyiYLIJa9XXNVt1q1jUzHdB+sJvx95VGCpPkCT+IbLecW6yfzy3E1bQrwQ==", "dev": true, "requires": { - "ethereumjs-abi": "^0.6.8", - "ethereumjs-util": "^6.2.1", - "ethjs-util": "^0.1.6", - "tweetnacl": "^1.0.3", - "tweetnacl-util": "^0.15.1" + "@chainsafe/ssz": "^0.10.0", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "ethereum-cryptography": "0.1.3" }, "dependencies": { - "@types/bn.js": { - "version": "4.11.6", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-4.11.6.tgz", - "integrity": "sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg==", + "@chainsafe/persistent-merkle-tree": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.5.0.tgz", + "integrity": "sha512-l0V1b5clxA3iwQLXP40zYjyZYospQLZXzBVIhhr9kDg/1qHZfzzHw0jj4VPBijfYCArZDlPkRi1wZaV2POKeuw==", "dev": true, "requires": { - "@types/node": "*" + "@chainsafe/as-sha256": "^0.3.1" } }, - "bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true + "@chainsafe/ssz": { + "version": "0.10.2", + "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.10.2.tgz", + "integrity": "sha512-/NL3Lh8K+0q7A3LsiFq09YXS9fPE+ead2rr7vM2QK8PLzrNsw3uqrif9bpRX5UxgeRjM+vYi+boCM3+GM4ovXg==", + "dev": true, + "requires": { + "@chainsafe/as-sha256": "^0.3.1", + "@chainsafe/persistent-merkle-tree": "^0.5.0" + } }, "ethereum-cryptography": { "version": "0.1.3", @@ -3988,35 +5148,142 @@ "secp256k1": "^4.0.1", "setimmediate": "^1.0.5" } - }, - "ethereumjs-util": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz", - "integrity": "sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw==", + } + } + }, + "@nomicfoundation/ethereumjs-vm": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-vm/-/ethereumjs-vm-7.0.2.tgz", + "integrity": "sha512-Bj3KZT64j54Tcwr7Qm/0jkeZXJMfdcAtRBedou+Hx0dPOSIgqaIr0vvLwP65TpHbak2DmAq+KJbW2KNtIoFwvA==", + "dev": true, + "requires": { + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-blockchain": "7.0.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-evm": "2.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-statemanager": "2.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "debug": "^4.3.3", + "ethereum-cryptography": "0.1.3", + "mcl-wasm": "^0.7.1", + "rustbn.js": "~0.2.0" + }, + "dependencies": { + "ethereum-cryptography": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", + "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", "dev": true, "requires": { - "@types/bn.js": "^4.11.3", - "bn.js": "^4.11.0", - "create-hash": "^1.1.2", - "elliptic": "^6.5.2", - "ethereum-cryptography": "^0.1.3", - "ethjs-util": "0.1.6", - "rlp": "^2.2.3" + "@types/pbkdf2": "^3.0.0", + "@types/secp256k1": "^4.0.1", + "blakejs": "^1.1.0", + "browserify-aes": "^1.2.0", + "bs58check": "^2.1.2", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "hash.js": "^1.1.7", + "keccak": "^3.0.0", + "pbkdf2": "^3.0.17", + "randombytes": "^2.1.0", + "safe-buffer": "^5.1.2", + "scrypt-js": "^3.0.0", + "secp256k1": "^4.0.1", + "setimmediate": "^1.0.5" } } } }, - "@noble/hashes": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.1.2.tgz", - "integrity": "sha512-KYRCASVTv6aeUi1tsF8/vpyR7zpfs3FUzy2Jqm+MU+LmUKhQ0y2FpfwqkCcxSg2ua4GALJd8k2R76WxwZGbQpA==", - "dev": true + "@nomicfoundation/solidity-analyzer": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer/-/solidity-analyzer-0.1.1.tgz", + "integrity": "sha512-1LMtXj1puAxyFusBgUIy5pZk3073cNXYnXUpuNKFghHbIit/xZgbk0AokpUADbNm3gyD6bFWl3LRFh3dhVdREg==", + "dev": true, + "requires": { + "@nomicfoundation/solidity-analyzer-darwin-arm64": "0.1.1", + "@nomicfoundation/solidity-analyzer-darwin-x64": "0.1.1", + "@nomicfoundation/solidity-analyzer-freebsd-x64": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-arm64-musl": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-x64-gnu": "0.1.1", + "@nomicfoundation/solidity-analyzer-linux-x64-musl": "0.1.1", + "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": "0.1.1", + "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": "0.1.1", + "@nomicfoundation/solidity-analyzer-win32-x64-msvc": "0.1.1" + } }, - "@noble/secp256k1": { - "version": "1.6.3", - "resolved": "https://registry.npmjs.org/@noble/secp256k1/-/secp256k1-1.6.3.tgz", - "integrity": "sha512-T04e4iTurVy7I8Sw4+c5OSN9/RkPlo1uKxAomtxQNLq8j1uPAqnsqG1bqvY3Jv7c13gyr6dui0zmh/I3+f/JaQ==", - "dev": true + "@nomicfoundation/solidity-analyzer-darwin-arm64": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-arm64/-/solidity-analyzer-darwin-arm64-0.1.1.tgz", + "integrity": "sha512-KcTodaQw8ivDZyF+D76FokN/HdpgGpfjc/gFCImdLUyqB6eSWVaZPazMbeAjmfhx3R0zm/NYVzxwAokFKgrc0w==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-darwin-x64": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-x64/-/solidity-analyzer-darwin-x64-0.1.1.tgz", + "integrity": "sha512-XhQG4BaJE6cIbjAVtzGOGbK3sn1BO9W29uhk9J8y8fZF1DYz0Doj8QDMfpMu+A6TjPDs61lbsmeYodIDnfveSA==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-freebsd-x64": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-freebsd-x64/-/solidity-analyzer-freebsd-x64-0.1.1.tgz", + "integrity": "sha512-GHF1VKRdHW3G8CndkwdaeLkVBi5A9u2jwtlS7SLhBc8b5U/GcoL39Q+1CSO3hYqePNP+eV5YI7Zgm0ea6kMHoA==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-gnu/-/solidity-analyzer-linux-arm64-gnu-0.1.1.tgz", + "integrity": "sha512-g4Cv2fO37ZsUENQ2vwPnZc2zRenHyAxHcyBjKcjaSmmkKrFr64yvzeNO8S3GBFCo90rfochLs99wFVGT/0owpg==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-linux-arm64-musl": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-musl/-/solidity-analyzer-linux-arm64-musl-0.1.1.tgz", + "integrity": "sha512-WJ3CE5Oek25OGE3WwzK7oaopY8xMw9Lhb0mlYuJl/maZVo+WtP36XoQTb7bW/i8aAdHW5Z+BqrHMux23pvxG3w==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-linux-x64-gnu": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-gnu/-/solidity-analyzer-linux-x64-gnu-0.1.1.tgz", + "integrity": "sha512-5WN7leSr5fkUBBjE4f3wKENUy9HQStu7HmWqbtknfXkkil+eNWiBV275IOlpXku7v3uLsXTOKpnnGHJYI2qsdA==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-linux-x64-musl": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-musl/-/solidity-analyzer-linux-x64-musl-0.1.1.tgz", + "integrity": "sha512-KdYMkJOq0SYPQMmErv/63CwGwMm5XHenEna9X9aB8mQmhDBrYrlAOSsIPgFCUSL0hjxE3xHP65/EPXR/InD2+w==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-arm64-msvc/-/solidity-analyzer-win32-arm64-msvc-0.1.1.tgz", + "integrity": "sha512-VFZASBfl4qiBYwW5xeY20exWhmv6ww9sWu/krWSesv3q5hA0o1JuzmPHR4LPN6SUZj5vcqci0O6JOL8BPw+APg==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-ia32-msvc/-/solidity-analyzer-win32-ia32-msvc-0.1.1.tgz", + "integrity": "sha512-JnFkYuyCSA70j6Si6cS1A9Gh1aHTEb8kOTBApp/c7NRTFGNMH8eaInKlyuuiIbvYFhlXW4LicqyYuWNNq9hkpQ==", + "dev": true, + "optional": true + }, + "@nomicfoundation/solidity-analyzer-win32-x64-msvc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-x64-msvc/-/solidity-analyzer-win32-x64-msvc-0.1.1.tgz", + "integrity": "sha512-HrVJr6+WjIXGnw3Q9u6KQcbZCtk0caVWhCdFADySvRyUxJ8PnzlaP+MhwNE8oyT8OZ6ejHBRrrgjSqDCFXGirw==", + "dev": true, + "optional": true }, "@scure/base": { "version": "1.1.1", @@ -4119,51 +5386,19 @@ "@sentry/utils": { "version": "5.30.0", "resolved": "https://registry.npmjs.org/@sentry/utils/-/utils-5.30.0.tgz", - "integrity": "sha512-zaYmoH0NWWtvnJjC9/CBseXMtKHm/tm40sz3YfJRxeQjyzRqNQPgivpd9R/oDJCYj999mzdW382p/qi2ypjLww==", - "dev": true, - "requires": { - "@sentry/types": "5.30.0", - "tslib": "^1.9.3" - } - }, - "@solidity-parser/parser": { - "version": "0.14.3", - "resolved": "https://registry.npmjs.org/@solidity-parser/parser/-/parser-0.14.3.tgz", - "integrity": "sha512-29g2SZ29HtsqA58pLCtopI1P/cPy5/UAzlcAXO6T/CNJimG6yA8kx4NaseMyJULiC+TEs02Y9/yeHzClqoA0hw==", - "dev": true, - "requires": { - "antlr4ts": "^0.5.0-alpha.4" - } - }, - "@types/abstract-leveldown": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@types/abstract-leveldown/-/abstract-leveldown-7.2.0.tgz", - "integrity": "sha512-q5veSX6zjUy/DlDhR4Y4cU0k2Ar+DT2LUraP00T19WLmTO6Se1djepCCaqU6nQrwcJ5Hyo/CWqxTzrrFg8eqbQ==", - "dev": true - }, - "@types/bn.js": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-5.1.0.tgz", - "integrity": "sha512-QSSVYj7pYFN49kW77o2s9xTCwZ8F2xLbjLLSEVh8D2F4JUhZtPAGOFLTD+ffqksBx/u4cE/KImFjyhqCjn/LIA==", + "integrity": "sha512-zaYmoH0NWWtvnJjC9/CBseXMtKHm/tm40sz3YfJRxeQjyzRqNQPgivpd9R/oDJCYj999mzdW382p/qi2ypjLww==", "dev": true, "requires": { - "@types/node": "*" + "@sentry/types": "5.30.0", + "tslib": "^1.9.3" } }, - "@types/level-errors": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/level-errors/-/level-errors-3.0.0.tgz", - "integrity": "sha512-/lMtoq/Cf/2DVOm6zE6ORyOM+3ZVm/BvzEZVxUhf6bgh8ZHglXlBqxbxSlJeVp8FCbD3IVvk/VbsaNmDjrQvqQ==", - "dev": true - }, - "@types/levelup": { - "version": "4.3.3", - "resolved": "https://registry.npmjs.org/@types/levelup/-/levelup-4.3.3.tgz", - "integrity": "sha512-K+OTIjJcZHVlZQN1HmU64VtrC0jC3dXWQozuEIR9zVvltIk90zaGPM2AgT+fIkChpzHhFE3YnvFLCbLtzAmexA==", + "@types/bn.js": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-5.1.5.tgz", + "integrity": "sha512-V46N0zwKRF5Q00AZ6hWtN0T8gGmDUaUzLWQvHFo5yThtVwK/VCenFY3wXVbOvNfajEpsTfQM4IN9k/d6gUVX3A==", "dev": true, "requires": { - "@types/abstract-leveldown": "*", - "@types/level-errors": "*", "@types/node": "*" } }, @@ -4188,6 +5423,24 @@ "@types/node": "*" } }, + "@types/readable-stream": { + "version": "2.3.15", + "resolved": "https://registry.npmjs.org/@types/readable-stream/-/readable-stream-2.3.15.tgz", + "integrity": "sha512-oM5JSKQCcICF1wvGgmecmHldZ48OZamtMxcGGVICOJA8o8cahXC1zEVAif8iwoc5j8etxFaRFnf095+CDsuoFQ==", + "dev": true, + "requires": { + "@types/node": "*", + "safe-buffer": "~5.1.1" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + } + } + }, "@types/secp256k1": { "version": "4.0.3", "resolved": "https://registry.npmjs.org/@types/secp256k1/-/secp256k1-4.0.3.tgz", @@ -4203,26 +5456,19 @@ "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", "dev": true }, - "abort-controller": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", - "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", - "dev": true, - "requires": { - "event-target-shim": "^5.0.0" - } - }, - "abstract-leveldown": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/abstract-leveldown/-/abstract-leveldown-6.3.0.tgz", - "integrity": "sha512-TU5nlYgta8YrBMNpc9FwQzRbiXsj49gsALsXadbGHt9CROPzX5fB0rWDR5mtdpOOKa5XqRFpbj1QroPAoPzVjQ==", + "abstract-level": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/abstract-level/-/abstract-level-1.0.3.tgz", + "integrity": "sha512-t6jv+xHy+VYwc4xqZMn2Pa9DjcdzvzZmQGRjTFc8spIbRGHgBrEKbPq+rYXc7CCo0lxgYvSgKVg9qZAhpVQSjA==", "dev": true, "requires": { - "buffer": "^5.5.0", - "immediate": "^3.2.3", - "level-concat-iterator": "~2.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" + "buffer": "^6.0.3", + "catering": "^2.1.0", + "is-buffer": "^2.0.5", + "level-supports": "^4.0.0", + "level-transcoder": "^1.0.1", + "module-error": "^1.0.1", + "queue-microtask": "^1.2.3" } }, "adm-zip": { @@ -4231,6 +5477,12 @@ "integrity": "sha512-TFi4HBKSGfIKsK5YCkKaaFG2m4PEDyViZmEwof3MTIgzimHLto6muaHVpbrljdIvIrFZzEq/p4nafOeLcYegrg==", "dev": true }, + "aes-js": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/aes-js/-/aes-js-3.0.0.tgz", + "integrity": "sha512-H7wUZRn8WpTq9jocdxQ2c8x2sKo9ZVmzfRE13GiNJXfp7NcKYEdvl3vspKjXox6RIG2VtaRe4JFvxG4rqp2Zuw==", + "dev": true + }, "agent-base": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", @@ -4280,12 +5532,6 @@ "color-convert": "^1.9.0" } }, - "antlr4ts": { - "version": "0.5.0-alpha.4", - "resolved": "https://registry.npmjs.org/antlr4ts/-/antlr4ts-0.5.0-alpha.4.tgz", - "integrity": "sha512-WPQDt1B74OfPv/IMS2ekXAKkTZIHl88uMetg6q3OTqgFxZ/dxDXI0EWLyZid/1Pe6hTftyg5N7gel5wNAGxXyQ==", - "dev": true - }, "anymatch": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", @@ -4302,24 +5548,6 @@ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", "dev": true }, - "async": { - "version": "2.6.4", - "resolved": "https://registry.npmjs.org/async/-/async-2.6.4.tgz", - "integrity": "sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA==", - "dev": true, - "requires": { - "lodash": "^4.17.14" - } - }, - "async-eventemitter": { - "version": "0.2.4", - "resolved": "https://registry.npmjs.org/async-eventemitter/-/async-eventemitter-0.2.4.tgz", - "integrity": "sha512-pd20BwL7Yt1zwDFy+8MX8F1+WCT8aQeKj0kQnTrH9WaeRETlRamVhD0JtRPmrV4GfOJ2F9CvdQkZeZhnh2TuHw==", - "dev": true, - "requires": { - "async": "^2.4.0" - } - }, "balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -4341,6 +5569,18 @@ "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", "dev": true }, + "bech32": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/bech32/-/bech32-1.1.4.tgz", + "integrity": "sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==", + "dev": true + }, + "bigint-crypto-utils": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/bigint-crypto-utils/-/bigint-crypto-utils-3.3.0.tgz", + "integrity": "sha512-jOTSb+drvEDxEq6OuUybOAv/xxoh3cuYRUIPyu8sSHQNKM303UQ2R1DAo45o1AkcIXw6fzbaFI1+xGGdaXs2lg==", + "dev": true + }, "binary-extensions": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", @@ -4384,6 +5624,18 @@ "integrity": "sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w==", "dev": true }, + "browser-level": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browser-level/-/browser-level-1.0.1.tgz", + "integrity": "sha512-XECYKJ+Dbzw0lbydyQuJzwNXtOpbMSq737qxJN11sIRTErOMShvDpbzTlgju7orJKvx4epULolZAuJGLzCmWRQ==", + "dev": true, + "requires": { + "abstract-level": "^1.0.2", + "catering": "^2.1.1", + "module-error": "^1.0.2", + "run-parallel-limit": "^1.1.0" + } + }, "browser-stdout": { "version": "1.3.1", "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", @@ -4433,13 +5685,13 @@ } }, "buffer": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", - "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", + "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", "dev": true, "requires": { "base64-js": "^1.3.1", - "ieee754": "^1.1.13" + "ieee754": "^1.2.1" } }, "buffer-from": { @@ -4448,37 +5700,30 @@ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", "dev": true }, - "buffer-xor": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-2.0.2.tgz", - "integrity": "sha512-eHslX0bin3GB+Lx2p7lEYRShRewuNZL3fUl4qlVJGGiwoPGftmt8JQgk2Y9Ji5/01TnVDo33E5b5O3vUB1HdqQ==", - "dev": true, - "requires": { - "safe-buffer": "^5.1.1" - } - }, "bytes": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", "dev": true }, - "call-bind": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", - "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", - "dev": true, - "requires": { - "function-bind": "^1.1.1", - "get-intrinsic": "^1.0.2" - } - }, "camelcase": { "version": "6.3.0", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", "dev": true }, + "case": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/case/-/case-1.6.3.tgz", + "integrity": "sha512-mzDSXIPaFwVDvZAHqZ9VlbyF4yyXRuX6IvB06WvPYkqJVO24kX1PPhv9bfpKNFZyxYFmmgo03HUiD8iklmJYRQ==", + "dev": true + }, + "catering": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/catering/-/catering-2.1.1.tgz", + "integrity": "sha512-K7Qy8O9p76sL3/3m7/zLKbRkyOlSZAgzEaLhyj2mXS8PsCud2Eo4hAb8aLtZqHh0QGqLcb9dlJSu6lHRVENm1w==", + "dev": true + }, "chalk": { "version": "2.4.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", @@ -4522,6 +5767,19 @@ "safe-buffer": "^5.0.1" } }, + "classic-level": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/classic-level/-/classic-level-1.3.0.tgz", + "integrity": "sha512-iwFAJQYtqRTRM0F6L8h4JCt00ZSGdOyqh7yVrhhjrOpFhmBjNlRUey64MCiyo6UmQHMJ+No3c81nujPv+n9yrg==", + "dev": true, + "requires": { + "abstract-level": "^1.0.2", + "catering": "^2.1.0", + "module-error": "^1.0.1", + "napi-macros": "^2.2.2", + "node-gyp-build": "^4.3.0" + } + }, "clean-stack": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", @@ -4578,12 +5836,6 @@ "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", "dev": true }, - "core-js-pure": { - "version": "3.23.5", - "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.23.5.tgz", - "integrity": "sha512-8t78LdpKSuCq4pJYCYk8hl7XEkAX+BP16yRIwL3AanTksxuEf7CM83vRyctmiEL8NDZ3jpUcv56fk9/zG3aIuw==", - "dev": true - }, "crc-32": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", @@ -4632,31 +5884,6 @@ "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", "dev": true }, - "deferred-leveldown": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/deferred-leveldown/-/deferred-leveldown-5.3.0.tgz", - "integrity": "sha512-a59VOT+oDy7vtAbLRCZwWgxu2BaCfd5Hk7wxJd48ei7I+nsg8Orlb9CLG0PMZienk9BSUKgeAqkO2+Lw+1+Ukw==", - "dev": true, - "requires": { - "abstract-leveldown": "~6.2.1", - "inherits": "^2.0.3" - }, - "dependencies": { - "abstract-leveldown": { - "version": "6.2.3", - "resolved": "https://registry.npmjs.org/abstract-leveldown/-/abstract-leveldown-6.2.3.tgz", - "integrity": "sha512-BsLm5vFMRUrrLeCcRc+G0t2qOaTzpoJQLOubq2XM72eNpjF5UdU5o/5NvlNhx95XHcAvcl8OMXr4mlg/fRgUXQ==", - "dev": true, - "requires": { - "buffer": "^5.5.0", - "immediate": "^3.2.3", - "level-concat-iterator": "~2.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" - } - } - } - }, "depd": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", @@ -4698,18 +5925,6 @@ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, - "encoding-down": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/encoding-down/-/encoding-down-6.3.0.tgz", - "integrity": "sha512-QKrV0iKR6MZVJV08QY0wp1e7vF6QbhnbQhb07bwpEyuz4uZiZgPlEGdkCROuFkUwdxlFaiPIhjyarH1ee/3vhw==", - "dev": true, - "requires": { - "abstract-leveldown": "^6.2.1", - "inherits": "^2.0.3", - "level-codec": "^9.0.0", - "level-errors": "^2.0.0" - } - }, "enquirer": { "version": "2.3.6", "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", @@ -4725,15 +5940,6 @@ "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==", "dev": true }, - "errno": { - "version": "0.1.8", - "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.8.tgz", - "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==", - "dev": true, - "requires": { - "prr": "~1.0.1" - } - }, "escalade": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", @@ -4823,42 +6029,42 @@ } } }, - "ethereumjs-util": { - "version": "7.1.5", - "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-7.1.5.tgz", - "integrity": "sha512-SDl5kKrQAudFBUe5OJM9Ac6WmMyYmXX/6sTmLZ3ffG2eY6ZIGBes3pEDxNN6V72WyOw4CPD5RomKdsa8DAAwLg==", - "dev": true, - "requires": { - "@types/bn.js": "^5.1.0", - "bn.js": "^5.1.2", - "create-hash": "^1.1.2", - "ethereum-cryptography": "^0.1.3", - "rlp": "^2.2.4" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } + "ethers": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/ethers/-/ethers-5.7.2.tgz", + "integrity": "sha512-wswUsmWo1aOK8rR7DIKiWSw9DbLWe6x98Jrn8wcTflTVvaXhAMaB5zGAXy0GYQEQp9iO1iSHWVyARQm11zUtyg==", + "dev": true, + "requires": { + "@ethersproject/abi": "5.7.0", + "@ethersproject/abstract-provider": "5.7.0", + "@ethersproject/abstract-signer": "5.7.0", + "@ethersproject/address": "5.7.0", + "@ethersproject/base64": "5.7.0", + "@ethersproject/basex": "5.7.0", + "@ethersproject/bignumber": "5.7.0", + "@ethersproject/bytes": "5.7.0", + "@ethersproject/constants": "5.7.0", + "@ethersproject/contracts": "5.7.0", + "@ethersproject/hash": "5.7.0", + "@ethersproject/hdnode": "5.7.0", + "@ethersproject/json-wallets": "5.7.0", + "@ethersproject/keccak256": "5.7.0", + "@ethersproject/logger": "5.7.0", + "@ethersproject/networks": "5.7.1", + "@ethersproject/pbkdf2": "5.7.0", + "@ethersproject/properties": "5.7.0", + "@ethersproject/providers": "5.7.2", + "@ethersproject/random": "5.7.0", + "@ethersproject/rlp": "5.7.0", + "@ethersproject/sha2": "5.7.0", + "@ethersproject/signing-key": "5.7.0", + "@ethersproject/solidity": "5.7.0", + "@ethersproject/strings": "5.7.0", + "@ethersproject/transactions": "5.7.0", + "@ethersproject/units": "5.7.0", + "@ethersproject/wallet": "5.7.0", + "@ethersproject/web": "5.7.1", + "@ethersproject/wordlists": "5.7.0" } }, "ethjs-util": { @@ -4871,12 +6077,6 @@ "strip-hex-prefix": "1.0.0" } }, - "event-target-shim": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", - "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", - "dev": true - }, "evp_bytestokey": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", @@ -4947,12 +6147,6 @@ "dev": true, "optional": true }, - "function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", - "dev": true - }, "functional-red-black-tree": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", @@ -4965,17 +6159,6 @@ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", "dev": true }, - "get-intrinsic": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz", - "integrity": "sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA==", - "dev": true, - "requires": { - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.3" - } - }, "glob": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", @@ -5006,23 +6189,27 @@ "dev": true }, "hardhat": { - "version": "2.10.1", - "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.10.1.tgz", - "integrity": "sha512-0FN9TyCtn7Lt25SB2ei2G7nA2rZjP+RN6MvFOm+zYwherxLZNo6RbD8nDz88eCbhRapevmXqOiL2nM8INKsjmA==", + "version": "2.19.0", + "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.19.0.tgz", + "integrity": "sha512-kMpwovOEfrFRQXEopCP+JTcKVwSYVj8rnXE0LynxDqnh06yvyKCQknmXL6IVYTHQL6Csysc/yNbCHQbjSeJGpA==", "dev": true, "requires": { - "@ethereumjs/block": "^3.6.2", - "@ethereumjs/blockchain": "^5.5.2", - "@ethereumjs/common": "^2.6.4", - "@ethereumjs/tx": "^3.5.1", - "@ethereumjs/vm": "^5.9.0", "@ethersproject/abi": "^5.1.2", "@metamask/eth-sig-util": "^4.0.0", + "@nomicfoundation/ethereumjs-block": "5.0.2", + "@nomicfoundation/ethereumjs-blockchain": "7.0.2", + "@nomicfoundation/ethereumjs-common": "4.0.2", + "@nomicfoundation/ethereumjs-evm": "2.0.2", + "@nomicfoundation/ethereumjs-rlp": "5.0.2", + "@nomicfoundation/ethereumjs-statemanager": "2.0.2", + "@nomicfoundation/ethereumjs-trie": "6.0.2", + "@nomicfoundation/ethereumjs-tx": "5.0.2", + "@nomicfoundation/ethereumjs-util": "9.0.2", + "@nomicfoundation/ethereumjs-vm": "7.0.2", + "@nomicfoundation/solidity-analyzer": "^0.1.0", "@sentry/node": "^5.18.1", - "@solidity-parser/parser": "^0.14.2", "@types/bn.js": "^5.1.0", "@types/lru-cache": "^5.1.0", - "abort-controller": "^3.0.0", "adm-zip": "^0.4.16", "aggregate-error": "^3.0.0", "ansi-escapes": "^4.3.0", @@ -5034,54 +6221,35 @@ "env-paths": "^2.2.0", "ethereum-cryptography": "^1.0.3", "ethereumjs-abi": "^0.6.8", - "ethereumjs-util": "^7.1.4", "find-up": "^2.1.0", "fp-ts": "1.19.3", "fs-extra": "^7.0.1", "glob": "7.2.0", "immutable": "^4.0.0-rc.12", "io-ts": "1.10.4", + "keccak": "^3.0.2", "lodash": "^4.17.11", - "merkle-patricia-tree": "^4.2.4", "mnemonist": "^0.38.0", "mocha": "^10.0.0", "p-map": "^4.0.0", - "qs": "^6.7.0", "raw-body": "^2.4.1", "resolve": "1.17.0", "semver": "^6.3.0", - "slash": "^3.0.0", "solc": "0.7.3", "source-map-support": "^0.5.13", "stacktrace-parser": "^0.1.10", - "true-case-path": "^2.2.1", "tsort": "0.0.1", - "undici": "^5.4.0", + "undici": "^5.14.0", "uuid": "^8.3.2", "ws": "^7.4.6" } }, - "has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dev": true, - "requires": { - "function-bind": "^1.1.1" - } - }, "has-flag": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", "dev": true }, - "has-symbols": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", - "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", - "dev": true - }, "hash-base": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.1.0.tgz", @@ -5158,12 +6326,6 @@ "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", "dev": true }, - "immediate": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.3.0.tgz", - "integrity": "sha512-HR7EVodfFUdQCTIeySw+WDRFJlPcLOJbXfwwZ7Oom6tjsvZ3bOkCDJHehQC3nxJrv7+f9XecwazynjU8e4Vw3Q==", - "dev": true - }, "immutable": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.1.0.tgz", @@ -5210,6 +6372,12 @@ "binary-extensions": "^2.0.0" } }, + "is-buffer": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", + "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==", + "dev": true + }, "is-extglob": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", @@ -5255,6 +6423,12 @@ "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", "dev": true }, + "js-sdsl": { + "version": "4.4.2", + "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.4.2.tgz", + "integrity": "sha512-dwXFwByc/ajSV6m5bcKAPwe4yDDF6D614pxmIi5odytzxRlwqF6nwoiCek80Ixc7Cvma5awClxrzFtxCQvcM8w==", + "dev": true + }, "js-sha3": { "version": "0.8.0", "resolved": "https://registry.npmjs.org/js-sha3/-/js-sha3-0.8.0.tgz", @@ -5299,92 +6473,30 @@ "graceful-fs": "^4.1.9" } }, - "level-codec": { - "version": "9.0.2", - "resolved": "https://registry.npmjs.org/level-codec/-/level-codec-9.0.2.tgz", - "integrity": "sha512-UyIwNb1lJBChJnGfjmO0OR+ezh2iVu1Kas3nvBS/BzGnx79dv6g7unpKIDNPMhfdTEGoc7mC8uAu51XEtX+FHQ==", + "level": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/level/-/level-8.0.0.tgz", + "integrity": "sha512-ypf0jjAk2BWI33yzEaaotpq7fkOPALKAgDBxggO6Q9HGX2MRXn0wbP1Jn/tJv1gtL867+YOjOB49WaUF3UoJNQ==", "dev": true, "requires": { - "buffer": "^5.6.0" + "browser-level": "^1.0.1", + "classic-level": "^1.2.0" } }, - "level-concat-iterator": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/level-concat-iterator/-/level-concat-iterator-2.0.1.tgz", - "integrity": "sha512-OTKKOqeav2QWcERMJR7IS9CUo1sHnke2C0gkSmcR7QuEtFNLLzHQAvnMw8ykvEcv0Qtkg0p7FOwP1v9e5Smdcw==", + "level-supports": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/level-supports/-/level-supports-4.0.1.tgz", + "integrity": "sha512-PbXpve8rKeNcZ9C1mUicC9auIYFyGpkV9/i6g76tLgANwWhtG2v7I4xNBUlkn3lE2/dZF3Pi0ygYGtLc4RXXdA==", "dev": true }, - "level-errors": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/level-errors/-/level-errors-2.0.1.tgz", - "integrity": "sha512-UVprBJXite4gPS+3VznfgDSU8PTRuVX0NXwoWW50KLxd2yw4Y1t2JUR5In1itQnudZqRMT9DlAM3Q//9NCjCFw==", - "dev": true, - "requires": { - "errno": "~0.1.1" - } - }, - "level-iterator-stream": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/level-iterator-stream/-/level-iterator-stream-4.0.2.tgz", - "integrity": "sha512-ZSthfEqzGSOMWoUGhTXdX9jv26d32XJuHz/5YnuHZzH6wldfWMOVwI9TBtKcya4BKTyTt3XVA0A3cF3q5CY30Q==", - "dev": true, - "requires": { - "inherits": "^2.0.4", - "readable-stream": "^3.4.0", - "xtend": "^4.0.2" - } - }, - "level-mem": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/level-mem/-/level-mem-5.0.1.tgz", - "integrity": "sha512-qd+qUJHXsGSFoHTziptAKXoLX87QjR7v2KMbqncDXPxQuCdsQlzmyX+gwrEHhlzn08vkf8TyipYyMmiC6Gobzg==", - "dev": true, - "requires": { - "level-packager": "^5.0.3", - "memdown": "^5.0.0" - } - }, - "level-packager": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/level-packager/-/level-packager-5.1.1.tgz", - "integrity": "sha512-HMwMaQPlTC1IlcwT3+swhqf/NUO+ZhXVz6TY1zZIIZlIR0YSn8GtAAWmIvKjNY16ZkEg/JcpAuQskxsXqC0yOQ==", - "dev": true, - "requires": { - "encoding-down": "^6.3.0", - "levelup": "^4.3.2" - } - }, - "level-supports": { + "level-transcoder": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/level-supports/-/level-supports-1.0.1.tgz", - "integrity": "sha512-rXM7GYnW8gsl1vedTJIbzOrRv85c/2uCMpiiCzO2fndd06U/kUXEEU9evYn4zFggBOg36IsBW8LzqIpETwwQzg==", + "resolved": "https://registry.npmjs.org/level-transcoder/-/level-transcoder-1.0.1.tgz", + "integrity": "sha512-t7bFwFtsQeD8cl8NIoQ2iwxA0CL/9IFw7/9gAjOonH0PWTTiRfY7Hq+Ejbsxh86tXobDQ6IOiddjNYIfOBs06w==", "dev": true, "requires": { - "xtend": "^4.0.2" - } - }, - "level-ws": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/level-ws/-/level-ws-2.0.0.tgz", - "integrity": "sha512-1iv7VXx0G9ec1isqQZ7y5LmoZo/ewAsyDHNA8EFDW5hqH2Kqovm33nSFkSdnLLAK+I5FlT+lo5Cw9itGe+CpQA==", - "dev": true, - "requires": { - "inherits": "^2.0.3", - "readable-stream": "^3.1.0", - "xtend": "^4.0.1" - } - }, - "levelup": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/levelup/-/levelup-4.4.0.tgz", - "integrity": "sha512-94++VFO3qN95cM/d6eBXvd894oJE0w3cInq9USsyQzzoJxmiYzPAocNcuGCPGGjoXqDVJcr3C1jzt1TSjyaiLQ==", - "dev": true, - "requires": { - "deferred-leveldown": "~5.3.0", - "level-errors": "~2.0.0", - "level-iterator-stream": "~4.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" + "buffer": "^6.0.3", + "module-error": "^1.0.1" } }, "locate-path": { @@ -5479,12 +6591,6 @@ "yallist": "^3.0.2" } }, - "ltgt": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/ltgt/-/ltgt-2.2.1.tgz", - "integrity": "sha512-AI2r85+4MquTw9ZYqabu4nMwy9Oftlfa/e/52t9IjtfG+mGBbTNdAoZ3RQKLHR6r0wQnwZnPIEh/Ya6XTWAKNA==", - "dev": true - }, "mcl-wasm": { "version": "0.7.9", "resolved": "https://registry.npmjs.org/mcl-wasm/-/mcl-wasm-0.7.9.tgz", @@ -5502,39 +6608,15 @@ "safe-buffer": "^5.1.2" } }, - "memdown": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/memdown/-/memdown-5.1.0.tgz", - "integrity": "sha512-B3J+UizMRAlEArDjWHTMmadet+UKwHd3UjMgGBkZcKAxAYVPS9o0Yeiha4qvz7iGiL2Sb3igUft6p7nbFWctpw==", + "memory-level": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/memory-level/-/memory-level-1.0.0.tgz", + "integrity": "sha512-UXzwewuWeHBz5krr7EvehKcmLFNoXxGcvuYhC41tRnkrTbJohtS7kVn9akmgirtRygg+f7Yjsfi8Uu5SGSQ4Og==", "dev": true, "requires": { - "abstract-leveldown": "~6.2.1", - "functional-red-black-tree": "~1.0.1", - "immediate": "~3.2.3", - "inherits": "~2.0.1", - "ltgt": "~2.2.0", - "safe-buffer": "~5.2.0" - }, - "dependencies": { - "abstract-leveldown": { - "version": "6.2.3", - "resolved": "https://registry.npmjs.org/abstract-leveldown/-/abstract-leveldown-6.2.3.tgz", - "integrity": "sha512-BsLm5vFMRUrrLeCcRc+G0t2qOaTzpoJQLOubq2XM72eNpjF5UdU5o/5NvlNhx95XHcAvcl8OMXr4mlg/fRgUXQ==", - "dev": true, - "requires": { - "buffer": "^5.5.0", - "immediate": "^3.2.3", - "level-concat-iterator": "~2.0.0", - "level-supports": "~1.0.0", - "xtend": "~4.0.0" - } - }, - "immediate": { - "version": "3.2.3", - "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.2.3.tgz", - "integrity": "sha512-RrGCXRm/fRVqMIhqXrGEX9rRADavPiDFSoMb/k64i9XMk8uH4r/Omi5Ctierj6XzNecwDbO4WuFbDD1zmpl3Tg==", - "dev": true - } + "abstract-level": "^1.0.0", + "functional-red-black-tree": "^1.0.1", + "module-error": "^1.0.1" } }, "memorystream": { @@ -5543,38 +6625,6 @@ "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", "dev": true }, - "merkle-patricia-tree": { - "version": "4.2.4", - "resolved": "https://registry.npmjs.org/merkle-patricia-tree/-/merkle-patricia-tree-4.2.4.tgz", - "integrity": "sha512-eHbf/BG6eGNsqqfbLED9rIqbsF4+sykEaBn6OLNs71tjclbMcMOk1tEPmJKcNcNCLkvbpY/lwyOlizWsqPNo8w==", - "dev": true, - "requires": { - "@types/levelup": "^4.3.0", - "ethereumjs-util": "^7.1.4", - "level-mem": "^5.0.1", - "level-ws": "^2.0.0", - "readable-stream": "^3.6.0", - "semaphore-async-await": "^1.5.1" - } - }, - "miller-rabin": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", - "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", - "dev": true, - "requires": { - "bn.js": "^4.0.0", - "brorand": "^1.0.1" - }, - "dependencies": { - "bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - } - } - }, "minimalistic-assert": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", @@ -5731,6 +6781,12 @@ } } }, + "module-error": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/module-error/-/module-error-1.0.2.tgz", + "integrity": "sha512-0yuvsqSCv8LbaOKhnsQ/T5JhyFlCYLPXK3U2sgV10zoKQwzs/MyfuQUOZQ1V/6OCOJsK/TRgNVrPuPDqtdMFtA==", + "dev": true + }, "ms": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", @@ -5743,6 +6799,12 @@ "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", "dev": true }, + "napi-macros": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/napi-macros/-/napi-macros-2.2.2.tgz", + "integrity": "sha512-hmEVtAGYzVQpCKdbQea4skABsdXW4RUh5t5mJ2zzqowJS2OyXZTU1KhDVFhx+NlWZ4ap9mqR9TcDO3LTTttd+g==", + "dev": true + }, "node-addon-api": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-2.0.2.tgz", @@ -5761,12 +6823,6 @@ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", "dev": true }, - "object-inspect": { - "version": "1.12.2", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", - "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", - "dev": true - }, "obliterator": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/obliterator/-/obliterator-2.0.4.tgz", @@ -5858,21 +6914,12 @@ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", "dev": true }, - "prr": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", - "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==", + "queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", "dev": true }, - "qs": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", - "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", - "dev": true, - "requires": { - "side-channel": "^1.0.4" - } - }, "randombytes": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", @@ -5963,6 +7010,15 @@ "bn.js": "^5.2.0" } }, + "run-parallel-limit": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/run-parallel-limit/-/run-parallel-limit-1.1.0.tgz", + "integrity": "sha512-jJA7irRNM91jaKc3Hcl1npHsFLOXOoTkPCUL1JEa1R82O2miplXXRaGdjW/KM/98YQWDhJLiSs793CnXfblJUw==", + "dev": true, + "requires": { + "queue-microtask": "^1.2.2" + } + }, "rustbn.js": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/rustbn.js/-/rustbn.js-0.2.0.tgz", @@ -5998,12 +7054,6 @@ "node-gyp-build": "^4.2.0" } }, - "semaphore-async-await": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/semaphore-async-await/-/semaphore-async-await-1.5.1.tgz", - "integrity": "sha512-b/ptP11hETwYWpeilHXXQiV5UJNJl7ZWWooKRE5eBIYWoom6dZ0SluCIdCtKycsMtZgKWE01/qAw6jblw1YVhg==", - "dev": true - }, "semver": { "version": "6.3.0", "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", @@ -6041,23 +7091,6 @@ "safe-buffer": "^5.0.1" } }, - "side-channel": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", - "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", - "dev": true, - "requires": { - "call-bind": "^1.0.0", - "get-intrinsic": "^1.0.2", - "object-inspect": "^1.9.0" - } - }, - "slash": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", - "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", - "dev": true - }, "solc": { "version": "0.7.3", "resolved": "https://registry.npmjs.org/solc/-/solc-0.7.3.tgz", @@ -6221,12 +7254,6 @@ "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", "dev": true }, - "true-case-path": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/true-case-path/-/true-case-path-2.2.1.tgz", - "integrity": "sha512-0z3j8R7MCjy10kc/g+qg7Ln3alJTodw9aDuVWZa3uiWqfuBMKeAeP2ocWcxoyM3D73yz3Jt/Pu4qPr4wHSdB/Q==", - "dev": true - }, "tslib": { "version": "1.14.1", "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", @@ -6258,10 +7285,13 @@ "dev": true }, "undici": { - "version": "5.8.0", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.8.0.tgz", - "integrity": "sha512-1F7Vtcez5w/LwH2G2tGnFIihuWUlc58YidwLiCv+jR2Z50x0tNXpRRw7eOIJ+GvqCqIkg9SB7NWAJ/T9TLfv8Q==", - "dev": true + "version": "5.27.2", + "resolved": "https://registry.npmjs.org/undici/-/undici-5.27.2.tgz", + "integrity": "sha512-iS857PdOEy/y3wlM3yRp+6SNQQ6xU0mmZcwRSriqk+et/cwWAtwmIGf6WkoDN2EK/AMdCO/dfXzIwi+rFMrjjQ==", + "dev": true, + "requires": { + "@fastify/busboy": "^2.0.0" + } }, "universalify": { "version": "0.1.2", @@ -6343,12 +7373,6 @@ "dev": true, "requires": {} }, - "xtend": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", - "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", - "dev": true - }, "y18n": { "version": "5.0.8", "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", diff --git a/package.json b/package.json index 8baeee6..31deec0 100644 --- a/package.json +++ b/package.json @@ -1,8 +1,8 @@ { "scripts": { - "preinstall": "npm i -g ganache-cli@6.12.1" + "preinstall": "npm install --global ganache@7.5.0" }, "devDependencies": { - "hardhat": "^2.10.1" + "hardhat": "^2.19.0" } } diff --git a/requirements.txt b/requirements.txt index 9e9e400..e891439 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,6 +1,6 @@ # -# This file is autogenerated by pip-compile with python 3.10 -# To update, run: +# This file is autogenerated by pip-compile with Python 3.10 +# by the following command: # # pip-compile requirements.in # @@ -16,8 +16,6 @@ ape-ledger==0.5.0 # via -r requirements.in ape-vyper==0.5.0 # via -r requirements.in -appnope==0.1.3 - # via ipython async-timeout==4.0.2 # via aiohttp attrs==22.1.0 @@ -99,6 +97,7 @@ eth-bloom==1.0.4 eth-hash[pycryptodome,pysha3]==0.3.3 # via # eth-bloom + # eth-hash # eth-tester # eth-utils # trie @@ -113,8 +112,10 @@ eth-keys==0.4.0 # py-evm eth-rlp==0.3.0 # via eth-account -eth-tester[py-evm]==v0.7.0-beta.1 - # via web3 +eth-tester[py-evm]==0.7.0b1 + # via + # eth-tester + # web3 eth-typing==3.2.0 # via # ape-ledger @@ -160,6 +161,8 @@ frozenlist==1.3.1 # via # aiohttp # aiosignal +greenlet==3.0.1 + # via sqlalchemy hexbytes==0.3.0 # via # ape-hardhat @@ -417,6 +420,7 @@ web3[tester]==6.0.0b6 # ape-alchemy # ape-hardhat # eth-ape + # web3 websockets==10.3 # via web3 wheel==0.37.1 From e89e4392c13e2e352bd37b67f7509fdb746afa2e Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Mon, 20 Nov 2023 23:17:08 +0100 Subject: [PATCH 03/19] Add boa dependencies, start converting fixtures --- .github/workflows/main.yaml | 28 +- .gitignore | 2 - Dockerfile | 12 +- README.md | 29 +- ape-config.yaml | 29 - hardhat.config.js | 16 - package-lock.json | 7428 ---------------------- package.json | 8 - requirements.in | 6 +- requirements.txt | 427 +- requirements_brownie.in | 8 - requirements_brownie.txt | 400 -- scripts/boa_scripts/set_up_registries.py | 46 +- scripts/setup_metaregistry.py | 2 +- scripts/setup_metaregistry_brownie.py | 346 - tests/conftest.py | 62 +- tests/fixtures/accounts.py | 28 +- tests/fixtures/contracts.py | 9 + tests/fixtures/deployments.py | 1 - 19 files changed, 192 insertions(+), 8695 deletions(-) delete mode 100644 ape-config.yaml delete mode 100644 hardhat.config.js delete mode 100644 package-lock.json delete mode 100644 package.json delete mode 100644 requirements_brownie.in delete mode 100644 requirements_brownie.txt delete mode 100644 scripts/setup_metaregistry_brownie.py create mode 100644 tests/fixtures/contracts.py diff --git a/.github/workflows/main.yaml b/.github/workflows/main.yaml index b86da2f..b5cdca9 100644 --- a/.github/workflows/main.yaml +++ b/.github/workflows/main.yaml @@ -2,12 +2,6 @@ name: unitary on: ["push", "pull_request"] -env: - ETHERSCAN_TOKEN: ${{ secrets.ETHERSKEM_TOKEN }} - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - WEB3_INFURA_PROJECT_ID: ${{ secrets.INFURA_TOKEN }} - WEB3_ALCHEMY_PROJECT_ID: ${{secrets.ALCHEMY_API_KEY}} - jobs: unitary: runs-on: ubuntu-latest @@ -18,25 +12,21 @@ jobs: - name: Cache Compiler Installations uses: actions/cache@v3 with: - path: | - ~/.vvm + path: ~/.vvm key: compiler-cache - - name: Setup Node.js - uses: actions/setup-node@v3 - with: - node-version: 20 - - - name: Install Hardhat - run: npm ci - - - name: Setup Python 3.10 + - name: Setup Python 3.11 uses: actions/setup-python@v4 with: - python-version: 3.10.13 + python-version: 3.11.6 - name: Install Requirements run: pip install -r requirements.txt - name: Run Tests - run: ape test + run: pytest + env: + ETHERSCAN_TOKEN: ${{ secrets.ETHERSKEM_TOKEN }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + WEB3_INFURA_PROJECT_ID: ${{ secrets.INFURA_TOKEN }} + WEB3_ALCHEMY_PROJECT_ID: ${{secrets.ALCHEMY_API_KEY}} diff --git a/.gitignore b/.gitignore index 78c32a4..a70f6d3 100644 --- a/.gitignore +++ b/.gitignore @@ -3,9 +3,7 @@ build/ .python-version .idea .pytest_cache -node_modules/ __pycache__/ .DS_Store venv/ -brownie-venv/ bvenv/ diff --git a/Dockerfile b/Dockerfile index f93232a..82d6aca 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,12 +1,10 @@ -FROM nikolaik/python-nodejs:python3.10-nodejs20 +FROM python:3.11-slim WORKDIR /usr/app -COPY package*.json ./ -RUN npm ci \ - && npm cache clean --force - +RUN pip cache purge COPY requirements.in ./ -RUN pip install -r requirements.in +RUN pip install --upgrade pip && \ + pip install --no-cache-dir -r requirements.in COPY . . -CMD ape test +CMD pytest diff --git a/README.md b/README.md index 719c87b..6c788ee 100644 --- a/README.md +++ b/README.md @@ -387,34 +387,13 @@ Set up the python environment using the following steps: ``` > python -m venv venv -> source ./venv/bin/active -> pip install --upgrade pip +> source ./venv/bin/activate +> python -m pip install --upgrade pip > pip install -r ./requirements.txt ``` -This project uses `eth-ape >= 0.4.0` developed at [Apeworx](https://apeworx.io). The various plugins used are: - -1. [`ape-vyper`](https://github.com/ApeWorX/ape-vyper) -2. [`ape-hardhat`](https://github.com/ApeWorX/ape-hardhat) -3. [`ape-alchemy`](https://github.com/ApeWorX/ape-alchemy) -4. [`ape-ledger`](https://github.com/ApeWorX/ape-ledger) -5. [`ape-etherscan`](https://github.com/ApeWorX/ape-etherscan) - -To install these, please follow instructions laid out in their respective Github repositories (by clicking on the links above). - -Note: If you choose to run tests using `Alchemy` as the upstream provider, please set up an alchemy api key into an environment variable labelled `WEB3_ALCHEMY_PROJECT_ID` or `WEB3_ALCHEMY_API_KEY`. If you choose to use a local node (`geth` or `erigon`) please change the hardhat upstream provider for mainnet-fork to `geth` in [ape-config.yaml](ape-config.yaml): - -``` - -hardhat: - port: auto - fork: - ethereum: - mainnet: - upstream_provider: geth - # upstream_provider: alchemy -``` +This project uses `titanoboa`. ### Testing @@ -480,4 +459,4 @@ Ethereum Mainnet: ### License -(c) Curve.Fi, 2022 - [All rights reserved](LICENSE). +(c) Curve.Fi, 2023 - [All rights reserved](LICENSE). diff --git a/ape-config.yaml b/ape-config.yaml deleted file mode 100644 index 66eca9f..0000000 --- a/ape-config.yaml +++ /dev/null @@ -1,29 +0,0 @@ -name: curve-metaregistry - -plugins: - - name: vyper - - name: alchemy - - name: hardhat - - name: ledger - - name: etherscan - -ethereum: - default_network: mainnet-fork - mainnet_fork: - default_provider: hardhat - transaction_acceptance_timeout: 99999999 - mainnet: - transaction_acceptance_timeout: 99999999 - -hardhat: - port: auto - fork: - ethereum: - mainnet: - upstream_provider: geth - # upstream_provider: alchemy - -geth: - ethereum: - mainnet: - uri: http://localhost:9090 diff --git a/hardhat.config.js b/hardhat.config.js deleted file mode 100644 index be70259..0000000 --- a/hardhat.config.js +++ /dev/null @@ -1,16 +0,0 @@ - -// See https://hardhat.org/config/ for config options. -module.exports = { - networks: { - hardhat: { - hardfork: "london", - // Base fee of 0 allows use of 0 gas price when testing - initialBaseFeePerGas: 0, - accounts: { - mnemonic: "test test test test test test test test test test test junk", - path: "m/44'/60'/0'", - count: 10 - } - }, - }, -}; diff --git a/package-lock.json b/package-lock.json deleted file mode 100644 index c056810..0000000 --- a/package-lock.json +++ /dev/null @@ -1,7428 +0,0 @@ -{ - "name": "metaregistry", - "lockfileVersion": 2, - "requires": true, - "packages": { - "": { - "hasInstallScript": true, - "devDependencies": { - "hardhat": "^2.19.0" - } - }, - "node_modules/@chainsafe/as-sha256": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/@chainsafe/as-sha256/-/as-sha256-0.3.1.tgz", - "integrity": "sha512-hldFFYuf49ed7DAakWVXSJODuq3pzJEguD8tQ7h+sGkM18vja+OFoJI9krnGmgzyuZC2ETX0NOIcCTy31v2Mtg==", - "dev": true - }, - "node_modules/@chainsafe/persistent-merkle-tree": { - "version": "0.4.2", - "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.4.2.tgz", - "integrity": "sha512-lLO3ihKPngXLTus/L7WHKaw9PnNJWizlOF1H9NNzHP6Xvh82vzg9F2bzkXhYIFshMZ2gTCEz8tq6STe7r5NDfQ==", - "dev": true, - "dependencies": { - "@chainsafe/as-sha256": "^0.3.1" - } - }, - "node_modules/@chainsafe/ssz": { - "version": "0.9.4", - "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.9.4.tgz", - "integrity": "sha512-77Qtg2N1ayqs4Bg/wvnWfg5Bta7iy7IRh8XqXh7oNMeP2HBbBwx8m6yTpA8p0EHItWPEBkgZd5S5/LSlp3GXuQ==", - "dev": true, - "dependencies": { - "@chainsafe/as-sha256": "^0.3.1", - "@chainsafe/persistent-merkle-tree": "^0.4.2", - "case": "^1.6.3" - } - }, - "node_modules/@ethersproject/abi": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/abi/-/abi-5.7.0.tgz", - "integrity": "sha512-351ktp42TiRcYB3H1OP8yajPeAQstMW/yCFokj/AthP9bLHzQFPlOrxOcwYEDkUAICmOHljvN4K39OMTMUa9RA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "node_modules/@ethersproject/abstract-provider": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-provider/-/abstract-provider-5.7.0.tgz", - "integrity": "sha512-R41c9UkchKCpAqStMYUpdunjo3pkEvZC3FAwZn5S5MGbXoMQOHIdHItezTETxAO5bevtMApSyEhn9+CHcDsWBw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/networks": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/web": "^5.7.0" - } - }, - "node_modules/@ethersproject/abstract-signer": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-signer/-/abstract-signer-5.7.0.tgz", - "integrity": "sha512-a16V8bq1/Cz+TGCkE2OPMTOUDLS3grCpdjoJCYNnVBbdYEMSgKrU0+B90s8b6H+ByYTBZN7a3g76jdIJi7UfKQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0" - } - }, - "node_modules/@ethersproject/address": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/address/-/address-5.7.0.tgz", - "integrity": "sha512-9wYhYt7aghVGo758POM5nqcOMaE168Q6aRLJZwUmiqSrAungkG74gSSeKEIR7ukixesdRZGPgVqme6vmxs1fkA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/rlp": "^5.7.0" - } - }, - "node_modules/@ethersproject/base64": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/base64/-/base64-5.7.0.tgz", - "integrity": "sha512-Dr8tcHt2mEbsZr/mwTPIQAf3Ai0Bks/7gTw9dSqk1mQvhW3XvRlmDJr/4n+wg1JmCl16NZue17CDh8xb/vZ0sQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0" - } - }, - "node_modules/@ethersproject/basex": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/basex/-/basex-5.7.0.tgz", - "integrity": "sha512-ywlh43GwZLv2Voc2gQVTKBoVQ1mti3d8HK5aMxsfu/nRDnMmNqaSJ3r3n85HBByT8OpoY96SXM1FogC533T4zw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/properties": "^5.7.0" - } - }, - "node_modules/@ethersproject/bignumber": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/bignumber/-/bignumber-5.7.0.tgz", - "integrity": "sha512-n1CAdIHRWjSucQO3MC1zPSVgV/6dy/fjL9pMrPP9peL+QxEg9wOsVqwD4+818B6LUEtaXzVHQiuivzRoxPxUGw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "bn.js": "^5.2.1" - } - }, - "node_modules/@ethersproject/bytes": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/bytes/-/bytes-5.7.0.tgz", - "integrity": "sha512-nsbxwgFXWh9NyYWo+U8atvmMsSdKJprTcICAkvbBffT75qDocbuggBU0SJiVK2MuTrp0q+xvLkTnGMPK1+uA9A==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/logger": "^5.7.0" - } - }, - "node_modules/@ethersproject/constants": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/constants/-/constants-5.7.0.tgz", - "integrity": "sha512-DHI+y5dBNvkpYUMiRQyxRBYBefZkJfo70VUkUAsRjcPs47muV9evftfZ0PJVCXYbAiCgght0DtcF9srFQmIgWA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bignumber": "^5.7.0" - } - }, - "node_modules/@ethersproject/contracts": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/contracts/-/contracts-5.7.0.tgz", - "integrity": "sha512-5GJbzEU3X+d33CdfPhcyS+z8MzsTrBGk/sc+G+59+tPa9yFkl6HQ9D6L0QMgNTA9q8dT0XKxxkyp883XsQvbbg==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abi": "^5.7.0", - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/transactions": "^5.7.0" - } - }, - "node_modules/@ethersproject/hash": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/hash/-/hash-5.7.0.tgz", - "integrity": "sha512-qX5WrQfnah1EFnO5zJv1v46a8HW0+E5xuBBDTwMFZLuVTx0tbU2kkx15NqdjxecrLGatQN9FGQKpb1FKdHCt+g==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/base64": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "node_modules/@ethersproject/hdnode": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/hdnode/-/hdnode-5.7.0.tgz", - "integrity": "sha512-OmyYo9EENBPPf4ERhR7oj6uAtUAhYGqOnIS+jE5pTXvdKBS99ikzq1E7Iv0ZQZ5V36Lqx1qZLeak0Ra16qpeOg==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/basex": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/pbkdf2": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/sha2": "^5.7.0", - "@ethersproject/signing-key": "^5.7.0", - "@ethersproject/strings": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/wordlists": "^5.7.0" - } - }, - "node_modules/@ethersproject/json-wallets": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/json-wallets/-/json-wallets-5.7.0.tgz", - "integrity": "sha512-8oee5Xgu6+RKgJTkvEMl2wDgSPSAQ9MB/3JYjFV9jlKvcYHUXZC+cQp0njgmxdHkYWn8s6/IqIZYm0YWCjO/0g==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/hdnode": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/pbkdf2": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/random": "^5.7.0", - "@ethersproject/strings": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "aes-js": "3.0.0", - "scrypt-js": "3.0.1" - } - }, - "node_modules/@ethersproject/keccak256": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/keccak256/-/keccak256-5.7.0.tgz", - "integrity": "sha512-2UcPboeL/iW+pSg6vZ6ydF8tCnv3Iu/8tUmLLzWWGzxWKFFqOBQFLo6uLUv6BDrLgCDfN28RJ/wtByx+jZ4KBg==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "js-sha3": "0.8.0" - } - }, - "node_modules/@ethersproject/logger": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/logger/-/logger-5.7.0.tgz", - "integrity": "sha512-0odtFdXu/XHtjQXJYA3u9G0G8btm0ND5Cu8M7i5vhEcE8/HmF4Lbdqanwyv4uQTr2tx6b7fQRmgLrsnpQlmnig==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ] - }, - "node_modules/@ethersproject/networks": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/@ethersproject/networks/-/networks-5.7.1.tgz", - "integrity": "sha512-n/MufjFYv3yFcUyfhnXotyDlNdFb7onmkSy8aQERi2PjNcnWQ66xXxa3XlS8nCcA8aJKJjIIMNJTC7tu80GwpQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/logger": "^5.7.0" - } - }, - "node_modules/@ethersproject/pbkdf2": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/pbkdf2/-/pbkdf2-5.7.0.tgz", - "integrity": "sha512-oR/dBRZR6GTyaofd86DehG72hY6NpAjhabkhxgr3X2FpJtJuodEl2auADWBZfhDHgVCbu3/H/Ocq2uC6dpNjjw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/sha2": "^5.7.0" - } - }, - "node_modules/@ethersproject/properties": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/properties/-/properties-5.7.0.tgz", - "integrity": "sha512-J87jy8suntrAkIZtecpxEPxY//szqr1mlBaYlQ0r4RCaiD2hjheqF9s1LVE8vVuJCXisjIP+JgtK/Do54ej4Sw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/logger": "^5.7.0" - } - }, - "node_modules/@ethersproject/providers": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/@ethersproject/providers/-/providers-5.7.2.tgz", - "integrity": "sha512-g34EWZ1WWAVgr4aptGlVBF8mhl3VWjv+8hoAnzStu8Ah22VHBsuGzP17eb6xDVRzw895G4W7vvx60lFFur/1Rg==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/base64": "^5.7.0", - "@ethersproject/basex": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/networks": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/random": "^5.7.0", - "@ethersproject/rlp": "^5.7.0", - "@ethersproject/sha2": "^5.7.0", - "@ethersproject/strings": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/web": "^5.7.0", - "bech32": "1.1.4", - "ws": "7.4.6" - } - }, - "node_modules/@ethersproject/providers/node_modules/ws": { - "version": "7.4.6", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.6.tgz", - "integrity": "sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A==", - "dev": true, - "engines": { - "node": ">=8.3.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": "^5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - }, - "node_modules/@ethersproject/random": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/random/-/random-5.7.0.tgz", - "integrity": "sha512-19WjScqRA8IIeWclFme75VMXSBvi4e6InrUNuaR4s5pTF2qNhcGdCUwdxUVGtDDqC00sDLCO93jPQoDUH4HVmQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "node_modules/@ethersproject/rlp": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/rlp/-/rlp-5.7.0.tgz", - "integrity": "sha512-rBxzX2vK8mVF7b0Tol44t5Tb8gomOHkj5guL+HhzQ1yBh/ydjGnpw6at+X6Iw0Kp3OzzzkcKp8N9r0W4kYSs9w==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "node_modules/@ethersproject/sha2": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/sha2/-/sha2-5.7.0.tgz", - "integrity": "sha512-gKlH42riwb3KYp0reLsFTokByAKoJdgFCwI+CCiX/k+Jm2mbNs6oOaCjYQSlI1+XBVejwH2KrmCbMAT/GnRDQw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "hash.js": "1.1.7" - } - }, - "node_modules/@ethersproject/signing-key": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/signing-key/-/signing-key-5.7.0.tgz", - "integrity": "sha512-MZdy2nL3wO0u7gkB4nA/pEf8lu1TlFswPNmy8AiYkfKTdO6eXBJyUdmHO/ehm/htHw9K/qF8ujnTyUAD+Ry54Q==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "bn.js": "^5.2.1", - "elliptic": "6.5.4", - "hash.js": "1.1.7" - } - }, - "node_modules/@ethersproject/solidity": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/solidity/-/solidity-5.7.0.tgz", - "integrity": "sha512-HmabMd2Dt/raavyaGukF4XxizWKhKQ24DoLtdNbBmNKUOPqwjsKQSdV9GQtj9CBEea9DlzETlVER1gYeXXBGaA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/sha2": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "node_modules/@ethersproject/strings": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/strings/-/strings-5.7.0.tgz", - "integrity": "sha512-/9nu+lj0YswRNSH0NXYqrh8775XNyEdUQAuf3f+SmOrnVewcJ5SBNAjF7lpgehKi4abvNNXyf+HX86czCdJ8Mg==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "node_modules/@ethersproject/transactions": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/transactions/-/transactions-5.7.0.tgz", - "integrity": "sha512-kmcNicCp1lp8qanMTC3RIikGgoJ80ztTyvtsFvCYpSCfkjhD0jZ2LOrnbcuxuToLIUYYf+4XwD1rP+B/erDIhQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/rlp": "^5.7.0", - "@ethersproject/signing-key": "^5.7.0" - } - }, - "node_modules/@ethersproject/units": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/units/-/units-5.7.0.tgz", - "integrity": "sha512-pD3xLMy3SJu9kG5xDGI7+xhTEmGXlEqXU4OfNapmfnxLVY4EMSSRp7j1k7eezutBPH7RBN/7QPnwR7hzNlEFeg==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "node_modules/@ethersproject/wallet": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/wallet/-/wallet-5.7.0.tgz", - "integrity": "sha512-MhmXlJXEJFBFVKrDLB4ZdDzxcBxQ3rLyCkhNqVu3CDYvR97E+8r01UgrI+TI99Le+aYm/in/0vp86guJuM7FCA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/hdnode": "^5.7.0", - "@ethersproject/json-wallets": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/random": "^5.7.0", - "@ethersproject/signing-key": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/wordlists": "^5.7.0" - } - }, - "node_modules/@ethersproject/web": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/@ethersproject/web/-/web-5.7.1.tgz", - "integrity": "sha512-Gueu8lSvyjBWL4cYsWsjh6MtMwM0+H4HvqFPZfB6dV8ctbP9zFAO73VG1cMWae0FLPCtz0peKPpZY8/ugJJX2w==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/base64": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "node_modules/@ethersproject/wordlists": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/wordlists/-/wordlists-5.7.0.tgz", - "integrity": "sha512-S2TFNJNfHWVHNE6cNDjbVlZ6MgE17MIxMbMg2zv3wn+3XSJGosL1m9ZVv3GXCf/2ymSsQ+hRI5IzoMJTG6aoVA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "node_modules/@fastify/busboy": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.0.tgz", - "integrity": "sha512-+KpH+QxZU7O4675t3mnkQKcZZg56u+K/Ct2K+N2AZYNVK8kyeo/bI18tI8aPm3tvNNRyTWfj6s5tnGNlcbQRsA==", - "dev": true, - "engines": { - "node": ">=14" - } - }, - "node_modules/@metamask/eth-sig-util": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/@metamask/eth-sig-util/-/eth-sig-util-4.0.1.tgz", - "integrity": "sha512-tghyZKLHZjcdlDqCA3gNZmLeR0XvOE9U1qoQO9ohyAZT6Pya+H9vkBPcsyXytmYLNgVoin7CKCmweo/R43V+tQ==", - "dev": true, - "dependencies": { - "ethereumjs-abi": "^0.6.8", - "ethereumjs-util": "^6.2.1", - "ethjs-util": "^0.1.6", - "tweetnacl": "^1.0.3", - "tweetnacl-util": "^0.15.1" - }, - "engines": { - "node": ">=12.0.0" - } - }, - "node_modules/@metamask/eth-sig-util/node_modules/@types/bn.js": { - "version": "4.11.6", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-4.11.6.tgz", - "integrity": "sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@metamask/eth-sig-util/node_modules/bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - }, - "node_modules/@metamask/eth-sig-util/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz", - "integrity": "sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw==", - "dev": true, - "dependencies": { - "@types/bn.js": "^4.11.3", - "bn.js": "^4.11.0", - "create-hash": "^1.1.2", - "elliptic": "^6.5.2", - "ethereum-cryptography": "^0.1.3", - "ethjs-util": "0.1.6", - "rlp": "^2.2.3" - } - }, - "node_modules/@noble/hashes": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.1.2.tgz", - "integrity": "sha512-KYRCASVTv6aeUi1tsF8/vpyR7zpfs3FUzy2Jqm+MU+LmUKhQ0y2FpfwqkCcxSg2ua4GALJd8k2R76WxwZGbQpA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ] - }, - "node_modules/@noble/secp256k1": { - "version": "1.6.3", - "resolved": "https://registry.npmjs.org/@noble/secp256k1/-/secp256k1-1.6.3.tgz", - "integrity": "sha512-T04e4iTurVy7I8Sw4+c5OSN9/RkPlo1uKxAomtxQNLq8j1uPAqnsqG1bqvY3Jv7c13gyr6dui0zmh/I3+f/JaQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ] - }, - "node_modules/@nomicfoundation/ethereumjs-block": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-block/-/ethereumjs-block-5.0.2.tgz", - "integrity": "sha512-hSe6CuHI4SsSiWWjHDIzWhSiAVpzMUcDRpWYzN0T9l8/Rz7xNn3elwVOJ/tAyS0LqL6vitUD78Uk7lQDXZun7Q==", - "dev": true, - "dependencies": { - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "ethereum-cryptography": "0.1.3", - "ethers": "^5.7.1" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-block/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-blockchain": { - "version": "7.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-blockchain/-/ethereumjs-blockchain-7.0.2.tgz", - "integrity": "sha512-8UUsSXJs+MFfIIAKdh3cG16iNmWzWC/91P40sazNvrqhhdR/RtGDlFk2iFTGbBAZPs2+klZVzhRX8m2wvuvz3w==", - "dev": true, - "dependencies": { - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-ethash": "3.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "abstract-level": "^1.0.3", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "level": "^8.0.0", - "lru-cache": "^5.1.1", - "memory-level": "^1.0.0" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-blockchain/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-common": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-common/-/ethereumjs-common-4.0.2.tgz", - "integrity": "sha512-I2WGP3HMGsOoycSdOTSqIaES0ughQTueOsddJ36aYVpI3SN8YSusgRFLwzDJwRFVIYDKx/iJz0sQ5kBHVgdDwg==", - "dev": true, - "dependencies": { - "@nomicfoundation/ethereumjs-util": "9.0.2", - "crc-32": "^1.2.0" - } - }, - "node_modules/@nomicfoundation/ethereumjs-ethash": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-ethash/-/ethereumjs-ethash-3.0.2.tgz", - "integrity": "sha512-8PfoOQCcIcO9Pylq0Buijuq/O73tmMVURK0OqdjhwqcGHYC2PwhbajDh7GZ55ekB0Px197ajK3PQhpKoiI/UPg==", - "dev": true, - "dependencies": { - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "abstract-level": "^1.0.3", - "bigint-crypto-utils": "^3.0.23", - "ethereum-cryptography": "0.1.3" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-ethash/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-evm": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-evm/-/ethereumjs-evm-2.0.2.tgz", - "integrity": "sha512-rBLcUaUfANJxyOx9HIdMX6uXGin6lANCulIm/pjMgRqfiCRMZie3WKYxTSd8ZE/d+qT+zTedBF4+VHTdTSePmQ==", - "dev": true, - "dependencies": { - "@ethersproject/providers": "^5.7.1", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "mcl-wasm": "^0.7.1", - "rustbn.js": "~0.2.0" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-evm/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-rlp": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-rlp/-/ethereumjs-rlp-5.0.2.tgz", - "integrity": "sha512-QwmemBc+MMsHJ1P1QvPl8R8p2aPvvVcKBbvHnQOKBpBztEo0omN0eaob6FeZS/e3y9NSe+mfu3nNFBHszqkjTA==", - "dev": true, - "bin": { - "rlp": "bin/rlp" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-statemanager": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-statemanager/-/ethereumjs-statemanager-2.0.2.tgz", - "integrity": "sha512-dlKy5dIXLuDubx8Z74sipciZnJTRSV/uHG48RSijhgm1V7eXYFC567xgKtsKiVZB1ViTP9iFL4B6Je0xD6X2OA==", - "dev": true, - "dependencies": { - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "ethers": "^5.7.1", - "js-sdsl": "^4.1.4" - } - }, - "node_modules/@nomicfoundation/ethereumjs-statemanager/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-trie": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-trie/-/ethereumjs-trie-6.0.2.tgz", - "integrity": "sha512-yw8vg9hBeLYk4YNg5MrSJ5H55TLOv2FSWUTROtDtTMMmDGROsAu+0tBjiNGTnKRi400M6cEzoFfa89Fc5k8NTQ==", - "dev": true, - "dependencies": { - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "@types/readable-stream": "^2.3.13", - "ethereum-cryptography": "0.1.3", - "readable-stream": "^3.6.0" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-trie/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-tx": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-tx/-/ethereumjs-tx-5.0.2.tgz", - "integrity": "sha512-T+l4/MmTp7VhJeNloMkM+lPU3YMUaXdcXgTGCf8+ZFvV9NYZTRLFekRwlG6/JMmVfIfbrW+dRRJ9A6H5Q/Z64g==", - "dev": true, - "dependencies": { - "@chainsafe/ssz": "^0.9.2", - "@ethersproject/providers": "^5.7.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "ethereum-cryptography": "0.1.3" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-tx/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-util": { - "version": "9.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-util/-/ethereumjs-util-9.0.2.tgz", - "integrity": "sha512-4Wu9D3LykbSBWZo8nJCnzVIYGvGCuyiYLIJa9XXNVt1q1jUzHdB+sJvx95VGCpPkCT+IbLecW6yfzy3E1bQrwQ==", - "dev": true, - "dependencies": { - "@chainsafe/ssz": "^0.10.0", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "ethereum-cryptography": "0.1.3" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-util/node_modules/@chainsafe/persistent-merkle-tree": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.5.0.tgz", - "integrity": "sha512-l0V1b5clxA3iwQLXP40zYjyZYospQLZXzBVIhhr9kDg/1qHZfzzHw0jj4VPBijfYCArZDlPkRi1wZaV2POKeuw==", - "dev": true, - "dependencies": { - "@chainsafe/as-sha256": "^0.3.1" - } - }, - "node_modules/@nomicfoundation/ethereumjs-util/node_modules/@chainsafe/ssz": { - "version": "0.10.2", - "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.10.2.tgz", - "integrity": "sha512-/NL3Lh8K+0q7A3LsiFq09YXS9fPE+ead2rr7vM2QK8PLzrNsw3uqrif9bpRX5UxgeRjM+vYi+boCM3+GM4ovXg==", - "dev": true, - "dependencies": { - "@chainsafe/as-sha256": "^0.3.1", - "@chainsafe/persistent-merkle-tree": "^0.5.0" - } - }, - "node_modules/@nomicfoundation/ethereumjs-util/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/ethereumjs-vm": { - "version": "7.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-vm/-/ethereumjs-vm-7.0.2.tgz", - "integrity": "sha512-Bj3KZT64j54Tcwr7Qm/0jkeZXJMfdcAtRBedou+Hx0dPOSIgqaIr0vvLwP65TpHbak2DmAq+KJbW2KNtIoFwvA==", - "dev": true, - "dependencies": { - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-blockchain": "7.0.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-evm": "2.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-statemanager": "2.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "mcl-wasm": "^0.7.1", - "rustbn.js": "~0.2.0" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@nomicfoundation/ethereumjs-vm/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer/-/solidity-analyzer-0.1.1.tgz", - "integrity": "sha512-1LMtXj1puAxyFusBgUIy5pZk3073cNXYnXUpuNKFghHbIit/xZgbk0AokpUADbNm3gyD6bFWl3LRFh3dhVdREg==", - "dev": true, - "engines": { - "node": ">= 12" - }, - "optionalDependencies": { - "@nomicfoundation/solidity-analyzer-darwin-arm64": "0.1.1", - "@nomicfoundation/solidity-analyzer-darwin-x64": "0.1.1", - "@nomicfoundation/solidity-analyzer-freebsd-x64": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-arm64-musl": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-x64-gnu": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-x64-musl": "0.1.1", - "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": "0.1.1", - "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": "0.1.1", - "@nomicfoundation/solidity-analyzer-win32-x64-msvc": "0.1.1" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-darwin-arm64": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-arm64/-/solidity-analyzer-darwin-arm64-0.1.1.tgz", - "integrity": "sha512-KcTodaQw8ivDZyF+D76FokN/HdpgGpfjc/gFCImdLUyqB6eSWVaZPazMbeAjmfhx3R0zm/NYVzxwAokFKgrc0w==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-darwin-x64": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-x64/-/solidity-analyzer-darwin-x64-0.1.1.tgz", - "integrity": "sha512-XhQG4BaJE6cIbjAVtzGOGbK3sn1BO9W29uhk9J8y8fZF1DYz0Doj8QDMfpMu+A6TjPDs61lbsmeYodIDnfveSA==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-freebsd-x64": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-freebsd-x64/-/solidity-analyzer-freebsd-x64-0.1.1.tgz", - "integrity": "sha512-GHF1VKRdHW3G8CndkwdaeLkVBi5A9u2jwtlS7SLhBc8b5U/GcoL39Q+1CSO3hYqePNP+eV5YI7Zgm0ea6kMHoA==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "freebsd" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-linux-arm64-gnu": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-gnu/-/solidity-analyzer-linux-arm64-gnu-0.1.1.tgz", - "integrity": "sha512-g4Cv2fO37ZsUENQ2vwPnZc2zRenHyAxHcyBjKcjaSmmkKrFr64yvzeNO8S3GBFCo90rfochLs99wFVGT/0owpg==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-linux-arm64-musl": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-musl/-/solidity-analyzer-linux-arm64-musl-0.1.1.tgz", - "integrity": "sha512-WJ3CE5Oek25OGE3WwzK7oaopY8xMw9Lhb0mlYuJl/maZVo+WtP36XoQTb7bW/i8aAdHW5Z+BqrHMux23pvxG3w==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-linux-x64-gnu": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-gnu/-/solidity-analyzer-linux-x64-gnu-0.1.1.tgz", - "integrity": "sha512-5WN7leSr5fkUBBjE4f3wKENUy9HQStu7HmWqbtknfXkkil+eNWiBV275IOlpXku7v3uLsXTOKpnnGHJYI2qsdA==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-linux-x64-musl": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-musl/-/solidity-analyzer-linux-x64-musl-0.1.1.tgz", - "integrity": "sha512-KdYMkJOq0SYPQMmErv/63CwGwMm5XHenEna9X9aB8mQmhDBrYrlAOSsIPgFCUSL0hjxE3xHP65/EPXR/InD2+w==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-win32-arm64-msvc": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-arm64-msvc/-/solidity-analyzer-win32-arm64-msvc-0.1.1.tgz", - "integrity": "sha512-VFZASBfl4qiBYwW5xeY20exWhmv6ww9sWu/krWSesv3q5hA0o1JuzmPHR4LPN6SUZj5vcqci0O6JOL8BPw+APg==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-win32-ia32-msvc": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-ia32-msvc/-/solidity-analyzer-win32-ia32-msvc-0.1.1.tgz", - "integrity": "sha512-JnFkYuyCSA70j6Si6cS1A9Gh1aHTEb8kOTBApp/c7NRTFGNMH8eaInKlyuuiIbvYFhlXW4LicqyYuWNNq9hkpQ==", - "cpu": [ - "ia32" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@nomicfoundation/solidity-analyzer-win32-x64-msvc": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-x64-msvc/-/solidity-analyzer-win32-x64-msvc-0.1.1.tgz", - "integrity": "sha512-HrVJr6+WjIXGnw3Q9u6KQcbZCtk0caVWhCdFADySvRyUxJ8PnzlaP+MhwNE8oyT8OZ6ejHBRrrgjSqDCFXGirw==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">= 10" - } - }, - "node_modules/@scure/base": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@scure/base/-/base-1.1.1.tgz", - "integrity": "sha512-ZxOhsSyxYwLJj3pLZCefNitxsj093tb2vq90mp2txoYeBqbcjDjqFhyM8eUjq/uFm6zJ+mUuqxlS2FkuSY1MTA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ] - }, - "node_modules/@scure/bip32": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@scure/bip32/-/bip32-1.1.0.tgz", - "integrity": "sha512-ftTW3kKX54YXLCxH6BB7oEEoJfoE2pIgw7MINKAs5PsS6nqKPuKk1haTF/EuHmYqG330t5GSrdmtRuHaY1a62Q==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], - "dependencies": { - "@noble/hashes": "~1.1.1", - "@noble/secp256k1": "~1.6.0", - "@scure/base": "~1.1.0" - } - }, - "node_modules/@scure/bip39": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@scure/bip39/-/bip39-1.1.0.tgz", - "integrity": "sha512-pwrPOS16VeTKg98dYXQyIjJEcWfz7/1YJIwxUEPFfQPtc86Ym/1sVgQ2RLoD43AazMk2l/unK4ITySSpW2+82w==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], - "dependencies": { - "@noble/hashes": "~1.1.1", - "@scure/base": "~1.1.0" - } - }, - "node_modules/@sentry/core": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/core/-/core-5.30.0.tgz", - "integrity": "sha512-TmfrII8w1PQZSZgPpUESqjB+jC6MvZJZdLtE/0hZ+SrnKhW3x5WlYLvTXZpcWePYBku7rl2wn1RZu6uT0qCTeg==", - "dev": true, - "dependencies": { - "@sentry/hub": "5.30.0", - "@sentry/minimal": "5.30.0", - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "tslib": "^1.9.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@sentry/hub": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/hub/-/hub-5.30.0.tgz", - "integrity": "sha512-2tYrGnzb1gKz2EkMDQcfLrDTvmGcQPuWxLnJKXJvYTQDGLlEvi2tWz1VIHjunmOvJrB5aIQLhm+dcMRwFZDCqQ==", - "dev": true, - "dependencies": { - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "tslib": "^1.9.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@sentry/minimal": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/minimal/-/minimal-5.30.0.tgz", - "integrity": "sha512-BwWb/owZKtkDX+Sc4zCSTNcvZUq7YcH3uAVlmh/gtR9rmUvbzAA3ewLuB3myi4wWRAMEtny6+J/FN/x+2wn9Xw==", - "dev": true, - "dependencies": { - "@sentry/hub": "5.30.0", - "@sentry/types": "5.30.0", - "tslib": "^1.9.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@sentry/node": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/node/-/node-5.30.0.tgz", - "integrity": "sha512-Br5oyVBF0fZo6ZS9bxbJZG4ApAjRqAnqFFurMVJJdunNb80brh7a5Qva2kjhm+U6r9NJAB5OmDyPkA1Qnt+QVg==", - "dev": true, - "dependencies": { - "@sentry/core": "5.30.0", - "@sentry/hub": "5.30.0", - "@sentry/tracing": "5.30.0", - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "cookie": "^0.4.1", - "https-proxy-agent": "^5.0.0", - "lru_map": "^0.3.3", - "tslib": "^1.9.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@sentry/tracing": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/tracing/-/tracing-5.30.0.tgz", - "integrity": "sha512-dUFowCr0AIMwiLD7Fs314Mdzcug+gBVo/+NCMyDw8tFxJkwWAKl7Qa2OZxLQ0ZHjakcj1hNKfCQJ9rhyfOl4Aw==", - "dev": true, - "dependencies": { - "@sentry/hub": "5.30.0", - "@sentry/minimal": "5.30.0", - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "tslib": "^1.9.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@sentry/types": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/types/-/types-5.30.0.tgz", - "integrity": "sha512-R8xOqlSTZ+htqrfteCWU5Nk0CDN5ApUTvrlvBuiH1DyP6czDZ4ktbZB0hAgBlVcK0U+qpD3ag3Tqqpa5Q67rPw==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/@sentry/utils": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/utils/-/utils-5.30.0.tgz", - "integrity": "sha512-zaYmoH0NWWtvnJjC9/CBseXMtKHm/tm40sz3YfJRxeQjyzRqNQPgivpd9R/oDJCYj999mzdW382p/qi2ypjLww==", - "dev": true, - "dependencies": { - "@sentry/types": "5.30.0", - "tslib": "^1.9.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@types/bn.js": { - "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-5.1.5.tgz", - "integrity": "sha512-V46N0zwKRF5Q00AZ6hWtN0T8gGmDUaUzLWQvHFo5yThtVwK/VCenFY3wXVbOvNfajEpsTfQM4IN9k/d6gUVX3A==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/lru-cache": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/@types/lru-cache/-/lru-cache-5.1.1.tgz", - "integrity": "sha512-ssE3Vlrys7sdIzs5LOxCzTVMsU7i9oa/IaW92wF32JFb3CVczqOkru2xspuKczHEbG3nvmPY7IFqVmGGHdNbYw==", - "dev": true - }, - "node_modules/@types/node": { - "version": "18.0.6", - "resolved": "https://registry.npmjs.org/@types/node/-/node-18.0.6.tgz", - "integrity": "sha512-/xUq6H2aQm261exT6iZTMifUySEt4GR5KX8eYyY+C4MSNPqSh9oNIP7tz2GLKTlFaiBbgZNxffoR3CVRG+cljw==", - "dev": true - }, - "node_modules/@types/pbkdf2": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@types/pbkdf2/-/pbkdf2-3.1.0.tgz", - "integrity": "sha512-Cf63Rv7jCQ0LaL8tNXmEyqTHuIJxRdlS5vMh1mj5voN4+QFhVZnlZruezqpWYDiJ8UTzhP0VmeLXCmBk66YrMQ==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/readable-stream": { - "version": "2.3.15", - "resolved": "https://registry.npmjs.org/@types/readable-stream/-/readable-stream-2.3.15.tgz", - "integrity": "sha512-oM5JSKQCcICF1wvGgmecmHldZ48OZamtMxcGGVICOJA8o8cahXC1zEVAif8iwoc5j8etxFaRFnf095+CDsuoFQ==", - "dev": true, - "dependencies": { - "@types/node": "*", - "safe-buffer": "~5.1.1" - } - }, - "node_modules/@types/readable-stream/node_modules/safe-buffer": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", - "dev": true - }, - "node_modules/@types/secp256k1": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/@types/secp256k1/-/secp256k1-4.0.3.tgz", - "integrity": "sha512-Da66lEIFeIz9ltsdMZcpQvmrmmoqrfju8pm1BH8WbYjZSwUgCwXLb9C+9XYogwBITnbsSaMdVPb2ekf7TV+03w==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@ungap/promise-all-settled": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", - "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", - "dev": true - }, - "node_modules/abstract-level": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/abstract-level/-/abstract-level-1.0.3.tgz", - "integrity": "sha512-t6jv+xHy+VYwc4xqZMn2Pa9DjcdzvzZmQGRjTFc8spIbRGHgBrEKbPq+rYXc7CCo0lxgYvSgKVg9qZAhpVQSjA==", - "dev": true, - "dependencies": { - "buffer": "^6.0.3", - "catering": "^2.1.0", - "is-buffer": "^2.0.5", - "level-supports": "^4.0.0", - "level-transcoder": "^1.0.1", - "module-error": "^1.0.1", - "queue-microtask": "^1.2.3" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/adm-zip": { - "version": "0.4.16", - "resolved": "https://registry.npmjs.org/adm-zip/-/adm-zip-0.4.16.tgz", - "integrity": "sha512-TFi4HBKSGfIKsK5YCkKaaFG2m4PEDyViZmEwof3MTIgzimHLto6muaHVpbrljdIvIrFZzEq/p4nafOeLcYegrg==", - "dev": true, - "engines": { - "node": ">=0.3.0" - } - }, - "node_modules/aes-js": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/aes-js/-/aes-js-3.0.0.tgz", - "integrity": "sha512-H7wUZRn8WpTq9jocdxQ2c8x2sKo9ZVmzfRE13GiNJXfp7NcKYEdvl3vspKjXox6RIG2VtaRe4JFvxG4rqp2Zuw==", - "dev": true - }, - "node_modules/agent-base": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", - "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", - "dev": true, - "dependencies": { - "debug": "4" - }, - "engines": { - "node": ">= 6.0.0" - } - }, - "node_modules/aggregate-error": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", - "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", - "dev": true, - "dependencies": { - "clean-stack": "^2.0.0", - "indent-string": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/ansi-colors": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", - "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/ansi-escapes": { - "version": "4.3.2", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", - "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", - "dev": true, - "dependencies": { - "type-fest": "^0.21.3" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "dependencies": { - "color-convert": "^1.9.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/anymatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", - "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", - "dev": true, - "dependencies": { - "normalize-path": "^3.0.0", - "picomatch": "^2.0.4" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true - }, - "node_modules/balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", - "dev": true - }, - "node_modules/base-x": { - "version": "3.0.9", - "resolved": "https://registry.npmjs.org/base-x/-/base-x-3.0.9.tgz", - "integrity": "sha512-H7JU6iBHTal1gp56aKoaa//YUxEaAOUiydvrV/pILqIHXTtqxSkATOnDA2u+jZ/61sD+L/412+7kzXRtWukhpQ==", - "dev": true, - "dependencies": { - "safe-buffer": "^5.0.1" - } - }, - "node_modules/base64-js": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", - "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/bech32": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/bech32/-/bech32-1.1.4.tgz", - "integrity": "sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==", - "dev": true - }, - "node_modules/bigint-crypto-utils": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/bigint-crypto-utils/-/bigint-crypto-utils-3.3.0.tgz", - "integrity": "sha512-jOTSb+drvEDxEq6OuUybOAv/xxoh3cuYRUIPyu8sSHQNKM303UQ2R1DAo45o1AkcIXw6fzbaFI1+xGGdaXs2lg==", - "dev": true, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/binary-extensions": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", - "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/blakejs": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/blakejs/-/blakejs-1.2.1.tgz", - "integrity": "sha512-QXUSXI3QVc/gJME0dBpXrag1kbzOqCjCX8/b54ntNyW6sjtoqxqRk3LTmXzaJoh71zMsDCjM+47jS7XiwN/+fQ==", - "dev": true - }, - "node_modules/bn.js": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-5.2.1.tgz", - "integrity": "sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ==", - "dev": true - }, - "node_modules/brace-expansion": { - "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", - "dev": true, - "dependencies": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "node_modules/braces": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", - "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", - "dev": true, - "dependencies": { - "fill-range": "^7.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/brorand": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", - "integrity": "sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w==", - "dev": true - }, - "node_modules/browser-level": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/browser-level/-/browser-level-1.0.1.tgz", - "integrity": "sha512-XECYKJ+Dbzw0lbydyQuJzwNXtOpbMSq737qxJN11sIRTErOMShvDpbzTlgju7orJKvx4epULolZAuJGLzCmWRQ==", - "dev": true, - "dependencies": { - "abstract-level": "^1.0.2", - "catering": "^2.1.1", - "module-error": "^1.0.2", - "run-parallel-limit": "^1.1.0" - } - }, - "node_modules/browser-stdout": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", - "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", - "dev": true - }, - "node_modules/browserify-aes": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", - "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", - "dev": true, - "dependencies": { - "buffer-xor": "^1.0.3", - "cipher-base": "^1.0.0", - "create-hash": "^1.1.0", - "evp_bytestokey": "^1.0.3", - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "node_modules/browserify-aes/node_modules/buffer-xor": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", - "integrity": "sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ==", - "dev": true - }, - "node_modules/bs58": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/bs58/-/bs58-4.0.1.tgz", - "integrity": "sha512-Ok3Wdf5vOIlBrgCvTq96gBkJw+JUEzdBgyaza5HLtPm7yTHkjRy8+JzNyHF7BHa0bNWOQIp3m5YF0nnFcOIKLw==", - "dev": true, - "dependencies": { - "base-x": "^3.0.2" - } - }, - "node_modules/bs58check": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/bs58check/-/bs58check-2.1.2.tgz", - "integrity": "sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA==", - "dev": true, - "dependencies": { - "bs58": "^4.0.0", - "create-hash": "^1.1.0", - "safe-buffer": "^5.1.2" - } - }, - "node_modules/buffer": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", - "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "dependencies": { - "base64-js": "^1.3.1", - "ieee754": "^1.2.1" - } - }, - "node_modules/buffer-from": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", - "dev": true - }, - "node_modules/bytes": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", - "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/case": { - "version": "1.6.3", - "resolved": "https://registry.npmjs.org/case/-/case-1.6.3.tgz", - "integrity": "sha512-mzDSXIPaFwVDvZAHqZ9VlbyF4yyXRuX6IvB06WvPYkqJVO24kX1PPhv9bfpKNFZyxYFmmgo03HUiD8iklmJYRQ==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/catering": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/catering/-/catering-2.1.1.tgz", - "integrity": "sha512-K7Qy8O9p76sL3/3m7/zLKbRkyOlSZAgzEaLhyj2mXS8PsCud2Eo4hAb8aLtZqHh0QGqLcb9dlJSu6lHRVENm1w==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "dependencies": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/chokidar": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", - "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], - "dependencies": { - "anymatch": "~3.1.2", - "braces": "~3.0.2", - "glob-parent": "~5.1.2", - "is-binary-path": "~2.1.0", - "is-glob": "~4.0.1", - "normalize-path": "~3.0.0", - "readdirp": "~3.6.0" - }, - "engines": { - "node": ">= 8.10.0" - }, - "optionalDependencies": { - "fsevents": "~2.3.2" - } - }, - "node_modules/ci-info": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", - "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", - "dev": true - }, - "node_modules/cipher-base": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", - "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", - "dev": true, - "dependencies": { - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "node_modules/classic-level": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/classic-level/-/classic-level-1.3.0.tgz", - "integrity": "sha512-iwFAJQYtqRTRM0F6L8h4JCt00ZSGdOyqh7yVrhhjrOpFhmBjNlRUey64MCiyo6UmQHMJ+No3c81nujPv+n9yrg==", - "dev": true, - "hasInstallScript": true, - "dependencies": { - "abstract-level": "^1.0.2", - "catering": "^2.1.0", - "module-error": "^1.0.1", - "napi-macros": "^2.2.2", - "node-gyp-build": "^4.3.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/clean-stack": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", - "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dev": true, - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" - } - }, - "node_modules/color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dev": true, - "dependencies": { - "color-name": "1.1.3" - } - }, - "node_modules/color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", - "dev": true - }, - "node_modules/command-exists": { - "version": "1.2.9", - "resolved": "https://registry.npmjs.org/command-exists/-/command-exists-1.2.9.tgz", - "integrity": "sha512-LTQ/SGc+s0Xc0Fu5WaKnR0YiygZkm9eKFvyS+fRsU7/ZWFF8ykFM6Pc9aCVf1+xasOOZpO3BAVgVrKvsqKHV7w==", - "dev": true - }, - "node_modules/commander": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/commander/-/commander-3.0.2.tgz", - "integrity": "sha512-Gar0ASD4BDyKC4hl4DwHqDrmvjoxWKZigVnAbn5H1owvm4CxCPdb0HQDehwNYMJpla5+M2tPmPARzhtYuwpHow==", - "dev": true - }, - "node_modules/concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", - "dev": true - }, - "node_modules/cookie": { - "version": "0.4.2", - "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", - "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/crc-32": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", - "integrity": "sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==", - "dev": true, - "bin": { - "crc32": "bin/crc32.njs" - }, - "engines": { - "node": ">=0.8" - } - }, - "node_modules/create-hash": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", - "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", - "dev": true, - "dependencies": { - "cipher-base": "^1.0.1", - "inherits": "^2.0.1", - "md5.js": "^1.3.4", - "ripemd160": "^2.0.1", - "sha.js": "^2.4.0" - } - }, - "node_modules/create-hmac": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", - "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", - "dev": true, - "dependencies": { - "cipher-base": "^1.0.3", - "create-hash": "^1.1.0", - "inherits": "^2.0.1", - "ripemd160": "^2.0.0", - "safe-buffer": "^5.0.1", - "sha.js": "^2.4.8" - } - }, - "node_modules/debug": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", - "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", - "dev": true, - "dependencies": { - "ms": "2.1.2" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } - } - }, - "node_modules/decamelize": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", - "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/depd": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", - "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/diff": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", - "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", - "dev": true, - "engines": { - "node": ">=0.3.1" - } - }, - "node_modules/elliptic": { - "version": "6.5.4", - "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.4.tgz", - "integrity": "sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ==", - "dev": true, - "dependencies": { - "bn.js": "^4.11.9", - "brorand": "^1.1.0", - "hash.js": "^1.0.0", - "hmac-drbg": "^1.0.1", - "inherits": "^2.0.4", - "minimalistic-assert": "^1.0.1", - "minimalistic-crypto-utils": "^1.0.1" - } - }, - "node_modules/elliptic/node_modules/bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - }, - "node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true - }, - "node_modules/enquirer": { - "version": "2.3.6", - "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", - "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", - "dev": true, - "dependencies": { - "ansi-colors": "^4.1.1" - }, - "engines": { - "node": ">=8.6" - } - }, - "node_modules/env-paths": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz", - "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/ethereum-cryptography": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-1.1.2.tgz", - "integrity": "sha512-XDSJlg4BD+hq9N2FjvotwUET9Tfxpxc3kWGE2AqUG5vcbeunnbImVk3cj6e/xT3phdW21mE8R5IugU4fspQDcQ==", - "dev": true, - "dependencies": { - "@noble/hashes": "1.1.2", - "@noble/secp256k1": "1.6.3", - "@scure/bip32": "1.1.0", - "@scure/bip39": "1.1.0" - } - }, - "node_modules/ethereumjs-abi": { - "version": "0.6.8", - "resolved": "https://registry.npmjs.org/ethereumjs-abi/-/ethereumjs-abi-0.6.8.tgz", - "integrity": "sha512-Tx0r/iXI6r+lRsdvkFDlut0N08jWMnKRZ6Gkq+Nmw75lZe4e6o3EkSnkaBP5NF6+m5PTGAr9JP43N3LyeoglsA==", - "dev": true, - "dependencies": { - "bn.js": "^4.11.8", - "ethereumjs-util": "^6.0.0" - } - }, - "node_modules/ethereumjs-abi/node_modules/@types/bn.js": { - "version": "4.11.6", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-4.11.6.tgz", - "integrity": "sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/ethereumjs-abi/node_modules/bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - }, - "node_modules/ethereumjs-abi/node_modules/ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "dependencies": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "node_modules/ethereumjs-abi/node_modules/ethereumjs-util": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz", - "integrity": "sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw==", - "dev": true, - "dependencies": { - "@types/bn.js": "^4.11.3", - "bn.js": "^4.11.0", - "create-hash": "^1.1.2", - "elliptic": "^6.5.2", - "ethereum-cryptography": "^0.1.3", - "ethjs-util": "0.1.6", - "rlp": "^2.2.3" - } - }, - "node_modules/ethers": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/ethers/-/ethers-5.7.2.tgz", - "integrity": "sha512-wswUsmWo1aOK8rR7DIKiWSw9DbLWe6x98Jrn8wcTflTVvaXhAMaB5zGAXy0GYQEQp9iO1iSHWVyARQm11zUtyg==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://gitcoin.co/grants/13/ethersjs-complete-simple-and-tiny-2" - }, - { - "type": "individual", - "url": "https://www.buymeacoffee.com/ricmoo" - } - ], - "dependencies": { - "@ethersproject/abi": "5.7.0", - "@ethersproject/abstract-provider": "5.7.0", - "@ethersproject/abstract-signer": "5.7.0", - "@ethersproject/address": "5.7.0", - "@ethersproject/base64": "5.7.0", - "@ethersproject/basex": "5.7.0", - "@ethersproject/bignumber": "5.7.0", - "@ethersproject/bytes": "5.7.0", - "@ethersproject/constants": "5.7.0", - "@ethersproject/contracts": "5.7.0", - "@ethersproject/hash": "5.7.0", - "@ethersproject/hdnode": "5.7.0", - "@ethersproject/json-wallets": "5.7.0", - "@ethersproject/keccak256": "5.7.0", - "@ethersproject/logger": "5.7.0", - "@ethersproject/networks": "5.7.1", - "@ethersproject/pbkdf2": "5.7.0", - "@ethersproject/properties": "5.7.0", - "@ethersproject/providers": "5.7.2", - "@ethersproject/random": "5.7.0", - "@ethersproject/rlp": "5.7.0", - "@ethersproject/sha2": "5.7.0", - "@ethersproject/signing-key": "5.7.0", - "@ethersproject/solidity": "5.7.0", - "@ethersproject/strings": "5.7.0", - "@ethersproject/transactions": "5.7.0", - "@ethersproject/units": "5.7.0", - "@ethersproject/wallet": "5.7.0", - "@ethersproject/web": "5.7.1", - "@ethersproject/wordlists": "5.7.0" - } - }, - "node_modules/ethjs-util": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/ethjs-util/-/ethjs-util-0.1.6.tgz", - "integrity": "sha512-CUnVOQq7gSpDHZVVrQW8ExxUETWrnrvXYvYz55wOU8Uj4VCgw56XC2B/fVqQN+f7gmrnRHSLVnFAwsCuNwji8w==", - "dev": true, - "dependencies": { - "is-hex-prefixed": "1.0.0", - "strip-hex-prefix": "1.0.0" - }, - "engines": { - "node": ">=6.5.0", - "npm": ">=3" - } - }, - "node_modules/evp_bytestokey": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", - "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", - "dev": true, - "dependencies": { - "md5.js": "^1.3.4", - "safe-buffer": "^5.1.1" - } - }, - "node_modules/fill-range": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", - "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", - "dev": true, - "dependencies": { - "to-regex-range": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/find-up": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", - "integrity": "sha512-NWzkk0jSJtTt08+FBFMvXoeZnOJD+jTtsRmBYbAIzJdX6l7dLgR7CTubCM5/eDdPUBvLCeVasP1brfVR/9/EZQ==", - "dev": true, - "dependencies": { - "locate-path": "^2.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/flat": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", - "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", - "dev": true, - "bin": { - "flat": "cli.js" - } - }, - "node_modules/follow-redirects": { - "version": "1.15.1", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.1.tgz", - "integrity": "sha512-yLAMQs+k0b2m7cVxpS1VKJVvoz7SS9Td1zss3XRwXj+ZDH00RJgnuLx7E44wx02kQLrdM3aOOy+FpzS7+8OizA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://github.com/sponsors/RubenVerborgh" - } - ], - "engines": { - "node": ">=4.0" - }, - "peerDependenciesMeta": { - "debug": { - "optional": true - } - } - }, - "node_modules/fp-ts": { - "version": "1.19.3", - "resolved": "https://registry.npmjs.org/fp-ts/-/fp-ts-1.19.3.tgz", - "integrity": "sha512-H5KQDspykdHuztLTg+ajGN0Z2qUjcEf3Ybxc6hLt0k7/zPkn29XnKnxlBPyW2XIddWrGaJBzBl4VLYOtk39yZg==", - "dev": true - }, - "node_modules/fs-extra": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", - "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", - "dev": true, - "dependencies": { - "graceful-fs": "^4.1.2", - "jsonfile": "^4.0.0", - "universalify": "^0.1.0" - }, - "engines": { - "node": ">=6 <7 || >=8" - } - }, - "node_modules/fs.realpath": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", - "dev": true - }, - "node_modules/fsevents": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", - "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", - "dev": true, - "hasInstallScript": true, - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": "^8.16.0 || ^10.6.0 || >=11.0.0" - } - }, - "node_modules/functional-red-black-tree": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", - "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", - "dev": true - }, - "node_modules/get-caller-file": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", - "dev": true, - "engines": { - "node": "6.* || 8.* || >= 10.*" - } - }, - "node_modules/glob": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", - "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", - "dev": true, - "dependencies": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.0.4", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - }, - "engines": { - "node": "*" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, - "dependencies": { - "is-glob": "^4.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", - "dev": true - }, - "node_modules/hardhat": { - "version": "2.19.0", - "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.19.0.tgz", - "integrity": "sha512-kMpwovOEfrFRQXEopCP+JTcKVwSYVj8rnXE0LynxDqnh06yvyKCQknmXL6IVYTHQL6Csysc/yNbCHQbjSeJGpA==", - "dev": true, - "dependencies": { - "@ethersproject/abi": "^5.1.2", - "@metamask/eth-sig-util": "^4.0.0", - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-blockchain": "7.0.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-evm": "2.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-statemanager": "2.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "@nomicfoundation/ethereumjs-vm": "7.0.2", - "@nomicfoundation/solidity-analyzer": "^0.1.0", - "@sentry/node": "^5.18.1", - "@types/bn.js": "^5.1.0", - "@types/lru-cache": "^5.1.0", - "adm-zip": "^0.4.16", - "aggregate-error": "^3.0.0", - "ansi-escapes": "^4.3.0", - "chalk": "^2.4.2", - "chokidar": "^3.4.0", - "ci-info": "^2.0.0", - "debug": "^4.1.1", - "enquirer": "^2.3.0", - "env-paths": "^2.2.0", - "ethereum-cryptography": "^1.0.3", - "ethereumjs-abi": "^0.6.8", - "find-up": "^2.1.0", - "fp-ts": "1.19.3", - "fs-extra": "^7.0.1", - "glob": "7.2.0", - "immutable": "^4.0.0-rc.12", - "io-ts": "1.10.4", - "keccak": "^3.0.2", - "lodash": "^4.17.11", - "mnemonist": "^0.38.0", - "mocha": "^10.0.0", - "p-map": "^4.0.0", - "raw-body": "^2.4.1", - "resolve": "1.17.0", - "semver": "^6.3.0", - "solc": "0.7.3", - "source-map-support": "^0.5.13", - "stacktrace-parser": "^0.1.10", - "tsort": "0.0.1", - "undici": "^5.14.0", - "uuid": "^8.3.2", - "ws": "^7.4.6" - }, - "bin": { - "hardhat": "internal/cli/bootstrap.js" - }, - "peerDependencies": { - "ts-node": "*", - "typescript": "*" - }, - "peerDependenciesMeta": { - "ts-node": { - "optional": true - }, - "typescript": { - "optional": true - } - } - }, - "node_modules/has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/hash-base": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.1.0.tgz", - "integrity": "sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA==", - "dev": true, - "dependencies": { - "inherits": "^2.0.4", - "readable-stream": "^3.6.0", - "safe-buffer": "^5.2.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/hash.js": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", - "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", - "dev": true, - "dependencies": { - "inherits": "^2.0.3", - "minimalistic-assert": "^1.0.1" - } - }, - "node_modules/he": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", - "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", - "dev": true, - "bin": { - "he": "bin/he" - } - }, - "node_modules/hmac-drbg": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", - "integrity": "sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg==", - "dev": true, - "dependencies": { - "hash.js": "^1.0.3", - "minimalistic-assert": "^1.0.0", - "minimalistic-crypto-utils": "^1.0.1" - } - }, - "node_modules/http-errors": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", - "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", - "dev": true, - "dependencies": { - "depd": "2.0.0", - "inherits": "2.0.4", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "toidentifier": "1.0.1" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/https-proxy-agent": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", - "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", - "dev": true, - "dependencies": { - "agent-base": "6", - "debug": "4" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/iconv-lite": { - "version": "0.4.24", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", - "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dev": true, - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/ieee754": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", - "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/immutable": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.1.0.tgz", - "integrity": "sha512-oNkuqVTA8jqG1Q6c+UglTOD1xhC1BtjKI7XkCXRkZHrN5m18/XsnUp8Q89GkQO/z+0WjonSvl0FLhDYftp46nQ==", - "dev": true - }, - "node_modules/indent-string": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", - "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/inflight": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", - "dev": true, - "dependencies": { - "once": "^1.3.0", - "wrappy": "1" - } - }, - "node_modules/inherits": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", - "dev": true - }, - "node_modules/io-ts": { - "version": "1.10.4", - "resolved": "https://registry.npmjs.org/io-ts/-/io-ts-1.10.4.tgz", - "integrity": "sha512-b23PteSnYXSONJ6JQXRAlvJhuw8KOtkqa87W4wDtvMrud/DTJd5X+NpOOI+O/zZwVq6v0VLAaJ+1EDViKEuN9g==", - "dev": true, - "dependencies": { - "fp-ts": "^1.0.0" - } - }, - "node_modules/is-binary-path": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", - "dev": true, - "dependencies": { - "binary-extensions": "^2.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-buffer": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", - "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "engines": { - "node": ">=4" - } - }, - "node_modules/is-extglob": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-fullwidth-code-point": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, - "dependencies": { - "is-extglob": "^2.1.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-hex-prefixed": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-hex-prefixed/-/is-hex-prefixed-1.0.0.tgz", - "integrity": "sha512-WvtOiug1VFrE9v1Cydwm+FnXd3+w9GaeVUss5W4v/SLy3UW00vP+6iNF2SdnfiBoLy4bTqVdkftNGTUeOFVsbA==", - "dev": true, - "engines": { - "node": ">=6.5.0", - "npm": ">=3" - } - }, - "node_modules/is-number": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", - "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "dev": true, - "engines": { - "node": ">=0.12.0" - } - }, - "node_modules/is-plain-obj": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", - "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-unicode-supported": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", - "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/js-sdsl": { - "version": "4.4.2", - "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.4.2.tgz", - "integrity": "sha512-dwXFwByc/ajSV6m5bcKAPwe4yDDF6D614pxmIi5odytzxRlwqF6nwoiCek80Ixc7Cvma5awClxrzFtxCQvcM8w==", - "dev": true, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/js-sdsl" - } - }, - "node_modules/js-sha3": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/js-sha3/-/js-sha3-0.8.0.tgz", - "integrity": "sha512-gF1cRrHhIzNfToc802P800N8PpXS+evLLXfsVpowqmAFR9uwbi89WvXg2QspOmXL8QL86J4T1EpFu+yUkwJY3Q==", - "dev": true - }, - "node_modules/js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", - "dev": true, - "dependencies": { - "argparse": "^2.0.1" - }, - "bin": { - "js-yaml": "bin/js-yaml.js" - } - }, - "node_modules/jsonfile": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", - "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", - "dev": true, - "optionalDependencies": { - "graceful-fs": "^4.1.6" - } - }, - "node_modules/keccak": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/keccak/-/keccak-3.0.2.tgz", - "integrity": "sha512-PyKKjkH53wDMLGrvmRGSNWgmSxZOUqbnXwKL9tmgbFYA1iAYqW21kfR7mZXV0MlESiefxQQE9X9fTa3X+2MPDQ==", - "dev": true, - "hasInstallScript": true, - "dependencies": { - "node-addon-api": "^2.0.0", - "node-gyp-build": "^4.2.0", - "readable-stream": "^3.6.0" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/klaw": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/klaw/-/klaw-1.3.1.tgz", - "integrity": "sha512-TED5xi9gGQjGpNnvRWknrwAB1eL5GciPfVFOt3Vk1OJCVDQbzuSfrF3hkUQKlsgKrG1F+0t5W0m+Fje1jIt8rw==", - "dev": true, - "optionalDependencies": { - "graceful-fs": "^4.1.9" - } - }, - "node_modules/level": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/level/-/level-8.0.0.tgz", - "integrity": "sha512-ypf0jjAk2BWI33yzEaaotpq7fkOPALKAgDBxggO6Q9HGX2MRXn0wbP1Jn/tJv1gtL867+YOjOB49WaUF3UoJNQ==", - "dev": true, - "dependencies": { - "browser-level": "^1.0.1", - "classic-level": "^1.2.0" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/level" - } - }, - "node_modules/level-supports": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/level-supports/-/level-supports-4.0.1.tgz", - "integrity": "sha512-PbXpve8rKeNcZ9C1mUicC9auIYFyGpkV9/i6g76tLgANwWhtG2v7I4xNBUlkn3lE2/dZF3Pi0ygYGtLc4RXXdA==", - "dev": true, - "engines": { - "node": ">=12" - } - }, - "node_modules/level-transcoder": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/level-transcoder/-/level-transcoder-1.0.1.tgz", - "integrity": "sha512-t7bFwFtsQeD8cl8NIoQ2iwxA0CL/9IFw7/9gAjOonH0PWTTiRfY7Hq+Ejbsxh86tXobDQ6IOiddjNYIfOBs06w==", - "dev": true, - "dependencies": { - "buffer": "^6.0.3", - "module-error": "^1.0.1" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/locate-path": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", - "integrity": "sha512-NCI2kiDkyR7VeEKm27Kda/iQHyKJe1Bu0FlTbYp3CqJu+9IFe9bLyAjMxf5ZDDbEg+iMPzB5zYyUTSm8wVTKmA==", - "dev": true, - "dependencies": { - "p-locate": "^2.0.0", - "path-exists": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/lodash": { - "version": "4.17.21", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", - "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", - "dev": true - }, - "node_modules/log-symbols": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", - "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", - "dev": true, - "dependencies": { - "chalk": "^4.1.0", - "is-unicode-supported": "^0.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/log-symbols/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/log-symbols/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/log-symbols/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/log-symbols/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/log-symbols/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/log-symbols/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/lru_map": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/lru_map/-/lru_map-0.3.3.tgz", - "integrity": "sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ==", - "dev": true - }, - "node_modules/lru-cache": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", - "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", - "dev": true, - "dependencies": { - "yallist": "^3.0.2" - } - }, - "node_modules/mcl-wasm": { - "version": "0.7.9", - "resolved": "https://registry.npmjs.org/mcl-wasm/-/mcl-wasm-0.7.9.tgz", - "integrity": "sha512-iJIUcQWA88IJB/5L15GnJVnSQJmf/YaxxV6zRavv83HILHaJQb6y0iFyDMdDO0gN8X37tdxmAOrH/P8B6RB8sQ==", - "dev": true, - "engines": { - "node": ">=8.9.0" - } - }, - "node_modules/md5.js": { - "version": "1.3.5", - "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", - "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", - "dev": true, - "dependencies": { - "hash-base": "^3.0.0", - "inherits": "^2.0.1", - "safe-buffer": "^5.1.2" - } - }, - "node_modules/memory-level": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/memory-level/-/memory-level-1.0.0.tgz", - "integrity": "sha512-UXzwewuWeHBz5krr7EvehKcmLFNoXxGcvuYhC41tRnkrTbJohtS7kVn9akmgirtRygg+f7Yjsfi8Uu5SGSQ4Og==", - "dev": true, - "dependencies": { - "abstract-level": "^1.0.0", - "functional-red-black-tree": "^1.0.1", - "module-error": "^1.0.1" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/memorystream": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", - "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", - "dev": true, - "engines": { - "node": ">= 0.10.0" - } - }, - "node_modules/minimalistic-assert": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", - "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", - "dev": true - }, - "node_modules/minimalistic-crypto-utils": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", - "integrity": "sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg==", - "dev": true - }, - "node_modules/minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", - "dev": true, - "dependencies": { - "brace-expansion": "^1.1.7" - }, - "engines": { - "node": "*" - } - }, - "node_modules/mnemonist": { - "version": "0.38.5", - "resolved": "https://registry.npmjs.org/mnemonist/-/mnemonist-0.38.5.tgz", - "integrity": "sha512-bZTFT5rrPKtPJxj8KSV0WkPyNxl72vQepqqVUAW2ARUpUSF2qXMB6jZj7hW5/k7C1rtpzqbD/IIbJwLXUjCHeg==", - "dev": true, - "dependencies": { - "obliterator": "^2.0.0" - } - }, - "node_modules/mocha": { - "version": "10.0.0", - "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.0.0.tgz", - "integrity": "sha512-0Wl+elVUD43Y0BqPZBzZt8Tnkw9CMUdNYnUsTfOM1vuhJVZL+kiesFYsqwBkEEuEixaiPe5ZQdqDgX2jddhmoA==", - "dev": true, - "dependencies": { - "@ungap/promise-all-settled": "1.1.2", - "ansi-colors": "4.1.1", - "browser-stdout": "1.3.1", - "chokidar": "3.5.3", - "debug": "4.3.4", - "diff": "5.0.0", - "escape-string-regexp": "4.0.0", - "find-up": "5.0.0", - "glob": "7.2.0", - "he": "1.2.0", - "js-yaml": "4.1.0", - "log-symbols": "4.1.0", - "minimatch": "5.0.1", - "ms": "2.1.3", - "nanoid": "3.3.3", - "serialize-javascript": "6.0.0", - "strip-json-comments": "3.1.1", - "supports-color": "8.1.1", - "workerpool": "6.2.1", - "yargs": "16.2.0", - "yargs-parser": "20.2.4", - "yargs-unparser": "2.0.0" - }, - "bin": { - "_mocha": "bin/_mocha", - "mocha": "bin/mocha.js" - }, - "engines": { - "node": ">= 14.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/mochajs" - } - }, - "node_modules/mocha/node_modules/ansi-colors": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", - "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/mocha/node_modules/brace-expansion": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", - "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", - "dev": true, - "dependencies": { - "balanced-match": "^1.0.0" - } - }, - "node_modules/mocha/node_modules/escape-string-regexp": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", - "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/mocha/node_modules/find-up": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", - "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", - "dev": true, - "dependencies": { - "locate-path": "^6.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/mocha/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/mocha/node_modules/locate-path": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", - "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", - "dev": true, - "dependencies": { - "p-locate": "^5.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/mocha/node_modules/minimatch": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", - "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", - "dev": true, - "dependencies": { - "brace-expansion": "^2.0.1" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/mocha/node_modules/ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", - "dev": true - }, - "node_modules/mocha/node_modules/p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", - "dev": true, - "dependencies": { - "yocto-queue": "^0.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/mocha/node_modules/p-locate": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", - "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", - "dev": true, - "dependencies": { - "p-limit": "^3.0.2" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/mocha/node_modules/path-exists": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", - "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/mocha/node_modules/supports-color": { - "version": "8.1.1", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", - "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/supports-color?sponsor=1" - } - }, - "node_modules/module-error": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/module-error/-/module-error-1.0.2.tgz", - "integrity": "sha512-0yuvsqSCv8LbaOKhnsQ/T5JhyFlCYLPXK3U2sgV10zoKQwzs/MyfuQUOZQ1V/6OCOJsK/TRgNVrPuPDqtdMFtA==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/ms": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", - "dev": true - }, - "node_modules/nanoid": { - "version": "3.3.3", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", - "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", - "dev": true, - "bin": { - "nanoid": "bin/nanoid.cjs" - }, - "engines": { - "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" - } - }, - "node_modules/napi-macros": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/napi-macros/-/napi-macros-2.2.2.tgz", - "integrity": "sha512-hmEVtAGYzVQpCKdbQea4skABsdXW4RUh5t5mJ2zzqowJS2OyXZTU1KhDVFhx+NlWZ4ap9mqR9TcDO3LTTttd+g==", - "dev": true - }, - "node_modules/node-addon-api": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-2.0.2.tgz", - "integrity": "sha512-Ntyt4AIXyaLIuMHF6IOoTakB3K+RWxwtsHNRxllEoA6vPwP9o4866g6YWDLUdnucilZhmkxiHwHr11gAENw+QA==", - "dev": true - }, - "node_modules/node-gyp-build": { - "version": "4.5.0", - "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.5.0.tgz", - "integrity": "sha512-2iGbaQBV+ITgCz76ZEjmhUKAKVf7xfY1sRl4UiKQspfZMH2h06SyhNsnSVy50cwkFQDGLyif6m/6uFXHkOZ6rg==", - "dev": true, - "bin": { - "node-gyp-build": "bin.js", - "node-gyp-build-optional": "optional.js", - "node-gyp-build-test": "build-test.js" - } - }, - "node_modules/normalize-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/obliterator": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/obliterator/-/obliterator-2.0.4.tgz", - "integrity": "sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ==", - "dev": true - }, - "node_modules/once": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", - "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", - "dev": true, - "dependencies": { - "wrappy": "1" - } - }, - "node_modules/os-tmpdir": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/p-limit": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", - "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", - "dev": true, - "dependencies": { - "p-try": "^1.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/p-locate": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", - "integrity": "sha512-nQja7m7gSKuewoVRen45CtVfODR3crN3goVQ0DDZ9N3yHxgpkuBhZqsaiotSQRrADUrne346peY7kT3TSACykg==", - "dev": true, - "dependencies": { - "p-limit": "^1.1.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/p-map": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", - "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", - "dev": true, - "dependencies": { - "aggregate-error": "^3.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/p-try": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", - "integrity": "sha512-U1etNYuMJoIz3ZXSrrySFjsXQTWOx2/jdi86L+2pRvph/qMKL6sbcCYdH23fqsbm8TH2Gn0OybpT4eSFlCVHww==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/path-exists": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/path-is-absolute": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", - "dev": true - }, - "node_modules/pbkdf2": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.1.2.tgz", - "integrity": "sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA==", - "dev": true, - "dependencies": { - "create-hash": "^1.1.2", - "create-hmac": "^1.1.4", - "ripemd160": "^2.0.1", - "safe-buffer": "^5.0.1", - "sha.js": "^2.4.8" - }, - "engines": { - "node": ">=0.12" - } - }, - "node_modules/picomatch": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", - "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "dev": true, - "engines": { - "node": ">=8.6" - }, - "funding": { - "url": "https://github.com/sponsors/jonschlinkert" - } - }, - "node_modules/queue-microtask": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", - "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/randombytes": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", - "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", - "dev": true, - "dependencies": { - "safe-buffer": "^5.1.0" - } - }, - "node_modules/raw-body": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", - "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", - "dev": true, - "dependencies": { - "bytes": "3.1.2", - "http-errors": "2.0.0", - "iconv-lite": "0.4.24", - "unpipe": "1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/readable-stream": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", - "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", - "dev": true, - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/readdirp": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", - "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dev": true, - "dependencies": { - "picomatch": "^2.2.1" - }, - "engines": { - "node": ">=8.10.0" - } - }, - "node_modules/require-directory": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/require-from-string": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", - "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/resolve": { - "version": "1.17.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", - "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", - "dev": true, - "dependencies": { - "path-parse": "^1.0.6" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/rimraf": { - "version": "2.7.1", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", - "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", - "dev": true, - "dependencies": { - "glob": "^7.1.3" - }, - "bin": { - "rimraf": "bin.js" - } - }, - "node_modules/ripemd160": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", - "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", - "dev": true, - "dependencies": { - "hash-base": "^3.0.0", - "inherits": "^2.0.1" - } - }, - "node_modules/rlp": { - "version": "2.2.7", - "resolved": "https://registry.npmjs.org/rlp/-/rlp-2.2.7.tgz", - "integrity": "sha512-d5gdPmgQ0Z+AklL2NVXr/IoSjNZFfTVvQWzL/AM2AOcSzYP2xjlb0AC8YyCLc41MSNf6P6QVtjgPdmVtzb+4lQ==", - "dev": true, - "dependencies": { - "bn.js": "^5.2.0" - }, - "bin": { - "rlp": "bin/rlp" - } - }, - "node_modules/run-parallel-limit": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/run-parallel-limit/-/run-parallel-limit-1.1.0.tgz", - "integrity": "sha512-jJA7irRNM91jaKc3Hcl1npHsFLOXOoTkPCUL1JEa1R82O2miplXXRaGdjW/KM/98YQWDhJLiSs793CnXfblJUw==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "dependencies": { - "queue-microtask": "^1.2.2" - } - }, - "node_modules/rustbn.js": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/rustbn.js/-/rustbn.js-0.2.0.tgz", - "integrity": "sha512-4VlvkRUuCJvr2J6Y0ImW7NvTCriMi7ErOAqWk1y69vAdoNIzCF3yPmgeNzx+RQTLEDFq5sHfscn1MwHxP9hNfA==", - "dev": true - }, - "node_modules/safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/safer-buffer": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", - "dev": true - }, - "node_modules/scrypt-js": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/scrypt-js/-/scrypt-js-3.0.1.tgz", - "integrity": "sha512-cdwTTnqPu0Hyvf5in5asVdZocVDTNRmR7XEcJuIzMjJeSHybHl7vpB66AzwTaIg6CLSbtjcxc8fqcySfnTkccA==", - "dev": true - }, - "node_modules/secp256k1": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/secp256k1/-/secp256k1-4.0.3.tgz", - "integrity": "sha512-NLZVf+ROMxwtEj3Xa562qgv2BK5e2WNmXPiOdVIPLgs6lyTzMvBq0aWTYMI5XCP9jZMVKOcqZLw/Wc4vDkuxhA==", - "dev": true, - "hasInstallScript": true, - "dependencies": { - "elliptic": "^6.5.4", - "node-addon-api": "^2.0.0", - "node-gyp-build": "^4.2.0" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "dev": true, - "bin": { - "semver": "bin/semver.js" - } - }, - "node_modules/serialize-javascript": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", - "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", - "dev": true, - "dependencies": { - "randombytes": "^2.1.0" - } - }, - "node_modules/setimmediate": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", - "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", - "dev": true - }, - "node_modules/setprototypeof": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", - "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", - "dev": true - }, - "node_modules/sha.js": { - "version": "2.4.11", - "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", - "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", - "dev": true, - "dependencies": { - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - }, - "bin": { - "sha.js": "bin.js" - } - }, - "node_modules/solc": { - "version": "0.7.3", - "resolved": "https://registry.npmjs.org/solc/-/solc-0.7.3.tgz", - "integrity": "sha512-GAsWNAjGzIDg7VxzP6mPjdurby3IkGCjQcM8GFYZT6RyaoUZKmMU6Y7YwG+tFGhv7dwZ8rmR4iwFDrrD99JwqA==", - "dev": true, - "dependencies": { - "command-exists": "^1.2.8", - "commander": "3.0.2", - "follow-redirects": "^1.12.1", - "fs-extra": "^0.30.0", - "js-sha3": "0.8.0", - "memorystream": "^0.3.1", - "require-from-string": "^2.0.0", - "semver": "^5.5.0", - "tmp": "0.0.33" - }, - "bin": { - "solcjs": "solcjs" - }, - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/solc/node_modules/fs-extra": { - "version": "0.30.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-0.30.0.tgz", - "integrity": "sha512-UvSPKyhMn6LEd/WpUaV9C9t3zATuqoqfWc3QdPhPLb58prN9tqYPlPWi8Krxi44loBoUzlobqZ3+8tGpxxSzwA==", - "dev": true, - "dependencies": { - "graceful-fs": "^4.1.2", - "jsonfile": "^2.1.0", - "klaw": "^1.0.0", - "path-is-absolute": "^1.0.0", - "rimraf": "^2.2.8" - } - }, - "node_modules/solc/node_modules/jsonfile": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", - "integrity": "sha512-PKllAqbgLgxHaj8TElYymKCAgrASebJrWpTnEkOaTowt23VKXXN0sUeriJ+eh7y6ufb/CC5ap11pz71/cM0hUw==", - "dev": true, - "optionalDependencies": { - "graceful-fs": "^4.1.6" - } - }, - "node_modules/solc/node_modules/semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", - "dev": true, - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/source-map-support": { - "version": "0.5.21", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", - "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", - "dev": true, - "dependencies": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - }, - "node_modules/stacktrace-parser": { - "version": "0.1.10", - "resolved": "https://registry.npmjs.org/stacktrace-parser/-/stacktrace-parser-0.1.10.tgz", - "integrity": "sha512-KJP1OCML99+8fhOHxwwzyWrlUuVX5GQ0ZpJTd1DFXhdkrvg1szxfHhawXUZ3g9TkXORQd4/WG68jMlQZ2p8wlg==", - "dev": true, - "dependencies": { - "type-fest": "^0.7.1" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/stacktrace-parser/node_modules/type-fest": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.7.1.tgz", - "integrity": "sha512-Ne2YiiGN8bmrmJJEuTWTLJR32nh/JdL1+PSicowtNb0WFpn59GK8/lfD61bVtzguz7b3PBt74nxpv/Pw5po5Rg==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/statuses": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", - "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dev": true, - "dependencies": { - "safe-buffer": "~5.2.0" - } - }, - "node_modules/string-width": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, - "dependencies": { - "emoji-regex": "^8.0.0", - "is-fullwidth-code-point": "^3.0.0", - "strip-ansi": "^6.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "dependencies": { - "ansi-regex": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-hex-prefix": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/strip-hex-prefix/-/strip-hex-prefix-1.0.0.tgz", - "integrity": "sha512-q8d4ue7JGEiVcypji1bALTos+0pWtyGlivAWyPuTkHzuTCJqrK9sWxYQZUq6Nq3cuyv3bm734IhHvHtGGURU6A==", - "dev": true, - "dependencies": { - "is-hex-prefixed": "1.0.0" - }, - "engines": { - "node": ">=6.5.0", - "npm": ">=3" - } - }, - "node_modules/strip-json-comments": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", - "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dev": true, - "dependencies": { - "has-flag": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/tmp": { - "version": "0.0.33", - "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", - "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", - "dev": true, - "dependencies": { - "os-tmpdir": "~1.0.2" - }, - "engines": { - "node": ">=0.6.0" - } - }, - "node_modules/to-regex-range": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", - "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dev": true, - "dependencies": { - "is-number": "^7.0.0" - }, - "engines": { - "node": ">=8.0" - } - }, - "node_modules/toidentifier": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", - "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", - "dev": true, - "engines": { - "node": ">=0.6" - } - }, - "node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", - "dev": true - }, - "node_modules/tsort": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/tsort/-/tsort-0.0.1.tgz", - "integrity": "sha512-Tyrf5mxF8Ofs1tNoxA13lFeZ2Zrbd6cKbuH3V+MQ5sb6DtBj5FjrXVsRWT8YvNAQTqNoz66dz1WsbigI22aEnw==", - "dev": true - }, - "node_modules/tweetnacl": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-1.0.3.tgz", - "integrity": "sha512-6rt+RN7aOi1nGMyC4Xa5DdYiukl2UWCbcJft7YhxReBGQD7OAM8Pbxw6YMo4r2diNEA8FEmu32YOn9rhaiE5yw==", - "dev": true - }, - "node_modules/tweetnacl-util": { - "version": "0.15.1", - "resolved": "https://registry.npmjs.org/tweetnacl-util/-/tweetnacl-util-0.15.1.tgz", - "integrity": "sha512-RKJBIj8lySrShN4w6i/BonWp2Z/uxwC3h4y7xsRrpP59ZboCd0GpEVsOnMDYLMmKBpYhb5TgHzZXy7wTfYFBRw==", - "dev": true - }, - "node_modules/type-fest": { - "version": "0.21.3", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", - "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/undici": { - "version": "5.27.2", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.27.2.tgz", - "integrity": "sha512-iS857PdOEy/y3wlM3yRp+6SNQQ6xU0mmZcwRSriqk+et/cwWAtwmIGf6WkoDN2EK/AMdCO/dfXzIwi+rFMrjjQ==", - "dev": true, - "dependencies": { - "@fastify/busboy": "^2.0.0" - }, - "engines": { - "node": ">=14.0" - } - }, - "node_modules/universalify": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", - "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", - "dev": true, - "engines": { - "node": ">= 4.0.0" - } - }, - "node_modules/unpipe": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", - "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/util-deprecate": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", - "dev": true - }, - "node_modules/uuid": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", - "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", - "dev": true, - "bin": { - "uuid": "dist/bin/uuid" - } - }, - "node_modules/workerpool": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", - "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", - "dev": true - }, - "node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/wrap-ansi/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/wrap-ansi/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/wrap-ansi/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/wrappy": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", - "dev": true - }, - "node_modules/ws": { - "version": "7.5.9", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.9.tgz", - "integrity": "sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==", - "dev": true, - "engines": { - "node": ">=8.3.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": "^5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - }, - "node_modules/y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/yallist": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", - "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", - "dev": true - }, - "node_modules/yargs": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", - "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", - "dev": true, - "dependencies": { - "cliui": "^7.0.2", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.0", - "y18n": "^5.0.5", - "yargs-parser": "^20.2.2" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/yargs-parser": { - "version": "20.2.4", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", - "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/yargs-unparser": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", - "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", - "dev": true, - "dependencies": { - "camelcase": "^6.0.0", - "decamelize": "^4.0.0", - "flat": "^5.0.2", - "is-plain-obj": "^2.1.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - } - }, - "dependencies": { - "@chainsafe/as-sha256": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/@chainsafe/as-sha256/-/as-sha256-0.3.1.tgz", - "integrity": "sha512-hldFFYuf49ed7DAakWVXSJODuq3pzJEguD8tQ7h+sGkM18vja+OFoJI9krnGmgzyuZC2ETX0NOIcCTy31v2Mtg==", - "dev": true - }, - "@chainsafe/persistent-merkle-tree": { - "version": "0.4.2", - "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.4.2.tgz", - "integrity": "sha512-lLO3ihKPngXLTus/L7WHKaw9PnNJWizlOF1H9NNzHP6Xvh82vzg9F2bzkXhYIFshMZ2gTCEz8tq6STe7r5NDfQ==", - "dev": true, - "requires": { - "@chainsafe/as-sha256": "^0.3.1" - } - }, - "@chainsafe/ssz": { - "version": "0.9.4", - "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.9.4.tgz", - "integrity": "sha512-77Qtg2N1ayqs4Bg/wvnWfg5Bta7iy7IRh8XqXh7oNMeP2HBbBwx8m6yTpA8p0EHItWPEBkgZd5S5/LSlp3GXuQ==", - "dev": true, - "requires": { - "@chainsafe/as-sha256": "^0.3.1", - "@chainsafe/persistent-merkle-tree": "^0.4.2", - "case": "^1.6.3" - } - }, - "@ethersproject/abi": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/abi/-/abi-5.7.0.tgz", - "integrity": "sha512-351ktp42TiRcYB3H1OP8yajPeAQstMW/yCFokj/AthP9bLHzQFPlOrxOcwYEDkUAICmOHljvN4K39OMTMUa9RA==", - "dev": true, - "requires": { - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "@ethersproject/abstract-provider": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-provider/-/abstract-provider-5.7.0.tgz", - "integrity": "sha512-R41c9UkchKCpAqStMYUpdunjo3pkEvZC3FAwZn5S5MGbXoMQOHIdHItezTETxAO5bevtMApSyEhn9+CHcDsWBw==", - "dev": true, - "requires": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/networks": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/web": "^5.7.0" - } - }, - "@ethersproject/abstract-signer": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/abstract-signer/-/abstract-signer-5.7.0.tgz", - "integrity": "sha512-a16V8bq1/Cz+TGCkE2OPMTOUDLS3grCpdjoJCYNnVBbdYEMSgKrU0+B90s8b6H+ByYTBZN7a3g76jdIJi7UfKQ==", - "dev": true, - "requires": { - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0" - } - }, - "@ethersproject/address": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/address/-/address-5.7.0.tgz", - "integrity": "sha512-9wYhYt7aghVGo758POM5nqcOMaE168Q6aRLJZwUmiqSrAungkG74gSSeKEIR7ukixesdRZGPgVqme6vmxs1fkA==", - "dev": true, - "requires": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/rlp": "^5.7.0" - } - }, - "@ethersproject/base64": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/base64/-/base64-5.7.0.tgz", - "integrity": "sha512-Dr8tcHt2mEbsZr/mwTPIQAf3Ai0Bks/7gTw9dSqk1mQvhW3XvRlmDJr/4n+wg1JmCl16NZue17CDh8xb/vZ0sQ==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0" - } - }, - "@ethersproject/basex": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/basex/-/basex-5.7.0.tgz", - "integrity": "sha512-ywlh43GwZLv2Voc2gQVTKBoVQ1mti3d8HK5aMxsfu/nRDnMmNqaSJ3r3n85HBByT8OpoY96SXM1FogC533T4zw==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/properties": "^5.7.0" - } - }, - "@ethersproject/bignumber": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/bignumber/-/bignumber-5.7.0.tgz", - "integrity": "sha512-n1CAdIHRWjSucQO3MC1zPSVgV/6dy/fjL9pMrPP9peL+QxEg9wOsVqwD4+818B6LUEtaXzVHQiuivzRoxPxUGw==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "bn.js": "^5.2.1" - } - }, - "@ethersproject/bytes": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/bytes/-/bytes-5.7.0.tgz", - "integrity": "sha512-nsbxwgFXWh9NyYWo+U8atvmMsSdKJprTcICAkvbBffT75qDocbuggBU0SJiVK2MuTrp0q+xvLkTnGMPK1+uA9A==", - "dev": true, - "requires": { - "@ethersproject/logger": "^5.7.0" - } - }, - "@ethersproject/constants": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/constants/-/constants-5.7.0.tgz", - "integrity": "sha512-DHI+y5dBNvkpYUMiRQyxRBYBefZkJfo70VUkUAsRjcPs47muV9evftfZ0PJVCXYbAiCgght0DtcF9srFQmIgWA==", - "dev": true, - "requires": { - "@ethersproject/bignumber": "^5.7.0" - } - }, - "@ethersproject/contracts": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/contracts/-/contracts-5.7.0.tgz", - "integrity": "sha512-5GJbzEU3X+d33CdfPhcyS+z8MzsTrBGk/sc+G+59+tPa9yFkl6HQ9D6L0QMgNTA9q8dT0XKxxkyp883XsQvbbg==", - "dev": true, - "requires": { - "@ethersproject/abi": "^5.7.0", - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/transactions": "^5.7.0" - } - }, - "@ethersproject/hash": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/hash/-/hash-5.7.0.tgz", - "integrity": "sha512-qX5WrQfnah1EFnO5zJv1v46a8HW0+E5xuBBDTwMFZLuVTx0tbU2kkx15NqdjxecrLGatQN9FGQKpb1FKdHCt+g==", - "dev": true, - "requires": { - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/base64": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "@ethersproject/hdnode": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/hdnode/-/hdnode-5.7.0.tgz", - "integrity": "sha512-OmyYo9EENBPPf4ERhR7oj6uAtUAhYGqOnIS+jE5pTXvdKBS99ikzq1E7Iv0ZQZ5V36Lqx1qZLeak0Ra16qpeOg==", - "dev": true, - "requires": { - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/basex": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/pbkdf2": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/sha2": "^5.7.0", - "@ethersproject/signing-key": "^5.7.0", - "@ethersproject/strings": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/wordlists": "^5.7.0" - } - }, - "@ethersproject/json-wallets": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/json-wallets/-/json-wallets-5.7.0.tgz", - "integrity": "sha512-8oee5Xgu6+RKgJTkvEMl2wDgSPSAQ9MB/3JYjFV9jlKvcYHUXZC+cQp0njgmxdHkYWn8s6/IqIZYm0YWCjO/0g==", - "dev": true, - "requires": { - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/hdnode": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/pbkdf2": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/random": "^5.7.0", - "@ethersproject/strings": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "aes-js": "3.0.0", - "scrypt-js": "3.0.1" - } - }, - "@ethersproject/keccak256": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/keccak256/-/keccak256-5.7.0.tgz", - "integrity": "sha512-2UcPboeL/iW+pSg6vZ6ydF8tCnv3Iu/8tUmLLzWWGzxWKFFqOBQFLo6uLUv6BDrLgCDfN28RJ/wtByx+jZ4KBg==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "js-sha3": "0.8.0" - } - }, - "@ethersproject/logger": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/logger/-/logger-5.7.0.tgz", - "integrity": "sha512-0odtFdXu/XHtjQXJYA3u9G0G8btm0ND5Cu8M7i5vhEcE8/HmF4Lbdqanwyv4uQTr2tx6b7fQRmgLrsnpQlmnig==", - "dev": true - }, - "@ethersproject/networks": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/@ethersproject/networks/-/networks-5.7.1.tgz", - "integrity": "sha512-n/MufjFYv3yFcUyfhnXotyDlNdFb7onmkSy8aQERi2PjNcnWQ66xXxa3XlS8nCcA8aJKJjIIMNJTC7tu80GwpQ==", - "dev": true, - "requires": { - "@ethersproject/logger": "^5.7.0" - } - }, - "@ethersproject/pbkdf2": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/pbkdf2/-/pbkdf2-5.7.0.tgz", - "integrity": "sha512-oR/dBRZR6GTyaofd86DehG72hY6NpAjhabkhxgr3X2FpJtJuodEl2auADWBZfhDHgVCbu3/H/Ocq2uC6dpNjjw==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/sha2": "^5.7.0" - } - }, - "@ethersproject/properties": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/properties/-/properties-5.7.0.tgz", - "integrity": "sha512-J87jy8suntrAkIZtecpxEPxY//szqr1mlBaYlQ0r4RCaiD2hjheqF9s1LVE8vVuJCXisjIP+JgtK/Do54ej4Sw==", - "dev": true, - "requires": { - "@ethersproject/logger": "^5.7.0" - } - }, - "@ethersproject/providers": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/@ethersproject/providers/-/providers-5.7.2.tgz", - "integrity": "sha512-g34EWZ1WWAVgr4aptGlVBF8mhl3VWjv+8hoAnzStu8Ah22VHBsuGzP17eb6xDVRzw895G4W7vvx60lFFur/1Rg==", - "dev": true, - "requires": { - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/base64": "^5.7.0", - "@ethersproject/basex": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/networks": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/random": "^5.7.0", - "@ethersproject/rlp": "^5.7.0", - "@ethersproject/sha2": "^5.7.0", - "@ethersproject/strings": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/web": "^5.7.0", - "bech32": "1.1.4", - "ws": "7.4.6" - }, - "dependencies": { - "ws": { - "version": "7.4.6", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.6.tgz", - "integrity": "sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A==", - "dev": true, - "requires": {} - } - } - }, - "@ethersproject/random": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/random/-/random-5.7.0.tgz", - "integrity": "sha512-19WjScqRA8IIeWclFme75VMXSBvi4e6InrUNuaR4s5pTF2qNhcGdCUwdxUVGtDDqC00sDLCO93jPQoDUH4HVmQ==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "@ethersproject/rlp": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/rlp/-/rlp-5.7.0.tgz", - "integrity": "sha512-rBxzX2vK8mVF7b0Tol44t5Tb8gomOHkj5guL+HhzQ1yBh/ydjGnpw6at+X6Iw0Kp3OzzzkcKp8N9r0W4kYSs9w==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "@ethersproject/sha2": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/sha2/-/sha2-5.7.0.tgz", - "integrity": "sha512-gKlH42riwb3KYp0reLsFTokByAKoJdgFCwI+CCiX/k+Jm2mbNs6oOaCjYQSlI1+XBVejwH2KrmCbMAT/GnRDQw==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "hash.js": "1.1.7" - } - }, - "@ethersproject/signing-key": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/signing-key/-/signing-key-5.7.0.tgz", - "integrity": "sha512-MZdy2nL3wO0u7gkB4nA/pEf8lu1TlFswPNmy8AiYkfKTdO6eXBJyUdmHO/ehm/htHw9K/qF8ujnTyUAD+Ry54Q==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "bn.js": "^5.2.1", - "elliptic": "6.5.4", - "hash.js": "1.1.7" - } - }, - "@ethersproject/solidity": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/solidity/-/solidity-5.7.0.tgz", - "integrity": "sha512-HmabMd2Dt/raavyaGukF4XxizWKhKQ24DoLtdNbBmNKUOPqwjsKQSdV9GQtj9CBEea9DlzETlVER1gYeXXBGaA==", - "dev": true, - "requires": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/sha2": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "@ethersproject/strings": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/strings/-/strings-5.7.0.tgz", - "integrity": "sha512-/9nu+lj0YswRNSH0NXYqrh8775XNyEdUQAuf3f+SmOrnVewcJ5SBNAjF7lpgehKi4abvNNXyf+HX86czCdJ8Mg==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "@ethersproject/transactions": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/transactions/-/transactions-5.7.0.tgz", - "integrity": "sha512-kmcNicCp1lp8qanMTC3RIikGgoJ80ztTyvtsFvCYpSCfkjhD0jZ2LOrnbcuxuToLIUYYf+4XwD1rP+B/erDIhQ==", - "dev": true, - "requires": { - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/rlp": "^5.7.0", - "@ethersproject/signing-key": "^5.7.0" - } - }, - "@ethersproject/units": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/units/-/units-5.7.0.tgz", - "integrity": "sha512-pD3xLMy3SJu9kG5xDGI7+xhTEmGXlEqXU4OfNapmfnxLVY4EMSSRp7j1k7eezutBPH7RBN/7QPnwR7hzNlEFeg==", - "dev": true, - "requires": { - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/constants": "^5.7.0", - "@ethersproject/logger": "^5.7.0" - } - }, - "@ethersproject/wallet": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/wallet/-/wallet-5.7.0.tgz", - "integrity": "sha512-MhmXlJXEJFBFVKrDLB4ZdDzxcBxQ3rLyCkhNqVu3CDYvR97E+8r01UgrI+TI99Le+aYm/in/0vp86guJuM7FCA==", - "dev": true, - "requires": { - "@ethersproject/abstract-provider": "^5.7.0", - "@ethersproject/abstract-signer": "^5.7.0", - "@ethersproject/address": "^5.7.0", - "@ethersproject/bignumber": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/hdnode": "^5.7.0", - "@ethersproject/json-wallets": "^5.7.0", - "@ethersproject/keccak256": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/random": "^5.7.0", - "@ethersproject/signing-key": "^5.7.0", - "@ethersproject/transactions": "^5.7.0", - "@ethersproject/wordlists": "^5.7.0" - } - }, - "@ethersproject/web": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/@ethersproject/web/-/web-5.7.1.tgz", - "integrity": "sha512-Gueu8lSvyjBWL4cYsWsjh6MtMwM0+H4HvqFPZfB6dV8ctbP9zFAO73VG1cMWae0FLPCtz0peKPpZY8/ugJJX2w==", - "dev": true, - "requires": { - "@ethersproject/base64": "^5.7.0", - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "@ethersproject/wordlists": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/@ethersproject/wordlists/-/wordlists-5.7.0.tgz", - "integrity": "sha512-S2TFNJNfHWVHNE6cNDjbVlZ6MgE17MIxMbMg2zv3wn+3XSJGosL1m9ZVv3GXCf/2ymSsQ+hRI5IzoMJTG6aoVA==", - "dev": true, - "requires": { - "@ethersproject/bytes": "^5.7.0", - "@ethersproject/hash": "^5.7.0", - "@ethersproject/logger": "^5.7.0", - "@ethersproject/properties": "^5.7.0", - "@ethersproject/strings": "^5.7.0" - } - }, - "@fastify/busboy": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.0.tgz", - "integrity": "sha512-+KpH+QxZU7O4675t3mnkQKcZZg56u+K/Ct2K+N2AZYNVK8kyeo/bI18tI8aPm3tvNNRyTWfj6s5tnGNlcbQRsA==", - "dev": true - }, - "@metamask/eth-sig-util": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/@metamask/eth-sig-util/-/eth-sig-util-4.0.1.tgz", - "integrity": "sha512-tghyZKLHZjcdlDqCA3gNZmLeR0XvOE9U1qoQO9ohyAZT6Pya+H9vkBPcsyXytmYLNgVoin7CKCmweo/R43V+tQ==", - "dev": true, - "requires": { - "ethereumjs-abi": "^0.6.8", - "ethereumjs-util": "^6.2.1", - "ethjs-util": "^0.1.6", - "tweetnacl": "^1.0.3", - "tweetnacl-util": "^0.15.1" - }, - "dependencies": { - "@types/bn.js": { - "version": "4.11.6", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-4.11.6.tgz", - "integrity": "sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg==", - "dev": true, - "requires": { - "@types/node": "*" - } - }, - "bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - }, - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "ethereumjs-util": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz", - "integrity": "sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw==", - "dev": true, - "requires": { - "@types/bn.js": "^4.11.3", - "bn.js": "^4.11.0", - "create-hash": "^1.1.2", - "elliptic": "^6.5.2", - "ethereum-cryptography": "^0.1.3", - "ethjs-util": "0.1.6", - "rlp": "^2.2.3" - } - } - } - }, - "@noble/hashes": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.1.2.tgz", - "integrity": "sha512-KYRCASVTv6aeUi1tsF8/vpyR7zpfs3FUzy2Jqm+MU+LmUKhQ0y2FpfwqkCcxSg2ua4GALJd8k2R76WxwZGbQpA==", - "dev": true - }, - "@noble/secp256k1": { - "version": "1.6.3", - "resolved": "https://registry.npmjs.org/@noble/secp256k1/-/secp256k1-1.6.3.tgz", - "integrity": "sha512-T04e4iTurVy7I8Sw4+c5OSN9/RkPlo1uKxAomtxQNLq8j1uPAqnsqG1bqvY3Jv7c13gyr6dui0zmh/I3+f/JaQ==", - "dev": true - }, - "@nomicfoundation/ethereumjs-block": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-block/-/ethereumjs-block-5.0.2.tgz", - "integrity": "sha512-hSe6CuHI4SsSiWWjHDIzWhSiAVpzMUcDRpWYzN0T9l8/Rz7xNn3elwVOJ/tAyS0LqL6vitUD78Uk7lQDXZun7Q==", - "dev": true, - "requires": { - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "ethereum-cryptography": "0.1.3", - "ethers": "^5.7.1" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-blockchain": { - "version": "7.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-blockchain/-/ethereumjs-blockchain-7.0.2.tgz", - "integrity": "sha512-8UUsSXJs+MFfIIAKdh3cG16iNmWzWC/91P40sazNvrqhhdR/RtGDlFk2iFTGbBAZPs2+klZVzhRX8m2wvuvz3w==", - "dev": true, - "requires": { - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-ethash": "3.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "abstract-level": "^1.0.3", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "level": "^8.0.0", - "lru-cache": "^5.1.1", - "memory-level": "^1.0.0" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-common": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-common/-/ethereumjs-common-4.0.2.tgz", - "integrity": "sha512-I2WGP3HMGsOoycSdOTSqIaES0ughQTueOsddJ36aYVpI3SN8YSusgRFLwzDJwRFVIYDKx/iJz0sQ5kBHVgdDwg==", - "dev": true, - "requires": { - "@nomicfoundation/ethereumjs-util": "9.0.2", - "crc-32": "^1.2.0" - } - }, - "@nomicfoundation/ethereumjs-ethash": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-ethash/-/ethereumjs-ethash-3.0.2.tgz", - "integrity": "sha512-8PfoOQCcIcO9Pylq0Buijuq/O73tmMVURK0OqdjhwqcGHYC2PwhbajDh7GZ55ekB0Px197ajK3PQhpKoiI/UPg==", - "dev": true, - "requires": { - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "abstract-level": "^1.0.3", - "bigint-crypto-utils": "^3.0.23", - "ethereum-cryptography": "0.1.3" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-evm": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-evm/-/ethereumjs-evm-2.0.2.tgz", - "integrity": "sha512-rBLcUaUfANJxyOx9HIdMX6uXGin6lANCulIm/pjMgRqfiCRMZie3WKYxTSd8ZE/d+qT+zTedBF4+VHTdTSePmQ==", - "dev": true, - "requires": { - "@ethersproject/providers": "^5.7.1", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "mcl-wasm": "^0.7.1", - "rustbn.js": "~0.2.0" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-rlp": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-rlp/-/ethereumjs-rlp-5.0.2.tgz", - "integrity": "sha512-QwmemBc+MMsHJ1P1QvPl8R8p2aPvvVcKBbvHnQOKBpBztEo0omN0eaob6FeZS/e3y9NSe+mfu3nNFBHszqkjTA==", - "dev": true - }, - "@nomicfoundation/ethereumjs-statemanager": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-statemanager/-/ethereumjs-statemanager-2.0.2.tgz", - "integrity": "sha512-dlKy5dIXLuDubx8Z74sipciZnJTRSV/uHG48RSijhgm1V7eXYFC567xgKtsKiVZB1ViTP9iFL4B6Je0xD6X2OA==", - "dev": true, - "requires": { - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "ethers": "^5.7.1", - "js-sdsl": "^4.1.4" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-trie": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-trie/-/ethereumjs-trie-6.0.2.tgz", - "integrity": "sha512-yw8vg9hBeLYk4YNg5MrSJ5H55TLOv2FSWUTROtDtTMMmDGROsAu+0tBjiNGTnKRi400M6cEzoFfa89Fc5k8NTQ==", - "dev": true, - "requires": { - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "@types/readable-stream": "^2.3.13", - "ethereum-cryptography": "0.1.3", - "readable-stream": "^3.6.0" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-tx": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-tx/-/ethereumjs-tx-5.0.2.tgz", - "integrity": "sha512-T+l4/MmTp7VhJeNloMkM+lPU3YMUaXdcXgTGCf8+ZFvV9NYZTRLFekRwlG6/JMmVfIfbrW+dRRJ9A6H5Q/Z64g==", - "dev": true, - "requires": { - "@chainsafe/ssz": "^0.9.2", - "@ethersproject/providers": "^5.7.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "ethereum-cryptography": "0.1.3" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-util": { - "version": "9.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-util/-/ethereumjs-util-9.0.2.tgz", - "integrity": "sha512-4Wu9D3LykbSBWZo8nJCnzVIYGvGCuyiYLIJa9XXNVt1q1jUzHdB+sJvx95VGCpPkCT+IbLecW6yfzy3E1bQrwQ==", - "dev": true, - "requires": { - "@chainsafe/ssz": "^0.10.0", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "ethereum-cryptography": "0.1.3" - }, - "dependencies": { - "@chainsafe/persistent-merkle-tree": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.5.0.tgz", - "integrity": "sha512-l0V1b5clxA3iwQLXP40zYjyZYospQLZXzBVIhhr9kDg/1qHZfzzHw0jj4VPBijfYCArZDlPkRi1wZaV2POKeuw==", - "dev": true, - "requires": { - "@chainsafe/as-sha256": "^0.3.1" - } - }, - "@chainsafe/ssz": { - "version": "0.10.2", - "resolved": "https://registry.npmjs.org/@chainsafe/ssz/-/ssz-0.10.2.tgz", - "integrity": "sha512-/NL3Lh8K+0q7A3LsiFq09YXS9fPE+ead2rr7vM2QK8PLzrNsw3uqrif9bpRX5UxgeRjM+vYi+boCM3+GM4ovXg==", - "dev": true, - "requires": { - "@chainsafe/as-sha256": "^0.3.1", - "@chainsafe/persistent-merkle-tree": "^0.5.0" - } - }, - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/ethereumjs-vm": { - "version": "7.0.2", - "resolved": "https://registry.npmjs.org/@nomicfoundation/ethereumjs-vm/-/ethereumjs-vm-7.0.2.tgz", - "integrity": "sha512-Bj3KZT64j54Tcwr7Qm/0jkeZXJMfdcAtRBedou+Hx0dPOSIgqaIr0vvLwP65TpHbak2DmAq+KJbW2KNtIoFwvA==", - "dev": true, - "requires": { - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-blockchain": "7.0.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-evm": "2.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-statemanager": "2.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "debug": "^4.3.3", - "ethereum-cryptography": "0.1.3", - "mcl-wasm": "^0.7.1", - "rustbn.js": "~0.2.0" - }, - "dependencies": { - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - } - } - }, - "@nomicfoundation/solidity-analyzer": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer/-/solidity-analyzer-0.1.1.tgz", - "integrity": "sha512-1LMtXj1puAxyFusBgUIy5pZk3073cNXYnXUpuNKFghHbIit/xZgbk0AokpUADbNm3gyD6bFWl3LRFh3dhVdREg==", - "dev": true, - "requires": { - "@nomicfoundation/solidity-analyzer-darwin-arm64": "0.1.1", - "@nomicfoundation/solidity-analyzer-darwin-x64": "0.1.1", - "@nomicfoundation/solidity-analyzer-freebsd-x64": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-arm64-musl": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-x64-gnu": "0.1.1", - "@nomicfoundation/solidity-analyzer-linux-x64-musl": "0.1.1", - "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": "0.1.1", - "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": "0.1.1", - "@nomicfoundation/solidity-analyzer-win32-x64-msvc": "0.1.1" - } - }, - "@nomicfoundation/solidity-analyzer-darwin-arm64": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-arm64/-/solidity-analyzer-darwin-arm64-0.1.1.tgz", - "integrity": "sha512-KcTodaQw8ivDZyF+D76FokN/HdpgGpfjc/gFCImdLUyqB6eSWVaZPazMbeAjmfhx3R0zm/NYVzxwAokFKgrc0w==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-darwin-x64": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-darwin-x64/-/solidity-analyzer-darwin-x64-0.1.1.tgz", - "integrity": "sha512-XhQG4BaJE6cIbjAVtzGOGbK3sn1BO9W29uhk9J8y8fZF1DYz0Doj8QDMfpMu+A6TjPDs61lbsmeYodIDnfveSA==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-freebsd-x64": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-freebsd-x64/-/solidity-analyzer-freebsd-x64-0.1.1.tgz", - "integrity": "sha512-GHF1VKRdHW3G8CndkwdaeLkVBi5A9u2jwtlS7SLhBc8b5U/GcoL39Q+1CSO3hYqePNP+eV5YI7Zgm0ea6kMHoA==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-gnu/-/solidity-analyzer-linux-arm64-gnu-0.1.1.tgz", - "integrity": "sha512-g4Cv2fO37ZsUENQ2vwPnZc2zRenHyAxHcyBjKcjaSmmkKrFr64yvzeNO8S3GBFCo90rfochLs99wFVGT/0owpg==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-linux-arm64-musl": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-arm64-musl/-/solidity-analyzer-linux-arm64-musl-0.1.1.tgz", - "integrity": "sha512-WJ3CE5Oek25OGE3WwzK7oaopY8xMw9Lhb0mlYuJl/maZVo+WtP36XoQTb7bW/i8aAdHW5Z+BqrHMux23pvxG3w==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-linux-x64-gnu": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-gnu/-/solidity-analyzer-linux-x64-gnu-0.1.1.tgz", - "integrity": "sha512-5WN7leSr5fkUBBjE4f3wKENUy9HQStu7HmWqbtknfXkkil+eNWiBV275IOlpXku7v3uLsXTOKpnnGHJYI2qsdA==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-linux-x64-musl": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-linux-x64-musl/-/solidity-analyzer-linux-x64-musl-0.1.1.tgz", - "integrity": "sha512-KdYMkJOq0SYPQMmErv/63CwGwMm5XHenEna9X9aB8mQmhDBrYrlAOSsIPgFCUSL0hjxE3xHP65/EPXR/InD2+w==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-arm64-msvc/-/solidity-analyzer-win32-arm64-msvc-0.1.1.tgz", - "integrity": "sha512-VFZASBfl4qiBYwW5xeY20exWhmv6ww9sWu/krWSesv3q5hA0o1JuzmPHR4LPN6SUZj5vcqci0O6JOL8BPw+APg==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-ia32-msvc/-/solidity-analyzer-win32-ia32-msvc-0.1.1.tgz", - "integrity": "sha512-JnFkYuyCSA70j6Si6cS1A9Gh1aHTEb8kOTBApp/c7NRTFGNMH8eaInKlyuuiIbvYFhlXW4LicqyYuWNNq9hkpQ==", - "dev": true, - "optional": true - }, - "@nomicfoundation/solidity-analyzer-win32-x64-msvc": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@nomicfoundation/solidity-analyzer-win32-x64-msvc/-/solidity-analyzer-win32-x64-msvc-0.1.1.tgz", - "integrity": "sha512-HrVJr6+WjIXGnw3Q9u6KQcbZCtk0caVWhCdFADySvRyUxJ8PnzlaP+MhwNE8oyT8OZ6ejHBRrrgjSqDCFXGirw==", - "dev": true, - "optional": true - }, - "@scure/base": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@scure/base/-/base-1.1.1.tgz", - "integrity": "sha512-ZxOhsSyxYwLJj3pLZCefNitxsj093tb2vq90mp2txoYeBqbcjDjqFhyM8eUjq/uFm6zJ+mUuqxlS2FkuSY1MTA==", - "dev": true - }, - "@scure/bip32": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@scure/bip32/-/bip32-1.1.0.tgz", - "integrity": "sha512-ftTW3kKX54YXLCxH6BB7oEEoJfoE2pIgw7MINKAs5PsS6nqKPuKk1haTF/EuHmYqG330t5GSrdmtRuHaY1a62Q==", - "dev": true, - "requires": { - "@noble/hashes": "~1.1.1", - "@noble/secp256k1": "~1.6.0", - "@scure/base": "~1.1.0" - } - }, - "@scure/bip39": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@scure/bip39/-/bip39-1.1.0.tgz", - "integrity": "sha512-pwrPOS16VeTKg98dYXQyIjJEcWfz7/1YJIwxUEPFfQPtc86Ym/1sVgQ2RLoD43AazMk2l/unK4ITySSpW2+82w==", - "dev": true, - "requires": { - "@noble/hashes": "~1.1.1", - "@scure/base": "~1.1.0" - } - }, - "@sentry/core": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/core/-/core-5.30.0.tgz", - "integrity": "sha512-TmfrII8w1PQZSZgPpUESqjB+jC6MvZJZdLtE/0hZ+SrnKhW3x5WlYLvTXZpcWePYBku7rl2wn1RZu6uT0qCTeg==", - "dev": true, - "requires": { - "@sentry/hub": "5.30.0", - "@sentry/minimal": "5.30.0", - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "tslib": "^1.9.3" - } - }, - "@sentry/hub": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/hub/-/hub-5.30.0.tgz", - "integrity": "sha512-2tYrGnzb1gKz2EkMDQcfLrDTvmGcQPuWxLnJKXJvYTQDGLlEvi2tWz1VIHjunmOvJrB5aIQLhm+dcMRwFZDCqQ==", - "dev": true, - "requires": { - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "tslib": "^1.9.3" - } - }, - "@sentry/minimal": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/minimal/-/minimal-5.30.0.tgz", - "integrity": "sha512-BwWb/owZKtkDX+Sc4zCSTNcvZUq7YcH3uAVlmh/gtR9rmUvbzAA3ewLuB3myi4wWRAMEtny6+J/FN/x+2wn9Xw==", - "dev": true, - "requires": { - "@sentry/hub": "5.30.0", - "@sentry/types": "5.30.0", - "tslib": "^1.9.3" - } - }, - "@sentry/node": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/node/-/node-5.30.0.tgz", - "integrity": "sha512-Br5oyVBF0fZo6ZS9bxbJZG4ApAjRqAnqFFurMVJJdunNb80brh7a5Qva2kjhm+U6r9NJAB5OmDyPkA1Qnt+QVg==", - "dev": true, - "requires": { - "@sentry/core": "5.30.0", - "@sentry/hub": "5.30.0", - "@sentry/tracing": "5.30.0", - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "cookie": "^0.4.1", - "https-proxy-agent": "^5.0.0", - "lru_map": "^0.3.3", - "tslib": "^1.9.3" - } - }, - "@sentry/tracing": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/tracing/-/tracing-5.30.0.tgz", - "integrity": "sha512-dUFowCr0AIMwiLD7Fs314Mdzcug+gBVo/+NCMyDw8tFxJkwWAKl7Qa2OZxLQ0ZHjakcj1hNKfCQJ9rhyfOl4Aw==", - "dev": true, - "requires": { - "@sentry/hub": "5.30.0", - "@sentry/minimal": "5.30.0", - "@sentry/types": "5.30.0", - "@sentry/utils": "5.30.0", - "tslib": "^1.9.3" - } - }, - "@sentry/types": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/types/-/types-5.30.0.tgz", - "integrity": "sha512-R8xOqlSTZ+htqrfteCWU5Nk0CDN5ApUTvrlvBuiH1DyP6czDZ4ktbZB0hAgBlVcK0U+qpD3ag3Tqqpa5Q67rPw==", - "dev": true - }, - "@sentry/utils": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@sentry/utils/-/utils-5.30.0.tgz", - "integrity": "sha512-zaYmoH0NWWtvnJjC9/CBseXMtKHm/tm40sz3YfJRxeQjyzRqNQPgivpd9R/oDJCYj999mzdW382p/qi2ypjLww==", - "dev": true, - "requires": { - "@sentry/types": "5.30.0", - "tslib": "^1.9.3" - } - }, - "@types/bn.js": { - "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-5.1.5.tgz", - "integrity": "sha512-V46N0zwKRF5Q00AZ6hWtN0T8gGmDUaUzLWQvHFo5yThtVwK/VCenFY3wXVbOvNfajEpsTfQM4IN9k/d6gUVX3A==", - "dev": true, - "requires": { - "@types/node": "*" - } - }, - "@types/lru-cache": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/@types/lru-cache/-/lru-cache-5.1.1.tgz", - "integrity": "sha512-ssE3Vlrys7sdIzs5LOxCzTVMsU7i9oa/IaW92wF32JFb3CVczqOkru2xspuKczHEbG3nvmPY7IFqVmGGHdNbYw==", - "dev": true - }, - "@types/node": { - "version": "18.0.6", - "resolved": "https://registry.npmjs.org/@types/node/-/node-18.0.6.tgz", - "integrity": "sha512-/xUq6H2aQm261exT6iZTMifUySEt4GR5KX8eYyY+C4MSNPqSh9oNIP7tz2GLKTlFaiBbgZNxffoR3CVRG+cljw==", - "dev": true - }, - "@types/pbkdf2": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@types/pbkdf2/-/pbkdf2-3.1.0.tgz", - "integrity": "sha512-Cf63Rv7jCQ0LaL8tNXmEyqTHuIJxRdlS5vMh1mj5voN4+QFhVZnlZruezqpWYDiJ8UTzhP0VmeLXCmBk66YrMQ==", - "dev": true, - "requires": { - "@types/node": "*" - } - }, - "@types/readable-stream": { - "version": "2.3.15", - "resolved": "https://registry.npmjs.org/@types/readable-stream/-/readable-stream-2.3.15.tgz", - "integrity": "sha512-oM5JSKQCcICF1wvGgmecmHldZ48OZamtMxcGGVICOJA8o8cahXC1zEVAif8iwoc5j8etxFaRFnf095+CDsuoFQ==", - "dev": true, - "requires": { - "@types/node": "*", - "safe-buffer": "~5.1.1" - }, - "dependencies": { - "safe-buffer": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", - "dev": true - } - } - }, - "@types/secp256k1": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/@types/secp256k1/-/secp256k1-4.0.3.tgz", - "integrity": "sha512-Da66lEIFeIz9ltsdMZcpQvmrmmoqrfju8pm1BH8WbYjZSwUgCwXLb9C+9XYogwBITnbsSaMdVPb2ekf7TV+03w==", - "dev": true, - "requires": { - "@types/node": "*" - } - }, - "@ungap/promise-all-settled": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", - "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", - "dev": true - }, - "abstract-level": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/abstract-level/-/abstract-level-1.0.3.tgz", - "integrity": "sha512-t6jv+xHy+VYwc4xqZMn2Pa9DjcdzvzZmQGRjTFc8spIbRGHgBrEKbPq+rYXc7CCo0lxgYvSgKVg9qZAhpVQSjA==", - "dev": true, - "requires": { - "buffer": "^6.0.3", - "catering": "^2.1.0", - "is-buffer": "^2.0.5", - "level-supports": "^4.0.0", - "level-transcoder": "^1.0.1", - "module-error": "^1.0.1", - "queue-microtask": "^1.2.3" - } - }, - "adm-zip": { - "version": "0.4.16", - "resolved": "https://registry.npmjs.org/adm-zip/-/adm-zip-0.4.16.tgz", - "integrity": "sha512-TFi4HBKSGfIKsK5YCkKaaFG2m4PEDyViZmEwof3MTIgzimHLto6muaHVpbrljdIvIrFZzEq/p4nafOeLcYegrg==", - "dev": true - }, - "aes-js": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/aes-js/-/aes-js-3.0.0.tgz", - "integrity": "sha512-H7wUZRn8WpTq9jocdxQ2c8x2sKo9ZVmzfRE13GiNJXfp7NcKYEdvl3vspKjXox6RIG2VtaRe4JFvxG4rqp2Zuw==", - "dev": true - }, - "agent-base": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", - "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", - "dev": true, - "requires": { - "debug": "4" - } - }, - "aggregate-error": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", - "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", - "dev": true, - "requires": { - "clean-stack": "^2.0.0", - "indent-string": "^4.0.0" - } - }, - "ansi-colors": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", - "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", - "dev": true - }, - "ansi-escapes": { - "version": "4.3.2", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", - "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", - "dev": true, - "requires": { - "type-fest": "^0.21.3" - } - }, - "ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true - }, - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "anymatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", - "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", - "dev": true, - "requires": { - "normalize-path": "^3.0.0", - "picomatch": "^2.0.4" - } - }, - "argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true - }, - "balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", - "dev": true - }, - "base-x": { - "version": "3.0.9", - "resolved": "https://registry.npmjs.org/base-x/-/base-x-3.0.9.tgz", - "integrity": "sha512-H7JU6iBHTal1gp56aKoaa//YUxEaAOUiydvrV/pILqIHXTtqxSkATOnDA2u+jZ/61sD+L/412+7kzXRtWukhpQ==", - "dev": true, - "requires": { - "safe-buffer": "^5.0.1" - } - }, - "base64-js": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", - "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", - "dev": true - }, - "bech32": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/bech32/-/bech32-1.1.4.tgz", - "integrity": "sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==", - "dev": true - }, - "bigint-crypto-utils": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/bigint-crypto-utils/-/bigint-crypto-utils-3.3.0.tgz", - "integrity": "sha512-jOTSb+drvEDxEq6OuUybOAv/xxoh3cuYRUIPyu8sSHQNKM303UQ2R1DAo45o1AkcIXw6fzbaFI1+xGGdaXs2lg==", - "dev": true - }, - "binary-extensions": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", - "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", - "dev": true - }, - "blakejs": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/blakejs/-/blakejs-1.2.1.tgz", - "integrity": "sha512-QXUSXI3QVc/gJME0dBpXrag1kbzOqCjCX8/b54ntNyW6sjtoqxqRk3LTmXzaJoh71zMsDCjM+47jS7XiwN/+fQ==", - "dev": true - }, - "bn.js": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-5.2.1.tgz", - "integrity": "sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ==", - "dev": true - }, - "brace-expansion": { - "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", - "dev": true, - "requires": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "braces": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", - "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", - "dev": true, - "requires": { - "fill-range": "^7.0.1" - } - }, - "brorand": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", - "integrity": "sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w==", - "dev": true - }, - "browser-level": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/browser-level/-/browser-level-1.0.1.tgz", - "integrity": "sha512-XECYKJ+Dbzw0lbydyQuJzwNXtOpbMSq737qxJN11sIRTErOMShvDpbzTlgju7orJKvx4epULolZAuJGLzCmWRQ==", - "dev": true, - "requires": { - "abstract-level": "^1.0.2", - "catering": "^2.1.1", - "module-error": "^1.0.2", - "run-parallel-limit": "^1.1.0" - } - }, - "browser-stdout": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", - "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", - "dev": true - }, - "browserify-aes": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", - "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", - "dev": true, - "requires": { - "buffer-xor": "^1.0.3", - "cipher-base": "^1.0.0", - "create-hash": "^1.1.0", - "evp_bytestokey": "^1.0.3", - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - }, - "dependencies": { - "buffer-xor": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", - "integrity": "sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ==", - "dev": true - } - } - }, - "bs58": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/bs58/-/bs58-4.0.1.tgz", - "integrity": "sha512-Ok3Wdf5vOIlBrgCvTq96gBkJw+JUEzdBgyaza5HLtPm7yTHkjRy8+JzNyHF7BHa0bNWOQIp3m5YF0nnFcOIKLw==", - "dev": true, - "requires": { - "base-x": "^3.0.2" - } - }, - "bs58check": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/bs58check/-/bs58check-2.1.2.tgz", - "integrity": "sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA==", - "dev": true, - "requires": { - "bs58": "^4.0.0", - "create-hash": "^1.1.0", - "safe-buffer": "^5.1.2" - } - }, - "buffer": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", - "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", - "dev": true, - "requires": { - "base64-js": "^1.3.1", - "ieee754": "^1.2.1" - } - }, - "buffer-from": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", - "dev": true - }, - "bytes": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", - "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", - "dev": true - }, - "camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true - }, - "case": { - "version": "1.6.3", - "resolved": "https://registry.npmjs.org/case/-/case-1.6.3.tgz", - "integrity": "sha512-mzDSXIPaFwVDvZAHqZ9VlbyF4yyXRuX6IvB06WvPYkqJVO24kX1PPhv9bfpKNFZyxYFmmgo03HUiD8iklmJYRQ==", - "dev": true - }, - "catering": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/catering/-/catering-2.1.1.tgz", - "integrity": "sha512-K7Qy8O9p76sL3/3m7/zLKbRkyOlSZAgzEaLhyj2mXS8PsCud2Eo4hAb8aLtZqHh0QGqLcb9dlJSu6lHRVENm1w==", - "dev": true - }, - "chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "chokidar": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", - "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", - "dev": true, - "requires": { - "anymatch": "~3.1.2", - "braces": "~3.0.2", - "fsevents": "~2.3.2", - "glob-parent": "~5.1.2", - "is-binary-path": "~2.1.0", - "is-glob": "~4.0.1", - "normalize-path": "~3.0.0", - "readdirp": "~3.6.0" - } - }, - "ci-info": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", - "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", - "dev": true - }, - "cipher-base": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", - "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "classic-level": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/classic-level/-/classic-level-1.3.0.tgz", - "integrity": "sha512-iwFAJQYtqRTRM0F6L8h4JCt00ZSGdOyqh7yVrhhjrOpFhmBjNlRUey64MCiyo6UmQHMJ+No3c81nujPv+n9yrg==", - "dev": true, - "requires": { - "abstract-level": "^1.0.2", - "catering": "^2.1.0", - "module-error": "^1.0.1", - "napi-macros": "^2.2.2", - "node-gyp-build": "^4.3.0" - } - }, - "clean-stack": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", - "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", - "dev": true - }, - "cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dev": true, - "requires": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" - } - }, - "color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dev": true, - "requires": { - "color-name": "1.1.3" - } - }, - "color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", - "dev": true - }, - "command-exists": { - "version": "1.2.9", - "resolved": "https://registry.npmjs.org/command-exists/-/command-exists-1.2.9.tgz", - "integrity": "sha512-LTQ/SGc+s0Xc0Fu5WaKnR0YiygZkm9eKFvyS+fRsU7/ZWFF8ykFM6Pc9aCVf1+xasOOZpO3BAVgVrKvsqKHV7w==", - "dev": true - }, - "commander": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/commander/-/commander-3.0.2.tgz", - "integrity": "sha512-Gar0ASD4BDyKC4hl4DwHqDrmvjoxWKZigVnAbn5H1owvm4CxCPdb0HQDehwNYMJpla5+M2tPmPARzhtYuwpHow==", - "dev": true - }, - "concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", - "dev": true - }, - "cookie": { - "version": "0.4.2", - "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", - "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", - "dev": true - }, - "crc-32": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", - "integrity": "sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==", - "dev": true - }, - "create-hash": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", - "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", - "dev": true, - "requires": { - "cipher-base": "^1.0.1", - "inherits": "^2.0.1", - "md5.js": "^1.3.4", - "ripemd160": "^2.0.1", - "sha.js": "^2.4.0" - } - }, - "create-hmac": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", - "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", - "dev": true, - "requires": { - "cipher-base": "^1.0.3", - "create-hash": "^1.1.0", - "inherits": "^2.0.1", - "ripemd160": "^2.0.0", - "safe-buffer": "^5.0.1", - "sha.js": "^2.4.8" - } - }, - "debug": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", - "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", - "dev": true, - "requires": { - "ms": "2.1.2" - } - }, - "decamelize": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", - "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", - "dev": true - }, - "depd": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", - "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", - "dev": true - }, - "diff": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", - "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", - "dev": true - }, - "elliptic": { - "version": "6.5.4", - "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.4.tgz", - "integrity": "sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ==", - "dev": true, - "requires": { - "bn.js": "^4.11.9", - "brorand": "^1.1.0", - "hash.js": "^1.0.0", - "hmac-drbg": "^1.0.1", - "inherits": "^2.0.4", - "minimalistic-assert": "^1.0.1", - "minimalistic-crypto-utils": "^1.0.1" - }, - "dependencies": { - "bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - } - } - }, - "emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true - }, - "enquirer": { - "version": "2.3.6", - "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", - "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", - "dev": true, - "requires": { - "ansi-colors": "^4.1.1" - } - }, - "env-paths": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz", - "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==", - "dev": true - }, - "escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", - "dev": true - }, - "escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true - }, - "ethereum-cryptography": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-1.1.2.tgz", - "integrity": "sha512-XDSJlg4BD+hq9N2FjvotwUET9Tfxpxc3kWGE2AqUG5vcbeunnbImVk3cj6e/xT3phdW21mE8R5IugU4fspQDcQ==", - "dev": true, - "requires": { - "@noble/hashes": "1.1.2", - "@noble/secp256k1": "1.6.3", - "@scure/bip32": "1.1.0", - "@scure/bip39": "1.1.0" - } - }, - "ethereumjs-abi": { - "version": "0.6.8", - "resolved": "https://registry.npmjs.org/ethereumjs-abi/-/ethereumjs-abi-0.6.8.tgz", - "integrity": "sha512-Tx0r/iXI6r+lRsdvkFDlut0N08jWMnKRZ6Gkq+Nmw75lZe4e6o3EkSnkaBP5NF6+m5PTGAr9JP43N3LyeoglsA==", - "dev": true, - "requires": { - "bn.js": "^4.11.8", - "ethereumjs-util": "^6.0.0" - }, - "dependencies": { - "@types/bn.js": { - "version": "4.11.6", - "resolved": "https://registry.npmjs.org/@types/bn.js/-/bn.js-4.11.6.tgz", - "integrity": "sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg==", - "dev": true, - "requires": { - "@types/node": "*" - } - }, - "bn.js": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", - "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", - "dev": true - }, - "ethereum-cryptography": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz", - "integrity": "sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ==", - "dev": true, - "requires": { - "@types/pbkdf2": "^3.0.0", - "@types/secp256k1": "^4.0.1", - "blakejs": "^1.1.0", - "browserify-aes": "^1.2.0", - "bs58check": "^2.1.2", - "create-hash": "^1.2.0", - "create-hmac": "^1.1.7", - "hash.js": "^1.1.7", - "keccak": "^3.0.0", - "pbkdf2": "^3.0.17", - "randombytes": "^2.1.0", - "safe-buffer": "^5.1.2", - "scrypt-js": "^3.0.0", - "secp256k1": "^4.0.1", - "setimmediate": "^1.0.5" - } - }, - "ethereumjs-util": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz", - "integrity": "sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw==", - "dev": true, - "requires": { - "@types/bn.js": "^4.11.3", - "bn.js": "^4.11.0", - "create-hash": "^1.1.2", - "elliptic": "^6.5.2", - "ethereum-cryptography": "^0.1.3", - "ethjs-util": "0.1.6", - "rlp": "^2.2.3" - } - } - } - }, - "ethers": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/ethers/-/ethers-5.7.2.tgz", - "integrity": "sha512-wswUsmWo1aOK8rR7DIKiWSw9DbLWe6x98Jrn8wcTflTVvaXhAMaB5zGAXy0GYQEQp9iO1iSHWVyARQm11zUtyg==", - "dev": true, - "requires": { - "@ethersproject/abi": "5.7.0", - "@ethersproject/abstract-provider": "5.7.0", - "@ethersproject/abstract-signer": "5.7.0", - "@ethersproject/address": "5.7.0", - "@ethersproject/base64": "5.7.0", - "@ethersproject/basex": "5.7.0", - "@ethersproject/bignumber": "5.7.0", - "@ethersproject/bytes": "5.7.0", - "@ethersproject/constants": "5.7.0", - "@ethersproject/contracts": "5.7.0", - "@ethersproject/hash": "5.7.0", - "@ethersproject/hdnode": "5.7.0", - "@ethersproject/json-wallets": "5.7.0", - "@ethersproject/keccak256": "5.7.0", - "@ethersproject/logger": "5.7.0", - "@ethersproject/networks": "5.7.1", - "@ethersproject/pbkdf2": "5.7.0", - "@ethersproject/properties": "5.7.0", - "@ethersproject/providers": "5.7.2", - "@ethersproject/random": "5.7.0", - "@ethersproject/rlp": "5.7.0", - "@ethersproject/sha2": "5.7.0", - "@ethersproject/signing-key": "5.7.0", - "@ethersproject/solidity": "5.7.0", - "@ethersproject/strings": "5.7.0", - "@ethersproject/transactions": "5.7.0", - "@ethersproject/units": "5.7.0", - "@ethersproject/wallet": "5.7.0", - "@ethersproject/web": "5.7.1", - "@ethersproject/wordlists": "5.7.0" - } - }, - "ethjs-util": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/ethjs-util/-/ethjs-util-0.1.6.tgz", - "integrity": "sha512-CUnVOQq7gSpDHZVVrQW8ExxUETWrnrvXYvYz55wOU8Uj4VCgw56XC2B/fVqQN+f7gmrnRHSLVnFAwsCuNwji8w==", - "dev": true, - "requires": { - "is-hex-prefixed": "1.0.0", - "strip-hex-prefix": "1.0.0" - } - }, - "evp_bytestokey": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", - "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", - "dev": true, - "requires": { - "md5.js": "^1.3.4", - "safe-buffer": "^5.1.1" - } - }, - "fill-range": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", - "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", - "dev": true, - "requires": { - "to-regex-range": "^5.0.1" - } - }, - "find-up": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", - "integrity": "sha512-NWzkk0jSJtTt08+FBFMvXoeZnOJD+jTtsRmBYbAIzJdX6l7dLgR7CTubCM5/eDdPUBvLCeVasP1brfVR/9/EZQ==", - "dev": true, - "requires": { - "locate-path": "^2.0.0" - } - }, - "flat": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", - "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", - "dev": true - }, - "follow-redirects": { - "version": "1.15.1", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.1.tgz", - "integrity": "sha512-yLAMQs+k0b2m7cVxpS1VKJVvoz7SS9Td1zss3XRwXj+ZDH00RJgnuLx7E44wx02kQLrdM3aOOy+FpzS7+8OizA==", - "dev": true - }, - "fp-ts": { - "version": "1.19.3", - "resolved": "https://registry.npmjs.org/fp-ts/-/fp-ts-1.19.3.tgz", - "integrity": "sha512-H5KQDspykdHuztLTg+ajGN0Z2qUjcEf3Ybxc6hLt0k7/zPkn29XnKnxlBPyW2XIddWrGaJBzBl4VLYOtk39yZg==", - "dev": true - }, - "fs-extra": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", - "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", - "dev": true, - "requires": { - "graceful-fs": "^4.1.2", - "jsonfile": "^4.0.0", - "universalify": "^0.1.0" - } - }, - "fs.realpath": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", - "dev": true - }, - "fsevents": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", - "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", - "dev": true, - "optional": true - }, - "functional-red-black-tree": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", - "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", - "dev": true - }, - "get-caller-file": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", - "dev": true - }, - "glob": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", - "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", - "dev": true, - "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.0.4", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - } - }, - "glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, - "requires": { - "is-glob": "^4.0.1" - } - }, - "graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", - "dev": true - }, - "hardhat": { - "version": "2.19.0", - "resolved": "https://registry.npmjs.org/hardhat/-/hardhat-2.19.0.tgz", - "integrity": "sha512-kMpwovOEfrFRQXEopCP+JTcKVwSYVj8rnXE0LynxDqnh06yvyKCQknmXL6IVYTHQL6Csysc/yNbCHQbjSeJGpA==", - "dev": true, - "requires": { - "@ethersproject/abi": "^5.1.2", - "@metamask/eth-sig-util": "^4.0.0", - "@nomicfoundation/ethereumjs-block": "5.0.2", - "@nomicfoundation/ethereumjs-blockchain": "7.0.2", - "@nomicfoundation/ethereumjs-common": "4.0.2", - "@nomicfoundation/ethereumjs-evm": "2.0.2", - "@nomicfoundation/ethereumjs-rlp": "5.0.2", - "@nomicfoundation/ethereumjs-statemanager": "2.0.2", - "@nomicfoundation/ethereumjs-trie": "6.0.2", - "@nomicfoundation/ethereumjs-tx": "5.0.2", - "@nomicfoundation/ethereumjs-util": "9.0.2", - "@nomicfoundation/ethereumjs-vm": "7.0.2", - "@nomicfoundation/solidity-analyzer": "^0.1.0", - "@sentry/node": "^5.18.1", - "@types/bn.js": "^5.1.0", - "@types/lru-cache": "^5.1.0", - "adm-zip": "^0.4.16", - "aggregate-error": "^3.0.0", - "ansi-escapes": "^4.3.0", - "chalk": "^2.4.2", - "chokidar": "^3.4.0", - "ci-info": "^2.0.0", - "debug": "^4.1.1", - "enquirer": "^2.3.0", - "env-paths": "^2.2.0", - "ethereum-cryptography": "^1.0.3", - "ethereumjs-abi": "^0.6.8", - "find-up": "^2.1.0", - "fp-ts": "1.19.3", - "fs-extra": "^7.0.1", - "glob": "7.2.0", - "immutable": "^4.0.0-rc.12", - "io-ts": "1.10.4", - "keccak": "^3.0.2", - "lodash": "^4.17.11", - "mnemonist": "^0.38.0", - "mocha": "^10.0.0", - "p-map": "^4.0.0", - "raw-body": "^2.4.1", - "resolve": "1.17.0", - "semver": "^6.3.0", - "solc": "0.7.3", - "source-map-support": "^0.5.13", - "stacktrace-parser": "^0.1.10", - "tsort": "0.0.1", - "undici": "^5.14.0", - "uuid": "^8.3.2", - "ws": "^7.4.6" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "dev": true - }, - "hash-base": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.1.0.tgz", - "integrity": "sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA==", - "dev": true, - "requires": { - "inherits": "^2.0.4", - "readable-stream": "^3.6.0", - "safe-buffer": "^5.2.0" - } - }, - "hash.js": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", - "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", - "dev": true, - "requires": { - "inherits": "^2.0.3", - "minimalistic-assert": "^1.0.1" - } - }, - "he": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", - "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", - "dev": true - }, - "hmac-drbg": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", - "integrity": "sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg==", - "dev": true, - "requires": { - "hash.js": "^1.0.3", - "minimalistic-assert": "^1.0.0", - "minimalistic-crypto-utils": "^1.0.1" - } - }, - "http-errors": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", - "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", - "dev": true, - "requires": { - "depd": "2.0.0", - "inherits": "2.0.4", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "toidentifier": "1.0.1" - } - }, - "https-proxy-agent": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", - "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", - "dev": true, - "requires": { - "agent-base": "6", - "debug": "4" - } - }, - "iconv-lite": { - "version": "0.4.24", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", - "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dev": true, - "requires": { - "safer-buffer": ">= 2.1.2 < 3" - } - }, - "ieee754": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", - "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", - "dev": true - }, - "immutable": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.1.0.tgz", - "integrity": "sha512-oNkuqVTA8jqG1Q6c+UglTOD1xhC1BtjKI7XkCXRkZHrN5m18/XsnUp8Q89GkQO/z+0WjonSvl0FLhDYftp46nQ==", - "dev": true - }, - "indent-string": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", - "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", - "dev": true - }, - "inflight": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", - "dev": true, - "requires": { - "once": "^1.3.0", - "wrappy": "1" - } - }, - "inherits": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", - "dev": true - }, - "io-ts": { - "version": "1.10.4", - "resolved": "https://registry.npmjs.org/io-ts/-/io-ts-1.10.4.tgz", - "integrity": "sha512-b23PteSnYXSONJ6JQXRAlvJhuw8KOtkqa87W4wDtvMrud/DTJd5X+NpOOI+O/zZwVq6v0VLAaJ+1EDViKEuN9g==", - "dev": true, - "requires": { - "fp-ts": "^1.0.0" - } - }, - "is-binary-path": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", - "dev": true, - "requires": { - "binary-extensions": "^2.0.0" - } - }, - "is-buffer": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", - "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==", - "dev": true - }, - "is-extglob": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", - "dev": true - }, - "is-fullwidth-code-point": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true - }, - "is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, - "requires": { - "is-extglob": "^2.1.1" - } - }, - "is-hex-prefixed": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-hex-prefixed/-/is-hex-prefixed-1.0.0.tgz", - "integrity": "sha512-WvtOiug1VFrE9v1Cydwm+FnXd3+w9GaeVUss5W4v/SLy3UW00vP+6iNF2SdnfiBoLy4bTqVdkftNGTUeOFVsbA==", - "dev": true - }, - "is-number": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", - "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "dev": true - }, - "is-plain-obj": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", - "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", - "dev": true - }, - "is-unicode-supported": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", - "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", - "dev": true - }, - "js-sdsl": { - "version": "4.4.2", - "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.4.2.tgz", - "integrity": "sha512-dwXFwByc/ajSV6m5bcKAPwe4yDDF6D614pxmIi5odytzxRlwqF6nwoiCek80Ixc7Cvma5awClxrzFtxCQvcM8w==", - "dev": true - }, - "js-sha3": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/js-sha3/-/js-sha3-0.8.0.tgz", - "integrity": "sha512-gF1cRrHhIzNfToc802P800N8PpXS+evLLXfsVpowqmAFR9uwbi89WvXg2QspOmXL8QL86J4T1EpFu+yUkwJY3Q==", - "dev": true - }, - "js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", - "dev": true, - "requires": { - "argparse": "^2.0.1" - } - }, - "jsonfile": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", - "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", - "dev": true, - "requires": { - "graceful-fs": "^4.1.6" - } - }, - "keccak": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/keccak/-/keccak-3.0.2.tgz", - "integrity": "sha512-PyKKjkH53wDMLGrvmRGSNWgmSxZOUqbnXwKL9tmgbFYA1iAYqW21kfR7mZXV0MlESiefxQQE9X9fTa3X+2MPDQ==", - "dev": true, - "requires": { - "node-addon-api": "^2.0.0", - "node-gyp-build": "^4.2.0", - "readable-stream": "^3.6.0" - } - }, - "klaw": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/klaw/-/klaw-1.3.1.tgz", - "integrity": "sha512-TED5xi9gGQjGpNnvRWknrwAB1eL5GciPfVFOt3Vk1OJCVDQbzuSfrF3hkUQKlsgKrG1F+0t5W0m+Fje1jIt8rw==", - "dev": true, - "requires": { - "graceful-fs": "^4.1.9" - } - }, - "level": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/level/-/level-8.0.0.tgz", - "integrity": "sha512-ypf0jjAk2BWI33yzEaaotpq7fkOPALKAgDBxggO6Q9HGX2MRXn0wbP1Jn/tJv1gtL867+YOjOB49WaUF3UoJNQ==", - "dev": true, - "requires": { - "browser-level": "^1.0.1", - "classic-level": "^1.2.0" - } - }, - "level-supports": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/level-supports/-/level-supports-4.0.1.tgz", - "integrity": "sha512-PbXpve8rKeNcZ9C1mUicC9auIYFyGpkV9/i6g76tLgANwWhtG2v7I4xNBUlkn3lE2/dZF3Pi0ygYGtLc4RXXdA==", - "dev": true - }, - "level-transcoder": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/level-transcoder/-/level-transcoder-1.0.1.tgz", - "integrity": "sha512-t7bFwFtsQeD8cl8NIoQ2iwxA0CL/9IFw7/9gAjOonH0PWTTiRfY7Hq+Ejbsxh86tXobDQ6IOiddjNYIfOBs06w==", - "dev": true, - "requires": { - "buffer": "^6.0.3", - "module-error": "^1.0.1" - } - }, - "locate-path": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", - "integrity": "sha512-NCI2kiDkyR7VeEKm27Kda/iQHyKJe1Bu0FlTbYp3CqJu+9IFe9bLyAjMxf5ZDDbEg+iMPzB5zYyUTSm8wVTKmA==", - "dev": true, - "requires": { - "p-locate": "^2.0.0", - "path-exists": "^3.0.0" - } - }, - "lodash": { - "version": "4.17.21", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", - "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", - "dev": true - }, - "log-symbols": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", - "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", - "dev": true, - "requires": { - "chalk": "^4.1.0", - "is-unicode-supported": "^0.1.0" - }, - "dependencies": { - "ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "requires": { - "color-convert": "^2.0.1" - } - }, - "chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "requires": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - } - }, - "color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "requires": { - "color-name": "~1.1.4" - } - }, - "color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true - }, - "supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "requires": { - "has-flag": "^4.0.0" - } - } - } - }, - "lru_map": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/lru_map/-/lru_map-0.3.3.tgz", - "integrity": "sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ==", - "dev": true - }, - "lru-cache": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", - "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", - "dev": true, - "requires": { - "yallist": "^3.0.2" - } - }, - "mcl-wasm": { - "version": "0.7.9", - "resolved": "https://registry.npmjs.org/mcl-wasm/-/mcl-wasm-0.7.9.tgz", - "integrity": "sha512-iJIUcQWA88IJB/5L15GnJVnSQJmf/YaxxV6zRavv83HILHaJQb6y0iFyDMdDO0gN8X37tdxmAOrH/P8B6RB8sQ==", - "dev": true - }, - "md5.js": { - "version": "1.3.5", - "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", - "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", - "dev": true, - "requires": { - "hash-base": "^3.0.0", - "inherits": "^2.0.1", - "safe-buffer": "^5.1.2" - } - }, - "memory-level": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/memory-level/-/memory-level-1.0.0.tgz", - "integrity": "sha512-UXzwewuWeHBz5krr7EvehKcmLFNoXxGcvuYhC41tRnkrTbJohtS7kVn9akmgirtRygg+f7Yjsfi8Uu5SGSQ4Og==", - "dev": true, - "requires": { - "abstract-level": "^1.0.0", - "functional-red-black-tree": "^1.0.1", - "module-error": "^1.0.1" - } - }, - "memorystream": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", - "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", - "dev": true - }, - "minimalistic-assert": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", - "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", - "dev": true - }, - "minimalistic-crypto-utils": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", - "integrity": "sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg==", - "dev": true - }, - "minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", - "dev": true, - "requires": { - "brace-expansion": "^1.1.7" - } - }, - "mnemonist": { - "version": "0.38.5", - "resolved": "https://registry.npmjs.org/mnemonist/-/mnemonist-0.38.5.tgz", - "integrity": "sha512-bZTFT5rrPKtPJxj8KSV0WkPyNxl72vQepqqVUAW2ARUpUSF2qXMB6jZj7hW5/k7C1rtpzqbD/IIbJwLXUjCHeg==", - "dev": true, - "requires": { - "obliterator": "^2.0.0" - } - }, - "mocha": { - "version": "10.0.0", - "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.0.0.tgz", - "integrity": "sha512-0Wl+elVUD43Y0BqPZBzZt8Tnkw9CMUdNYnUsTfOM1vuhJVZL+kiesFYsqwBkEEuEixaiPe5ZQdqDgX2jddhmoA==", - "dev": true, - "requires": { - "@ungap/promise-all-settled": "1.1.2", - "ansi-colors": "4.1.1", - "browser-stdout": "1.3.1", - "chokidar": "3.5.3", - "debug": "4.3.4", - "diff": "5.0.0", - "escape-string-regexp": "4.0.0", - "find-up": "5.0.0", - "glob": "7.2.0", - "he": "1.2.0", - "js-yaml": "4.1.0", - "log-symbols": "4.1.0", - "minimatch": "5.0.1", - "ms": "2.1.3", - "nanoid": "3.3.3", - "serialize-javascript": "6.0.0", - "strip-json-comments": "3.1.1", - "supports-color": "8.1.1", - "workerpool": "6.2.1", - "yargs": "16.2.0", - "yargs-parser": "20.2.4", - "yargs-unparser": "2.0.0" - }, - "dependencies": { - "ansi-colors": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", - "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", - "dev": true - }, - "brace-expansion": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", - "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", - "dev": true, - "requires": { - "balanced-match": "^1.0.0" - } - }, - "escape-string-regexp": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", - "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", - "dev": true - }, - "find-up": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", - "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", - "dev": true, - "requires": { - "locate-path": "^6.0.0", - "path-exists": "^4.0.0" - } - }, - "has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true - }, - "locate-path": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", - "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", - "dev": true, - "requires": { - "p-locate": "^5.0.0" - } - }, - "minimatch": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", - "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", - "dev": true, - "requires": { - "brace-expansion": "^2.0.1" - } - }, - "ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", - "dev": true - }, - "p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", - "dev": true, - "requires": { - "yocto-queue": "^0.1.0" - } - }, - "p-locate": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", - "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", - "dev": true, - "requires": { - "p-limit": "^3.0.2" - } - }, - "path-exists": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", - "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true - }, - "supports-color": { - "version": "8.1.1", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", - "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", - "dev": true, - "requires": { - "has-flag": "^4.0.0" - } - } - } - }, - "module-error": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/module-error/-/module-error-1.0.2.tgz", - "integrity": "sha512-0yuvsqSCv8LbaOKhnsQ/T5JhyFlCYLPXK3U2sgV10zoKQwzs/MyfuQUOZQ1V/6OCOJsK/TRgNVrPuPDqtdMFtA==", - "dev": true - }, - "ms": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", - "dev": true - }, - "nanoid": { - "version": "3.3.3", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", - "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", - "dev": true - }, - "napi-macros": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/napi-macros/-/napi-macros-2.2.2.tgz", - "integrity": "sha512-hmEVtAGYzVQpCKdbQea4skABsdXW4RUh5t5mJ2zzqowJS2OyXZTU1KhDVFhx+NlWZ4ap9mqR9TcDO3LTTttd+g==", - "dev": true - }, - "node-addon-api": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-2.0.2.tgz", - "integrity": "sha512-Ntyt4AIXyaLIuMHF6IOoTakB3K+RWxwtsHNRxllEoA6vPwP9o4866g6YWDLUdnucilZhmkxiHwHr11gAENw+QA==", - "dev": true - }, - "node-gyp-build": { - "version": "4.5.0", - "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.5.0.tgz", - "integrity": "sha512-2iGbaQBV+ITgCz76ZEjmhUKAKVf7xfY1sRl4UiKQspfZMH2h06SyhNsnSVy50cwkFQDGLyif6m/6uFXHkOZ6rg==", - "dev": true - }, - "normalize-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true - }, - "obliterator": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/obliterator/-/obliterator-2.0.4.tgz", - "integrity": "sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ==", - "dev": true - }, - "once": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", - "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", - "dev": true, - "requires": { - "wrappy": "1" - } - }, - "os-tmpdir": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==", - "dev": true - }, - "p-limit": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", - "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", - "dev": true, - "requires": { - "p-try": "^1.0.0" - } - }, - "p-locate": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", - "integrity": "sha512-nQja7m7gSKuewoVRen45CtVfODR3crN3goVQ0DDZ9N3yHxgpkuBhZqsaiotSQRrADUrne346peY7kT3TSACykg==", - "dev": true, - "requires": { - "p-limit": "^1.1.0" - } - }, - "p-map": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", - "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", - "dev": true, - "requires": { - "aggregate-error": "^3.0.0" - } - }, - "p-try": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", - "integrity": "sha512-U1etNYuMJoIz3ZXSrrySFjsXQTWOx2/jdi86L+2pRvph/qMKL6sbcCYdH23fqsbm8TH2Gn0OybpT4eSFlCVHww==", - "dev": true - }, - "path-exists": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", - "dev": true - }, - "path-is-absolute": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", - "dev": true - }, - "path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", - "dev": true - }, - "pbkdf2": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.1.2.tgz", - "integrity": "sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA==", - "dev": true, - "requires": { - "create-hash": "^1.1.2", - "create-hmac": "^1.1.4", - "ripemd160": "^2.0.1", - "safe-buffer": "^5.0.1", - "sha.js": "^2.4.8" - } - }, - "picomatch": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", - "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "dev": true - }, - "queue-microtask": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", - "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", - "dev": true - }, - "randombytes": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", - "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", - "dev": true, - "requires": { - "safe-buffer": "^5.1.0" - } - }, - "raw-body": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", - "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", - "dev": true, - "requires": { - "bytes": "3.1.2", - "http-errors": "2.0.0", - "iconv-lite": "0.4.24", - "unpipe": "1.0.0" - } - }, - "readable-stream": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", - "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", - "dev": true, - "requires": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - } - }, - "readdirp": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", - "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dev": true, - "requires": { - "picomatch": "^2.2.1" - } - }, - "require-directory": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", - "dev": true - }, - "require-from-string": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", - "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", - "dev": true - }, - "resolve": { - "version": "1.17.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", - "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", - "dev": true, - "requires": { - "path-parse": "^1.0.6" - } - }, - "rimraf": { - "version": "2.7.1", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", - "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", - "dev": true, - "requires": { - "glob": "^7.1.3" - } - }, - "ripemd160": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", - "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", - "dev": true, - "requires": { - "hash-base": "^3.0.0", - "inherits": "^2.0.1" - } - }, - "rlp": { - "version": "2.2.7", - "resolved": "https://registry.npmjs.org/rlp/-/rlp-2.2.7.tgz", - "integrity": "sha512-d5gdPmgQ0Z+AklL2NVXr/IoSjNZFfTVvQWzL/AM2AOcSzYP2xjlb0AC8YyCLc41MSNf6P6QVtjgPdmVtzb+4lQ==", - "dev": true, - "requires": { - "bn.js": "^5.2.0" - } - }, - "run-parallel-limit": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/run-parallel-limit/-/run-parallel-limit-1.1.0.tgz", - "integrity": "sha512-jJA7irRNM91jaKc3Hcl1npHsFLOXOoTkPCUL1JEa1R82O2miplXXRaGdjW/KM/98YQWDhJLiSs793CnXfblJUw==", - "dev": true, - "requires": { - "queue-microtask": "^1.2.2" - } - }, - "rustbn.js": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/rustbn.js/-/rustbn.js-0.2.0.tgz", - "integrity": "sha512-4VlvkRUuCJvr2J6Y0ImW7NvTCriMi7ErOAqWk1y69vAdoNIzCF3yPmgeNzx+RQTLEDFq5sHfscn1MwHxP9hNfA==", - "dev": true - }, - "safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "dev": true - }, - "safer-buffer": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", - "dev": true - }, - "scrypt-js": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/scrypt-js/-/scrypt-js-3.0.1.tgz", - "integrity": "sha512-cdwTTnqPu0Hyvf5in5asVdZocVDTNRmR7XEcJuIzMjJeSHybHl7vpB66AzwTaIg6CLSbtjcxc8fqcySfnTkccA==", - "dev": true - }, - "secp256k1": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/secp256k1/-/secp256k1-4.0.3.tgz", - "integrity": "sha512-NLZVf+ROMxwtEj3Xa562qgv2BK5e2WNmXPiOdVIPLgs6lyTzMvBq0aWTYMI5XCP9jZMVKOcqZLw/Wc4vDkuxhA==", - "dev": true, - "requires": { - "elliptic": "^6.5.4", - "node-addon-api": "^2.0.0", - "node-gyp-build": "^4.2.0" - } - }, - "semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "dev": true - }, - "serialize-javascript": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", - "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", - "dev": true, - "requires": { - "randombytes": "^2.1.0" - } - }, - "setimmediate": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", - "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", - "dev": true - }, - "setprototypeof": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", - "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", - "dev": true - }, - "sha.js": { - "version": "2.4.11", - "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", - "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "solc": { - "version": "0.7.3", - "resolved": "https://registry.npmjs.org/solc/-/solc-0.7.3.tgz", - "integrity": "sha512-GAsWNAjGzIDg7VxzP6mPjdurby3IkGCjQcM8GFYZT6RyaoUZKmMU6Y7YwG+tFGhv7dwZ8rmR4iwFDrrD99JwqA==", - "dev": true, - "requires": { - "command-exists": "^1.2.8", - "commander": "3.0.2", - "follow-redirects": "^1.12.1", - "fs-extra": "^0.30.0", - "js-sha3": "0.8.0", - "memorystream": "^0.3.1", - "require-from-string": "^2.0.0", - "semver": "^5.5.0", - "tmp": "0.0.33" - }, - "dependencies": { - "fs-extra": { - "version": "0.30.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-0.30.0.tgz", - "integrity": "sha512-UvSPKyhMn6LEd/WpUaV9C9t3zATuqoqfWc3QdPhPLb58prN9tqYPlPWi8Krxi44loBoUzlobqZ3+8tGpxxSzwA==", - "dev": true, - "requires": { - "graceful-fs": "^4.1.2", - "jsonfile": "^2.1.0", - "klaw": "^1.0.0", - "path-is-absolute": "^1.0.0", - "rimraf": "^2.2.8" - } - }, - "jsonfile": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", - "integrity": "sha512-PKllAqbgLgxHaj8TElYymKCAgrASebJrWpTnEkOaTowt23VKXXN0sUeriJ+eh7y6ufb/CC5ap11pz71/cM0hUw==", - "dev": true, - "requires": { - "graceful-fs": "^4.1.6" - } - }, - "semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", - "dev": true - } - } - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true - }, - "source-map-support": { - "version": "0.5.21", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", - "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", - "dev": true, - "requires": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - }, - "stacktrace-parser": { - "version": "0.1.10", - "resolved": "https://registry.npmjs.org/stacktrace-parser/-/stacktrace-parser-0.1.10.tgz", - "integrity": "sha512-KJP1OCML99+8fhOHxwwzyWrlUuVX5GQ0ZpJTd1DFXhdkrvg1szxfHhawXUZ3g9TkXORQd4/WG68jMlQZ2p8wlg==", - "dev": true, - "requires": { - "type-fest": "^0.7.1" - }, - "dependencies": { - "type-fest": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.7.1.tgz", - "integrity": "sha512-Ne2YiiGN8bmrmJJEuTWTLJR32nh/JdL1+PSicowtNb0WFpn59GK8/lfD61bVtzguz7b3PBt74nxpv/Pw5po5Rg==", - "dev": true - } - } - }, - "statuses": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", - "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", - "dev": true - }, - "string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dev": true, - "requires": { - "safe-buffer": "~5.2.0" - } - }, - "string-width": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, - "requires": { - "emoji-regex": "^8.0.0", - "is-fullwidth-code-point": "^3.0.0", - "strip-ansi": "^6.0.1" - } - }, - "strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "requires": { - "ansi-regex": "^5.0.1" - } - }, - "strip-hex-prefix": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/strip-hex-prefix/-/strip-hex-prefix-1.0.0.tgz", - "integrity": "sha512-q8d4ue7JGEiVcypji1bALTos+0pWtyGlivAWyPuTkHzuTCJqrK9sWxYQZUq6Nq3cuyv3bm734IhHvHtGGURU6A==", - "dev": true, - "requires": { - "is-hex-prefixed": "1.0.0" - } - }, - "strip-json-comments": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", - "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", - "dev": true - }, - "supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - }, - "tmp": { - "version": "0.0.33", - "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", - "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", - "dev": true, - "requires": { - "os-tmpdir": "~1.0.2" - } - }, - "to-regex-range": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", - "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dev": true, - "requires": { - "is-number": "^7.0.0" - } - }, - "toidentifier": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", - "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", - "dev": true - }, - "tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", - "dev": true - }, - "tsort": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/tsort/-/tsort-0.0.1.tgz", - "integrity": "sha512-Tyrf5mxF8Ofs1tNoxA13lFeZ2Zrbd6cKbuH3V+MQ5sb6DtBj5FjrXVsRWT8YvNAQTqNoz66dz1WsbigI22aEnw==", - "dev": true - }, - "tweetnacl": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-1.0.3.tgz", - "integrity": "sha512-6rt+RN7aOi1nGMyC4Xa5DdYiukl2UWCbcJft7YhxReBGQD7OAM8Pbxw6YMo4r2diNEA8FEmu32YOn9rhaiE5yw==", - "dev": true - }, - "tweetnacl-util": { - "version": "0.15.1", - "resolved": "https://registry.npmjs.org/tweetnacl-util/-/tweetnacl-util-0.15.1.tgz", - "integrity": "sha512-RKJBIj8lySrShN4w6i/BonWp2Z/uxwC3h4y7xsRrpP59ZboCd0GpEVsOnMDYLMmKBpYhb5TgHzZXy7wTfYFBRw==", - "dev": true - }, - "type-fest": { - "version": "0.21.3", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", - "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", - "dev": true - }, - "undici": { - "version": "5.27.2", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.27.2.tgz", - "integrity": "sha512-iS857PdOEy/y3wlM3yRp+6SNQQ6xU0mmZcwRSriqk+et/cwWAtwmIGf6WkoDN2EK/AMdCO/dfXzIwi+rFMrjjQ==", - "dev": true, - "requires": { - "@fastify/busboy": "^2.0.0" - } - }, - "universalify": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", - "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", - "dev": true - }, - "unpipe": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", - "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", - "dev": true - }, - "util-deprecate": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", - "dev": true - }, - "uuid": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", - "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", - "dev": true - }, - "workerpool": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", - "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", - "dev": true - }, - "wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "requires": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "dependencies": { - "ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "requires": { - "color-convert": "^2.0.1" - } - }, - "color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "requires": { - "color-name": "~1.1.4" - } - }, - "color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - } - } - }, - "wrappy": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", - "dev": true - }, - "ws": { - "version": "7.5.9", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.9.tgz", - "integrity": "sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==", - "dev": true, - "requires": {} - }, - "y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true - }, - "yallist": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", - "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", - "dev": true - }, - "yargs": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", - "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", - "dev": true, - "requires": { - "cliui": "^7.0.2", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.0", - "y18n": "^5.0.5", - "yargs-parser": "^20.2.2" - } - }, - "yargs-parser": { - "version": "20.2.4", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", - "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", - "dev": true - }, - "yargs-unparser": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", - "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", - "dev": true, - "requires": { - "camelcase": "^6.0.0", - "decamelize": "^4.0.0", - "flat": "^5.0.2", - "is-plain-obj": "^2.1.0" - } - }, - "yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true - } - } -} diff --git a/package.json b/package.json deleted file mode 100644 index 31deec0..0000000 --- a/package.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "scripts": { - "preinstall": "npm install --global ganache@7.5.0" - }, - "devDependencies": { - "hardhat": "^2.19.0" - } -} diff --git a/requirements.in b/requirements.in index 53bfadc..7aea6c1 100644 --- a/requirements.in +++ b/requirements.in @@ -1,8 +1,4 @@ -eth-ape -ape-vyper -ape-alchemy -ape-hardhat -ape-ledger +titanoboa==0.1.8 black flake8 isort diff --git a/requirements.txt b/requirements.txt index e891439..96190f3 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,435 +1,202 @@ # -# This file is autogenerated by pip-compile with Python 3.10 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # -# pip-compile requirements.in +# pip-compile # -aiohttp==3.8.3 - # via web3 -aiosignal==1.2.0 - # via aiohttp -ape-alchemy==0.5.0 - # via -r requirements.in -ape-hardhat==0.5.0 - # via -r requirements.in -ape-ledger==0.5.0 - # via -r requirements.in -ape-vyper==0.5.0 - # via -r requirements.in -async-timeout==4.0.2 - # via aiohttp -attrs==22.1.0 - # via - # aiohttp - # jsonschema - # pytest -backcall==0.2.0 - # via ipython -base58==1.0.3 - # via - # multiaddr - # py-cid - # py-multihash -bitarray==2.6.0 +asttokens==2.4.1 + # via vyper +attrs==23.1.0 + # via hypothesis +bitarray==2.8.3 # via eth-account -black==22.10.0 +black==23.11.0 # via -r requirements.in -build==0.8.0 +build==1.0.3 # via pip-tools cached-property==1.5.2 # via # py-ecc # py-evm -certifi==2022.9.24 +cbor2==5.5.1 + # via vyper +certifi==2023.11.17 # via requests -cffi==1.15.1 - # via - # pygit2 - # pynacl -cfgv==3.3.1 +cfgv==3.4.0 # via pre-commit -charset-normalizer==2.1.1 - # via - # aiohttp - # requests -click==8.1.3 +charset-normalizer==3.3.2 + # via requests +click==8.1.7 # via - # ape-ledger # black - # eth-ape # pip-tools -commonmark==0.9.1 - # via rich -cytoolz==0.12.0 +cytoolz==0.12.2 # via eth-utils -dataclassy==0.11.1 - # via eip712 -decorator==5.1.1 - # via ipython -deprecated==1.2.13 - # via pygithub -distlib==0.3.6 +distlib==0.3.7 # via virtualenv -eip712==0.1.4 - # via eth-ape -eth-abi==3.0.1 +eth-abi==4.2.1 # via - # eip712 # eth-account - # eth-ape - # eth-tester - # web3 -eth-account==0.7.0 - # via - # ape-ledger - # eth-ape - # eth-tester - # web3 -eth-ape==0.5.2 - # via - # -r requirements.in - # ape-alchemy - # ape-hardhat - # ape-ledger - # ape-vyper -eth-bloom==1.0.4 + # titanoboa +eth-account==0.10.0 + # via titanoboa +eth-bloom==3.0.0 # via py-evm -eth-hash[pycryptodome,pysha3]==0.3.3 +eth-hash[pycryptodome]==0.5.2 # via # eth-bloom # eth-hash - # eth-tester # eth-utils # trie - # web3 -eth-keyfile==0.6.0 +eth-keyfile==0.6.1 # via eth-account eth-keys==0.4.0 # via # eth-account # eth-keyfile - # eth-tester # py-evm eth-rlp==0.3.0 # via eth-account -eth-tester[py-evm]==0.7.0b1 - # via - # eth-tester - # web3 -eth-typing==3.2.0 +eth-stdlib==0.2.7 + # via titanoboa +eth-typing==3.5.2 # via - # ape-ledger - # eip712 # eth-abi - # eth-ape # eth-keys # eth-utils # py-ecc # py-evm - # web3 -eth-utils==2.0.0 + # titanoboa +eth-utils==2.3.1 # via - # ape-ledger - # eip712 # eth-abi # eth-account - # eth-ape # eth-keyfile # eth-keys # eth-rlp - # eth-tester - # ethpm-types - # evm-trace # py-ecc # py-evm # rlp # trie - # web3 -ethpm-types==0.3.7 - # via - # eth-ape - # evm-trace -evm-trace==0.1.0a10 - # via - # ape-hardhat - # eth-ape -filelock==3.8.0 +filelock==3.13.1 # via virtualenv -flake8==5.0.4 +flake8==6.1.0 # via -r requirements.in -frozenlist==1.3.1 +hexbytes==0.3.1 # via - # aiohttp - # aiosignal -greenlet==3.0.1 - # via sqlalchemy -hexbytes==0.3.0 - # via - # ape-hardhat - # ape-ledger - # eip712 # eth-account - # eth-ape # eth-rlp - # ethpm-types - # evm-trace # trie - # web3 -hidapi==0.10.1 - # via ape-ledger -identify==2.5.6 +hypothesis==6.90.0 + # via titanoboa +identify==2.5.32 # via pre-commit idna==3.4 - # via - # requests - # yarl -ijson==3.1.4 - # via eth-ape -importlib-metadata==5.0.0 - # via - # ape-ledger - # eth-ape -iniconfig==1.1.1 + # via requests +importlib-metadata==6.8.0 + # via vyper +iniconfig==2.0.0 # via pytest -ipfshttpclient==0.8.0a2 - # via web3 -ipython==7.34.0 - # via eth-ape -isort==5.10.1 +isort==5.12.0 # via -r requirements.in -jedi==0.18.1 - # via ipython -jsonschema==4.16.0 - # via web3 -lru-dict==1.1.8 - # via - # py-evm - # web3 -matplotlib-inline==0.1.6 - # via ipython +lru-dict==1.3.0 + # via py-evm +markdown-it-py==3.0.0 + # via rich mccabe==0.7.0 # via flake8 -morphys==1.0 - # via - # py-cid - # py-multibase - # py-multicodec - # py-multihash -msgspec==0.9.0 - # via evm-trace -multiaddr==0.0.9 - # via ipfshttpclient -multidict==6.0.2 - # via - # aiohttp - # yarl -mypy-extensions==0.4.3 +mdurl==0.1.2 + # via markdown-it-py +mypy-extensions==1.0.0 # via # black # py-ecc # py-evm -netaddr==0.8.0 - # via multiaddr -nodeenv==1.7.0 +nodeenv==1.8.0 # via pre-commit -numpy==1.23.4 - # via pandas -packaging==20.9 +packaging==23.2 # via + # black # build - # eth-ape # pytest -pandas==1.5.0 - # via eth-ape -parsimonious==0.8.1 + # vyper +parsimonious==0.9.0 # via eth-abi -parso==0.8.3 - # via jedi -pathspec==0.10.1 +pathspec==0.11.2 # via black -pep517==0.13.0 - # via build -pexpect==4.8.0 - # via ipython -pickleshare==0.7.5 - # via ipython -pip-tools==6.9.0 +pip-tools==7.3.0 # via -r requirements.in -platformdirs==2.5.2 +platformdirs==3.11.0 # via # black # virtualenv -pluggy==1.0.0 - # via - # eth-ape - # pytest -pre-commit==2.20.0 - # via -r requirements.in -prompt-toolkit==3.0.31 - # via ipython -protobuf==3.20.1 - # via web3 -ptyprocess==0.7.0 - # via pexpect -py==1.11.0 +pluggy==1.3.0 # via pytest -py-cid==0.3.0 - # via ethpm-types +pre-commit==3.5.0 + # via -r requirements.in py-ecc==6.0.0 # via py-evm -py-evm==0.6.0a1 - # via eth-tester -py-geth==3.9.1 - # via - # eth-ape - # web3 -py-multibase==1.0.3 - # via py-cid -py-multicodec==0.2.1 - # via py-cid -py-multihash==0.2.3 - # via py-cid -pycodestyle==2.9.1 +py-evm==0.8.0b1 + # via titanoboa +pycodestyle==2.11.1 # via flake8 -pycparser==2.21 - # via cffi -pycryptodome==3.15.0 +pycryptodome==3.19.0 # via - # eip712 # eth-hash # eth-keyfile -pydantic==1.10.2 - # via - # eth-ape - # ethpm-types - # evm-trace -pyethash==0.1.27 - # via py-evm -pyflakes==2.5.0 + # eth-stdlib + # vyper +pyflakes==3.1.0 # via flake8 -pygit2==1.10.1 - # via eth-ape -pygithub==1.56 - # via eth-ape -pygments==2.13.0 - # via - # ipython - # rich -pyjwt==2.5.0 - # via pygithub -pynacl==1.5.0 - # via pygithub -pyparsing==3.0.9 - # via packaging -pyrsistent==0.18.1 - # via jsonschema -pysha3==1.0.2 - # via eth-hash -pytest==7.1.3 - # via eth-ape -python-baseconv==1.2.2 - # via py-multibase -python-dateutil==2.8.2 - # via - # eth-ape - # pandas -pytz==2022.4 - # via pandas -pyyaml==6.0 - # via - # eth-ape - # pre-commit -requests==2.28.1 - # via - # ape-alchemy - # eth-ape - # ethpm-types - # ipfshttpclient - # pygithub - # vvm - # web3 -rich==12.6.0 +pygments==2.17.1 + # via rich +pyproject-hooks==1.0.0 + # via build +pytest==7.4.3 + # via titanoboa +pyyaml==6.0.1 + # via pre-commit +regex==2023.10.3 + # via parsimonious +requests==2.31.0 + # via titanoboa +rich==13.7.0 # via # -r requirements.in - # eth-ape + # titanoboa rlp==3.0.0 # via - # ape-ledger # eth-account # eth-rlp - # eth-tester # py-evm # trie -semantic-version==2.10.0 - # via - # eth-tester - # py-geth - # vvm six==1.16.0 - # via - # multiaddr - # parsimonious - # py-multibase - # py-multicodec - # py-multihash - # python-dateutil + # via asttokens sortedcontainers==2.4.0 - # via trie -sqlalchemy==1.4.41 - # via eth-ape + # via + # hypothesis + # trie tabulate==0.9.0 # via -r requirements.in -toml==0.10.2 - # via pre-commit -tomli==2.0.1 - # via - # black - # build - # pep517 - # pytest +titanoboa==0.1.8 + # via -r requirements.in toolz==0.12.0 # via cytoolz -tqdm==4.64.1 - # via - # ape-vyper - # eth-ape -traitlets==5.4.0 - # via - # eth-ape - # ipython - # matplotlib-inline -trie==2.0.2 +trie==2.2.0 # via py-evm -typing-extensions==4.4.0 - # via pydantic -urllib3==1.26.12 +typing-extensions==4.8.0 + # via eth-typing +urllib3==2.1.0 # via requests -varint==1.0.2 - # via - # multiaddr - # py-multicodec - # py-multihash -virtualenv==20.16.5 +virtualenv==20.24.6 # via pre-commit -vvm==0.1.0 - # via ape-vyper -wcwidth==0.2.5 - # via prompt-toolkit -web3[tester]==6.0.0b6 +vyper==0.3.10 + # via titanoboa +wheel==0.41.3 # via - # ape-alchemy - # ape-hardhat - # eth-ape - # web3 -websockets==10.3 - # via web3 -wheel==0.37.1 - # via pip-tools -wrapt==1.14.1 - # via deprecated -yarl==1.8.1 - # via aiohttp -zipp==3.9.0 + # pip-tools + # vyper +zipp==3.17.0 # via importlib-metadata # The following packages are considered to be unsafe in a requirements file: diff --git a/requirements_brownie.in b/requirements_brownie.in deleted file mode 100644 index e0472a6..0000000 --- a/requirements_brownie.in +++ /dev/null @@ -1,8 +0,0 @@ -eth-brownie -black -flake8 -isort -pip-tools -pre-commit -tabulate -rich diff --git a/requirements_brownie.txt b/requirements_brownie.txt deleted file mode 100644 index ae87a52..0000000 --- a/requirements_brownie.txt +++ /dev/null @@ -1,400 +0,0 @@ -# -# This file is autogenerated by pip-compile with python 3.10 -# To update, run: -# -# pip-compile requirements_brownie.in -# -aiohttp==3.8.1 - # via - # eth-brownie - # web3 -aiosignal==1.2.0 - # via - # aiohttp - # eth-brownie -asttokens==2.0.5 - # via - # eth-brownie - # vyper -async-timeout==4.0.2 - # via - # aiohttp - # eth-brownie -attrs==22.1.0 - # via - # aiohttp - # eth-brownie - # hypothesis - # jsonschema - # pytest -base58==2.1.1 - # via - # eth-brownie - # multiaddr -bitarray==2.6.0 - # via - # eth-account - # eth-brownie -black==22.6.0 - # via - # -r requirements_brownie.in - # eth-brownie -build==0.8.0 - # via pip-tools -certifi==2022.6.15 - # via - # eth-brownie - # requests -cfgv==3.3.1 - # via pre-commit -charset-normalizer==2.1.0 - # via - # aiohttp - # eth-brownie - # requests -click==8.1.3 - # via - # black - # eth-brownie - # pip-tools -commonmark==0.9.1 - # via rich -cytoolz==0.12.0 - # via - # eth-brownie - # eth-keyfile - # eth-utils -dataclassy==0.11.1 - # via - # eip712 - # eth-brownie -distlib==0.3.6 - # via virtualenv -eip712==0.1.0 - # via eth-brownie -eth-abi==2.2.0 - # via - # eip712 - # eth-account - # eth-brownie - # eth-event - # web3 -eth-account==0.5.9 - # via - # eth-brownie - # web3 -eth-brownie==1.19.1 - # via -r requirements_brownie.in -eth-event==1.2.3 - # via eth-brownie -eth-hash[pycryptodome]==0.3.3 - # via - # eth-brownie - # eth-event - # eth-utils - # web3 -eth-keyfile==0.5.1 - # via - # eth-account - # eth-brownie -eth-keys==0.3.4 - # via - # eth-account - # eth-brownie - # eth-keyfile -eth-rlp==0.2.1 - # via - # eth-account - # eth-brownie - # web3 -eth-typing==2.3.0 - # via - # eip712 - # eth-abi - # eth-brownie - # eth-keys - # eth-utils - # web3 -eth-utils==1.10.0 - # via - # eip712 - # eth-abi - # eth-account - # eth-brownie - # eth-event - # eth-keyfile - # eth-keys - # eth-rlp - # rlp - # web3 -execnet==1.9.0 - # via - # eth-brownie - # pytest-xdist -filelock==3.8.0 - # via virtualenv -flake8==5.0.4 - # via -r requirements_brownie.in -frozenlist==1.3.1 - # via - # aiohttp - # aiosignal - # eth-brownie -hexbytes==0.2.2 - # via - # eip712 - # eth-account - # eth-brownie - # eth-event - # eth-rlp - # web3 -hypothesis==6.27.3 - # via eth-brownie -identify==2.5.6 - # via pre-commit -idna==3.3 - # via - # eth-brownie - # requests - # yarl -inflection==0.5.0 - # via - # eth-brownie - # mythx-models - # pythx -iniconfig==1.1.1 - # via - # eth-brownie - # pytest -ipfshttpclient==0.8.0a2 - # via - # eth-brownie - # web3 -isort==5.10.1 - # via -r requirements_brownie.in -jsonschema==3.2.0 - # via - # eth-brownie - # mythx-models - # web3 -lazy-object-proxy==1.7.1 - # via eth-brownie -lru-dict==1.1.8 - # via - # eth-brownie - # web3 -mccabe==0.7.0 - # via flake8 -multiaddr==0.0.9 - # via - # eth-brownie - # ipfshttpclient -multidict==6.0.2 - # via - # aiohttp - # eth-brownie - # yarl -mypy-extensions==0.4.3 - # via - # black - # eth-brownie -mythx-models==1.9.1 - # via - # eth-brownie - # pythx -netaddr==0.8.0 - # via - # eth-brownie - # multiaddr -nodeenv==1.7.0 - # via pre-commit -packaging==21.3 - # via - # build - # eth-brownie - # pytest -parsimonious==0.8.1 - # via - # eth-abi - # eth-brownie -pathspec==0.9.0 - # via - # black - # eth-brownie -pep517==0.13.0 - # via build -pip-tools==6.9.0 - # via -r requirements_brownie.in -platformdirs==2.5.2 - # via - # black - # eth-brownie - # virtualenv -pluggy==1.0.0 - # via - # eth-brownie - # pytest -pre-commit==2.20.0 - # via -r requirements_brownie.in -prompt-toolkit==3.0.30 - # via eth-brownie -protobuf==3.20.1 - # via - # eth-brownie - # web3 -psutil==5.9.1 - # via eth-brownie -py==1.11.0 - # via - # eth-brownie - # pytest - # pytest-forked -py-solc-ast==1.2.9 - # via eth-brownie -py-solc-x==1.1.1 - # via eth-brownie -pycodestyle==2.9.1 - # via flake8 -pycryptodome==3.15.0 - # via - # eip712 - # eth-brownie - # eth-hash - # eth-keyfile - # vyper -pyflakes==2.5.0 - # via flake8 -pygments==2.12.0 - # via - # eth-brownie - # pygments-lexer-solidity - # rich -pygments-lexer-solidity==0.7.0 - # via eth-brownie -pyjwt==1.7.1 - # via - # eth-brownie - # pythx -pyparsing==3.0.9 - # via - # eth-brownie - # packaging -pyrsistent==0.18.1 - # via - # eth-brownie - # jsonschema -pytest==6.2.5 - # via - # eth-brownie - # pytest-forked - # pytest-xdist -pytest-forked==1.4.0 - # via - # eth-brownie - # pytest-xdist -pytest-xdist==1.34.0 - # via eth-brownie -python-dateutil==2.8.1 - # via - # eth-brownie - # mythx-models - # pythx -python-dotenv==0.16.0 - # via eth-brownie -pythx==1.6.1 - # via eth-brownie -pyyaml==5.4.1 - # via - # eth-brownie - # pre-commit -requests==2.28.1 - # via - # eth-brownie - # ipfshttpclient - # py-solc-x - # pythx - # vvm - # web3 -rich==12.6.0 - # via -r requirements_brownie.in -rlp==2.0.1 - # via - # eth-account - # eth-brownie - # eth-rlp -semantic-version==2.8.5 - # via - # eth-brownie - # py-solc-x - # vvm - # vyper -six==1.16.0 - # via - # asttokens - # eth-brownie - # jsonschema - # multiaddr - # parsimonious - # pytest-xdist - # python-dateutil -sortedcontainers==2.4.0 - # via - # eth-brownie - # hypothesis -tabulate==0.9.0 - # via -r requirements_brownie.in -toml==0.10.2 - # via - # eth-brownie - # pre-commit - # pytest -tomli==2.0.1 - # via - # black - # build - # eth-brownie -toolz==0.12.0 - # via - # cytoolz - # eth-brownie -tqdm==4.64.0 - # via eth-brownie -urllib3==1.26.11 - # via - # eth-brownie - # requests -varint==1.0.2 - # via - # eth-brownie - # multiaddr -virtualenv==20.16.5 - # via pre-commit -vvm==0.1.0 - # via eth-brownie -vyper==0.3.6 - # via eth-brownie -wcwidth==0.2.5 - # via - # eth-brownie - # prompt-toolkit -web3==5.30.0 - # via eth-brownie -websockets==9.1 - # via - # eth-brownie - # web3 -wheel==0.37.1 - # via - # eth-brownie - # pip-tools - # vyper -wrapt==1.14.1 - # via eth-brownie -yarl==1.8.1 - # via - # aiohttp - # eth-brownie - -# The following packages are considered to be unsafe in a requirements file: -# pip -# setuptools diff --git a/scripts/boa_scripts/set_up_registries.py b/scripts/boa_scripts/set_up_registries.py index b383ff8..1a3cb6b 100644 --- a/scripts/boa_scripts/set_up_registries.py +++ b/scripts/boa_scripts/set_up_registries.py @@ -22,7 +22,14 @@ def deploy_factory_handler(): pass -def set_up_registries(network, url, account, fork: bool = False): +def set_up_registries(network: str, url: str, account: str, fork: bool = False): + """ + Set up registries for the Curve StableSwapNG factory. + :param network: Network to deploy to. + :param url: URL to connect to. + :param account: Account to use. + :param fork: Whether to deploy to a fork (test) network. + """ logger.log(f"Connecting to {network} ...") if fork: @@ -34,14 +41,12 @@ def set_up_registries(network, url, account, fork: bool = False): boa.set_env(NetworkEnv(url)) boa.env.add_account(Account.from_key(os.environ[account])) - for _network, data in deploy_utils.curve_dao_network_settings.items(): - - if _network in network: - - owner = data.dao_ownership_contract - fee_receiver = data.fee_receiver_address - address_provider = Contract(data.address_provider) + data = next((data for _network, data in deploy_utils.curve_dao_network_settings.items() + if _network in network), None) + owner = data.dao_ownership_contract + fee_receiver = data.fee_receiver_address + address_provider = Contract(data.address_provider) assert owner, f"Curve's DAO contracts may not be on {network}." assert fee_receiver, f"Curve's DAO contracts may not be on {network}." @@ -52,21 +57,19 @@ def set_up_registries(network, url, account, fork: bool = False): boss = Contract(address_provider.admin()) # check if account can handle boss: - account_is_boss_handler = False - for i in range(2): - if account.address.lower() == boss.admins(i).lower(): - account_is_boss_handler = True - break - + account_is_boss_handler = any( + account.address.lower() == boss.admins(i).lower() for i in range(2) + ) assert account_is_boss_handler # only authorised accounts can write to address provider # noqa: E501 - for index in range(max_id + 1): - if address_provider.get_id_info(index).description is description: - break + is_new_deployment = not any( + address_provider.get_id_info(i).description is description + for i in range(max_id + 1) + ) - if index == max_id: + if is_new_deployment: - logger.info(f"Adding a new registry provider entry at id: {index + 1}") + logger.info(f"Adding a new registry provider entry at id: {max_id + 1}") # we're adding a new id with accounts.use_sender(account) as account: @@ -134,14 +137,11 @@ def set_up_registries(network, url, account, fork: bool = False): def main(): - - fork = False - set_up_registries( "ethereum:mainnet", os.environ["RPC_ETHEREUM"], "FIDDYDEPLOYER", - fork=fork, + fork=False, ) diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index 82b683a..3946e9d 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -137,7 +137,7 @@ def cli(): @cli.command(cls=NetworkBoundCommand) @network_option() @account_option() -def main(network, account): +def main(network: str, account: str): # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: address_provider = project.AddressProvider.at(ADDRESS_PROVIDER) diff --git a/scripts/setup_metaregistry_brownie.py b/scripts/setup_metaregistry_brownie.py deleted file mode 100644 index fcd90b8..0000000 --- a/scripts/setup_metaregistry_brownie.py +++ /dev/null @@ -1,346 +0,0 @@ -import json -import sys - -from brownie import ( - ZERO_ADDRESS, - AddressProvider, - BasePoolRegistry, - CryptoFactoryHandler, - CryptoRegistryHandler, - CryptoRegistryV1, - MetaRegistry, - ProxyAdmin, - StableFactoryHandler, - StableRegistryHandler, - accounts, - network, -) -from brownie.network.gas.strategies import GasNowScalingStrategy -from rich.console import Console as RichConsole - -RICH_CONSOLE = RichConsole(file=sys.stdout) - -ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" -BASE_POOLS = { - "tripool": { - "pool": "0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7", - "lp_token": "0x6c3F90f043a72FA612cbac8115EE7e52BDe6E490", - "num_coins": 3, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - }, - "fraxusdc": { - "pool": "0xdcef968d416a41cdac0ed8702fac8128a64241a2", - "lp_token": "0x3175df0976dfa876431c2e9ee6bc45b65d3473cc", - "num_coins": 2, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - }, - "sbtc": { - "pool": "0x7fC77b5c7614E1533320Ea6DDc2Eb61fa00A9714", - "lp_token": "0x075b1bb99792c9E1041bA13afEf80C91a1e70fB3", - "num_coins": 3, - "is_legacy": True, - "is_lending": False, - "is_v2": False, - }, -} -CRYPTO_REGISTRY_POOLS = { - "tricrypto2": { - "pool": "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46", - "lp_token": "0xc4AD29ba4B3c580e6D59105FFf484999997675Ff", - "gauge": "0xDeFd8FdD20e0f34115C7018CCfb655796F6B2168", - "zap": "0x3993d34e7e99Abf6B6f367309975d1360222D446", - "num_coins": 3, - "name": "tricrypto2", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "eurt3crv": { - "pool": "0x9838eccc42659fa8aa7daf2ad134b53984c9427b", - "lp_token": "0x3b6831c0077a1e44ed0a21841c3bc4dc11bce833", - "gauge": "0x4Fd86Ce7Ecea88F7E0aA78DC12625996Fb3a04bC", - "zap": "0x5D0F47B32fDd343BfA74cE221808e2abE4A53827", - "num_coins": 2, - "name": "eurtusd", - "base_pool": BASE_POOLS["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, - "eursusdc": { - "pool": "0x98a7F18d4E56Cfe84E3D081B40001B3d5bD3eB8B", - "lp_token": "0x3D229E1B4faab62F621eF2F6A610961f7BD7b23B", - "gauge": "0x65CA7Dc5CB661fC58De57B1E1aF404649a27AD35", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "eursusd", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "crveth": { - "pool": "0x8301AE4fc9c624d1D396cbDAa1ed877821D7C511", - "lp_token": "0xEd4064f376cB8d68F770FB1Ff088a3d0F3FF5c4d", - "gauge": "0x1cEBdB0856dd985fAe9b8fEa2262469360B8a3a6", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "crveth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "cvxeth": { - "pool": "0xB576491F1E6e5E62f1d8F26062Ee822B40B0E0d4", - "lp_token": "0x3A283D9c08E8b55966afb64C515f5143cf907611", - "gauge": "0x7E1444BA99dcdFfE8fBdb42C02F0005D14f13BE1", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "cvxeth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "xaut3crv": { - "pool": "0xAdCFcf9894335dC340f6Cd182aFA45999F45Fc44", - "lp_token": "0x8484673cA7BfF40F82B041916881aeA15ee84834", - "gauge": "0x1B3E14157ED33F60668f2103bCd5Db39a1573E5B", - "zap": "0xc5FA220347375ac4f91f9E4A4AAb362F22801504", - "num_coins": 2, - "name": "xaut3crv", - "base_pool": BASE_POOLS["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, - "spelleth": { - "pool": "0x98638FAcf9a3865cd033F36548713183f6996122", - "lp_token": "0x8282BD15dcA2EA2bDf24163E8f2781B30C43A2ef", - "gauge": "0x08380a4999Be1a958E2abbA07968d703C7A3027C", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "spelleth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "teth": { - "pool": "0x752eBeb79963cf0732E9c0fec72a49FD1DEfAEAC", - "lp_token": "0xCb08717451aaE9EF950a2524E33B6DCaBA60147B", - "gauge": "0x6070fBD4E608ee5391189E7205d70cc4A274c017", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "teth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "eurocusd": { - "pool": "0xE84f5b1582BA325fDf9cE6B0c1F087ccfC924e54", - "lp_token": "0x70fc957eb90e37af82acdbd12675699797745f68", - "gauge": "0x4329c8F09725c0e3b6884C1daB1771bcE17934F9", - "zap": "0xd446a98f88e1d053d1f64986e3ed083bb1ab7e5a", - "num_coins": 2, - "name": "eurocusd", - "base_pool": BASE_POOLS["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, -} - -if network.show_active() == "mainnet": - print("Deploying on mainnet") - accounts.load("babe") - txparams = {"from": accounts[0], "required_confs": 5} - try: - network.gas_price(GasNowScalingStrategy("slow", "fast")) - except ConnectionError: - pass - -else: - RICH_CONSOLE.log("Simulation Mode. Deploying to mainnet-fork.") - txparams = { - "from": accounts.at( - "0xbabe61887f1de2713c6f97e567623453d3C79f67", force=True - ) - } - - -def main(): - - # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: - address_provider = AddressProvider.at(ADDRESS_PROVIDER) - address_provider_admin = address_provider.admin() - proxy_admin = ProxyAdmin.at(address_provider_admin) - - # deployed contracts: - base_pool_registry = BasePoolRegistry.at( - "0xDE3eAD9B2145bBA2EB74007e58ED07308716B725" - ) - crypto_registry = CryptoRegistryV1.at( - "0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0" - ) - stable_registry_handler = StableRegistryHandler.at( - "0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68" - ) - stable_factory_handler = StableFactoryHandler.at( - "0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9" - ) - crypto_registry_handler = CryptoRegistryHandler.at( - "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94" - ) - crypto_factory_handler = CryptoFactoryHandler.at( - "0xC4F389020002396143B863F6325aA6ae481D19CE" - ) - metaregistry = MetaRegistry.at( - "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC" - ) - registry_handlers = [ - stable_registry_handler, - stable_factory_handler, - crypto_registry_handler, - crypto_factory_handler, - ] - - # setup the metaregistry: - - total_gas_used = ( - 0 # gets total gas used for setting up. should be about 5mil gas. - ) - - # populate base pool registry: - base_pool_index = 0 - for _, data in BASE_POOLS.items(): - - # check if base pool already exists in the registry: - entry_at_index = base_pool_registry.base_pool_list( - base_pool_index - ).lower() - if entry_at_index == data["pool"].lower(): - base_pool_index += 1 - continue - - # set up tx calldata for proxy admin: - call_data = base_pool_registry.add_base_pool.encode_input( - data["pool"], - data["lp_token"], - data["num_coins"], - data["is_legacy"], - data["is_lending"], - data["is_v2"], - ) - - # add base_pool to registry: - tx = proxy_admin.execute(base_pool_registry, call_data, txparams) - total_gas_used += tx.gas_used - - # check if deployment is correct: - assert ( - base_pool_registry.base_pool_list(base_pool_index).lower() - == data["pool"].lower() - ) - RICH_CONSOLE.log( - f"Added base pool [blue]{data['pool']} to base pool registry. " - f"Gas used: [green]{tx.gas_used}" - ) - base_pool_index += 1 - - # populate crypto registry: - crypto_pool_index = 0 - for _, pool in CRYPTO_REGISTRY_POOLS.items(): - - # check if base pool already exists in the registry: - entry_at_index = crypto_registry.pool_list(crypto_pool_index).lower() - if entry_at_index == pool["pool"].lower(): - crypto_pool_index += 1 - continue - - # set up tx calldata for proxy admin: - call_data = crypto_registry.add_pool.encode_input( - pool["pool"], - pool["lp_token"], - pool["gauge"], - pool["zap"], - pool["num_coins"], - pool["name"], - pool["base_pool"], - pool["has_positive_rebasing_tokens"], - ) - - # add pool to registry: - tx = proxy_admin.execute(crypto_registry, call_data, txparams) - total_gas_used += tx.gas_used - - # check if deployment is correct: - assert ( - crypto_registry.pool_list(crypto_pool_index).lower() - == pool["pool"].lower() - ) - RICH_CONSOLE.log( - f"Added pool [blue]{pool['pool']} to crypto registry. " - f"Gas used: [green]{tx.gas_used}" - ) - crypto_pool_index += 1 - - # populate metaregistry: - registry_handler_index = 0 - for registry_handler in registry_handlers: - - # check if base pool already exists in the registry: - entry_at_index = metaregistry.get_registry( - registry_handler_index - ).lower() - if entry_at_index == registry_handler.address.lower(): - registry_handler_index += 1 - continue - - # set up tx calldata for proxy admin: - call_data = metaregistry.add_registry_handler.encode_input( - registry_handler.address - ) - # add registry handler to metaregistry: - tx = proxy_admin.execute(metaregistry, call_data, txparams) - total_gas_used += tx.gas_used - - # check if deployment is correct: - assert ( - metaregistry.get_registry(registry_handler_index).lower() - == registry_handler.address.lower() - ) - RICH_CONSOLE.log( - f"Added registry handler [blue]{registry_handler.address} to metaregistry. " - f"Gas used: [green]{tx.gas_used}" - ) - registry_handler_index += 1 - - # add metaregistry to address provider: - max_id = address_provider.max_id() - RICH_CONSOLE.log( - f"Max id: [yellow]{max_id}, entry: [blue]{address_provider.get_address(max_id)}." - ) - metaregistry_description = "Metaregistry" - call_data = address_provider.add_new_id.encode_input( - metaregistry.address, - metaregistry_description, - ) - tx = proxy_admin.execute(address_provider.address, call_data, txparams) - total_gas_used += tx.gas_used - - # check if adding metaregistry was done properly: - new_max_id = address_provider.max_id() - assert new_max_id > max_id - assert ( - address_provider.get_address(new_max_id).lower() - == metaregistry.address.lower() - ) - RICH_CONSOLE.log( - f"Added Metaregistry [blue]{metaregistry.address} to AddressProvider. " - f"Gas used: [green]{tx.gas_used}" - ) - RICH_CONSOLE.log( - f"Deployment complete! Total gas used: [green]{total_gas_used}" - ) - - # test metaregistry. get a list of pools that have shibainu <> frax: - RICH_CONSOLE.log("SHIBAINU <> FRAX pool list from MetaRegistry:") - sample_pool_list = metaregistry.find_pools_for_coins( - "0x95aD61b0a150d79219dCF64E1E6Cc01f0B64C4cE", - "0x853d955aCEf822Db058eb8505911ED77F175b99e", - ) - RICH_CONSOLE.print_json(json.dumps(sample_pool_list, indent=4)) - - -if __name__ == "__main__": - main() diff --git a/tests/conftest.py b/tests/conftest.py index 57050c5..2c4f61e 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -1,9 +1,11 @@ -import ape import pytest +import boa +from boa.network import NetworkEnv pytest_plugins = [ "fixtures.accounts", "fixtures.constants", + "fixtures.contracts", "fixtures.deployments", "fixtures.functions", ] @@ -15,7 +17,7 @@ ALL_POOLS = None -def pytest_sessionstart(session): +def pytest_sessionstart(): """Set up pools into global variables at session start""" global CRYPTO_REGISTRY_POOLS global CRYPTO_FACTORY_POOLS @@ -23,53 +25,15 @@ def pytest_sessionstart(session): global STABLE_REGISTRY_POOLS global ALL_POOLS - # fetch the pytest ape runner plugin - ape_runner = session.config.pluginmanager.getplugin("ape-test") + boa.env.fork("https://mainnet.infura.io/v3/84842078b09946638c03157f83405213") - # connect to the network - # https://github.com/ApeWorX/ape/blob/main/src/ape/pytest/runners.py#L149-L153 - ape_runner.network_manager.active_provider = ( - ape_runner.network_manager.get_provider_from_choice( - ape_runner._network_choice - ) - ) - ape_runner.network_manager.active_provider.connect() - ape_runner._provider_is_connected = True - - # store instance of registries globally so we don't have to recreate multiple times + # store instance of registries globally, so we don't have to recreate multiple times # when generating tests: - # stable registry: - registry = ape.project.StableRegistry.at( - "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" - ) - STABLE_REGISTRY_POOLS = [ - registry.pool_list(i) for i in range(registry.pool_count()) - ] - - # stable_factory: - registry = ape.project.StableFactory.at( - "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" - ) - STABLE_FACTORY_POOLS = [ - registry.pool_list(i) for i in range(registry.pool_count()) - ] - - # crypto_registry: - registry = ape.project.CryptoRegistry.at( - "0x8F942C20D02bEfc377D41445793068908E2250D0" - ) - CRYPTO_REGISTRY_POOLS = [ - registry.pool_list(i) for i in range(registry.pool_count()) - ] - - # crypto_factory: - registry = ape.project.CryptoFactory.at( - "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" - ) - CRYPTO_FACTORY_POOLS = [ - registry.pool_list(i) for i in range(registry.pool_count()) - ] + STABLE_REGISTRY_POOLS = get_pools("StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5") + STABLE_FACTORY_POOLS = get_pools("StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4") + CRYPTO_REGISTRY_POOLS = get_pools("CryptoRegistry", "0x8F942C20D02bEfc377D41445793068908E2250D0") + CRYPTO_FACTORY_POOLS = get_pools("CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99") ALL_POOLS = ( STABLE_REGISTRY_POOLS @@ -79,6 +43,12 @@ def pytest_sessionstart(session): ) +def get_pools(registryName, registryAddress): + deployer = boa.load_partial(f"contracts/mainnet/mocks/{registryName}", registryName) + registry = deployer.at(registryAddress) + return [registry.pool_list(i) for i in range(registry.pool_count())] + + def pytest_generate_tests(metafunc): if "stable_registry_pool" in metafunc.fixturenames: metafunc.parametrize("stable_registry_pool", STABLE_REGISTRY_POOLS) diff --git a/tests/fixtures/accounts.py b/tests/fixtures/accounts.py index 443edeb..5708cff 100644 --- a/tests/fixtures/accounts.py +++ b/tests/fixtures/accounts.py @@ -1,6 +1,32 @@ -import ape +from collections import namedtuple + import pytest +from eth_account import Account +from eth_account.hdaccount import HDPath +from eth_account.hdaccount.mnemonic import Mnemonic +from ethpm_types import HexBytes + +GeneratedDevAccount = namedtuple("GeneratedDevAccount", ("address", "private_key")) + +@pytest.fixture(scope="session") +def seed() -> bytes: + return Mnemonic.to_seed("test") + +@pytest.fixture(scope="session") +def accounts(seed) -> list[GeneratedDevAccount]: + """ + Generate 10 dev accounts from a seed. + Based on ape's `generate_test_accounts` method: + https://github.com/ApeWorX/ape/blob/9d4b66786/src/ape/utils/testing.py#L28 + """ + def generate_account(index: int, hd_path_format="m/44'/60'/0'/{}") -> GeneratedDevAccount: + hd_path = HDPath(hd_path_format.format(index)) + private_key = HexBytes(hd_path.derive(seed)).hex() + address = Account.from_key(private_key).address + return GeneratedDevAccount(address, private_key) + + return [generate_account(index) for index in range(10)] @pytest.fixture(scope="session") def alice(accounts): diff --git a/tests/fixtures/contracts.py b/tests/fixtures/contracts.py new file mode 100644 index 0000000..96e39d0 --- /dev/null +++ b/tests/fixtures/contracts.py @@ -0,0 +1,9 @@ +import pytest + + +@pytest.fixture(scope="module") +def address_provider_contract(accounts): + address_provider = ape.project.AddressProvider.at( + "0x0000000022D53366457F9d5E68Ec105046FC4383" + ) + return accounts[address_provider.admin()] diff --git a/tests/fixtures/deployments.py b/tests/fixtures/deployments.py index a40662f..ef57cd1 100644 --- a/tests/fixtures/deployments.py +++ b/tests/fixtures/deployments.py @@ -1,4 +1,3 @@ -import ape import pytest ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" From de1e9dede7017ef245a56c41cdfaa577cf998405 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Tue, 21 Nov 2023 16:16:36 +0100 Subject: [PATCH 04/19] Replace contracts with ABI --- .github/workflows/main.yaml | 5 +- .gitignore | 1 + contracts/mainnet/MetaRegistry.vy | 2 +- contracts/mainnet/abi/AddressProvider.json | 309 ++++ contracts/mainnet/abi/CryptoFactory.json | 635 +++++++++ contracts/mainnet/abi/CryptoRegistry.json | 601 ++++++++ contracts/mainnet/abi/GaugeController.json | 822 +++++++++++ contracts/mainnet/abi/ProxyAdmin.json | 204 +++ contracts/mainnet/abi/StableFactory.json | 1063 ++++++++++++++ contracts/mainnet/abi/StableRegistry.json | 940 +++++++++++++ contracts/mainnet/mocks/AddressProvider.vy | 213 --- contracts/mainnet/mocks/CryptoFactory.vy | 441 ------ contracts/mainnet/mocks/CryptoRegistry.vy | 681 --------- contracts/mainnet/mocks/GaugeController.vy | 596 -------- contracts/mainnet/mocks/ProxyAdmin.vy | 155 -- contracts/mainnet/mocks/StableFactory.vy | 955 ------------- contracts/mainnet/mocks/StableRegistry.vy | 1245 ----------------- .../mainnet/registries/BasePoolRegistry.vy | 2 +- .../mainnet/registries/CryptoRegistryV1.vy | 2 +- .../registry_handlers/CryptoFactoryHandler.vy | 2 +- .../CryptoRegistryHandler.vy | 2 +- .../registry_handlers/StableFactoryHandler.vy | 2 +- .../StableRegistryHandler.vy | 2 +- docker-compose.yaml | 7 + scripts/setup_metaregistry.py | 38 +- tests/conftest.py | 29 +- tests/fixtures/accounts.py | 30 +- tests/fixtures/constants.py | 26 +- tests/fixtures/contracts.py | 2 +- tests/fixtures/deployments.py | 107 +- tests/fixtures/functions.py | 17 +- .../api/test_get_admin_balances.py | 16 +- .../metaregistry/api/test_get_pool_name.py | 8 +- .../api/test_get_underlying_balances.py | 2 +- .../api/test_get_underlying_decimals.py | 2 +- .../api/test_get_virtual_price.py | 2 +- .../test_add_remove_update_registry.py | 16 +- .../test_base_registry_tracking.py | 8 +- .../registries/test_add_remove_basepool.py | 8 +- .../registries/test_add_remove_pool.py | 8 +- tests/utils.py | 35 + 41 files changed, 4765 insertions(+), 4476 deletions(-) create mode 100644 contracts/mainnet/abi/AddressProvider.json create mode 100644 contracts/mainnet/abi/CryptoFactory.json create mode 100644 contracts/mainnet/abi/CryptoRegistry.json create mode 100644 contracts/mainnet/abi/GaugeController.json create mode 100644 contracts/mainnet/abi/ProxyAdmin.json create mode 100644 contracts/mainnet/abi/StableFactory.json create mode 100644 contracts/mainnet/abi/StableRegistry.json delete mode 100644 contracts/mainnet/mocks/AddressProvider.vy delete mode 100644 contracts/mainnet/mocks/CryptoFactory.vy delete mode 100644 contracts/mainnet/mocks/CryptoRegistry.vy delete mode 100644 contracts/mainnet/mocks/GaugeController.vy delete mode 100644 contracts/mainnet/mocks/ProxyAdmin.vy delete mode 100644 contracts/mainnet/mocks/StableFactory.vy delete mode 100644 contracts/mainnet/mocks/StableRegistry.vy create mode 100644 docker-compose.yaml create mode 100644 tests/utils.py diff --git a/.github/workflows/main.yaml b/.github/workflows/main.yaml index b5cdca9..e97f134 100644 --- a/.github/workflows/main.yaml +++ b/.github/workflows/main.yaml @@ -26,7 +26,4 @@ jobs: - name: Run Tests run: pytest env: - ETHERSCAN_TOKEN: ${{ secrets.ETHERSKEM_TOKEN }} - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - WEB3_INFURA_PROJECT_ID: ${{ secrets.INFURA_TOKEN }} - WEB3_ALCHEMY_PROJECT_ID: ${{secrets.ALCHEMY_API_KEY}} + DRPC_KEY: ${{ secrets.DRPC_KEY }} diff --git a/.gitignore b/.gitignore index a70f6d3..500de94 100644 --- a/.gitignore +++ b/.gitignore @@ -7,3 +7,4 @@ __pycache__/ .DS_Store venv/ bvenv/ +.env \ No newline at end of file diff --git a/contracts/mainnet/MetaRegistry.vy b/contracts/mainnet/MetaRegistry.vy index f9f4ab0..71f4d0a 100644 --- a/contracts/mainnet/MetaRegistry.vy +++ b/contracts/mainnet/MetaRegistry.vy @@ -1,4 +1,4 @@ -# @version 0.3.7 +# @version 0.3.10 """ @title Curve Meta Registry @license MIT diff --git a/contracts/mainnet/abi/AddressProvider.json b/contracts/mainnet/abi/AddressProvider.json new file mode 100644 index 0000000..734cd08 --- /dev/null +++ b/contracts/mainnet/abi/AddressProvider.json @@ -0,0 +1,309 @@ +[ + { + "name": "NewAddressIdentifier", + "inputs": [ + { + "type": "uint256", + "name": "id", + "indexed": true + }, + { + "type": "address", + "name": "addr", + "indexed": false + }, + { + "type": "string", + "name": "description", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "AddressModified", + "inputs": [ + { + "type": "uint256", + "name": "id", + "indexed": true + }, + { + "type": "address", + "name": "new_address", + "indexed": false + }, + { + "type": "uint256", + "name": "version", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "CommitNewAdmin", + "inputs": [ + { + "type": "uint256", + "name": "deadline", + "indexed": true + }, + { + "type": "address", + "name": "admin", + "indexed": true + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "NewAdmin", + "inputs": [ + { + "type": "address", + "name": "admin", + "indexed": true + } + ], + "anonymous": false, + "type": "event" + }, + { + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "_admin" + } + ], + "stateMutability": "nonpayable", + "type": "constructor" + }, + { + "name": "get_registry", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1061 + }, + { + "name": "max_id", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1258 + }, + { + "name": "get_address", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "_id" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 1308 + }, + { + "name": "add_new_id", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "_address" + }, + { + "type": "string", + "name": "_description" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 291275 + }, + { + "name": "set_address", + "outputs": [ + { + "type": "bool", + "name": "" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "_id" + }, + { + "type": "address", + "name": "_address" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 182430 + }, + { + "name": "unset_address", + "outputs": [ + { + "type": "bool", + "name": "" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "_id" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 101348 + }, + { + "name": "commit_transfer_ownership", + "outputs": [ + { + "type": "bool", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "_new_admin" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 74048 + }, + { + "name": "apply_transfer_ownership", + "outputs": [ + { + "type": "bool", + "name": "" + } + ], + "inputs": [], + "stateMutability": "nonpayable", + "type": "function", + "gas": 60125 + }, + { + "name": "revert_transfer_ownership", + "outputs": [ + { + "type": "bool", + "name": "" + } + ], + "inputs": [], + "stateMutability": "nonpayable", + "type": "function", + "gas": 21400 + }, + { + "name": "admin", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1331 + }, + { + "name": "transfer_ownership_deadline", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1361 + }, + { + "name": "future_admin", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1391 + }, + { + "name": "get_id_info", + "outputs": [ + { + "type": "address", + "name": "addr" + }, + { + "type": "bool", + "name": "is_active" + }, + { + "type": "uint256", + "name": "version" + }, + { + "type": "uint256", + "name": "last_modified" + }, + { + "type": "string", + "name": "description" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 12168 + } +] \ No newline at end of file diff --git a/contracts/mainnet/abi/CryptoFactory.json b/contracts/mainnet/abi/CryptoFactory.json new file mode 100644 index 0000000..f8c5747 --- /dev/null +++ b/contracts/mainnet/abi/CryptoFactory.json @@ -0,0 +1,635 @@ +[ + { + "name": "CryptoPoolDeployed", + "inputs": [ + { + "name": "token", + "type": "address", + "indexed": false + }, + { + "name": "coins", + "type": "address[2]", + "indexed": false + }, + { + "name": "A", + "type": "uint256", + "indexed": false + }, + { + "name": "gamma", + "type": "uint256", + "indexed": false + }, + { + "name": "mid_fee", + "type": "uint256", + "indexed": false + }, + { + "name": "out_fee", + "type": "uint256", + "indexed": false + }, + { + "name": "allowed_extra_profit", + "type": "uint256", + "indexed": false + }, + { + "name": "fee_gamma", + "type": "uint256", + "indexed": false + }, + { + "name": "adjustment_step", + "type": "uint256", + "indexed": false + }, + { + "name": "admin_fee", + "type": "uint256", + "indexed": false + }, + { + "name": "ma_half_time", + "type": "uint256", + "indexed": false + }, + { + "name": "initial_price", + "type": "uint256", + "indexed": false + }, + { + "name": "deployer", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "LiquidityGaugeDeployed", + "inputs": [ + { + "name": "pool", + "type": "address", + "indexed": false + }, + { + "name": "token", + "type": "address", + "indexed": false + }, + { + "name": "gauge", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "UpdateFeeReceiver", + "inputs": [ + { + "name": "_old_fee_receiver", + "type": "address", + "indexed": false + }, + { + "name": "_new_fee_receiver", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "UpdatePoolImplementation", + "inputs": [ + { + "name": "_old_pool_implementation", + "type": "address", + "indexed": false + }, + { + "name": "_new_pool_implementation", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "UpdateTokenImplementation", + "inputs": [ + { + "name": "_old_token_implementation", + "type": "address", + "indexed": false + }, + { + "name": "_new_token_implementation", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "UpdateGaugeImplementation", + "inputs": [ + { + "name": "_old_gauge_implementation", + "type": "address", + "indexed": false + }, + { + "name": "_new_gauge_implementation", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "TransferOwnership", + "inputs": [ + { + "name": "_old_owner", + "type": "address", + "indexed": false + }, + { + "name": "_new_owner", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "stateMutability": "nonpayable", + "type": "constructor", + "inputs": [ + { + "name": "_fee_receiver", + "type": "address" + }, + { + "name": "_pool_implementation", + "type": "address" + }, + { + "name": "_token_implementation", + "type": "address" + }, + { + "name": "_gauge_implementation", + "type": "address" + }, + { + "name": "_weth", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_pool", + "inputs": [ + { + "name": "_name", + "type": "string" + }, + { + "name": "_symbol", + "type": "string" + }, + { + "name": "_coins", + "type": "address[2]" + }, + { + "name": "A", + "type": "uint256" + }, + { + "name": "gamma", + "type": "uint256" + }, + { + "name": "mid_fee", + "type": "uint256" + }, + { + "name": "out_fee", + "type": "uint256" + }, + { + "name": "allowed_extra_profit", + "type": "uint256" + }, + { + "name": "fee_gamma", + "type": "uint256" + }, + { + "name": "adjustment_step", + "type": "uint256" + }, + { + "name": "admin_fee", + "type": "uint256" + }, + { + "name": "ma_half_time", + "type": "uint256" + }, + { + "name": "initial_price", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_gauge", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_fee_receiver", + "inputs": [ + { + "name": "_fee_receiver", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_pool_implementation", + "inputs": [ + { + "name": "_pool_implementation", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_token_implementation", + "inputs": [ + { + "name": "_token_implementation", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_gauge_implementation", + "inputs": [ + { + "name": "_gauge_implementation", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "commit_transfer_ownership", + "inputs": [ + { + "name": "_addr", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "accept_transfer_ownership", + "inputs": [], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + }, + { + "name": "i", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[2]" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_decimals", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[2]" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[2]" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_indices", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + }, + { + "name": "", + "type": "uint256" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_gauge", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_eth_index", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_token", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "admin", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "future_admin", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "fee_receiver", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_implementation", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "token_implementation", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "gauge_implementation", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_count", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_list", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + } +] \ No newline at end of file diff --git a/contracts/mainnet/abi/CryptoRegistry.json b/contracts/mainnet/abi/CryptoRegistry.json new file mode 100644 index 0000000..486ef19 --- /dev/null +++ b/contracts/mainnet/abi/CryptoRegistry.json @@ -0,0 +1,601 @@ +[ + { + "name": "PoolAdded", + "inputs": [ + { + "name": "pool", + "type": "address", + "indexed": true + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "PoolRemoved", + "inputs": [ + { + "name": "pool", + "type": "address", + "indexed": true + } + ], + "anonymous": false, + "type": "event" + }, + { + "stateMutability": "nonpayable", + "type": "constructor", + "inputs": [ + { + "name": "_address_provider", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3111 + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + }, + { + "name": "i", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3111 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_n_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 2834 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[8]" + } + ], + "gas": 22975 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_decimals", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 9818 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_gauges", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[10]" + }, + { + "name": "", + "type": "int128[10]" + } + ], + "gas": 26055 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 41626 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_virtual_price_from_lp_token", + "inputs": [ + { + "name": "_token", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 5321 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_A", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3139 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_D", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3169 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_gamma", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3199 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_fees", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[4]" + } + ], + "gas": 10333 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_admin_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 85771 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_indices", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + }, + { + "name": "", + "type": "uint256" + } + ], + "gas": 23608 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_pool_name", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "string" + } + ], + "gas": 13576 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_swap_count", + "inputs": [ + { + "name": "_coin", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3224 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_swap_complement", + "inputs": [ + { + "name": "_coin", + "type": "address" + }, + { + "name": "_index", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3299 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "add_pool", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_n_coins", + "type": "uint256" + }, + { + "name": "_lp_token", + "type": "address" + }, + { + "name": "_gauge", + "type": "address" + }, + { + "name": "_zap", + "type": "address" + }, + { + "name": "_decimals", + "type": "uint256" + }, + { + "name": "_name", + "type": "string" + } + ], + "outputs": [], + "gas": 18586944 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "remove_pool", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [], + "gas": 399675363514 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_liquidity_gauges", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_liquidity_gauges", + "type": "address[10]" + } + ], + "outputs": [], + "gas": 422284 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "batch_set_liquidity_gauges", + "inputs": [ + { + "name": "_pools", + "type": "address[10]" + }, + { + "name": "_liquidity_gauges", + "type": "address[10]" + } + ], + "outputs": [], + "gas": 444084 + }, + { + "stateMutability": "view", + "type": "function", + "name": "address_provider", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3126 + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_list", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3201 + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_count", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3186 + }, + { + "stateMutability": "view", + "type": "function", + "name": "coin_count", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3216 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3291 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_pool_from_lp_token", + "inputs": [ + { + "name": "arg0", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3548 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_lp_token", + "inputs": [ + { + "name": "arg0", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3578 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_zap", + "inputs": [ + { + "name": "arg0", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3608 + }, + { + "stateMutability": "view", + "type": "function", + "name": "last_updated", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3366 + } +] \ No newline at end of file diff --git a/contracts/mainnet/abi/GaugeController.json b/contracts/mainnet/abi/GaugeController.json new file mode 100644 index 0000000..12179c6 --- /dev/null +++ b/contracts/mainnet/abi/GaugeController.json @@ -0,0 +1,822 @@ +[ + { + "name": "CommitOwnership", + "inputs": [ + { + "type": "address", + "name": "admin", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "ApplyOwnership", + "inputs": [ + { + "type": "address", + "name": "admin", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "AddType", + "inputs": [ + { + "type": "string", + "name": "name", + "indexed": false + }, + { + "type": "int128", + "name": "type_id", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "NewTypeWeight", + "inputs": [ + { + "type": "int128", + "name": "type_id", + "indexed": false + }, + { + "type": "uint256", + "name": "time", + "indexed": false + }, + { + "type": "uint256", + "name": "weight", + "indexed": false + }, + { + "type": "uint256", + "name": "total_weight", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "NewGaugeWeight", + "inputs": [ + { + "type": "address", + "name": "gauge_address", + "indexed": false + }, + { + "type": "uint256", + "name": "time", + "indexed": false + }, + { + "type": "uint256", + "name": "weight", + "indexed": false + }, + { + "type": "uint256", + "name": "total_weight", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "VoteForGauge", + "inputs": [ + { + "type": "uint256", + "name": "time", + "indexed": false + }, + { + "type": "address", + "name": "user", + "indexed": false + }, + { + "type": "address", + "name": "gauge_addr", + "indexed": false + }, + { + "type": "uint256", + "name": "weight", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "NewGauge", + "inputs": [ + { + "type": "address", + "name": "addr", + "indexed": false + }, + { + "type": "int128", + "name": "gauge_type", + "indexed": false + }, + { + "type": "uint256", + "name": "weight", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "_token" + }, + { + "type": "address", + "name": "_voting_escrow" + } + ], + "stateMutability": "nonpayable", + "type": "constructor" + }, + { + "name": "commit_transfer_ownership", + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "addr" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 37597 + }, + { + "name": "apply_transfer_ownership", + "outputs": [], + "inputs": [], + "stateMutability": "nonpayable", + "type": "function", + "gas": 38497 + }, + { + "name": "gauge_types", + "outputs": [ + { + "type": "int128", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "_addr" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 1625 + }, + { + "name": "add_gauge", + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "addr" + }, + { + "type": "int128", + "name": "gauge_type" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "name": "add_gauge", + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "addr" + }, + { + "type": "int128", + "name": "gauge_type" + }, + { + "type": "uint256", + "name": "weight" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "name": "checkpoint", + "outputs": [], + "inputs": [], + "stateMutability": "nonpayable", + "type": "function", + "gas": 18033784416 + }, + { + "name": "checkpoint_gauge", + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "addr" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 18087678795 + }, + { + "name": "gauge_relative_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "addr" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "name": "gauge_relative_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "addr" + }, + { + "type": "uint256", + "name": "time" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "name": "gauge_relative_weight_write", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "addr" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "name": "gauge_relative_weight_write", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "addr" + }, + { + "type": "uint256", + "name": "time" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "name": "add_type", + "outputs": [], + "inputs": [ + { + "type": "string", + "name": "_name" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "name": "add_type", + "outputs": [], + "inputs": [ + { + "type": "string", + "name": "_name" + }, + { + "type": "uint256", + "name": "weight" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "name": "change_type_weight", + "outputs": [], + "inputs": [ + { + "type": "int128", + "name": "type_id" + }, + { + "type": "uint256", + "name": "weight" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 36246310050 + }, + { + "name": "change_gauge_weight", + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "addr" + }, + { + "type": "uint256", + "name": "weight" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 36354170809 + }, + { + "name": "vote_for_gauge_weights", + "outputs": [], + "inputs": [ + { + "type": "address", + "name": "_gauge_addr" + }, + { + "type": "uint256", + "name": "_user_weight" + } + ], + "stateMutability": "nonpayable", + "type": "function", + "gas": 18142052127 + }, + { + "name": "get_gauge_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "addr" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2974 + }, + { + "name": "get_type_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "int128", + "name": "type_id" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2977 + }, + { + "name": "get_total_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 2693 + }, + { + "name": "get_weights_sum_per_type", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "int128", + "name": "type_id" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 3109 + }, + { + "name": "admin", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1841 + }, + { + "name": "future_admin", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1871 + }, + { + "name": "token", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1901 + }, + { + "name": "voting_escrow", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1931 + }, + { + "name": "n_gauge_types", + "outputs": [ + { + "type": "int128", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1961 + }, + { + "name": "n_gauges", + "outputs": [ + { + "type": "int128", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 1991 + }, + { + "name": "gauge_type_names", + "outputs": [ + { + "type": "string", + "name": "" + } + ], + "inputs": [ + { + "type": "int128", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 8628 + }, + { + "name": "gauges", + "outputs": [ + { + "type": "address", + "name": "" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2160 + }, + { + "name": "vote_user_slopes", + "outputs": [ + { + "type": "uint256", + "name": "slope" + }, + { + "type": "uint256", + "name": "power" + }, + { + "type": "uint256", + "name": "end" + } + ], + "inputs": [ + { + "type": "address", + "name": "arg0" + }, + { + "type": "address", + "name": "arg1" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 5020 + }, + { + "name": "vote_user_power", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2265 + }, + { + "name": "last_user_vote", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "arg0" + }, + { + "type": "address", + "name": "arg1" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2449 + }, + { + "name": "points_weight", + "outputs": [ + { + "type": "uint256", + "name": "bias" + }, + { + "type": "uint256", + "name": "slope" + } + ], + "inputs": [ + { + "type": "address", + "name": "arg0" + }, + { + "type": "uint256", + "name": "arg1" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 3859 + }, + { + "name": "time_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "address", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2355 + }, + { + "name": "points_sum", + "outputs": [ + { + "type": "uint256", + "name": "bias" + }, + { + "type": "uint256", + "name": "slope" + } + ], + "inputs": [ + { + "type": "int128", + "name": "arg0" + }, + { + "type": "uint256", + "name": "arg1" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 3970 + }, + { + "name": "time_sum", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2370 + }, + { + "name": "points_total", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2406 + }, + { + "name": "time_total", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [], + "stateMutability": "view", + "type": "function", + "gas": 2321 + }, + { + "name": "points_type_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "int128", + "name": "arg0" + }, + { + "type": "uint256", + "name": "arg1" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2671 + }, + { + "name": "time_type_weight", + "outputs": [ + { + "type": "uint256", + "name": "" + } + ], + "inputs": [ + { + "type": "uint256", + "name": "arg0" + } + ], + "stateMutability": "view", + "type": "function", + "gas": 2490 + } +] \ No newline at end of file diff --git a/contracts/mainnet/abi/ProxyAdmin.json b/contracts/mainnet/abi/ProxyAdmin.json new file mode 100644 index 0000000..d4bc6c0 --- /dev/null +++ b/contracts/mainnet/abi/ProxyAdmin.json @@ -0,0 +1,204 @@ +[ + { + "name": "TransactionExecuted", + "inputs": [ + { + "name": "admin", + "type": "address", + "indexed": true + }, + { + "name": "target", + "type": "address", + "indexed": true + }, + { + "name": "calldata", + "type": "bytes", + "indexed": false + }, + { + "name": "value", + "type": "uint256", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "RequestAdminChange", + "inputs": [ + { + "name": "current_admin", + "type": "address", + "indexed": false + }, + { + "name": "future_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "RevokeAdminChange", + "inputs": [ + { + "name": "current_admin", + "type": "address", + "indexed": false + }, + { + "name": "future_admin", + "type": "address", + "indexed": false + }, + { + "name": "calling_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "ApproveAdminChange", + "inputs": [ + { + "name": "current_admin", + "type": "address", + "indexed": false + }, + { + "name": "future_admin", + "type": "address", + "indexed": false + }, + { + "name": "calling_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "AcceptAdminChange", + "inputs": [ + { + "name": "previous_admin", + "type": "address", + "indexed": false + }, + { + "name": "current_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "stateMutability": "nonpayable", + "type": "constructor", + "inputs": [ + { + "name": "_authorized", + "type": "address[2]" + } + ], + "outputs": [] + }, + { + "stateMutability": "payable", + "type": "function", + "name": "execute", + "inputs": [ + { + "name": "_target", + "type": "address" + }, + { + "name": "_calldata", + "type": "bytes" + } + ], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_admin_change_status", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + }, + { + "name": "", + "type": "address" + }, + { + "name": "", + "type": "bool" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "request_admin_change", + "inputs": [ + { + "name": "_new_admin", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "approve_admin_change", + "inputs": [], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "revoke_admin_change", + "inputs": [], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "accept_admin_change", + "inputs": [], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "admins", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + } +] \ No newline at end of file diff --git a/contracts/mainnet/abi/StableFactory.json b/contracts/mainnet/abi/StableFactory.json new file mode 100644 index 0000000..d6697ca --- /dev/null +++ b/contracts/mainnet/abi/StableFactory.json @@ -0,0 +1,1063 @@ +[ + { + "name": "BasePoolAdded", + "inputs": [ + { + "name": "base_pool", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "PlainPoolDeployed", + "inputs": [ + { + "name": "coins", + "type": "address[4]", + "indexed": false + }, + { + "name": "A", + "type": "uint256", + "indexed": false + }, + { + "name": "fee", + "type": "uint256", + "indexed": false + }, + { + "name": "deployer", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "MetaPoolDeployed", + "inputs": [ + { + "name": "coin", + "type": "address", + "indexed": false + }, + { + "name": "base_pool", + "type": "address", + "indexed": false + }, + { + "name": "A", + "type": "uint256", + "indexed": false + }, + { + "name": "fee", + "type": "uint256", + "indexed": false + }, + { + "name": "deployer", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "LiquidityGaugeDeployed", + "inputs": [ + { + "name": "pool", + "type": "address", + "indexed": false + }, + { + "name": "gauge", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "stateMutability": "nonpayable", + "type": "constructor", + "inputs": [ + { + "name": "_fee_receiver", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "metapool_implementations", + "inputs": [ + { + "name": "_base_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[10]" + } + ], + "gas": 21716 + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + }, + { + "name": "i", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_base_pool", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2663 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_n_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 2699 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_meta_n_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + }, + { + "name": "", + "type": "uint256" + } + ], + "gas": 5201 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[4]" + } + ], + "gas": 9164 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_underlying_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[8]" + } + ], + "gas": 21345 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_decimals", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[4]" + } + ], + "gas": 20185 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_underlying_decimals", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 19730 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_metapool_rates", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[2]" + } + ], + "gas": 5281 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[4]" + } + ], + "gas": 20435 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_underlying_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 39733 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_A", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3135 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_fees", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + }, + { + "name": "", + "type": "uint256" + } + ], + "gas": 5821 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_admin_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[4]" + } + ], + "gas": 13535 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_indices", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "int128" + }, + { + "name": "", + "type": "int128" + }, + { + "name": "", + "type": "bool" + } + ], + "gas": 33407 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_gauge", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3089 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_implementation_address", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3119 + }, + { + "stateMutability": "view", + "type": "function", + "name": "is_meta", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "gas": 3152 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_pool_asset_type", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 5450 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_fee_receiver", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 5480 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_plain_pool", + "inputs": [ + { + "name": "_name", + "type": "string" + }, + { + "name": "_symbol", + "type": "string" + }, + { + "name": "_coins", + "type": "address[4]" + }, + { + "name": "_A", + "type": "uint256" + }, + { + "name": "_fee", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_plain_pool", + "inputs": [ + { + "name": "_name", + "type": "string" + }, + { + "name": "_symbol", + "type": "string" + }, + { + "name": "_coins", + "type": "address[4]" + }, + { + "name": "_A", + "type": "uint256" + }, + { + "name": "_fee", + "type": "uint256" + }, + { + "name": "_asset_type", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_plain_pool", + "inputs": [ + { + "name": "_name", + "type": "string" + }, + { + "name": "_symbol", + "type": "string" + }, + { + "name": "_coins", + "type": "address[4]" + }, + { + "name": "_A", + "type": "uint256" + }, + { + "name": "_fee", + "type": "uint256" + }, + { + "name": "_asset_type", + "type": "uint256" + }, + { + "name": "_implementation_idx", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_metapool", + "inputs": [ + { + "name": "_base_pool", + "type": "address" + }, + { + "name": "_name", + "type": "string" + }, + { + "name": "_symbol", + "type": "string" + }, + { + "name": "_coin", + "type": "address" + }, + { + "name": "_A", + "type": "uint256" + }, + { + "name": "_fee", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_metapool", + "inputs": [ + { + "name": "_base_pool", + "type": "address" + }, + { + "name": "_name", + "type": "string" + }, + { + "name": "_symbol", + "type": "string" + }, + { + "name": "_coin", + "type": "address" + }, + { + "name": "_A", + "type": "uint256" + }, + { + "name": "_fee", + "type": "uint256" + }, + { + "name": "_implementation_idx", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "deploy_gauge", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 93079 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "add_base_pool", + "inputs": [ + { + "name": "_base_pool", + "type": "address" + }, + { + "name": "_fee_receiver", + "type": "address" + }, + { + "name": "_asset_type", + "type": "uint256" + }, + { + "name": "_implementations", + "type": "address[10]" + } + ], + "outputs": [], + "gas": 1206132 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_metapool_implementations", + "inputs": [ + { + "name": "_base_pool", + "type": "address" + }, + { + "name": "_implementations", + "type": "address[10]" + } + ], + "outputs": [], + "gas": 382072 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_plain_implementations", + "inputs": [ + { + "name": "_n_coins", + "type": "uint256" + }, + { + "name": "_implementations", + "type": "address[10]" + } + ], + "outputs": [], + "gas": 379687 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_gauge_implementation", + "inputs": [ + { + "name": "_gauge_implementation", + "type": "address" + } + ], + "outputs": [], + "gas": 38355 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "batch_set_pool_asset_type", + "inputs": [ + { + "name": "_pools", + "type": "address[32]" + }, + { + "name": "_asset_types", + "type": "uint256[32]" + } + ], + "outputs": [], + "gas": 1139545 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "commit_transfer_ownership", + "inputs": [ + { + "name": "_addr", + "type": "address" + } + ], + "outputs": [], + "gas": 38415 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "accept_transfer_ownership", + "inputs": [], + "outputs": [], + "gas": 58366 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_manager", + "inputs": [ + { + "name": "_manager", + "type": "address" + } + ], + "outputs": [], + "gas": 40996 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_fee_receiver", + "inputs": [ + { + "name": "_base_pool", + "type": "address" + }, + { + "name": "_fee_receiver", + "type": "address" + } + ], + "outputs": [], + "gas": 38770 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "convert_metapool_fees", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "gas": 12880 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "add_existing_metapools", + "inputs": [ + { + "name": "_pools", + "type": "address[10]" + } + ], + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "gas": 8610792 + }, + { + "stateMutability": "view", + "type": "function", + "name": "admin", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3438 + }, + { + "stateMutability": "view", + "type": "function", + "name": "future_admin", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3468 + }, + { + "stateMutability": "view", + "type": "function", + "name": "manager", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3498 + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_list", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3573 + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_count", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3558 + }, + { + "stateMutability": "view", + "type": "function", + "name": "base_pool_list", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3633 + }, + { + "stateMutability": "view", + "type": "function", + "name": "base_pool_count", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 3618 + }, + { + "stateMutability": "view", + "type": "function", + "name": "base_pool_assets", + "inputs": [ + { + "name": "arg0", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "gas": 3863 + }, + { + "stateMutability": "view", + "type": "function", + "name": "plain_implementations", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + }, + { + "name": "arg1", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3838 + }, + { + "stateMutability": "view", + "type": "function", + "name": "gauge_implementation", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 3708 + } +] \ No newline at end of file diff --git a/contracts/mainnet/abi/StableRegistry.json b/contracts/mainnet/abi/StableRegistry.json new file mode 100644 index 0000000..ac50894 --- /dev/null +++ b/contracts/mainnet/abi/StableRegistry.json @@ -0,0 +1,940 @@ +[ + { + "name": "PoolAdded", + "inputs": [ + { + "name": "pool", + "type": "address", + "indexed": true + }, + { + "name": "rate_method_id", + "type": "bytes", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "PoolRemoved", + "inputs": [ + { + "name": "pool", + "type": "address", + "indexed": true + } + ], + "anonymous": false, + "type": "event" + }, + { + "stateMutability": "nonpayable", + "type": "constructor", + "inputs": [ + { + "name": "_address_provider", + "type": "address" + }, + { + "name": "_gauge_controller", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "find_pool_for_coins", + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + }, + { + "name": "i", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_n_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[2]" + } + ], + "gas": 1521 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[8]" + } + ], + "gas": 12102 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_underlying_coins", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[8]" + } + ], + "gas": 12194 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_decimals", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 7874 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_underlying_decimals", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 7966 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_rates", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 36992 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_gauges", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address[10]" + }, + { + "name": "", + "type": "int128[10]" + } + ], + "gas": 20157 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 16583 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_underlying_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 162842 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_virtual_price_from_lp_token", + "inputs": [ + { + "name": "_token", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 1927 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_A", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 1045 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_parameters", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "A", + "type": "uint256" + }, + { + "name": "future_A", + "type": "uint256" + }, + { + "name": "fee", + "type": "uint256" + }, + { + "name": "admin_fee", + "type": "uint256" + }, + { + "name": "future_fee", + "type": "uint256" + }, + { + "name": "future_admin_fee", + "type": "uint256" + }, + { + "name": "future_owner", + "type": "address" + }, + { + "name": "initial_A", + "type": "uint256" + }, + { + "name": "initial_A_time", + "type": "uint256" + }, + { + "name": "future_A_time", + "type": "uint256" + } + ], + "gas": 6305 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_fees", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[2]" + } + ], + "gas": 1450 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_admin_balances", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256[8]" + } + ], + "gas": 36454 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_indices", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "int128" + }, + { + "name": "", + "type": "int128" + }, + { + "name": "", + "type": "bool" + } + ], + "gas": 27131 + }, + { + "stateMutability": "view", + "type": "function", + "name": "estimate_gas_used", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 32004 + }, + { + "stateMutability": "view", + "type": "function", + "name": "is_meta", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "gas": 1900 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_pool_name", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "string" + } + ], + "gas": 8323 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_swap_count", + "inputs": [ + { + "name": "_coin", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 1951 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin_swap_complement", + "inputs": [ + { + "name": "_coin", + "type": "address" + }, + { + "name": "_index", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2090 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_pool_asset_type", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 2011 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "add_pool", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_n_coins", + "type": "uint256" + }, + { + "name": "_lp_token", + "type": "address" + }, + { + "name": "_rate_info", + "type": "bytes32" + }, + { + "name": "_decimals", + "type": "uint256" + }, + { + "name": "_underlying_decimals", + "type": "uint256" + }, + { + "name": "_has_initial_A", + "type": "bool" + }, + { + "name": "_is_v1", + "type": "bool" + }, + { + "name": "_name", + "type": "string" + } + ], + "outputs": [], + "gas": 61485845 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "add_pool_without_underlying", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_n_coins", + "type": "uint256" + }, + { + "name": "_lp_token", + "type": "address" + }, + { + "name": "_rate_info", + "type": "bytes32" + }, + { + "name": "_decimals", + "type": "uint256" + }, + { + "name": "_use_rates", + "type": "uint256" + }, + { + "name": "_has_initial_A", + "type": "bool" + }, + { + "name": "_is_v1", + "type": "bool" + }, + { + "name": "_name", + "type": "string" + } + ], + "outputs": [], + "gas": 31306062 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "add_metapool", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_n_coins", + "type": "uint256" + }, + { + "name": "_lp_token", + "type": "address" + }, + { + "name": "_decimals", + "type": "uint256" + }, + { + "name": "_name", + "type": "string" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "add_metapool", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_n_coins", + "type": "uint256" + }, + { + "name": "_lp_token", + "type": "address" + }, + { + "name": "_decimals", + "type": "uint256" + }, + { + "name": "_name", + "type": "string" + }, + { + "name": "_base_pool", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "remove_pool", + "inputs": [ + { + "name": "_pool", + "type": "address" + } + ], + "outputs": [], + "gas": 779731418758 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_pool_gas_estimates", + "inputs": [ + { + "name": "_addr", + "type": "address[5]" + }, + { + "name": "_amount", + "type": "uint256[2][5]" + } + ], + "outputs": [], + "gas": 390460 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_coin_gas_estimates", + "inputs": [ + { + "name": "_addr", + "type": "address[10]" + }, + { + "name": "_amount", + "type": "uint256[10]" + } + ], + "outputs": [], + "gas": 392047 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_gas_estimate_contract", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_estimator", + "type": "address" + } + ], + "outputs": [], + "gas": 72629 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_liquidity_gauges", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_liquidity_gauges", + "type": "address[10]" + } + ], + "outputs": [], + "gas": 400675 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "set_pool_asset_type", + "inputs": [ + { + "name": "_pool", + "type": "address" + }, + { + "name": "_asset_type", + "type": "uint256" + } + ], + "outputs": [], + "gas": 72667 + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "batch_set_pool_asset_type", + "inputs": [ + { + "name": "_pools", + "type": "address[32]" + }, + { + "name": "_asset_types", + "type": "uint256[32]" + } + ], + "outputs": [], + "gas": 1173447 + }, + { + "stateMutability": "view", + "type": "function", + "name": "address_provider", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2048 + }, + { + "stateMutability": "view", + "type": "function", + "name": "gauge_controller", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2078 + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_list", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2217 + }, + { + "stateMutability": "view", + "type": "function", + "name": "pool_count", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 2138 + }, + { + "stateMutability": "view", + "type": "function", + "name": "coin_count", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 2168 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_coin", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2307 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_pool_from_lp_token", + "inputs": [ + { + "name": "arg0", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2443 + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_lp_token", + "inputs": [ + { + "name": "arg0", + "type": "address" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ], + "gas": 2473 + }, + { + "stateMutability": "view", + "type": "function", + "name": "last_updated", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "gas": 2288 + } +] \ No newline at end of file diff --git a/contracts/mainnet/mocks/AddressProvider.vy b/contracts/mainnet/mocks/AddressProvider.vy deleted file mode 100644 index cef5f21..0000000 --- a/contracts/mainnet/mocks/AddressProvider.vy +++ /dev/null @@ -1,213 +0,0 @@ -# @version 0.2.7 -""" -@title Curve Registry Address Provider -@license MIT -@author Curve.Fi -""" - -event NewAddressIdentifier: - id: indexed(uint256) - addr: address - description: String[64] - -event AddressModified: - id: indexed(uint256) - new_address: address - version: uint256 - -event CommitNewAdmin: - deadline: indexed(uint256) - admin: indexed(address) - -event NewAdmin: - admin: indexed(address) - - -struct AddressInfo: - addr: address - is_active: bool - version: uint256 - last_modified: uint256 - description: String[64] - - -registry: address -admin: public(address) -transfer_ownership_deadline: public(uint256) -future_admin: public(address) - -queue_length: uint256 -get_id_info: public(HashMap[uint256, AddressInfo]) - - -@external -def __init__(_admin: address): - self.admin = _admin - self.queue_length = 1 - self.get_id_info[0].description = "Main Registry" - - -@view -@external -def get_registry() -> address: - """ - @notice Get the address of the main registry contract - @dev This is a gas-efficient way of calling `AddressProvider.get_address(0)` - @return address main registry contract - """ - return self.registry - - -@view -@external -def max_id() -> uint256: - """ - @notice Get the highest ID set within the address provider - @return uint256 max ID - """ - return self.queue_length - 1 - - -@view -@external -def get_address(_id: uint256) -> address: - """ - @notice Fetch the address associated with `_id` - @dev Returns ZERO_ADDRESS if `_id` has not been defined, or has been unset - @param _id Identifier to fetch an address for - @return Current address associated to `_id` - """ - return self.get_id_info[_id].addr - - -@external -def add_new_id(_address: address, _description: String[64]) -> uint256: - """ - @notice Add a new identifier to the registry - @dev ID is auto-incremented - @param _address Initial address to assign to new identifier - @param _description Human-readable description of the identifier - @return uint256 identifier - """ - assert msg.sender == self.admin # dev: admin-only function - assert _address.is_contract # dev: not a contract - - id: uint256 = self.queue_length - self.get_id_info[id] = AddressInfo({ - addr: _address, - is_active: True, - version: 1, - last_modified: block.timestamp, - description: _description - }) - self.queue_length = id + 1 - - log NewAddressIdentifier(id, _address, _description) - - return id - - -@external -def set_address(_id: uint256, _address: address) -> bool: - """ - @notice Set a new address for an existing identifier - @param _id Identifier to set the new address for - @param _address Address to set - @return bool success - """ - assert msg.sender == self.admin # dev: admin-only function - assert _address.is_contract # dev: not a contract - assert self.queue_length > _id # dev: id does not exist - - version: uint256 = self.get_id_info[_id].version + 1 - - self.get_id_info[_id].addr = _address - self.get_id_info[_id].is_active = True - self.get_id_info[_id].version = version - self.get_id_info[_id].last_modified = block.timestamp - - if _id == 0: - self.registry = _address - - log AddressModified(_id, _address, version) - - return True - - -@external -def unset_address(_id: uint256) -> bool: - """ - @notice Unset an existing identifier - @dev An identifier cannot ever be removed, it can only have the - address unset so that it returns ZERO_ADDRESS - @param _id Identifier to unset - @return bool success - """ - assert msg.sender == self.admin # dev: admin-only function - assert self.get_id_info[_id].is_active # dev: not active - - self.get_id_info[_id].is_active = False - self.get_id_info[_id].addr = ZERO_ADDRESS - self.get_id_info[_id].last_modified = block.timestamp - - if _id == 0: - self.registry = ZERO_ADDRESS - - log AddressModified(_id, ZERO_ADDRESS, self.get_id_info[_id].version) - - return True - - -@external -def commit_transfer_ownership(_new_admin: address) -> bool: - """ - @notice Initiate a transfer of contract ownership - @dev Once initiated, the actual transfer may be performed three days later - @param _new_admin Address of the new owner account - @return bool success - """ - assert msg.sender == self.admin # dev: admin-only function - assert self.transfer_ownership_deadline == 0 # dev: transfer already active - - deadline: uint256 = block.timestamp + 3*86400 - self.transfer_ownership_deadline = deadline - self.future_admin = _new_admin - - log CommitNewAdmin(deadline, _new_admin) - - return True - - -@external -def apply_transfer_ownership() -> bool: - """ - @notice Finalize a transfer of contract ownership - @dev May only be called by the current owner, three days after a - call to `commit_transfer_ownership` - @return bool success - """ - assert msg.sender == self.admin # dev: admin-only function - assert self.transfer_ownership_deadline != 0 # dev: transfer not active - assert block.timestamp >= self.transfer_ownership_deadline # dev: now < deadline - - new_admin: address = self.future_admin - self.admin = new_admin - self.transfer_ownership_deadline = 0 - - log NewAdmin(new_admin) - - return True - - -@external -def revert_transfer_ownership() -> bool: - """ - @notice Revert a transfer of contract ownership - @dev May only be called by the current owner - @return bool success - """ - assert msg.sender == self.admin # dev: admin-only function - - self.transfer_ownership_deadline = 0 - - return True diff --git a/contracts/mainnet/mocks/CryptoFactory.vy b/contracts/mainnet/mocks/CryptoFactory.vy deleted file mode 100644 index 0780165..0000000 --- a/contracts/mainnet/mocks/CryptoFactory.vy +++ /dev/null @@ -1,441 +0,0 @@ -# @version 0.3.1 -""" -@title Curve Factory -@license MIT -@author Curve.Fi -@notice Permissionless pool deployer and registry -""" - - -interface CryptoPool: - def balances(i: uint256) -> uint256: view - def initialize( - A: uint256, - gamma: uint256, - mid_fee: uint256, - out_fee: uint256, - allowed_extra_profit: uint256, - fee_gamma: uint256, - adjustment_step: uint256, - admin_fee: uint256, - ma_half_time: uint256, - initial_price: uint256, - _token: address, - _coins: address[2], - _precisions: uint256 - ): nonpayable - -interface ERC20: - def decimals() -> uint256: view - -interface LiquidityGauge: - def initialize(_lp_token: address): nonpayable - -interface Token: - def initialize(_name: String[64], _symbol: String[32], _pool: address): nonpayable - - -event CryptoPoolDeployed: - token: address - coins: address[2] - A: uint256 - gamma: uint256 - mid_fee: uint256 - out_fee: uint256 - allowed_extra_profit: uint256 - fee_gamma: uint256 - adjustment_step: uint256 - admin_fee: uint256 - ma_half_time: uint256 - initial_price: uint256 - deployer: address - -event LiquidityGaugeDeployed: - pool: address - token: address - gauge: address - -event UpdateFeeReceiver: - _old_fee_receiver: address - _new_fee_receiver: address - -event UpdatePoolImplementation: - _old_pool_implementation: address - _new_pool_implementation: address - -event UpdateTokenImplementation: - _old_token_implementation: address - _new_token_implementation: address - -event UpdateGaugeImplementation: - _old_gauge_implementation: address - _new_gauge_implementation: address - -event TransferOwnership: - _old_owner: address - _new_owner: address - - -struct PoolArray: - token: address - liquidity_gauge: address - coins: address[2] - decimals: uint256 - - -N_COINS: constant(int128) = 2 -A_MULTIPLIER: constant(uint256) = 10000 - -# Limits -MAX_ADMIN_FEE: constant(uint256) = 10 * 10 ** 9 -MIN_FEE: constant(uint256) = 5 * 10 ** 5 # 0.5 bps -MAX_FEE: constant(uint256) = 10 * 10 ** 9 - -MIN_GAMMA: constant(uint256) = 10 ** 10 -MAX_GAMMA: constant(uint256) = 2 * 10 ** 16 - -MIN_A: constant(uint256) = N_COINS ** N_COINS * A_MULTIPLIER / 10 -MAX_A: constant(uint256) = N_COINS ** N_COINS * A_MULTIPLIER * 100000 - - -WETH: immutable(address) - - -admin: public(address) -future_admin: public(address) - -# fee receiver for plain pools -fee_receiver: public(address) - -pool_implementation: public(address) -token_implementation: public(address) -gauge_implementation: public(address) - -# mapping of coins -> pools for trading -# a mapping key is generated for each pair of addresses via -# `bitwise_xor(convert(a, uint256), convert(b, uint256))` -markets: HashMap[uint256, address[4294967296]] -market_counts: HashMap[uint256, uint256] - -pool_count: public(uint256) # actual length of pool_list -pool_data: HashMap[address, PoolArray] -pool_list: public(address[4294967296]) # master list of pools - - -@external -def __init__( - _fee_receiver: address, - _pool_implementation: address, - _token_implementation: address, - _gauge_implementation: address, - _weth: address -): - self.fee_receiver = _fee_receiver - self.pool_implementation = _pool_implementation - self.token_implementation = _token_implementation - self.gauge_implementation = _gauge_implementation - - self.admin = msg.sender - WETH = _weth - - log UpdateFeeReceiver(ZERO_ADDRESS, _fee_receiver) - log UpdatePoolImplementation(ZERO_ADDRESS, _pool_implementation) - log UpdateTokenImplementation(ZERO_ADDRESS, _token_implementation) - log UpdateGaugeImplementation(ZERO_ADDRESS, _gauge_implementation) - log TransferOwnership(ZERO_ADDRESS, msg.sender) - - -# <--- Pool Deployers ---> - -@external -def deploy_pool( - _name: String[32], - _symbol: String[10], - _coins: address[2], - A: uint256, - gamma: uint256, - mid_fee: uint256, - out_fee: uint256, - allowed_extra_profit: uint256, - fee_gamma: uint256, - adjustment_step: uint256, - admin_fee: uint256, - ma_half_time: uint256, - initial_price: uint256 -) -> address: - """ - @notice Deploy a new pool - @param _name Name of the new plain pool - @param _symbol Symbol for the new plain pool - will be concatenated with factory symbol - Other parameters need some description - @return Address of the deployed pool - """ - # Validate parameters - assert A > MIN_A-1 - assert A < MAX_A+1 - assert gamma > MIN_GAMMA-1 - assert gamma < MAX_GAMMA+1 - assert mid_fee > MIN_FEE-1 - assert mid_fee < MAX_FEE-1 - assert out_fee >= mid_fee - assert out_fee < MAX_FEE-1 - assert admin_fee < 10**18+1 - assert allowed_extra_profit < 10**16+1 - assert fee_gamma < 10**18+1 - assert fee_gamma > 0 - assert adjustment_step < 10**18+1 - assert adjustment_step > 0 - assert ma_half_time < 7 * 86400 - assert ma_half_time > 0 - assert initial_price > 10**6 - assert initial_price < 10**30 - assert _coins[0] != _coins[1], "Duplicate coins" - - decimals: uint256[2] = empty(uint256[2]) - for i in range(2): - d: uint256 = ERC20(_coins[i]).decimals() - assert d < 19, "Max 18 decimals for coins" - decimals[i] = d - precisions: uint256 = (18 - decimals[0]) + shift(18 - decimals[1], 8) - - - name: String[64] = concat("Curve.fi Factory Crypto Pool: ", _name) - symbol: String[32] = concat(_symbol, "-f") - - token: address = create_forwarder_to(self.token_implementation) - pool: address = create_forwarder_to(self.pool_implementation) - - Token(token).initialize(name, symbol, pool) - CryptoPool(pool).initialize( - A, gamma, mid_fee, out_fee, allowed_extra_profit, fee_gamma, - adjustment_step, admin_fee, ma_half_time, initial_price, - token, _coins, precisions) - - length: uint256 = self.pool_count - self.pool_list[length] = pool - self.pool_count = length + 1 - self.pool_data[pool].token = token - self.pool_data[pool].decimals = shift(decimals[0], 8) + decimals[1] - self.pool_data[pool].coins = _coins - - key: uint256 = bitwise_xor(convert(_coins[0], uint256), convert(_coins[1], uint256)) - length = self.market_counts[key] - self.markets[key][length] = pool - self.market_counts[key] = length + 1 - - log CryptoPoolDeployed( - token, _coins, - A, gamma, mid_fee, out_fee, allowed_extra_profit, fee_gamma, - adjustment_step, admin_fee, ma_half_time, initial_price, - msg.sender) - return pool - - -@external -def deploy_gauge(_pool: address) -> address: - """ - @notice Deploy a liquidity gauge for a factory pool - @param _pool Factory pool address to deploy a gauge for - @return Address of the deployed gauge - """ - assert self.pool_data[_pool].coins[0] != ZERO_ADDRESS, "Unknown pool" - assert self.pool_data[_pool].liquidity_gauge == ZERO_ADDRESS, "Gauge already deployed" - - gauge: address = create_forwarder_to(self.gauge_implementation) - token: address = self.pool_data[_pool].token - LiquidityGauge(gauge).initialize(token) - self.pool_data[_pool].liquidity_gauge = gauge - - log LiquidityGaugeDeployed(_pool, token, gauge) - return gauge - - -# <--- Admin / Guarded Functionality ---> - - -@external -def set_fee_receiver(_fee_receiver: address): - """ - @notice Set fee receiver - @param _fee_receiver Address that fees are sent to - """ - assert msg.sender == self.admin # dev: admin only - - log UpdateFeeReceiver(self.fee_receiver, _fee_receiver) - self.fee_receiver = _fee_receiver - - -@external -def set_pool_implementation(_pool_implementation: address): - """ - @notice Set pool implementation - @dev Set to ZERO_ADDRESS to prevent deployment of new pools - @param _pool_implementation Address of the new pool implementation - """ - assert msg.sender == self.admin # dev: admin only - - log UpdatePoolImplementation(self.pool_implementation, _pool_implementation) - self.pool_implementation = _pool_implementation - - -@external -def set_token_implementation(_token_implementation: address): - """ - @notice Set token implementation - @dev Set to ZERO_ADDRESS to prevent deployment of new pools - @param _token_implementation Address of the new token implementation - """ - assert msg.sender == self.admin # dev: admin only - - log UpdateTokenImplementation(self.token_implementation, _token_implementation) - self.token_implementation = _token_implementation - - -@external -def set_gauge_implementation(_gauge_implementation: address): - """ - @notice Set gauge implementation - @dev Set to ZERO_ADDRESS to prevent deployment of new gauges - @param _gauge_implementation Address of the new token implementation - """ - assert msg.sender == self.admin # dev: admin-only function - - log UpdateGaugeImplementation(self.gauge_implementation, _gauge_implementation) - self.gauge_implementation = _gauge_implementation - - -@external -def commit_transfer_ownership(_addr: address): - """ - @notice Transfer ownership of this contract to `addr` - @param _addr Address of the new owner - """ - assert msg.sender == self.admin # dev: admin only - - self.future_admin = _addr - - -@external -def accept_transfer_ownership(): - """ - @notice Accept a pending ownership transfer - @dev Only callable by the new owner - """ - assert msg.sender == self.future_admin # dev: future admin only - - log TransferOwnership(self.admin, msg.sender) - self.admin = msg.sender - - -# <--- Factory Getters ---> - - -@view -@external -def find_pool_for_coins(_from: address, _to: address, i: uint256 = 0) -> address: - """ - @notice Find an available pool for exchanging two coins - @param _from Address of coin to be sent - @param _to Address of coin to be received - @param i Index value. When multiple pools are available - this value is used to return the n'th address. - @return Pool address - """ - key: uint256 = bitwise_xor(convert(_from, uint256), convert(_to, uint256)) - return self.markets[key][i] - - -# <--- Pool Getters ---> - - -@view -@external -def get_coins(_pool: address) -> address[2]: - """ - @notice Get the coins within a pool - @param _pool Pool address - @return List of coin addresses - """ - return self.pool_data[_pool].coins - - -@view -@external -def get_decimals(_pool: address) -> uint256[2]: - """ - @notice Get decimal places for each coin within a pool - @param _pool Pool address - @return uint256 list of decimals - """ - decimals: uint256 = self.pool_data[_pool].decimals - return [shift(decimals, -8), decimals % 256] - - -@view -@external -def get_balances(_pool: address) -> uint256[2]: - """ - @notice Get balances for each coin within a pool - @dev For pools using lending, these are the wrapped coin balances - @param _pool Pool address - @return uint256 list of balances - """ - return [CryptoPool(_pool).balances(0), CryptoPool(_pool).balances(1)] - - -@view -@external -def get_coin_indices( - _pool: address, - _from: address, - _to: address -) -> (uint256, uint256): - """ - @notice Convert coin addresses to indices for use with pool methods - @param _pool Pool address - @param _from Coin address to be used as `i` within a pool - @param _to Coin address to be used as `j` within a pool - @return uint256 `i`, uint256 `j` - """ - coins: address[2] = self.pool_data[_pool].coins - - if _from == coins[0] and _to == coins[1]: - return 0, 1 - elif _from == coins[1] and _to == coins[0]: - return 1, 0 - else: - raise "Coins not found" - - -@view -@external -def get_gauge(_pool: address) -> address: - """ - @notice Get the address of the liquidity gauge contract for a factory pool - @dev Returns `ZERO_ADDRESS` if a gauge has not been deployed - @param _pool Pool address - @return Implementation contract address - """ - return self.pool_data[_pool].liquidity_gauge - - -@view -@external -def get_eth_index(_pool: address) -> uint256: - """ - @notice Get the index of WETH for a pool - @dev Returns MAX_UINT256 if WETH is not a coin in the pool - """ - for i in range(2): - if self.pool_data[_pool].coins[i] == WETH: - return i - return MAX_UINT256 - - -@view -@external -def get_token(_pool: address) -> address: - """ - @notice Get the address of the LP token of a pool - """ - return self.pool_data[_pool].token diff --git a/contracts/mainnet/mocks/CryptoRegistry.vy b/contracts/mainnet/mocks/CryptoRegistry.vy deleted file mode 100644 index c7ee9b5..0000000 --- a/contracts/mainnet/mocks/CryptoRegistry.vy +++ /dev/null @@ -1,681 +0,0 @@ -# @version 0.3.0 -""" -@title Curve CryptoSwap Registry -@license MIT -@author Curve.Fi -""" - -MAX_COINS: constant(int128) = 8 -CALC_INPUT_SIZE: constant(int128) = 100 - - -struct CoinInfo: - index: uint256 - register_count: uint256 - swap_count: uint256 - swap_for: address[MAX_INT128] - -struct PoolArray: - location: uint256 - decimals: uint256 - coins: address[MAX_COINS] - n_coins: uint256 - name: String[64] - - -interface AddressProvider: - def admin() -> address: view - def get_address(_id: uint256) -> address: view - def get_registry() -> address: view - -interface ERC20: - def balanceOf(_addr: address) -> uint256: view - def decimals() -> uint256: view - def totalSupply() -> uint256: view - -interface CurvePool: - def token() -> address: view - def coins(i: uint256) -> address: view - def A() -> uint256: view - def gamma() -> uint256: view - def fee() -> uint256: view - def get_virtual_price() -> uint256: view - def mid_fee() -> uint256: view - def out_fee() -> uint256: view - def admin_fee() -> uint256: view - def balances(i: uint256) -> uint256: view - def D() -> uint256: view - -interface LiquidityGauge: - def lp_token() -> address: view - -interface GaugeController: - def gauge_types(gauge: address) -> int128: view - - -event PoolAdded: - pool: indexed(address) - -event PoolRemoved: - pool: indexed(address) - - -address_provider: public(AddressProvider) -pool_list: public(address[65536]) # master list of pools -pool_count: public(uint256) # actual length of pool_list - -pool_data: HashMap[address, PoolArray] - -coin_count: public(uint256) # total unique coins registered -coins: HashMap[address, CoinInfo] -get_coin: public(address[65536]) # unique list of registered coins -# bitwise_xor(coina, coinb) -> (coina_pos, coinb_pos) sorted -# stored as uint128[2] -coin_swap_indexes: HashMap[uint256, uint256] - -# lp token -> pool -get_pool_from_lp_token: public(HashMap[address, address]) - -# pool -> lp token -get_lp_token: public(HashMap[address, address]) - -# mapping of coins -> pools for trading -# a mapping key is generated for each pair of addresses via -# `bitwise_xor(convert(a, uint256), convert(b, uint256))` -markets: HashMap[uint256, address[65536]] -market_counts: HashMap[uint256, uint256] - -liquidity_gauges: HashMap[address, address[10]] - -# mapping of pool -> deposit/exchange zap -get_zap: public(HashMap[address, address]) - -last_updated: public(uint256) - - -@external -def __init__(_address_provider: AddressProvider): - """ - @notice Constructor function - """ - self.address_provider = _address_provider - -# internal functionality for getters - -@view -@internal -def _get_balances(_pool: address) -> uint256[MAX_COINS]: - balances: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - for i in range(MAX_COINS): - if self.pool_data[_pool].coins[i] == ZERO_ADDRESS: - assert i != 0 - break - - balances[i] = CurvePool(_pool).balances(i) - - return balances - - -# targetted external getters, optimized for on-chain calls - -@view -@external -def find_pool_for_coins(_from: address, _to: address, i: uint256 = 0) -> address: - """ - @notice Find an available pool for exchanging two coins - @param _from Address of coin to be sent - @param _to Address of coin to be received - @param i Index value. When multiple pools are available - this value is used to return the n'th address. - @return Pool address - """ - key: uint256 = bitwise_xor(convert(_from, uint256), convert(_to, uint256)) - return self.markets[key][i] - - -@view -@external -def get_n_coins(_pool: address) -> uint256: - """ - @notice Get the number of coins in a pool - @dev For non-metapools, both returned values are identical - even when the pool does not use wrapping/lending - @param _pool Pool address - @return Number of wrapped coins, number of underlying coins - """ - return self.pool_data[_pool].n_coins - - -@view -@external -def get_coins(_pool: address) -> address[MAX_COINS]: - """ - @notice Get the coins within a pool - @dev For pools using lending, these are the wrapped coin addresses - @param _pool Pool address - @return List of coin addresses - """ - coins: address[MAX_COINS] = empty(address[MAX_COINS]) - n_coins: uint256 = self.pool_data[_pool].n_coins - for i in range(MAX_COINS): - if i == n_coins: - break - coins[i] = self.pool_data[_pool].coins[i] - - return coins - - -@view -@external -def get_decimals(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get decimal places for each coin within a pool - @dev For pools using lending, these are the wrapped coin decimal places - @param _pool Pool address - @return uint256 list of decimals - """ - - # decimals are tightly packed as a series of uint8 within a little-endian bytes32 - # the packed value is stored as uint256 to simplify unpacking via shift and modulo - packed: uint256 = self.pool_data[_pool].decimals - decimals: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - n_coins: int128 = convert(self.pool_data[_pool].n_coins, int128) - for i in range(MAX_COINS): - if i == n_coins: - break - decimals[i] = shift(packed, -8 * i) % 256 - - return decimals - - -@view -@external -def get_gauges(_pool: address) -> (address[10], int128[10]): - """ - @notice Get a list of LiquidityGauge contracts associated with a pool - @param _pool Pool address - @return address[10] of gauge addresses, int128[10] of gauge types - """ - liquidity_gauges: address[10] = empty(address[10]) - gauge_types: int128[10] = empty(int128[10]) - for i in range(10): - gauge: address = self.liquidity_gauges[_pool][i] - if gauge == ZERO_ADDRESS: - break - liquidity_gauges[i] = gauge - - return liquidity_gauges, gauge_types - - -@view -@external -def get_balances(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get balances for each coin within a pool - @dev For pools using lending, these are the wrapped coin balances - @param _pool Pool address - @return uint256 list of balances - """ - return self._get_balances(_pool) - - -@view -@external -def get_virtual_price_from_lp_token(_token: address) -> uint256: - """ - @notice Get the virtual price of a pool LP token - @param _token LP token address - @return uint256 Virtual price - """ - return CurvePool(self.get_pool_from_lp_token[_token]).get_virtual_price() - - -@view -@external -def get_A(_pool: address) -> uint256: - return CurvePool(_pool).A() - - -@view -@external -def get_D(_pool: address) -> uint256: - return CurvePool(_pool).D() - - -@view -@external -def get_gamma(_pool: address) -> uint256: - return CurvePool(_pool).gamma() - - -@view -@external -def get_fees(_pool: address) -> uint256[4]: - """ - @notice Get the fees for a pool - @dev Fees are expressed as integers - @return Pool fee as uint256 with 1e10 precision - Admin fee as 1e10 percentage of pool fee - Mid fee - Out fee - """ - return [CurvePool(_pool).fee(), CurvePool(_pool).admin_fee(), CurvePool(_pool).mid_fee(), CurvePool(_pool).out_fee()] - - -@view -@external -def get_admin_balances(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get the current admin balances (uncollected fees) for a pool - @param _pool Pool address - @return List of uint256 admin balances - """ - balances: uint256[MAX_COINS] = self._get_balances(_pool) - n_coins: uint256 = self.pool_data[_pool].n_coins - for i in range(MAX_COINS): - coin: address = self.pool_data[_pool].coins[i] - if i == n_coins: - break - if coin == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE: - balances[i] = _pool.balance - balances[i] - else: - balances[i] = ERC20(coin).balanceOf(_pool) - balances[i] - - return balances - - -@view -@external -def get_coin_indices( - _pool: address, - _from: address, - _to: address -) -> (uint256, uint256): - """ - @notice Convert coin addresses to indices for use with pool methods - @param _from Coin address to be used as `i` within a pool - @param _to Coin address to be used as `j` within a pool - @return int128 `i`, int128 `j`, boolean indicating if `i` and `j` are underlying coins - """ - # the return value is stored as `uint256[3]` to reduce gas costs - # from index, to index, is the market underlying? - result: uint256[2] = empty(uint256[2]) - - found_market: bool = False - - # check coin markets - for x in range(MAX_COINS): - coin: address = self.pool_data[_pool].coins[x] - if coin == ZERO_ADDRESS: - # if we reach the end of the coins, reset `found_market` and try again - # with the underlying coins - found_market = False - break - if coin == _from: - result[0] = x - elif coin == _to: - result[1] = x - else: - continue - if found_market: - # the second time we find a match, break out of the loop - return result[0], result[1] - # the first time we find a match, set `found_market` to True - found_market = True - - raise "No available market" - - -@view -@external -def get_pool_name(_pool: address) -> String[64]: - """ - @notice Get the given name for a pool - @param _pool Pool address - @return The name of a pool - """ - return self.pool_data[_pool].name - - -@view -@external -def get_coin_swap_count(_coin: address) -> uint256: - """ - @notice Get the number of unique coins available to swap `_coin` against - @param _coin Coin address - @return The number of unique coins available to swap for - """ - return self.coins[_coin].swap_count - - -@view -@external -def get_coin_swap_complement(_coin: address, _index: uint256) -> address: - """ - @notice Get the coin available to swap against `_coin` at `_index` - @param _coin Coin address - @param _index An index in the `_coin`'s set of available counter - coin's - @return Address of a coin available to swap against `_coin` - """ - return self.coins[_coin].swap_for[_index] - - -# internal functionality used in admin setters - - -@internal -def _register_coin(_coin: address): - if self.coins[_coin].register_count == 0: - coin_count: uint256 = self.coin_count - self.coins[_coin].index = coin_count - self.get_coin[coin_count] = _coin - self.coin_count += 1 - self.coins[_coin].register_count += 1 - - -@internal -def _register_coin_pair(_coina: address, _coinb: address, _key: uint256): - # register _coinb in _coina's array of coins - coin_b_pos: uint256 = self.coins[_coina].swap_count - self.coins[_coina].swap_for[coin_b_pos] = _coinb - self.coins[_coina].swap_count += 1 - # register _coina in _coinb's array of coins - coin_a_pos: uint256 = self.coins[_coinb].swap_count - self.coins[_coinb].swap_for[coin_a_pos] = _coina - self.coins[_coinb].swap_count += 1 - # register indexes (coina pos in coinb array, coinb pos in coina array) - if convert(_coina, uint256) < convert(_coinb, uint256): - self.coin_swap_indexes[_key] = shift(coin_a_pos, 128) + coin_b_pos - else: - self.coin_swap_indexes[_key] = shift(coin_b_pos, 128) + coin_a_pos - - -@internal -def _unregister_coin(_coin: address): - self.coins[_coin].register_count -= 1 - - if self.coins[_coin].register_count == 0: - self.coin_count -= 1 - coin_count: uint256 = self.coin_count - location: uint256 = self.coins[_coin].index - - if location < coin_count: - coin_b: address = self.get_coin[coin_count] - self.get_coin[location] = coin_b - self.coins[coin_b].index = location - - self.coins[_coin].index = 0 - self.get_coin[coin_count] = ZERO_ADDRESS - - -@internal -def _unregister_coin_pair(_coina: address, _coinb: address, _coinb_idx: uint256): - """ - @param _coinb_idx the index of _coinb in _coina's array of unique coin's - """ - # decrement swap counts for both coins - self.coins[_coina].swap_count -= 1 - - # retrieve the last currently occupied index in coina's array - coina_arr_last_idx: uint256 = self.coins[_coina].swap_count - - # if coinb's index in coina's array is less than the last - # overwrite it's position with the last coin - if _coinb_idx < coina_arr_last_idx: - # here's our last coin in coina's array - coin_c: address = self.coins[_coina].swap_for[coina_arr_last_idx] - # get the bitwise_xor of the pair to retrieve their indexes - key: uint256 = bitwise_xor(convert(_coina, uint256), convert(coin_c, uint256)) - indexes: uint256 = self.coin_swap_indexes[key] - - # update the pairing's indexes - if convert(_coina, uint256) < convert(coin_c, uint256): - # least complicated most readable way of shifting twice to remove the lower order bits - self.coin_swap_indexes[key] = shift(shift(indexes, -128), 128) + _coinb_idx - else: - self.coin_swap_indexes[key] = shift(_coinb_idx, 128) + indexes % 2 ** 128 - # set _coinb_idx in coina's array to coin_c - self.coins[_coina].swap_for[_coinb_idx] = coin_c - - self.coins[_coina].swap_for[coina_arr_last_idx] = ZERO_ADDRESS - - -@internal -def _get_new_pool_coins( - _pool: address, - _n_coins: uint256, -) -> address[MAX_COINS]: - coin_list: address[MAX_COINS] = empty(address[MAX_COINS]) - coin: address = ZERO_ADDRESS - for i in range(MAX_COINS): - if i == _n_coins: - break - coin = CurvePool(_pool).coins(i) - self.pool_data[_pool].coins[i] = coin - coin_list[i] = coin - - for i in range(MAX_COINS): - if i == _n_coins: - break - - self._register_coin(coin_list[i]) - # add pool to markets - i2: uint256 = i + 1 - for x in range(i2, i2 + MAX_COINS): - if x == _n_coins: - break - - key: uint256 = bitwise_xor(convert(coin_list[i], uint256), convert(coin_list[x], uint256)) - length: uint256 = self.market_counts[key] - self.markets[key][length] = _pool - self.market_counts[key] = length + 1 - - # register the coin pair - if length == 0: - self._register_coin_pair(coin_list[x], coin_list[i], key) - - return coin_list - - -@view -@internal -def _get_new_pool_decimals(_coins: address[MAX_COINS], _n_coins: uint256) -> uint256: - packed: uint256 = 0 - value: uint256 = 0 - - n_coins: int128 = convert(_n_coins, int128) - for i in range(MAX_COINS): - if i == n_coins: - break - coin: address = _coins[i] - if coin == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE: - value = 18 - else: - value = ERC20(coin).decimals() - assert value < 256 # dev: decimal overflow - - packed += shift(value, i * 8) - - return packed - - -@internal -def _remove_market(_pool: address, _coina: address, _coinb: address): - key: uint256 = bitwise_xor(convert(_coina, uint256), convert(_coinb, uint256)) - length: uint256 = self.market_counts[key] - 1 - if length == 0: - indexes: uint256 = self.coin_swap_indexes[key] - if convert(_coina, uint256) < convert(_coinb, uint256): - self._unregister_coin_pair(_coina, _coinb, indexes % 2 ** 128) - self._unregister_coin_pair(_coinb, _coina, shift(indexes, -128)) - else: - self._unregister_coin_pair(_coina, _coinb, shift(indexes, -128)) - self._unregister_coin_pair(_coinb, _coina, indexes % 2 ** 128) - self.coin_swap_indexes[key] = 0 - for i in range(65536): - if i > length: - break - if self.markets[key][i] == _pool: - if i < length: - self.markets[key][i] = self.markets[key][length] - self.markets[key][length] = ZERO_ADDRESS - self.market_counts[key] = length - break - - -# admin functions - -@external -def add_pool( - _pool: address, - _n_coins: uint256, - _lp_token: address, - _gauge: address, - _zap: address, - _decimals: uint256, - _name: String[64], -): - """ - @notice Add a pool to the registry - @dev Only callable by admin - @param _pool Pool address to add - @param _n_coins Number of coins in the pool - @param _lp_token Pool deposit token address - @param _decimals Coin decimal values, tightly packed as uint8 in a little-endian bytes32 - @param _name The name of the pool - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - assert _lp_token != ZERO_ADDRESS - assert self.pool_data[_pool].coins[0] == ZERO_ADDRESS # dev: pool exists - assert self.get_pool_from_lp_token[_lp_token] == ZERO_ADDRESS - - # add pool to pool_list - length: uint256 = self.pool_count - self.pool_list[length] = _pool - self.pool_count = length + 1 - self.pool_data[_pool].location = length - self.pool_data[_pool].n_coins = _n_coins - self.pool_data[_pool].name = _name - - # update public mappings - self.get_pool_from_lp_token[_lp_token] = _pool - self.get_lp_token[_pool] = _lp_token - - coins: address[MAX_COINS] = self._get_new_pool_coins(_pool, _n_coins) - decimals: uint256 = _decimals - if decimals == 0: - decimals = self._get_new_pool_decimals(coins, _n_coins) - self.pool_data[_pool].decimals = decimals - - if _zap != ZERO_ADDRESS: - self.get_zap[_pool] = _zap - - if _gauge != ZERO_ADDRESS: - self.liquidity_gauges[_pool][0] = _gauge - - self.last_updated = block.timestamp - log PoolAdded(_pool) - - -@external -def remove_pool(_pool: address): - """ - @notice Remove a pool to the registry - @dev Only callable by admin - @param _pool Pool address to remove - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - assert self.pool_data[_pool].coins[0] != ZERO_ADDRESS # dev: pool does not exist - - self.get_pool_from_lp_token[self.get_lp_token[_pool]] = ZERO_ADDRESS - self.get_lp_token[_pool] = ZERO_ADDRESS - - # remove _pool from pool_list - location: uint256 = self.pool_data[_pool].location - length: uint256 = self.pool_count - 1 - - if location < length: - # replace _pool with final value in pool_list - addr: address = self.pool_list[length] - self.pool_list[location] = addr - self.pool_data[addr].location = location - - # delete final pool_list value - self.pool_list[length] = ZERO_ADDRESS - self.pool_count = length - - self.pool_data[_pool].decimals = 0 - self.pool_data[_pool].n_coins = 0 - self.pool_data[_pool].name = "" - - coins: address[MAX_COINS] = empty(address[MAX_COINS]) - - for i in range(MAX_COINS): - coins[i] = self.pool_data[_pool].coins[i] - if coins[i] == ZERO_ADDRESS: - break - # delete coin address from pool_data - self.pool_data[_pool].coins[i] = ZERO_ADDRESS - self._unregister_coin(coins[i]) - - for i in range(MAX_COINS): - coin: address = coins[i] - if coin == ZERO_ADDRESS: - break - - # remove pool from markets - i2: uint256 = i + 1 - for x in range(i2, i2 + MAX_COINS): - coinx: address = coins[x] - if coinx == ZERO_ADDRESS: - break - self._remove_market(_pool, coin, coinx) - - if self.get_zap[_pool] != ZERO_ADDRESS: - self.get_zap[_pool] = ZERO_ADDRESS - - self.last_updated = block.timestamp - log PoolRemoved(_pool) - - -@external -def set_liquidity_gauges(_pool: address, _liquidity_gauges: address[10]): - """ - @notice Set liquidity gauge contracts - @param _pool Pool address - @param _liquidity_gauges Liquidity gauge address - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - _lp_token: address = self.get_lp_token[_pool] - for i in range(10): - _gauge: address = _liquidity_gauges[i] - if _gauge != ZERO_ADDRESS: - assert LiquidityGauge(_gauge).lp_token() == _lp_token # dev: wrong token - self.liquidity_gauges[_pool][i] = _gauge - elif self.liquidity_gauges[_pool][i] != ZERO_ADDRESS: - self.liquidity_gauges[_pool][i] = ZERO_ADDRESS - else: - break - self.last_updated = block.timestamp - - -@external -def batch_set_liquidity_gauges(_pools: address[10], _liquidity_gauges: address[10]): - """ - @notice Set many liquidity gauge contracts - @param _pools List of pool addresses - @param _liquidity_gauges List of liquidity gauge addresses - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - for i in range(10): - _pool: address = _pools[i] - if _pool == ZERO_ADDRESS: - break - _gauge: address = _liquidity_gauges[i] - assert LiquidityGauge(_gauge).lp_token() == self.get_lp_token[_pool] # dev: wrong token - self.liquidity_gauges[_pool][0] = _gauge - - self.last_updated = block.timestamp diff --git a/contracts/mainnet/mocks/GaugeController.vy b/contracts/mainnet/mocks/GaugeController.vy deleted file mode 100644 index 576f498..0000000 --- a/contracts/mainnet/mocks/GaugeController.vy +++ /dev/null @@ -1,596 +0,0 @@ -# @version 0.2.4 - -""" -@title Gauge Controller -@author Curve Finance -@license MIT -@notice Controls liquidity gauges and the issuance of coins through the gauges -""" - -# 7 * 86400 seconds - all future times are rounded by week -WEEK: constant(uint256) = 604800 - -# Cannot change weight votes more often than once in 10 days -WEIGHT_VOTE_DELAY: constant(uint256) = 10 * 86400 - - -struct Point: - bias: uint256 - slope: uint256 - -struct VotedSlope: - slope: uint256 - power: uint256 - end: uint256 - - -interface VotingEscrow: - def get_last_user_slope(addr: address) -> int128: view - def locked__end(addr: address) -> uint256: view - - -event CommitOwnership: - admin: address - -event ApplyOwnership: - admin: address - -event AddType: - name: String[64] - type_id: int128 - -event NewTypeWeight: - type_id: int128 - time: uint256 - weight: uint256 - total_weight: uint256 - -event NewGaugeWeight: - gauge_address: address - time: uint256 - weight: uint256 - total_weight: uint256 - -event VoteForGauge: - time: uint256 - user: address - gauge_addr: address - weight: uint256 - -event NewGauge: - addr: address - gauge_type: int128 - weight: uint256 - - -MULTIPLIER: constant(uint256) = 10 ** 18 - -admin: public(address) # Can and will be a smart contract -future_admin: public(address) # Can and will be a smart contract - -token: public(address) # CRV token -voting_escrow: public(address) # Voting escrow - -# Gauge parameters -# All numbers are "fixed point" on the basis of 1e18 -n_gauge_types: public(int128) -n_gauges: public(int128) -gauge_type_names: public(HashMap[int128, String[64]]) - -# Needed for enumeration -gauges: public(address[1000000000]) - -# we increment values by 1 prior to storing them here so we can rely on a value -# of zero as meaning the gauge has not been set -gauge_types_: HashMap[address, int128] - -vote_user_slopes: public(HashMap[address, HashMap[address, VotedSlope]]) # user -> gauge_addr -> VotedSlope -vote_user_power: public(HashMap[address, uint256]) # Total vote power used by user -last_user_vote: public(HashMap[address, HashMap[address, uint256]]) # Last user vote's timestamp for each gauge address - -# Past and scheduled points for gauge weight, sum of weights per type, total weight -# Point is for bias+slope -# changes_* are for changes in slope -# time_* are for the last change timestamp -# timestamps are rounded to whole weeks - -points_weight: public(HashMap[address, HashMap[uint256, Point]]) # gauge_addr -> time -> Point -changes_weight: HashMap[address, HashMap[uint256, uint256]] # gauge_addr -> time -> slope -time_weight: public(HashMap[address, uint256]) # gauge_addr -> last scheduled time (next week) - -points_sum: public(HashMap[int128, HashMap[uint256, Point]]) # type_id -> time -> Point -changes_sum: HashMap[int128, HashMap[uint256, uint256]] # type_id -> time -> slope -time_sum: public(uint256[1000000000]) # type_id -> last scheduled time (next week) - -points_total: public(HashMap[uint256, uint256]) # time -> total weight -time_total: public(uint256) # last scheduled time - -points_type_weight: public(HashMap[int128, HashMap[uint256, uint256]]) # type_id -> time -> type weight -time_type_weight: public(uint256[1000000000]) # type_id -> last scheduled time (next week) - - -@external -def __init__(_token: address, _voting_escrow: address): - """ - @notice Contract constructor - @param _token `ERC20CRV` contract address - @param _voting_escrow `VotingEscrow` contract address - """ - assert _token != ZERO_ADDRESS - assert _voting_escrow != ZERO_ADDRESS - - self.admin = msg.sender - self.token = _token - self.voting_escrow = _voting_escrow - self.time_total = block.timestamp / WEEK * WEEK - - -@external -def commit_transfer_ownership(addr: address): - """ - @notice Transfer ownership of GaugeController to `addr` - @param addr Address to have ownership transferred to - """ - assert msg.sender == self.admin # dev: admin only - self.future_admin = addr - log CommitOwnership(addr) - - -@external -def apply_transfer_ownership(): - """ - @notice Apply pending ownership transfer - """ - assert msg.sender == self.admin # dev: admin only - _admin: address = self.future_admin - assert _admin != ZERO_ADDRESS # dev: admin not set - self.admin = _admin - log ApplyOwnership(_admin) - - -@external -@view -def gauge_types(_addr: address) -> int128: - """ - @notice Get gauge type for address - @param _addr Gauge address - @return Gauge type id - """ - gauge_type: int128 = self.gauge_types_[_addr] - assert gauge_type != 0 - - return gauge_type - 1 - - -@internal -def _get_type_weight(gauge_type: int128) -> uint256: - """ - @notice Fill historic type weights week-over-week for missed checkins - and return the type weight for the future week - @param gauge_type Gauge type id - @return Type weight - """ - t: uint256 = self.time_type_weight[gauge_type] - if t > 0: - w: uint256 = self.points_type_weight[gauge_type][t] - for i in range(500): - if t > block.timestamp: - break - t += WEEK - self.points_type_weight[gauge_type][t] = w - if t > block.timestamp: - self.time_type_weight[gauge_type] = t - return w - else: - return 0 - - -@internal -def _get_sum(gauge_type: int128) -> uint256: - """ - @notice Fill sum of gauge weights for the same type week-over-week for - missed checkins and return the sum for the future week - @param gauge_type Gauge type id - @return Sum of weights - """ - t: uint256 = self.time_sum[gauge_type] - if t > 0: - pt: Point = self.points_sum[gauge_type][t] - for i in range(500): - if t > block.timestamp: - break - t += WEEK - d_bias: uint256 = pt.slope * WEEK - if pt.bias > d_bias: - pt.bias -= d_bias - d_slope: uint256 = self.changes_sum[gauge_type][t] - pt.slope -= d_slope - else: - pt.bias = 0 - pt.slope = 0 - self.points_sum[gauge_type][t] = pt - if t > block.timestamp: - self.time_sum[gauge_type] = t - return pt.bias - else: - return 0 - - -@internal -def _get_total() -> uint256: - """ - @notice Fill historic total weights week-over-week for missed checkins - and return the total for the future week - @return Total weight - """ - t: uint256 = self.time_total - _n_gauge_types: int128 = self.n_gauge_types - if t > block.timestamp: - # If we have already checkpointed - still need to change the value - t -= WEEK - pt: uint256 = self.points_total[t] - - for gauge_type in range(100): - if gauge_type == _n_gauge_types: - break - self._get_sum(gauge_type) - self._get_type_weight(gauge_type) - - for i in range(500): - if t > block.timestamp: - break - t += WEEK - pt = 0 - # Scales as n_types * n_unchecked_weeks (hopefully 1 at most) - for gauge_type in range(100): - if gauge_type == _n_gauge_types: - break - type_sum: uint256 = self.points_sum[gauge_type][t].bias - type_weight: uint256 = self.points_type_weight[gauge_type][t] - pt += type_sum * type_weight - self.points_total[t] = pt - - if t > block.timestamp: - self.time_total = t - return pt - - -@internal -def _get_weight(gauge_addr: address) -> uint256: - """ - @notice Fill historic gauge weights week-over-week for missed checkins - and return the total for the future week - @param gauge_addr Address of the gauge - @return Gauge weight - """ - t: uint256 = self.time_weight[gauge_addr] - if t > 0: - pt: Point = self.points_weight[gauge_addr][t] - for i in range(500): - if t > block.timestamp: - break - t += WEEK - d_bias: uint256 = pt.slope * WEEK - if pt.bias > d_bias: - pt.bias -= d_bias - d_slope: uint256 = self.changes_weight[gauge_addr][t] - pt.slope -= d_slope - else: - pt.bias = 0 - pt.slope = 0 - self.points_weight[gauge_addr][t] = pt - if t > block.timestamp: - self.time_weight[gauge_addr] = t - return pt.bias - else: - return 0 - - -@external -def add_gauge(addr: address, gauge_type: int128, weight: uint256 = 0): - """ - @notice Add gauge `addr` of type `gauge_type` with weight `weight` - @param addr Gauge address - @param gauge_type Gauge type - @param weight Gauge weight - """ - assert msg.sender == self.admin - assert (gauge_type >= 0) and (gauge_type < self.n_gauge_types) - assert self.gauge_types_[addr] == 0 # dev: cannot add the same gauge twice - - n: int128 = self.n_gauges - self.n_gauges = n + 1 - self.gauges[n] = addr - - self.gauge_types_[addr] = gauge_type + 1 - next_time: uint256 = (block.timestamp + WEEK) / WEEK * WEEK - - if weight > 0: - _type_weight: uint256 = self._get_type_weight(gauge_type) - _old_sum: uint256 = self._get_sum(gauge_type) - _old_total: uint256 = self._get_total() - - self.points_sum[gauge_type][next_time].bias = weight + _old_sum - self.time_sum[gauge_type] = next_time - self.points_total[next_time] = _old_total + _type_weight * weight - self.time_total = next_time - - self.points_weight[addr][next_time].bias = weight - - if self.time_sum[gauge_type] == 0: - self.time_sum[gauge_type] = next_time - self.time_weight[addr] = next_time - - log NewGauge(addr, gauge_type, weight) - - -@external -def checkpoint(): - """ - @notice Checkpoint to fill data common for all gauges - """ - self._get_total() - - -@external -def checkpoint_gauge(addr: address): - """ - @notice Checkpoint to fill data for both a specific gauge and common for all gauges - @param addr Gauge address - """ - self._get_weight(addr) - self._get_total() - - -@internal -@view -def _gauge_relative_weight(addr: address, time: uint256) -> uint256: - """ - @notice Get Gauge relative weight (not more than 1.0) normalized to 1e18 - (e.g. 1.0 == 1e18). Inflation which will be received by it is - inflation_rate * relative_weight / 1e18 - @param addr Gauge address - @param time Relative weight at the specified timestamp in the past or present - @return Value of relative weight normalized to 1e18 - """ - t: uint256 = time / WEEK * WEEK - _total_weight: uint256 = self.points_total[t] - - if _total_weight > 0: - gauge_type: int128 = self.gauge_types_[addr] - 1 - _type_weight: uint256 = self.points_type_weight[gauge_type][t] - _gauge_weight: uint256 = self.points_weight[addr][t].bias - return MULTIPLIER * _type_weight * _gauge_weight / _total_weight - - else: - return 0 - - -@external -@view -def gauge_relative_weight(addr: address, time: uint256 = block.timestamp) -> uint256: - """ - @notice Get Gauge relative weight (not more than 1.0) normalized to 1e18 - (e.g. 1.0 == 1e18). Inflation which will be received by it is - inflation_rate * relative_weight / 1e18 - @param addr Gauge address - @param time Relative weight at the specified timestamp in the past or present - @return Value of relative weight normalized to 1e18 - """ - return self._gauge_relative_weight(addr, time) - - -@external -def gauge_relative_weight_write(addr: address, time: uint256 = block.timestamp) -> uint256: - """ - @notice Get gauge weight normalized to 1e18 and also fill all the unfilled - values for type and gauge records - @dev Any address can call, however nothing is recorded if the values are filled already - @param addr Gauge address - @param time Relative weight at the specified timestamp in the past or present - @return Value of relative weight normalized to 1e18 - """ - self._get_weight(addr) - self._get_total() # Also calculates get_sum - return self._gauge_relative_weight(addr, time) - - - - -@internal -def _change_type_weight(type_id: int128, weight: uint256): - """ - @notice Change type weight - @param type_id Type id - @param weight New type weight - """ - old_weight: uint256 = self._get_type_weight(type_id) - old_sum: uint256 = self._get_sum(type_id) - _total_weight: uint256 = self._get_total() - next_time: uint256 = (block.timestamp + WEEK) / WEEK * WEEK - - _total_weight = _total_weight + old_sum * weight - old_sum * old_weight - self.points_total[next_time] = _total_weight - self.points_type_weight[type_id][next_time] = weight - self.time_total = next_time - self.time_type_weight[type_id] = next_time - - log NewTypeWeight(type_id, next_time, weight, _total_weight) - - -@external -def add_type(_name: String[64], weight: uint256 = 0): - """ - @notice Add gauge type with name `_name` and weight `weight` - @param _name Name of gauge type - @param weight Weight of gauge type - """ - assert msg.sender == self.admin - type_id: int128 = self.n_gauge_types - self.gauge_type_names[type_id] = _name - self.n_gauge_types = type_id + 1 - if weight != 0: - self._change_type_weight(type_id, weight) - log AddType(_name, type_id) - - -@external -def change_type_weight(type_id: int128, weight: uint256): - """ - @notice Change gauge type `type_id` weight to `weight` - @param type_id Gauge type id - @param weight New Gauge weight - """ - assert msg.sender == self.admin - self._change_type_weight(type_id, weight) - - -@internal -def _change_gauge_weight(addr: address, weight: uint256): - # Change gauge weight - # Only needed when testing in reality - gauge_type: int128 = self.gauge_types_[addr] - 1 - old_gauge_weight: uint256 = self._get_weight(addr) - type_weight: uint256 = self._get_type_weight(gauge_type) - old_sum: uint256 = self._get_sum(gauge_type) - _total_weight: uint256 = self._get_total() - next_time: uint256 = (block.timestamp + WEEK) / WEEK * WEEK - - self.points_weight[addr][next_time].bias = weight - self.time_weight[addr] = next_time - - new_sum: uint256 = old_sum + weight - old_gauge_weight - self.points_sum[gauge_type][next_time].bias = new_sum - self.time_sum[gauge_type] = next_time - - _total_weight = _total_weight + new_sum * type_weight - old_sum * type_weight - self.points_total[next_time] = _total_weight - self.time_total = next_time - - log NewGaugeWeight(addr, block.timestamp, weight, _total_weight) - - -@external -def change_gauge_weight(addr: address, weight: uint256): - """ - @notice Change weight of gauge `addr` to `weight` - @param addr `GaugeController` contract address - @param weight New Gauge weight - """ - assert msg.sender == self.admin - self._change_gauge_weight(addr, weight) - - -@external -def vote_for_gauge_weights(_gauge_addr: address, _user_weight: uint256): - """ - @notice Allocate voting power for changing pool weights - @param _gauge_addr Gauge which `msg.sender` votes for - @param _user_weight Weight for a gauge in bps (units of 0.01%). Minimal is 0.01%. Ignored if 0 - """ - escrow: address = self.voting_escrow - slope: uint256 = convert(VotingEscrow(escrow).get_last_user_slope(msg.sender), uint256) - lock_end: uint256 = VotingEscrow(escrow).locked__end(msg.sender) - _n_gauges: int128 = self.n_gauges - next_time: uint256 = (block.timestamp + WEEK) / WEEK * WEEK - assert lock_end > next_time, "Your token lock expires too soon" - assert (_user_weight >= 0) and (_user_weight <= 10000), "You used all your voting power" - assert block.timestamp >= self.last_user_vote[msg.sender][_gauge_addr] + WEIGHT_VOTE_DELAY, "Cannot vote so often" - - gauge_type: int128 = self.gauge_types_[_gauge_addr] - 1 - assert gauge_type >= 0, "Gauge not added" - # Prepare slopes and biases in memory - old_slope: VotedSlope = self.vote_user_slopes[msg.sender][_gauge_addr] - old_dt: uint256 = 0 - if old_slope.end > next_time: - old_dt = old_slope.end - next_time - old_bias: uint256 = old_slope.slope * old_dt - new_slope: VotedSlope = VotedSlope({ - slope: slope * _user_weight / 10000, - end: lock_end, - power: _user_weight - }) - new_dt: uint256 = lock_end - next_time # dev: raises when expired - new_bias: uint256 = new_slope.slope * new_dt - - # Check and update powers (weights) used - power_used: uint256 = self.vote_user_power[msg.sender] - power_used = power_used + new_slope.power - old_slope.power - self.vote_user_power[msg.sender] = power_used - assert (power_used >= 0) and (power_used <= 10000), 'Used too much power' - - ## Remove old and schedule new slope changes - # Remove slope changes for old slopes - # Schedule recording of initial slope for next_time - old_weight_bias: uint256 = self._get_weight(_gauge_addr) - old_weight_slope: uint256 = self.points_weight[_gauge_addr][next_time].slope - old_sum_bias: uint256 = self._get_sum(gauge_type) - old_sum_slope: uint256 = self.points_sum[gauge_type][next_time].slope - - self.points_weight[_gauge_addr][next_time].bias = max(old_weight_bias + new_bias, old_bias) - old_bias - self.points_sum[gauge_type][next_time].bias = max(old_sum_bias + new_bias, old_bias) - old_bias - if old_slope.end > next_time: - self.points_weight[_gauge_addr][next_time].slope = max(old_weight_slope + new_slope.slope, old_slope.slope) - old_slope.slope - self.points_sum[gauge_type][next_time].slope = max(old_sum_slope + new_slope.slope, old_slope.slope) - old_slope.slope - else: - self.points_weight[_gauge_addr][next_time].slope += new_slope.slope - self.points_sum[gauge_type][next_time].slope += new_slope.slope - if old_slope.end > block.timestamp: - # Cancel old slope changes if they still didn't happen - self.changes_weight[_gauge_addr][old_slope.end] -= old_slope.slope - self.changes_sum[gauge_type][old_slope.end] -= old_slope.slope - # Add slope changes for new slopes - self.changes_weight[_gauge_addr][new_slope.end] += new_slope.slope - self.changes_sum[gauge_type][new_slope.end] += new_slope.slope - - self._get_total() - - self.vote_user_slopes[msg.sender][_gauge_addr] = new_slope - - # Record last action time - self.last_user_vote[msg.sender][_gauge_addr] = block.timestamp - - log VoteForGauge(block.timestamp, msg.sender, _gauge_addr, _user_weight) - - -@external -@view -def get_gauge_weight(addr: address) -> uint256: - """ - @notice Get current gauge weight - @param addr Gauge address - @return Gauge weight - """ - return self.points_weight[addr][self.time_weight[addr]].bias - - -@external -@view -def get_type_weight(type_id: int128) -> uint256: - """ - @notice Get current type weight - @param type_id Type id - @return Type weight - """ - return self.points_type_weight[type_id][self.time_type_weight[type_id]] - - -@external -@view -def get_total_weight() -> uint256: - """ - @notice Get current total (type-weighted) weight - @return Total weight - """ - return self.points_total[self.time_total] - - -@external -@view -def get_weights_sum_per_type(type_id: int128) -> uint256: - """ - @notice Get sum of gauge weights per type - @param type_id Type id - @return Sum of gauge weights - """ - return self.points_sum[type_id][self.time_sum[type_id]].bias diff --git a/contracts/mainnet/mocks/ProxyAdmin.vy b/contracts/mainnet/mocks/ProxyAdmin.vy deleted file mode 100644 index df57810..0000000 --- a/contracts/mainnet/mocks/ProxyAdmin.vy +++ /dev/null @@ -1,155 +0,0 @@ -# @version 0.2.11 -""" -@title ProxyAdmin -@notice Thin proxy allowing shared ownership of contracts -@author Ben Hauser -@license MIT -""" - - -event TransactionExecuted: - admin: indexed(address) - target: indexed(address) - calldata: Bytes[100000] - value: uint256 - -event RequestAdminChange: - current_admin: address - future_admin: address - -event RevokeAdminChange: - current_admin: address - future_admin: address - calling_admin: address - -event ApproveAdminChange: - current_admin: address - future_admin: address - calling_admin: address - -event AcceptAdminChange: - previous_admin: address - current_admin: address - - -admins: public(address[2]) - -pending_current_admin: uint256 -pending_new_admin: address -change_approved: bool - - -@external -def __init__(_authorized: address[2]): - """ - @notice Contract constructor - @param _authorized Admin accounts for this contract - """ - self.admins = _authorized - - -@payable -@external -def execute(_target: address, _calldata: Bytes[100000]): - """ - @notice Execute a contract call - @dev Ether sent when calling this function is forwarded onward - @param _target Address of the contract to call - @param _calldata Calldata to use in the call - """ - assert msg.sender in self.admins # dev: only admin - - raw_call(_target, _calldata, value=msg.value) - log TransactionExecuted(msg.sender, _target, _calldata, msg.value) - - -@view -@external -def get_admin_change_status() -> (address, address, bool): - """ - @notice Get information about a pending admin change - @return Admin address to be replaced, - admin address to be added, - has change been approved? - """ - idx: uint256 = self.pending_current_admin - if idx == 0: - return ZERO_ADDRESS, ZERO_ADDRESS, False - else: - return self.admins[idx - 1], self.pending_new_admin, self.change_approved - - -@external -def request_admin_change(_new_admin: address): - """ - @notice Initiate changing an admin address - @param _new_admin New admin address (replaces msg.sender) - """ - assert self.pending_current_admin == 0 # dev: already an active request - - admin_list: address[2] = self.admins - assert _new_admin not in admin_list # dev: new admin is already admin - - for i in range(2): - if admin_list[i] == msg.sender: - self.pending_current_admin = i + 1 - self.pending_new_admin = _new_admin - log RequestAdminChange(msg.sender, _new_admin) - return - - raise # dev: only admin - - -@external -def approve_admin_change(): - """ - @notice Approve changing an admin address - @dev Only callable by the 2nd admin address (the one that will not change) - """ - idx: uint256 = self.pending_current_admin - - assert idx > 0 # dev: no active request - assert msg.sender == self.admins[idx % 2] # dev: caller is not 2nd admin - - self.change_approved = True - log ApproveAdminChange(self.admins[idx - 1], self.pending_new_admin, msg.sender) - - -@external -def revoke_admin_change(): - """ - @notice Revoke changing an admin address - @dev May be called by either admin at any time to reset the process, - even if approval has previous been given - """ - assert msg.sender in self.admins # dev: only admin - - idx: uint256 = self.pending_current_admin - pending_admin: address = ZERO_ADDRESS - if idx > 0: - pending_admin = self.admins[idx - 1] - - log RevokeAdminChange(pending_admin, self.pending_new_admin, msg.sender) - - self.pending_current_admin = 0 - self.pending_new_admin = ZERO_ADDRESS - self.change_approved = False - - - -@external -def accept_admin_change(): - """ - @notice Accept a changed admin address - @dev Only callable by the new admin address, after approval has been given - """ - assert self.change_approved == True # dev: change not approved - assert msg.sender == self.pending_new_admin # dev: only new admin - - idx: uint256 = self.pending_current_admin - 1 - log AcceptAdminChange(self.admins[idx], msg.sender) - self.admins[idx] = msg.sender - - self.pending_current_admin = 0 - self.pending_new_admin = ZERO_ADDRESS - self.change_approved = False diff --git a/contracts/mainnet/mocks/StableFactory.vy b/contracts/mainnet/mocks/StableFactory.vy deleted file mode 100644 index 4616ae4..0000000 --- a/contracts/mainnet/mocks/StableFactory.vy +++ /dev/null @@ -1,955 +0,0 @@ -# @version 0.2.15 -""" -@title Curve Factory -@license MIT -@author Curve.Fi -@notice Permissionless pool deployer and registry -""" - -struct PoolArray: - base_pool: address - implementation: address - liquidity_gauge: address - coins: address[MAX_PLAIN_COINS] - decimals: uint256[MAX_PLAIN_COINS] - n_coins: uint256 - asset_type: uint256 - -struct BasePoolArray: - implementations: address[10] - lp_token: address - fee_receiver: address - coins: address[MAX_COINS] - decimals: uint256 - n_coins: uint256 - asset_type: uint256 - - -interface AddressProvider: - def admin() -> address: view - def get_registry() -> address: view - -interface Registry: - def get_lp_token(pool: address) -> address: view - def get_n_coins(pool: address) -> uint256: view - def get_coins(pool: address) -> address[MAX_COINS]: view - def get_pool_from_lp_token(lp_token: address) -> address: view - -interface ERC20: - def balanceOf(_addr: address) -> uint256: view - def decimals() -> uint256: view - def totalSupply() -> uint256: view - def approve(_spender: address, _amount: uint256): nonpayable - -interface CurvePlainPool: - def initialize( - _name: String[32], - _symbol: String[10], - _coins: address[4], - _rate_multipliers: uint256[4], - _A: uint256, - _fee: uint256, - ): nonpayable - -interface CurvePool: - def A() -> uint256: view - def fee() -> uint256: view - def admin_fee() -> uint256: view - def balances(i: uint256) -> uint256: view - def admin_balances(i: uint256) -> uint256: view - def get_virtual_price() -> uint256: view - def initialize( - _name: String[32], - _symbol: String[10], - _coin: address, - _rate_multiplier: uint256, - _A: uint256, - _fee: uint256, - ): nonpayable - def exchange( - i: int128, - j: int128, - dx: uint256, - min_dy: uint256, - _receiver: address, - ) -> uint256: nonpayable - -interface CurveFactoryMetapool: - def coins(i :uint256) -> address: view - def decimals() -> uint256: view - -interface OldFactory: - def get_coins(_pool: address) -> address[2]: view - -interface LiquidityGauge: - def initialize(_lp_token: address): nonpayable - - -event BasePoolAdded: - base_pool: address - -event PlainPoolDeployed: - coins: address[MAX_PLAIN_COINS] - A: uint256 - fee: uint256 - deployer: address - -event MetaPoolDeployed: - coin: address - base_pool: address - A: uint256 - fee: uint256 - deployer: address - -event LiquidityGaugeDeployed: - pool: address - gauge: address - - -MAX_COINS: constant(int128) = 8 -MAX_PLAIN_COINS: constant(int128) = 4 # max coins in a plain pool -ADDRESS_PROVIDER: constant(address) = 0x0000000022D53366457F9d5E68Ec105046FC4383 -OLD_FACTORY: constant(address) = 0x0959158b6040D32d04c301A72CBFD6b39E21c9AE - -admin: public(address) -future_admin: public(address) -manager: public(address) - -pool_list: public(address[4294967296]) # master list of pools -pool_count: public(uint256) # actual length of pool_list -pool_data: HashMap[address, PoolArray] - -base_pool_list: public(address[4294967296]) # master list of pools -base_pool_count: public(uint256) # actual length of pool_list -base_pool_data: HashMap[address, BasePoolArray] - -# asset -> is used in a metapool? -base_pool_assets: public(HashMap[address, bool]) - -# number of coins -> implementation addresses -# for "plain pools" (as opposed to metapools), implementation contracts -# are organized according to the number of coins in the pool -plain_implementations: public(HashMap[uint256, address[10]]) - -# fee receiver for plain pools -fee_receiver: address - -gauge_implementation: public(address) - -# mapping of coins -> pools for trading -# a mapping key is generated for each pair of addresses via -# `bitwise_xor(convert(a, uint256), convert(b, uint256))` -markets: HashMap[uint256, address[4294967296]] -market_counts: HashMap[uint256, uint256] - - -@external -def __init__(_fee_receiver: address): - self.admin = msg.sender - self.manager = msg.sender - self.fee_receiver = _fee_receiver - - -# <--- Factory Getters ---> - -@view -@external -def metapool_implementations(_base_pool: address) -> address[10]: - """ - @notice Get a list of implementation contracts for metapools targetting the given base pool - @dev A base pool is the pool for the LP token contained within the metapool - @param _base_pool Address of the base pool - @return List of implementation contract addresses - """ - return self.base_pool_data[_base_pool].implementations - - -@view -@external -def find_pool_for_coins(_from: address, _to: address, i: uint256 = 0) -> address: - """ - @notice Find an available pool for exchanging two coins - @param _from Address of coin to be sent - @param _to Address of coin to be received - @param i Index value. When multiple pools are available - this value is used to return the n'th address. - @return Pool address - """ - key: uint256 = bitwise_xor(convert(_from, uint256), convert(_to, uint256)) - return self.markets[key][i] - - -# <--- Pool Getters ---> - -@view -@external -def get_base_pool(_pool: address) -> address: - """ - @notice Get the base pool for a given factory metapool - @param _pool Metapool address - @return Address of base pool - """ - return self.pool_data[_pool].base_pool - - -@view -@external -def get_n_coins(_pool: address) -> (uint256): - """ - @notice Get the number of coins in a pool - @param _pool Pool address - @return Number of coins - """ - return self.pool_data[_pool].n_coins - - -@view -@external -def get_meta_n_coins(_pool: address) -> (uint256, uint256): - """ - @notice Get the number of coins in a metapool - @param _pool Pool address - @return Number of wrapped coins, number of underlying coins - """ - base_pool: address = self.pool_data[_pool].base_pool - return 2, self.base_pool_data[base_pool].n_coins + 1 - - -@view -@external -def get_coins(_pool: address) -> address[MAX_PLAIN_COINS]: - """ - @notice Get the coins within a pool - @param _pool Pool address - @return List of coin addresses - """ - return self.pool_data[_pool].coins - - -@view -@external -def get_underlying_coins(_pool: address) -> address[MAX_COINS]: - """ - @notice Get the underlying coins within a pool - @dev Reverts if a pool does not exist or is not a metapool - @param _pool Pool address - @return List of coin addresses - """ - coins: address[MAX_COINS] = empty(address[MAX_COINS]) - base_pool: address = self.pool_data[_pool].base_pool - assert base_pool != ZERO_ADDRESS # dev: pool is not metapool - coins[0] = self.pool_data[_pool].coins[0] - for i in range(1, MAX_COINS): - coins[i] = self.base_pool_data[base_pool].coins[i - 1] - if coins[i] == ZERO_ADDRESS: - break - - return coins - - -@view -@external -def get_decimals(_pool: address) -> uint256[MAX_PLAIN_COINS]: - """ - @notice Get decimal places for each coin within a pool - @param _pool Pool address - @return uint256 list of decimals - """ - if self.pool_data[_pool].base_pool != ZERO_ADDRESS: - decimals: uint256[MAX_PLAIN_COINS] = empty(uint256[MAX_PLAIN_COINS]) - decimals = self.pool_data[_pool].decimals - decimals[1] = 18 - return decimals - return self.pool_data[_pool].decimals - - -@view -@external -def get_underlying_decimals(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get decimal places for each underlying coin within a pool - @param _pool Pool address - @return uint256 list of decimals - """ - # decimals are tightly packed as a series of uint8 within a little-endian bytes32 - # the packed value is stored as uint256 to simplify unpacking via shift and modulo - pool_decimals: uint256[MAX_PLAIN_COINS] = empty(uint256[MAX_PLAIN_COINS]) - pool_decimals = self.pool_data[_pool].decimals - decimals: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - decimals[0] = pool_decimals[0] - base_pool: address = self.pool_data[_pool].base_pool - packed_decimals: uint256 = self.base_pool_data[base_pool].decimals - for i in range(MAX_COINS): - unpacked: uint256 = shift(packed_decimals, -8 * i) % 256 - if unpacked == 0: - break - decimals[i+1] = unpacked - - return decimals - - -@view -@external -def get_metapool_rates(_pool: address) -> uint256[2]: - """ - @notice Get rates for coins within a metapool - @param _pool Pool address - @return Rates for each coin, precision normalized to 10**18 - """ - rates: uint256[2] = [10**18, 0] - rates[1] = CurvePool(self.pool_data[_pool].base_pool).get_virtual_price() - return rates - - -@view -@external -def get_balances(_pool: address) -> uint256[MAX_PLAIN_COINS]: - """ - @notice Get balances for each coin within a pool - @dev For pools using lending, these are the wrapped coin balances - @param _pool Pool address - @return uint256 list of balances - """ - if self.pool_data[_pool].base_pool != ZERO_ADDRESS: - return [CurvePool(_pool).balances(0), CurvePool(_pool).balances(1), 0, 0] - n_coins: uint256 = self.pool_data[_pool].n_coins - balances: uint256[MAX_PLAIN_COINS] = empty(uint256[MAX_PLAIN_COINS]) - for i in range(MAX_PLAIN_COINS): - if i < n_coins: - balances[i] = CurvePool(_pool).balances(i) - else: - balances[i] = 0 - return balances - - -@view -@external -def get_underlying_balances(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get balances for each underlying coin within a metapool - @param _pool Metapool address - @return uint256 list of underlying balances - """ - - underlying_balances: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - underlying_balances[0] = CurvePool(_pool).balances(0) - - base_total_supply: uint256 = ERC20(self.pool_data[_pool].coins[1]).totalSupply() - if base_total_supply > 0: - underlying_pct: uint256 = CurvePool(_pool).balances(1) * 10**36 / base_total_supply - base_pool: address = self.pool_data[_pool].base_pool - assert base_pool != ZERO_ADDRESS # dev: pool is not a metapool - n_coins: uint256 = self.base_pool_data[base_pool].n_coins - for i in range(MAX_COINS): - if i == n_coins: - break - underlying_balances[i + 1] = CurvePool(base_pool).balances(i) * underlying_pct / 10**36 - - return underlying_balances - - -@view -@external -def get_A(_pool: address) -> uint256: - """ - @notice Get the amplfication co-efficient for a pool - @param _pool Pool address - @return uint256 A - """ - return CurvePool(_pool).A() - - -@view -@external -def get_fees(_pool: address) -> (uint256, uint256): - """ - @notice Get the fees for a pool - @dev Fees are expressed as integers - @return Pool fee and admin fee as uint256 with 1e10 precision - """ - return CurvePool(_pool).fee(), CurvePool(_pool).admin_fee() - - -@view -@external -def get_admin_balances(_pool: address) -> uint256[MAX_PLAIN_COINS]: - """ - @notice Get the current admin balances (uncollected fees) for a pool - @param _pool Pool address - @return List of uint256 admin balances - """ - n_coins: uint256 = self.pool_data[_pool].n_coins - admin_balances: uint256[MAX_PLAIN_COINS] = empty(uint256[MAX_PLAIN_COINS]) - for i in range(MAX_PLAIN_COINS): - if i == n_coins: - break - admin_balances[i] = CurvePool(_pool).admin_balances(i) - return admin_balances - - -@view -@external -def get_coin_indices( - _pool: address, - _from: address, - _to: address -) -> (int128, int128, bool): - """ - @notice Convert coin addresses to indices for use with pool methods - @param _pool Pool address - @param _from Coin address to be used as `i` within a pool - @param _to Coin address to be used as `j` within a pool - @return int128 `i`, int128 `j`, boolean indicating if `i` and `j` are underlying coins - """ - coin: address = self.pool_data[_pool].coins[0] - base_pool: address = self.pool_data[_pool].base_pool - if coin in [_from, _to] and base_pool != ZERO_ADDRESS: - base_lp_token: address = self.pool_data[_pool].coins[1] - if base_lp_token in [_from, _to]: - # True and False convert to 1 and 0 - a bit of voodoo that - # works because we only ever have 2 non-underlying coins if base pool is ZERO_ADDRESS - return convert(_to == coin, int128), convert(_from == coin, int128), False - - found_market: bool = False - i: int128 = 0 - j: int128 = 0 - for x in range(MAX_COINS): - if base_pool == ZERO_ADDRESS: - if x >= MAX_PLAIN_COINS: - raise "No available market" - if x != 0: - coin = self.pool_data[_pool].coins[x] - else: - if x != 0: - coin = self.base_pool_data[base_pool].coins[x-1] - if coin == ZERO_ADDRESS: - raise "No available market" - if coin == _from: - i = x - elif coin == _to: - j = x - else: - continue - if found_market: - # the second time we find a match, break out of the loop - break - # the first time we find a match, set `found_market` to True - found_market = True - - return i, j, True - - -@view -@external -def get_gauge(_pool: address) -> address: - """ - @notice Get the address of the liquidity gauge contract for a factory pool - @dev Returns `ZERO_ADDRESS` if a gauge has not been deployed - @param _pool Pool address - @return Implementation contract address - """ - return self.pool_data[_pool].liquidity_gauge - - -@view -@external -def get_implementation_address(_pool: address) -> address: - """ - @notice Get the address of the implementation contract used for a factory pool - @param _pool Pool address - @return Implementation contract address - """ - return self.pool_data[_pool].implementation - - -@view -@external -def is_meta(_pool: address) -> bool: - """ - @notice Verify `_pool` is a metapool - @param _pool Pool address - @return True if `_pool` is a metapool - """ - return self.pool_data[_pool].base_pool != ZERO_ADDRESS - - -@view -@external -def get_pool_asset_type(_pool: address) -> uint256: - """ - @notice Query the asset type of `_pool` - @dev 0 = USD, 1 = ETH, 2 = BTC, 3 = Other - @param _pool Pool Address - @return Integer indicating the pool asset type - """ - base_pool: address = self.pool_data[_pool].base_pool - if base_pool == ZERO_ADDRESS: - return self.pool_data[_pool].asset_type - else: - return self.base_pool_data[base_pool].asset_type - - -@view -@external -def get_fee_receiver(_pool: address) -> address: - base_pool: address = self.pool_data[_pool].base_pool - if base_pool == ZERO_ADDRESS: - return self.fee_receiver - else: - return self.base_pool_data[base_pool].fee_receiver - - -# <--- Pool Deployers ---> - -@external -def deploy_plain_pool( - _name: String[32], - _symbol: String[10], - _coins: address[MAX_PLAIN_COINS], - _A: uint256, - _fee: uint256, - _asset_type: uint256 = 0, - _implementation_idx: uint256 = 0, -) -> address: - """ - @notice Deploy a new plain pool - @param _name Name of the new plain pool - @param _symbol Symbol for the new plain pool - will be - concatenated with factory symbol - @param _coins List of addresses of the coins being used in the pool. - @param _A Amplification co-efficient - a lower value here means - less tolerance for imbalance within the pool's assets. - Suggested values include: - * Uncollateralized algorithmic stablecoins: 5-10 - * Non-redeemable, collateralized assets: 100 - * Redeemable assets: 200-400 - @param _fee Trade fee, given as an integer with 1e10 precision. The - minimum fee is 0.04% (4000000), the maximum is 1% (100000000). - 50% of the fee is distributed to veCRV holders. - @param _asset_type Asset type for pool, as an integer - 0 = USD, 1 = ETH, 2 = BTC, 3 = Other - @param _implementation_idx Index of the implementation to use. All possible - implementations for a pool of N_COINS can be publicly accessed - via `plain_implementations(N_COINS)` - @return Address of the deployed pool - """ - # fee must be between 0.04% and 1% - assert _fee >= 4000000 and _fee <= 100000000, "Invalid fee" - - n_coins: uint256 = MAX_PLAIN_COINS - rate_multipliers: uint256[MAX_PLAIN_COINS] = empty(uint256[MAX_PLAIN_COINS]) - decimals: uint256[MAX_PLAIN_COINS] = empty(uint256[MAX_PLAIN_COINS]) - - for i in range(MAX_PLAIN_COINS): - coin: address = _coins[i] - if coin == ZERO_ADDRESS: - assert i > 1, "Insufficient coins" - n_coins = i - break - assert self.base_pool_assets[coin] == False, "Invalid asset, deploy a metapool" - - if _coins[i] == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE: - assert i == 0, "ETH must be first coin" - decimals[0] = 18 - else: - decimals[i] = ERC20(coin).decimals() - assert decimals[i] < 19, "Max 18 decimals for coins" - - rate_multipliers[i] = 10 ** (36 - decimals[i]) - - for x in range(i, i+MAX_PLAIN_COINS): - if x+1 == MAX_PLAIN_COINS: - break - if _coins[x+1] == ZERO_ADDRESS: - break - assert coin != _coins[x+1], "Duplicate coins" - - implementation: address = self.plain_implementations[n_coins][_implementation_idx] - assert implementation != ZERO_ADDRESS, "Invalid implementation index" - pool: address = create_forwarder_to(implementation) - CurvePlainPool(pool).initialize(_name, _symbol, _coins, rate_multipliers, _A, _fee) - - length: uint256 = self.pool_count - self.pool_list[length] = pool - self.pool_count = length + 1 - self.pool_data[pool].decimals = decimals - self.pool_data[pool].n_coins = n_coins - self.pool_data[pool].base_pool = ZERO_ADDRESS - self.pool_data[pool].implementation = implementation - if _asset_type != 0: - self.pool_data[pool].asset_type = _asset_type - - for i in range(MAX_PLAIN_COINS): - coin: address = _coins[i] - if coin == ZERO_ADDRESS: - break - self.pool_data[pool].coins[i] = coin - raw_call( - coin, - concat( - method_id("approve(address,uint256)"), - convert(pool, bytes32), - convert(MAX_UINT256, bytes32) - ) - ) - for j in range(MAX_PLAIN_COINS): - if i < j: - swappable_coin: address = _coins[j] - key: uint256 = bitwise_xor(convert(coin, uint256), convert(swappable_coin, uint256)) - length = self.market_counts[key] - self.markets[key][length] = pool - self.market_counts[key] = length + 1 - - log PlainPoolDeployed(_coins, _A, _fee, msg.sender) - return pool - - -@external -def deploy_metapool( - _base_pool: address, - _name: String[32], - _symbol: String[10], - _coin: address, - _A: uint256, - _fee: uint256, - _implementation_idx: uint256 = 0, -) -> address: - """ - @notice Deploy a new metapool - @param _base_pool Address of the base pool to use - within the metapool - @param _name Name of the new metapool - @param _symbol Symbol for the new metapool - will be - concatenated with the base pool symbol - @param _coin Address of the coin being used in the metapool - @param _A Amplification co-efficient - a higher value here means - less tolerance for imbalance within the pool's assets. - Suggested values include: - * Uncollateralized algorithmic stablecoins: 5-10 - * Non-redeemable, collateralized assets: 100 - * Redeemable assets: 200-400 - @param _fee Trade fee, given as an integer with 1e10 precision. The - minimum fee is 0.04% (4000000), the maximum is 1% (100000000). - 50% of the fee is distributed to veCRV holders. - @param _implementation_idx Index of the implementation to use. All possible - implementations for a BASE_POOL can be publicly accessed - via `metapool_implementations(BASE_POOL)` - @return Address of the deployed pool - """ - # fee must be between 0.04% and 1% - assert _fee >= 4000000 and _fee <= 100000000, "Invalid fee" - - implementation: address = self.base_pool_data[_base_pool].implementations[_implementation_idx] - assert implementation != ZERO_ADDRESS, "Invalid implementation index" - - # things break if a token has >18 decimals - decimals: uint256 = ERC20(_coin).decimals() - assert decimals < 19, "Max 18 decimals for coins" - - pool: address = create_forwarder_to(implementation) - CurvePool(pool).initialize(_name, _symbol, _coin, 10 ** (36 - decimals), _A, _fee) - ERC20(_coin).approve(pool, MAX_UINT256) - - # add pool to pool_list - length: uint256 = self.pool_count - self.pool_list[length] = pool - self.pool_count = length + 1 - - base_lp_token: address = self.base_pool_data[_base_pool].lp_token - - self.pool_data[pool].decimals = [decimals, 0, 0, 0] - self.pool_data[pool].n_coins = 2 - self.pool_data[pool].base_pool = _base_pool - self.pool_data[pool].coins[0] = _coin - self.pool_data[pool].coins[1] = self.base_pool_data[_base_pool].lp_token - self.pool_data[pool].implementation = implementation - - is_finished: bool = False - for i in range(MAX_COINS): - swappable_coin: address = self.base_pool_data[_base_pool].coins[i] - if swappable_coin == ZERO_ADDRESS: - is_finished = True - swappable_coin = base_lp_token - - key: uint256 = bitwise_xor(convert(_coin, uint256), convert(swappable_coin, uint256)) - length = self.market_counts[key] - self.markets[key][length] = pool - self.market_counts[key] = length + 1 - if is_finished: - break - - log MetaPoolDeployed(_coin, _base_pool, _A, _fee, msg.sender) - return pool - - -@external -def deploy_gauge(_pool: address) -> address: - """ - @notice Deploy a liquidity gauge for a factory pool - @param _pool Factory pool address to deploy a gauge for - @return Address of the deployed gauge - """ - assert self.pool_data[_pool].coins[0] != ZERO_ADDRESS, "Unknown pool" - assert self.pool_data[_pool].liquidity_gauge == ZERO_ADDRESS, "Gauge already deployed" - implementation: address = self.gauge_implementation - assert implementation != ZERO_ADDRESS, "Gauge implementation not set" - - gauge: address = create_forwarder_to(implementation) - LiquidityGauge(gauge).initialize(_pool) - self.pool_data[_pool].liquidity_gauge = gauge - - log LiquidityGaugeDeployed(_pool, gauge) - return gauge - - -# <--- Admin / Guarded Functionality ---> - -@external -def add_base_pool( - _base_pool: address, - _fee_receiver: address, - _asset_type: uint256, - _implementations: address[10], -): - """ - @notice Add a base pool to the registry, which may be used in factory metapools - @dev Only callable by admin - @param _base_pool Pool address to add - @param _fee_receiver Admin fee receiver address for metapools using this base pool - @param _asset_type Asset type for pool, as an integer 0 = USD, 1 = ETH, 2 = BTC, 3 = Other - @param _implementations List of implementation addresses that can be used with this base pool - """ - assert msg.sender == self.admin # dev: admin-only function - assert self.base_pool_data[_base_pool].coins[0] == ZERO_ADDRESS # dev: pool exists - - registry: address = AddressProvider(ADDRESS_PROVIDER).get_registry() - n_coins: uint256 = Registry(registry).get_n_coins(_base_pool) - - # add pool to pool_list - length: uint256 = self.base_pool_count - self.base_pool_list[length] = _base_pool - self.base_pool_count = length + 1 - self.base_pool_data[_base_pool].lp_token = Registry(registry).get_lp_token(_base_pool) - self.base_pool_data[_base_pool].n_coins = n_coins - self.base_pool_data[_base_pool].fee_receiver = _fee_receiver - if _asset_type != 0: - self.base_pool_data[_base_pool].asset_type = _asset_type - - for i in range(10): - implementation: address = _implementations[i] - if implementation == ZERO_ADDRESS: - break - self.base_pool_data[_base_pool].implementations[i] = implementation - - decimals: uint256 = 0 - coins: address[MAX_COINS] = Registry(registry).get_coins(_base_pool) - for i in range(MAX_COINS): - if i == n_coins: - break - coin: address = coins[i] - self.base_pool_data[_base_pool].coins[i] = coin - self.base_pool_assets[coin] = True - decimals += shift(ERC20(coin).decimals(), convert(i*8, int128)) - self.base_pool_data[_base_pool].decimals = decimals - - log BasePoolAdded(_base_pool) - - -@external -def set_metapool_implementations( - _base_pool: address, - _implementations: address[10], -): - """ - @notice Set implementation contracts for a metapool - @dev Only callable by admin - @param _base_pool Pool address to add - @param _implementations Implementation address to use when deploying metapools - """ - assert msg.sender == self.admin # dev: admin-only function - assert self.base_pool_data[_base_pool].coins[0] != ZERO_ADDRESS # dev: base pool does not exist - - for i in range(10): - new_imp: address = _implementations[i] - current_imp: address = self.base_pool_data[_base_pool].implementations[i] - if new_imp == current_imp: - if new_imp == ZERO_ADDRESS: - break - else: - self.base_pool_data[_base_pool].implementations[i] = new_imp - - -@external -def set_plain_implementations( - _n_coins: uint256, - _implementations: address[10], -): - assert msg.sender == self.admin # dev: admin-only function - - for i in range(10): - new_imp: address = _implementations[i] - current_imp: address = self.plain_implementations[_n_coins][i] - if new_imp == current_imp: - if new_imp == ZERO_ADDRESS: - break - else: - self.plain_implementations[_n_coins][i] = new_imp - - -@external -def set_gauge_implementation(_gauge_implementation: address): - assert msg.sender == self.admin # dev: admin-only function - - self.gauge_implementation = _gauge_implementation - - -@external -def batch_set_pool_asset_type(_pools: address[32], _asset_types: uint256[32]): - """ - @notice Batch set the asset type for factory pools - @dev Used to modify asset types that were set incorrectly at deployment - """ - assert msg.sender in [self.manager, self.admin] # dev: admin-only function - - for i in range(32): - if _pools[i] == ZERO_ADDRESS: - break - self.pool_data[_pools[i]].asset_type = _asset_types[i] - - -@external -def commit_transfer_ownership(_addr: address): - """ - @notice Transfer ownership of this contract to `addr` - @param _addr Address of the new owner - """ - assert msg.sender == self.admin # dev: admin only - - self.future_admin = _addr - - -@external -def accept_transfer_ownership(): - """ - @notice Accept a pending ownership transfer - @dev Only callable by the new owner - """ - _admin: address = self.future_admin - assert msg.sender == _admin # dev: future admin only - - self.admin = _admin - self.future_admin = ZERO_ADDRESS - - -@external -def set_manager(_manager: address): - """ - @notice Set the manager - @dev Callable by the admin or existing manager - @param _manager Manager address - """ - assert msg.sender in [self.manager, self.admin] # dev: admin-only function - - self.manager = _manager - - -@external -def set_fee_receiver(_base_pool: address, _fee_receiver: address): - """ - @notice Set fee receiver for base and plain pools - @param _base_pool Address of base pool to set fee receiver for. - For plain pools, leave as `ZERO_ADDRESS`. - @param _fee_receiver Address that fees are sent to - """ - assert msg.sender == self.admin # dev: admin only - if _base_pool == ZERO_ADDRESS: - self.fee_receiver = _fee_receiver - else: - self.base_pool_data[_base_pool].fee_receiver = _fee_receiver - - -@external -def convert_metapool_fees() -> bool: - """ - @notice Convert the fees of a metapool and transfer to - the metapool's fee receiver - @dev All fees are converted to LP token of base pool - """ - base_pool: address = self.pool_data[msg.sender].base_pool - assert base_pool != ZERO_ADDRESS # dev: sender must be metapool - coin: address = self.pool_data[msg.sender].coins[0] - - amount: uint256 = ERC20(coin).balanceOf(self) - receiver: address = self.base_pool_data[base_pool].fee_receiver - - CurvePool(msg.sender).exchange(0, 1, amount, 0, receiver) - return True - - -# <--- Pool Migration ---> - -@external -def add_existing_metapools(_pools: address[10]) -> bool: - """ - @notice Add existing metapools from the old factory - @dev Base pools that are used by the pools to be added must - be added separately with `add_base_pool` - @param _pools Addresses of existing pools to add - """ - - length: uint256 = self.pool_count - for pool in _pools: - if pool == ZERO_ADDRESS: - break - - assert self.pool_data[pool].coins[0] == ZERO_ADDRESS # dev: pool already exists - - coins: address[2] = OldFactory(OLD_FACTORY).get_coins(pool) - assert coins[0] != ZERO_ADDRESS # dev: pool not in old factory - - # add pool to pool list - self.pool_list[length] = pool - length += 1 - - base_pool: address = ZERO_ADDRESS - implementation: address = ZERO_ADDRESS - - if coins[1] == 0x6c3F90f043a72FA612cbac8115EE7e52BDe6E490: - # 3pool - base_pool = 0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7 - implementation = 0x5F890841f657d90E081bAbdB532A05996Af79Fe6 - elif coins[1] == 0x075b1bb99792c9E1041bA13afEf80C91a1e70fB3: - # sbtc - base_pool = 0x7fC77b5c7614E1533320Ea6DDc2Eb61fa00A9714 - implementation = 0x2f956eEe002B0dEbD468CF2E0490d1aEc65e027F - self.pool_data[pool].asset_type = 2 - else: - raise - - # update pool data - self.pool_data[pool].decimals[0] = ERC20(coins[0]).decimals() - self.pool_data[pool].base_pool = base_pool - meta_coin: address = CurveFactoryMetapool(pool).coins(0) - self.pool_data[pool].coins[0] = coins[0] - self.pool_data[pool].coins[1] = coins[1] - self.pool_data[pool].implementation = implementation - - base_pool_coins: address[MAX_COINS] = self.base_pool_data[base_pool].coins - assert base_pool_coins[0] != ZERO_ADDRESS # dev: unknown base pool - - is_finished: bool = False - for i in range(MAX_COINS): - swappable_coin: address = base_pool_coins[i] - if swappable_coin == ZERO_ADDRESS: - is_finished = True - swappable_coin = coins[1] - - key: uint256 = bitwise_xor(convert(meta_coin, uint256), convert(swappable_coin, uint256)) - market_idx: uint256 = self.market_counts[key] - self.markets[key][market_idx] = pool - self.market_counts[key] = market_idx + 1 - if is_finished: - break - - self.pool_count = length - return True diff --git a/contracts/mainnet/mocks/StableRegistry.vy b/contracts/mainnet/mocks/StableRegistry.vy deleted file mode 100644 index 91e5b98..0000000 --- a/contracts/mainnet/mocks/StableRegistry.vy +++ /dev/null @@ -1,1245 +0,0 @@ -# @version 0.2.11 -""" -@title Curve Registry -@license MIT -@author Curve.Fi -""" - -MAX_COINS: constant(int128) = 8 -CALC_INPUT_SIZE: constant(int128) = 100 - - -struct CoinInfo: - index: uint256 - register_count: uint256 - swap_count: uint256 - swap_for: address[MAX_INT128] - -struct PoolArray: - location: uint256 - decimals: uint256 - underlying_decimals: uint256 - rate_info: bytes32 - base_pool: address - coins: address[MAX_COINS] - ul_coins: address[MAX_COINS] - n_coins: uint256 # [coins, underlying coins] tightly packed as uint128[2] - has_initial_A: bool - is_v1: bool - name: String[64] - asset_type: uint256 - -struct PoolParams: - A: uint256 - future_A: uint256 - fee: uint256 - admin_fee: uint256 - future_fee: uint256 - future_admin_fee: uint256 - future_owner: address - initial_A: uint256 - initial_A_time: uint256 - future_A_time: uint256 - - -interface AddressProvider: - def admin() -> address: view - def get_address(_id: uint256) -> address: view - -interface ERC20: - def balanceOf(_addr: address) -> uint256: view - def decimals() -> uint256: view - def totalSupply() -> uint256: view - -interface CurvePool: - def A() -> uint256: view - def future_A() -> uint256: view - def fee() -> uint256: view - def admin_fee() -> uint256: view - def future_fee() -> uint256: view - def future_admin_fee() -> uint256: view - def future_owner() -> address: view - def initial_A() -> uint256: view - def initial_A_time() -> uint256: view - def future_A_time() -> uint256: view - def coins(i: uint256) -> address: view - def underlying_coins(i: uint256) -> address: view - def balances(i: uint256) -> uint256: view - def get_virtual_price() -> uint256: view - -interface CurvePoolV1: - def coins(i: int128) -> address: view - def underlying_coins(i: int128) -> address: view - def balances(i: int128) -> uint256: view - -interface CurveMetapool: - def base_pool() -> address: view - -interface GasEstimator: - def estimate_gas_used(_pool: address, _from: address, _to: address) -> uint256: view - -interface LiquidityGauge: - def lp_token() -> address: view - -interface GaugeController: - def gauge_types(gauge: address) -> int128: view - -interface RateCalc: - def get_rate(_coin: address) -> uint256: view - - -event PoolAdded: - pool: indexed(address) - rate_method_id: Bytes[4] - -event PoolRemoved: - pool: indexed(address) - - -address_provider: public(AddressProvider) -gauge_controller: public(address) -pool_list: public(address[65536]) # master list of pools -pool_count: public(uint256) # actual length of pool_list - -pool_data: HashMap[address, PoolArray] - -coin_count: public(uint256) # total unique coins registered -coins: HashMap[address, CoinInfo] -get_coin: public(address[65536]) # unique list of registered coins -# bitwise_xor(coina, coinb) -> (coina_pos, coinb_pos) sorted -# stored as uint128[2] -coin_swap_indexes: HashMap[uint256, uint256] - -# lp token -> pool -get_pool_from_lp_token: public(HashMap[address, address]) - -# pool -> lp token -get_lp_token: public(HashMap[address, address]) - -# mapping of estimated gas costs for pools and coins -# for a pool the values are [wrapped exchange, underlying exchange] -# for a coin the values are [transfer cost, 0] -gas_estimate_values: HashMap[address, uint256[2]] - -# pool -> gas estimation contract -# used when gas costs for a pool are too complex to be handled by summing -# values in `gas_estimate_values` -gas_estimate_contracts: HashMap[address, address] - -# mapping of coins -> pools for trading -# a mapping key is generated for each pair of addresses via -# `bitwise_xor(convert(a, uint256), convert(b, uint256))` -markets: HashMap[uint256, address[65536]] -market_counts: HashMap[uint256, uint256] - -liquidity_gauges: HashMap[address, address[10]] - -last_updated: public(uint256) - - -@external -def __init__(_address_provider: address, _gauge_controller: address): - """ - @notice Constructor function - """ - self.address_provider = AddressProvider(_address_provider) - self.gauge_controller = _gauge_controller - - -# internal functionality for getters - -@view -@internal -def _unpack_decimals(_packed: uint256, _n_coins: uint256) -> uint256[MAX_COINS]: - # decimals are tightly packed as a series of uint8 within a little-endian bytes32 - # the packed value is stored as uint256 to simplify unpacking via shift and modulo - decimals: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - n_coins: int128 = convert(_n_coins, int128) - for i in range(MAX_COINS): - if i == n_coins: - break - decimals[i] = shift(_packed, -8 * i) % 256 - - return decimals - - -@view -@internal -def _get_rates(_pool: address) -> uint256[MAX_COINS]: - rates: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - base_pool: address = self.pool_data[_pool].base_pool - if base_pool == ZERO_ADDRESS: - rate_info: bytes32 = self.pool_data[_pool].rate_info - rate_calc_addr: uint256 = convert(slice(rate_info, 8, 20), uint256) - rate_method_id: Bytes[4] = slice(rate_info, 28, 4) - - for i in range(MAX_COINS): - coin: address = self.pool_data[_pool].coins[i] - if coin == ZERO_ADDRESS: - break - if rate_info == EMPTY_BYTES32 or coin == self.pool_data[_pool].ul_coins[i]: - rates[i] = 10 ** 18 - elif rate_calc_addr != 0: - rates[i] = RateCalc(convert(rate_calc_addr, address)).get_rate(coin) - else: - rates[i] = convert( - raw_call(coin, rate_method_id, max_outsize=32, is_static_call=True), # dev: bad response - uint256 - ) - else: - base_coin_idx: uint256 = shift(self.pool_data[_pool].n_coins, -128) - 1 - rates[base_coin_idx] = CurvePool(base_pool).get_virtual_price() - for i in range(MAX_COINS): - if i == base_coin_idx: - break - rates[i] = 10 ** 18 - - return rates - -@view -@internal -def _get_balances(_pool: address) -> uint256[MAX_COINS]: - is_v1: bool = self.pool_data[_pool].is_v1 - - balances: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - for i in range(MAX_COINS): - if self.pool_data[_pool].coins[i] == ZERO_ADDRESS: - assert i != 0 - break - - if is_v1: - balances[i] = CurvePoolV1(_pool).balances(i) - else: - balances[i] = CurvePool(_pool).balances(convert(i, uint256)) - - return balances - - -@view -@internal -def _get_underlying_balances(_pool: address) -> uint256[MAX_COINS]: - balances: uint256[MAX_COINS] = self._get_balances(_pool) - rates: uint256[MAX_COINS] = self._get_rates(_pool) - decimals: uint256 = self.pool_data[_pool].underlying_decimals - underlying_balances: uint256[MAX_COINS] = balances - for i in range(MAX_COINS): - coin: address = self.pool_data[_pool].coins[i] - if coin == ZERO_ADDRESS: - break - ucoin: address = self.pool_data[_pool].ul_coins[i] - if ucoin == ZERO_ADDRESS: - continue - if ucoin != coin: - underlying_balances[i] = balances[i] * rates[i] / 10**(shift(decimals, -8 * i) % 256) - - return underlying_balances - - -@view -@internal -def _get_meta_underlying_balances(_pool: address, _base_pool: address) -> uint256[MAX_COINS]: - base_coin_idx: uint256 = shift(self.pool_data[_pool].n_coins, -128) - 1 - is_v1: bool = self.pool_data[_base_pool].is_v1 - base_total_supply: uint256 = ERC20(self.get_lp_token[_base_pool]).totalSupply() - - underlying_balances: uint256[MAX_COINS] = empty(uint256[MAX_COINS]) - ul_balance: uint256 = 0 - underlying_pct: uint256 = 0 - if base_total_supply > 0: - underlying_pct = CurvePool(_pool).balances(base_coin_idx) * 10**36 / base_total_supply - - for i in range(MAX_COINS): - if self.pool_data[_pool].ul_coins[i] == ZERO_ADDRESS: - break - if i < base_coin_idx: - ul_balance = CurvePool(_pool).balances(i) - else: - if is_v1: - ul_balance = CurvePoolV1(_base_pool).balances(convert(i - base_coin_idx, int128)) - else: - ul_balance = CurvePool(_base_pool).balances(i-base_coin_idx) - ul_balance = ul_balance * underlying_pct / 10**36 - underlying_balances[i] = ul_balance - - return underlying_balances - - -@view -@internal -def _get_coin_indices( - _pool: address, - _from: address, - _to: address -) -> uint256[3]: - """ - Convert coin addresses to indices for use with pool methods. - """ - # the return value is stored as `uint256[3]` to reduce gas costs - # from index, to index, is the market underlying? - result: uint256[3] = empty(uint256[3]) - - found_market: bool = False - - # check coin markets - for x in range(MAX_COINS): - coin: address = self.pool_data[_pool].coins[x] - if coin == ZERO_ADDRESS: - # if we reach the end of the coins, reset `found_market` and try again - # with the underlying coins - found_market = False - break - if coin == _from: - result[0] = x - elif coin == _to: - result[1] = x - else: - continue - - if found_market: - # the second time we find a match, break out of the loop - break - # the first time we find a match, set `found_market` to True - found_market = True - - if not found_market: - # check underlying coin markets - for x in range(MAX_COINS): - coin: address = self.pool_data[_pool].ul_coins[x] - if coin == ZERO_ADDRESS: - raise "No available market" - if coin == _from: - result[0] = x - elif coin == _to: - result[1] = x - else: - continue - - if found_market: - result[2] = 1 - break - found_market = True - - return result - - -# targetted external getters, optimized for on-chain calls - -@view -@external -def find_pool_for_coins(_from: address, _to: address, i: uint256 = 0) -> address: - """ - @notice Find an available pool for exchanging two coins - @param _from Address of coin to be sent - @param _to Address of coin to be received - @param i Index value. When multiple pools are available - this value is used to return the n'th address. - @return Pool address - """ - key: uint256 = bitwise_xor(convert(_from, uint256), convert(_to, uint256)) - return self.markets[key][i] - - -@view -@external -def get_n_coins(_pool: address) -> uint256[2]: - """ - @notice Get the number of coins in a pool - @dev For non-metapools, both returned values are identical - even when the pool does not use wrapping/lending - @param _pool Pool address - @return Number of wrapped coins, number of underlying coins - """ - n_coins: uint256 = self.pool_data[_pool].n_coins - return [shift(n_coins, -128), n_coins % 2**128] - - -@view -@external -def get_coins(_pool: address) -> address[MAX_COINS]: - """ - @notice Get the coins within a pool - @dev For pools using lending, these are the wrapped coin addresses - @param _pool Pool address - @return List of coin addresses - """ - coins: address[MAX_COINS] = empty(address[MAX_COINS]) - n_coins: uint256 = shift(self.pool_data[_pool].n_coins, -128) - for i in range(MAX_COINS): - if i == n_coins: - break - coins[i] = self.pool_data[_pool].coins[i] - - return coins - - -@view -@external -def get_underlying_coins(_pool: address) -> address[MAX_COINS]: - """ - @notice Get the underlying coins within a pool - @dev For pools that do not lend, returns the same value as `get_coins` - @param _pool Pool address - @return List of coin addresses - """ - coins: address[MAX_COINS] = empty(address[MAX_COINS]) - n_coins: uint256 = self.pool_data[_pool].n_coins % 2**128 - for i in range(MAX_COINS): - if i == n_coins: - break - coins[i] = self.pool_data[_pool].ul_coins[i] - - return coins - - -@view -@external -def get_decimals(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get decimal places for each coin within a pool - @dev For pools using lending, these are the wrapped coin decimal places - @param _pool Pool address - @return uint256 list of decimals - """ - n_coins: uint256 = shift(self.pool_data[_pool].n_coins, -128) - return self._unpack_decimals(self.pool_data[_pool].decimals, n_coins) - - -@view -@external -def get_underlying_decimals(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get decimal places for each underlying coin within a pool - @dev For pools that do not lend, returns the same value as `get_decimals` - @param _pool Pool address - @return uint256 list of decimals - """ - n_coins: uint256 = self.pool_data[_pool].n_coins % 2**128 - return self._unpack_decimals(self.pool_data[_pool].underlying_decimals, n_coins) - - -@view -@external -def get_rates(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get rates between coins and underlying coins - @dev For coins where there is no underlying coin, or where - the underlying coin cannot be swapped, the rate is - given as 1e18 - @param _pool Pool address - @return Rates between coins and underlying coins - """ - return self._get_rates(_pool) - - -@view -@external -def get_gauges(_pool: address) -> (address[10], int128[10]): - """ - @notice Get a list of LiquidityGauge contracts associated with a pool - @param _pool Pool address - @return address[10] of gauge addresses, int128[10] of gauge types - """ - liquidity_gauges: address[10] = empty(address[10]) - gauge_types: int128[10] = empty(int128[10]) - gauge_controller: address = self.gauge_controller - for i in range(10): - gauge: address = self.liquidity_gauges[_pool][i] - if gauge == ZERO_ADDRESS: - break - liquidity_gauges[i] = gauge - gauge_types[i] = GaugeController(gauge_controller).gauge_types(gauge) - - return liquidity_gauges, gauge_types - - -@view -@external -def get_balances(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get balances for each coin within a pool - @dev For pools using lending, these are the wrapped coin balances - @param _pool Pool address - @return uint256 list of balances - """ - return self._get_balances(_pool) - - -@view -@external -def get_underlying_balances(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get balances for each underlying coin within a pool - @dev For pools that do not lend, returns the same value as `get_balances` - @param _pool Pool address - @return uint256 list of underlyingbalances - """ - base_pool: address = self.pool_data[_pool].base_pool - if base_pool == ZERO_ADDRESS: - return self._get_underlying_balances(_pool) - return self._get_meta_underlying_balances(_pool, base_pool) - - -@view -@external -def get_virtual_price_from_lp_token(_token: address) -> uint256: - """ - @notice Get the virtual price of a pool LP token - @param _token LP token address - @return uint256 Virtual price - """ - return CurvePool(self.get_pool_from_lp_token[_token]).get_virtual_price() - - -@view -@external -def get_A(_pool: address) -> uint256: - return CurvePool(_pool).A() - - -@view -@external -def get_parameters(_pool: address) -> PoolParams: - """ - @notice Get parameters for a pool - @dev For older pools where `initial_A` is not public, this value is set to 0 - @param _pool Pool address - @return Pool amp, future amp, fee, admin fee, future fee, future admin fee, - future owner, initial amp, initial amp time, future amp time - """ - pool_params: PoolParams = empty(PoolParams) - pool_params.A = CurvePool(_pool).A() - pool_params.future_A = CurvePool(_pool).future_A() - pool_params.fee = CurvePool(_pool).fee() - pool_params.future_fee = CurvePool(_pool).future_fee() - pool_params.admin_fee = CurvePool(_pool).admin_fee() - pool_params.future_admin_fee = CurvePool(_pool).future_admin_fee() - pool_params.future_owner = CurvePool(_pool).future_owner() - - if self.pool_data[_pool].has_initial_A: - pool_params.initial_A = CurvePool(_pool).initial_A() - pool_params.initial_A_time = CurvePool(_pool).initial_A_time() - pool_params.future_A_time = CurvePool(_pool).future_A_time() - - return pool_params - - -@view -@external -def get_fees(_pool: address) -> uint256[2]: - """ - @notice Get the fees for a pool - @dev Fees are expressed as integers - @return Pool fee as uint256 with 1e10 precision - Admin fee as 1e10 percentage of pool fee - """ - return [CurvePool(_pool).fee(), CurvePool(_pool).admin_fee()] - - -@view -@external -def get_admin_balances(_pool: address) -> uint256[MAX_COINS]: - """ - @notice Get the current admin balances (uncollected fees) for a pool - @param _pool Pool address - @return List of uint256 admin balances - """ - balances: uint256[MAX_COINS] = self._get_balances(_pool) - n_coins: uint256 = shift(self.pool_data[_pool].n_coins, -128) - for i in range(MAX_COINS): - coin: address = self.pool_data[_pool].coins[i] - if i == n_coins: - break - if coin == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE: - balances[i] = _pool.balance - balances[i] - else: - balances[i] = ERC20(coin).balanceOf(_pool) - balances[i] - - return balances - - -@view -@external -def get_coin_indices( - _pool: address, - _from: address, - _to: address -) -> (int128, int128, bool): - """ - @notice Convert coin addresses to indices for use with pool methods - @param _from Coin address to be used as `i` within a pool - @param _to Coin address to be used as `j` within a pool - @return int128 `i`, int128 `j`, boolean indicating if `i` and `j` are underlying coins - """ - result: uint256[3] = self._get_coin_indices(_pool, _from, _to) - return convert(result[0], int128), convert(result[1], int128), result[2] > 0 - - -@view -@external -def estimate_gas_used(_pool: address, _from: address, _to: address) -> uint256: - """ - @notice Estimate the gas used in an exchange. - @param _pool Pool address - @param _from Address of coin to be sent - @param _to Address of coin to be received - @return Upper-bound gas estimate, in wei - """ - estimator: address = self.gas_estimate_contracts[_pool] - if estimator != ZERO_ADDRESS: - return GasEstimator(estimator).estimate_gas_used(_pool, _from, _to) - - # here we call `_get_coin_indices` to find out if the exchange involves wrapped - # or underlying coins, and use the result as an index in `gas_estimate_values` - # 0 == wrapped 1 == underlying - idx_underlying: uint256 = self._get_coin_indices(_pool, _from, _to)[2] - - total: uint256 = self.gas_estimate_values[_pool][idx_underlying] - assert total != 0 # dev: pool value not set - - for addr in [_from, _to]: - _gas: uint256 = self.gas_estimate_values[addr][0] - assert _gas != 0 # dev: coin value not set - total += _gas - - return total - -@view -@external -def is_meta(_pool: address) -> bool: - """ - @notice Verify `_pool` is a metapool - @param _pool Pool address - @return True if `_pool` is a metapool - """ - return self.pool_data[_pool].base_pool != ZERO_ADDRESS - - -@view -@external -def get_pool_name(_pool: address) -> String[64]: - """ - @notice Get the given name for a pool - @param _pool Pool address - @return The name of a pool - """ - return self.pool_data[_pool].name - - -@view -@external -def get_coin_swap_count(_coin: address) -> uint256: - """ - @notice Get the number of unique coins available to swap `_coin` against - @param _coin Coin address - @return The number of unique coins available to swap for - """ - return self.coins[_coin].swap_count - - -@view -@external -def get_coin_swap_complement(_coin: address, _index: uint256) -> address: - """ - @notice Get the coin available to swap against `_coin` at `_index` - @param _coin Coin address - @param _index An index in the `_coin`'s set of available counter - coin's - @return Address of a coin available to swap against `_coin` - """ - return self.coins[_coin].swap_for[_index] - - -@view -@external -def get_pool_asset_type(_pool: address) -> uint256: - """ - @notice Query the asset type of `_pool` - @param _pool Pool Address - @return The asset type as an unstripped string - """ - return self.pool_data[_pool].asset_type - - -# internal functionality used in admin setters - -@internal -def _add_pool( - _sender: address, - _pool: address, - _n_coins: uint256, - _lp_token: address, - _rate_info: bytes32, - _has_initial_A: bool, - _is_v1: bool, - _name: String[64], -): - assert _sender == self.address_provider.admin() # dev: admin-only function - assert _lp_token != ZERO_ADDRESS - assert self.pool_data[_pool].coins[0] == ZERO_ADDRESS # dev: pool exists - assert self.get_pool_from_lp_token[_lp_token] == ZERO_ADDRESS - - # add pool to pool_list - length: uint256 = self.pool_count - self.pool_list[length] = _pool - self.pool_count = length + 1 - self.pool_data[_pool].location = length - self.pool_data[_pool].rate_info = _rate_info - self.pool_data[_pool].has_initial_A = _has_initial_A - self.pool_data[_pool].is_v1 = _is_v1 - self.pool_data[_pool].n_coins = _n_coins - self.pool_data[_pool].name = _name - - # update public mappings - self.get_pool_from_lp_token[_lp_token] = _pool - self.get_lp_token[_pool] = _lp_token - self.last_updated = block.timestamp - - log PoolAdded(_pool, slice(_rate_info, 28, 4)) - - -@internal -def _register_coin(_coin: address): - if self.coins[_coin].register_count == 0: - coin_count: uint256 = self.coin_count - self.coins[_coin].index = coin_count - self.get_coin[coin_count] = _coin - self.coin_count += 1 - self.coins[_coin].register_count += 1 - - -@internal -def _register_coin_pair(_coina: address, _coinb: address, _key: uint256): - # register _coinb in _coina's array of coins - coin_b_pos: uint256 = self.coins[_coina].swap_count - self.coins[_coina].swap_for[coin_b_pos] = _coinb - self.coins[_coina].swap_count += 1 - # register _coina in _coinb's array of coins - coin_a_pos: uint256 = self.coins[_coinb].swap_count - self.coins[_coinb].swap_for[coin_a_pos] = _coina - self.coins[_coinb].swap_count += 1 - # register indexes (coina pos in coinb array, coinb pos in coina array) - if convert(_coina, uint256) < convert(_coinb, uint256): - self.coin_swap_indexes[_key] = shift(coin_a_pos, 128) + coin_b_pos - else: - self.coin_swap_indexes[_key] = shift(coin_b_pos, 128) + coin_a_pos - - -@internal -def _unregister_coin(_coin: address): - self.coins[_coin].register_count -= 1 - - if self.coins[_coin].register_count == 0: - self.coin_count -= 1 - coin_count: uint256 = self.coin_count - location: uint256 = self.coins[_coin].index - - if location < coin_count: - coin_b: address = self.get_coin[coin_count] - self.get_coin[location] = coin_b - self.coins[coin_b].index = location - - self.coins[_coin].index = 0 - self.get_coin[coin_count] = ZERO_ADDRESS - - -@internal -def _unregister_coin_pair(_coina: address, _coinb: address, _coinb_idx: uint256): - """ - @param _coinb_idx the index of _coinb in _coina's array of unique coin's - """ - # decrement swap counts for both coins - self.coins[_coina].swap_count -= 1 - - # retrieve the last currently occupied index in coina's array - coina_arr_last_idx: uint256 = self.coins[_coina].swap_count - - # if coinb's index in coina's array is less than the last - # overwrite it's position with the last coin - if _coinb_idx < coina_arr_last_idx: - # here's our last coin in coina's array - coin_c: address = self.coins[_coina].swap_for[coina_arr_last_idx] - # get the bitwise_xor of the pair to retrieve their indexes - key: uint256 = bitwise_xor(convert(_coina, uint256), convert(coin_c, uint256)) - indexes: uint256 = self.coin_swap_indexes[key] - - # update the pairing's indexes - if convert(_coina, uint256) < convert(coin_c, uint256): - # least complicated most readable way of shifting twice to remove the lower order bits - self.coin_swap_indexes[key] = shift(shift(indexes, -128), 128) + _coinb_idx - else: - self.coin_swap_indexes[key] = shift(_coinb_idx, 128) + indexes % 2 ** 128 - # set _coinb_idx in coina's array to coin_c - self.coins[_coina].swap_for[_coinb_idx] = coin_c - - self.coins[_coina].swap_for[coina_arr_last_idx] = ZERO_ADDRESS - - -@internal -def _get_new_pool_coins( - _pool: address, - _n_coins: uint256, - _is_underlying: bool, - _is_v1: bool -) -> address[MAX_COINS]: - coin_list: address[MAX_COINS] = empty(address[MAX_COINS]) - coin: address = ZERO_ADDRESS - for i in range(MAX_COINS): - if i == _n_coins: - break - if _is_underlying: - if _is_v1: - coin = CurvePoolV1(_pool).underlying_coins(convert(i, int128)) - else: - coin = CurvePool(_pool).underlying_coins(i) - self.pool_data[_pool].ul_coins[i] = coin - else: - if _is_v1: - coin = CurvePoolV1(_pool).coins(convert(i, int128)) - else: - coin = CurvePool(_pool).coins(i) - self.pool_data[_pool].coins[i] = coin - coin_list[i] = coin - - for i in range(MAX_COINS): - if i == _n_coins: - break - - self._register_coin(coin_list[i]) - # add pool to markets - i2: uint256 = i + 1 - for x in range(i2, i2 + MAX_COINS): - if x == _n_coins: - break - - key: uint256 = bitwise_xor(convert(coin_list[i], uint256), convert(coin_list[x], uint256)) - length: uint256 = self.market_counts[key] - self.markets[key][length] = _pool - self.market_counts[key] = length + 1 - - # register the coin pair - if length == 0: - self._register_coin_pair(coin_list[x], coin_list[i], key) - - return coin_list - - -@view -@internal -def _get_new_pool_decimals(_coins: address[MAX_COINS], _n_coins: uint256) -> uint256: - packed: uint256 = 0 - value: uint256 = 0 - - n_coins: int128 = convert(_n_coins, int128) - for i in range(MAX_COINS): - if i == n_coins: - break - coin: address = _coins[i] - if coin == 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE: - value = 18 - else: - value = ERC20(coin).decimals() - assert value < 256 # dev: decimal overflow - - packed += shift(value, i * 8) - - return packed - - -@internal -def _remove_market(_pool: address, _coina: address, _coinb: address): - key: uint256 = bitwise_xor(convert(_coina, uint256), convert(_coinb, uint256)) - length: uint256 = self.market_counts[key] - 1 - if length == 0: - indexes: uint256 = self.coin_swap_indexes[key] - if convert(_coina, uint256) < convert(_coinb, uint256): - self._unregister_coin_pair(_coina, _coinb, indexes % 2 ** 128) - self._unregister_coin_pair(_coinb, _coina, shift(indexes, -128)) - else: - self._unregister_coin_pair(_coina, _coinb, shift(indexes, -128)) - self._unregister_coin_pair(_coinb, _coina, indexes % 2 ** 128) - self.coin_swap_indexes[key] = 0 - for i in range(65536): - if i > length: - break - if self.markets[key][i] == _pool: - if i < length: - self.markets[key][i] = self.markets[key][length] - self.markets[key][length] = ZERO_ADDRESS - self.market_counts[key] = length - break - - -# admin functions - -@external -def add_pool( - _pool: address, - _n_coins: uint256, - _lp_token: address, - _rate_info: bytes32, - _decimals: uint256, - _underlying_decimals: uint256, - _has_initial_A: bool, - _is_v1: bool, - _name: String[64], -): - """ - @notice Add a pool to the registry - @dev Only callable by admin - @param _pool Pool address to add - @param _n_coins Number of coins in the pool - @param _lp_token Pool deposit token address - @param _rate_info Encoded twenty-byte rate calculator address and/or four-byte - function signature to query coin rates - @param _decimals Coin decimal values, tightly packed as uint8 in a little-endian bytes32 - @param _underlying_decimals Underlying coin decimal values, tightly packed - as uint8 in a little-endian bytes32 - @param _name The name of the pool - """ - self._add_pool( - msg.sender, - _pool, - _n_coins + shift(_n_coins, 128), - _lp_token, - _rate_info, - _has_initial_A, - _is_v1, - _name, - ) - - coins: address[MAX_COINS] = self._get_new_pool_coins(_pool, _n_coins, False, _is_v1) - decimals: uint256 = _decimals - if decimals == 0: - decimals = self._get_new_pool_decimals(coins, _n_coins) - self.pool_data[_pool].decimals = decimals - - coins = self._get_new_pool_coins(_pool, _n_coins, True, _is_v1) - decimals = _underlying_decimals - if decimals == 0: - decimals = self._get_new_pool_decimals(coins, _n_coins) - self.pool_data[_pool].underlying_decimals = decimals - - -@external -def add_pool_without_underlying( - _pool: address, - _n_coins: uint256, - _lp_token: address, - _rate_info: bytes32, - _decimals: uint256, - _use_rates: uint256, - _has_initial_A: bool, - _is_v1: bool, - _name: String[64], -): - """ - @notice Add a pool to the registry - @dev Only callable by admin - @param _pool Pool address to add - @param _n_coins Number of coins in the pool - @param _lp_token Pool deposit token address - @param _rate_info Encoded twenty-byte rate calculator address and/or four-byte - function signature to query coin rates - @param _decimals Coin decimal values, tightly packed as uint8 in a little-endian bytes32 - @param _use_rates Boolean array indicating which coins use lending rates, - tightly packed in a little-endian bytes32 - @param _name The name of the pool - """ - self._add_pool( - msg.sender, - _pool, - _n_coins + shift(_n_coins, 128), - _lp_token, - _rate_info, - _has_initial_A, - _is_v1, - _name, - ) - - coins: address[MAX_COINS] = self._get_new_pool_coins(_pool, _n_coins, False, _is_v1) - - decimals: uint256 = _decimals - if decimals == 0: - decimals = self._get_new_pool_decimals(coins, _n_coins) - self.pool_data[_pool].decimals = decimals - - udecimals: uint256 = 0 - for i in range(MAX_COINS): - if i == _n_coins: - break - offset: int128 = -8 * convert(i, int128) - if shift(_use_rates, offset) % 256 == 0: - self.pool_data[_pool].ul_coins[i] = coins[i] - udecimals += shift(shift(decimals, offset) % 256, -offset) - - self.pool_data[_pool].underlying_decimals = udecimals - - -@external -def add_metapool( - _pool: address, - _n_coins: uint256, - _lp_token: address, - _decimals: uint256, - _name: String[64], - _base_pool: address = ZERO_ADDRESS -): - """ - @notice Add a pool to the registry - @dev Only callable by admin - @param _pool Pool address to add - @param _n_coins Number of coins in the pool - @param _lp_token Pool deposit token address - @param _decimals Coin decimal values, tightly packed as uint8 in a little-endian bytes32 - @param _name The name of the pool - @param _base_pool Address of the base_pool useful for adding factory pools - """ - base_coin_offset: uint256 = _n_coins - 1 - - base_pool: address = _base_pool - if base_pool == ZERO_ADDRESS: - base_pool = CurveMetapool(_pool).base_pool() - base_n_coins: uint256 = shift(self.pool_data[base_pool].n_coins, -128) - assert base_n_coins > 0 # dev: base pool unknown - - self._add_pool( - msg.sender, - _pool, - base_n_coins + base_coin_offset + shift(_n_coins, 128), - _lp_token, - EMPTY_BYTES32, - True, - False, - _name, - ) - - coins: address[MAX_COINS] = self._get_new_pool_coins(_pool, _n_coins, False, False) - - decimals: uint256 = _decimals - if decimals == 0: - decimals = self._get_new_pool_decimals(coins, _n_coins) - - self.pool_data[_pool].decimals = decimals - self.pool_data[_pool].base_pool = base_pool - - base_coins: address[MAX_COINS] = empty(address[MAX_COINS]) - coin: address = ZERO_ADDRESS - for i in range(MAX_COINS): - if i == base_n_coins + base_coin_offset: - break - if i < base_coin_offset: - coin = coins[i] - else: - x: uint256 = i - base_coin_offset - coin = self.pool_data[base_pool].coins[x] - base_coins[x] = coin - self._register_coin(base_coins[x]) - self.pool_data[_pool].ul_coins[i] = coin - - underlying_decimals: uint256 = shift( - self.pool_data[base_pool].decimals, 8 * convert(base_coin_offset, int128) - ) - underlying_decimals += decimals % 256 ** base_coin_offset - - self.pool_data[_pool].underlying_decimals = underlying_decimals - - for i in range(MAX_COINS): - if i == base_coin_offset: - break - for x in range(MAX_COINS): - if x == base_n_coins: - break - key: uint256 = bitwise_xor(convert(coins[i], uint256), convert(base_coins[x], uint256)) - length: uint256 = self.market_counts[key] - self.markets[key][length] = _pool - self.market_counts[key] = length + 1 - - # register the coin pair - if length == 0: - self._register_coin_pair(coins[i], base_coins[x], key) - - -@external -def remove_pool(_pool: address): - """ - @notice Remove a pool to the registry - @dev Only callable by admin - @param _pool Pool address to remove - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - assert self.pool_data[_pool].coins[0] != ZERO_ADDRESS # dev: pool does not exist - - - self.get_pool_from_lp_token[self.get_lp_token[_pool]] = ZERO_ADDRESS - self.get_lp_token[_pool] = ZERO_ADDRESS - - # remove _pool from pool_list - location: uint256 = self.pool_data[_pool].location - length: uint256 = self.pool_count - 1 - - if location < length: - # replace _pool with final value in pool_list - addr: address = self.pool_list[length] - self.pool_list[location] = addr - self.pool_data[addr].location = location - - # delete final pool_list value - self.pool_list[length] = ZERO_ADDRESS - self.pool_count = length - - self.pool_data[_pool].underlying_decimals = 0 - self.pool_data[_pool].decimals = 0 - self.pool_data[_pool].n_coins = 0 - self.pool_data[_pool].name = "" - self.pool_data[_pool].asset_type = 0 - - coins: address[MAX_COINS] = empty(address[MAX_COINS]) - ucoins: address[MAX_COINS] = empty(address[MAX_COINS]) - - for i in range(MAX_COINS): - coins[i] = self.pool_data[_pool].coins[i] - ucoins[i] = self.pool_data[_pool].ul_coins[i] - if ucoins[i] == ZERO_ADDRESS and coins[i] == ZERO_ADDRESS: - break - if coins[i] != ZERO_ADDRESS: - # delete coin address from pool_data - self.pool_data[_pool].coins[i] = ZERO_ADDRESS - self._unregister_coin(coins[i]) - if ucoins[i] != ZERO_ADDRESS: - # delete underlying_coin from pool_data - self.pool_data[_pool].ul_coins[i] = ZERO_ADDRESS - if self.coins[ucoins[i]].register_count != 0: - self._unregister_coin(ucoins[i]) - - is_meta: bool = self.pool_data[_pool].base_pool != ZERO_ADDRESS - for i in range(MAX_COINS): - coin: address = coins[i] - ucoin: address = ucoins[i] - if coin == ZERO_ADDRESS: - break - - # remove pool from markets - i2: uint256 = i + 1 - for x in range(i2, i2 + MAX_COINS): - ucoinx: address = ucoins[x] - if ucoinx == ZERO_ADDRESS: - break - - coinx: address = coins[x] - if coinx != ZERO_ADDRESS: - self._remove_market(_pool, coin, coinx) - - if coin != ucoin or coinx != ucoinx: - self._remove_market(_pool, ucoin, ucoinx) - - if is_meta and not ucoin in coins: - key: uint256 = bitwise_xor(convert(ucoin, uint256), convert(ucoinx, uint256)) - self._register_coin_pair(ucoin, ucoinx, key) - - self.pool_data[_pool].base_pool = ZERO_ADDRESS - self.last_updated = block.timestamp - log PoolRemoved(_pool) - - -@external -def set_pool_gas_estimates(_addr: address[5], _amount: uint256[2][5]): - """ - @notice Set gas estimate amounts - @param _addr Array of pool addresses - @param _amount Array of gas estimate amounts as `[(wrapped, underlying), ..]` - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - for i in range(5): - _pool: address = _addr[i] - if _pool == ZERO_ADDRESS: - break - self.gas_estimate_values[_pool] = _amount[i] - self.last_updated = block.timestamp - - -@external -def set_coin_gas_estimates(_addr: address[10], _amount: uint256[10]): - """ - @notice Set gas estimate amounts - @param _addr Array of coin addresses - @param _amount Array of gas estimate amounts - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - for i in range(10): - _coin: address = _addr[i] - if _coin == ZERO_ADDRESS: - break - self.gas_estimate_values[_coin][0] = _amount[i] - self.last_updated = block.timestamp - - -@external -def set_gas_estimate_contract(_pool: address, _estimator: address): - """ - @notice Set gas estimate contract - @param _pool Pool address - @param _estimator GasEstimator address - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - self.gas_estimate_contracts[_pool] = _estimator - self.last_updated = block.timestamp - - -@external -def set_liquidity_gauges(_pool: address, _liquidity_gauges: address[10]): - """ - @notice Set liquidity gauge contracts`` - @param _pool Pool address - @param _liquidity_gauges Liquidity gauge address - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - _lp_token: address = self.get_lp_token[_pool] - _gauge_controller: address = self.gauge_controller - for i in range(10): - _gauge: address = _liquidity_gauges[i] - if _gauge != ZERO_ADDRESS: - assert LiquidityGauge(_gauge).lp_token() == _lp_token # dev: wrong token - GaugeController(_gauge_controller).gauge_types(_gauge) - self.liquidity_gauges[_pool][i] = _gauge - elif self.liquidity_gauges[_pool][i] != ZERO_ADDRESS: - self.liquidity_gauges[_pool][i] = ZERO_ADDRESS - else: - break - self.last_updated = block.timestamp - - -@external -def set_pool_asset_type(_pool: address, _asset_type: uint256): - """ - @notice Set the asset type name for a curve pool - @dev This is a simple way to setting the cache of categories instead of - performing some computation for no reason. Pool's don't necessarily - change once they are deployed. - @param _pool Pool address - @param _asset_type String of asset type - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - self.pool_data[_pool].asset_type = _asset_type - self.last_updated = block.timestamp - - -@external -def batch_set_pool_asset_type(_pools: address[32], _asset_types: uint256[32]): - """ - @notice Batch set the asset type name for curve pools - @dev This is a simple way of setting the cache of categories instead of - performing some computation for no reason. Pool's don't necessarily - change once they are deployed. - """ - assert msg.sender == self.address_provider.admin() # dev: admin-only function - - for i in range(32): - if _pools[i] == ZERO_ADDRESS: - break - self.pool_data[_pools[i]].asset_type = _asset_types[i] - self.last_updated = block.timestamp diff --git a/contracts/mainnet/registries/BasePoolRegistry.vy b/contracts/mainnet/registries/BasePoolRegistry.vy index 0b9e395..9332a83 100644 --- a/contracts/mainnet/registries/BasePoolRegistry.vy +++ b/contracts/mainnet/registries/BasePoolRegistry.vy @@ -1,4 +1,4 @@ -# @version 0.3.7 +# @version 0.3.10 """ @title Curve BasePool Registry @license MIT diff --git a/contracts/mainnet/registries/CryptoRegistryV1.vy b/contracts/mainnet/registries/CryptoRegistryV1.vy index 65b2680..d88d089 100644 --- a/contracts/mainnet/registries/CryptoRegistryV1.vy +++ b/contracts/mainnet/registries/CryptoRegistryV1.vy @@ -1,4 +1,4 @@ -# @version 0.3.7 +# @version 0.3.10 """ @title Curve CryptoSwap Registry @license MIT diff --git a/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy b/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy index a1ce65a..6a42afc 100644 --- a/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy +++ b/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.4 +# @version 0.3.10 """ @title Curve Registry Handler for v2 Factory @license MIT diff --git a/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy b/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy index 4b73217..3a2d33e 100644 --- a/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy +++ b/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.4 +# @version 0.3.10 """ @title Curve Registry Handler for v2 Crypto Registry @license MIT diff --git a/contracts/mainnet/registry_handlers/StableFactoryHandler.vy b/contracts/mainnet/registry_handlers/StableFactoryHandler.vy index fd8cfda..4710c93 100644 --- a/contracts/mainnet/registry_handlers/StableFactoryHandler.vy +++ b/contracts/mainnet/registry_handlers/StableFactoryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.4 +# @version 0.3.10 """ @title Curve Registry Handler for v1 Factory (latest) @license MIT diff --git a/contracts/mainnet/registry_handlers/StableRegistryHandler.vy b/contracts/mainnet/registry_handlers/StableRegistryHandler.vy index c61cb28..521a3f6 100644 --- a/contracts/mainnet/registry_handlers/StableRegistryHandler.vy +++ b/contracts/mainnet/registry_handlers/StableRegistryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.4 +# @version 0.3.10 """ @title Curve Registry Handler for v1 Registry @license MIT diff --git a/docker-compose.yaml b/docker-compose.yaml new file mode 100644 index 0000000..385d6ca --- /dev/null +++ b/docker-compose.yaml @@ -0,0 +1,7 @@ +version: '3.1' + +services: + test: + build: ./ + container_name: metaregistry-test + env_file: .env diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index 3946e9d..820e783 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -1,11 +1,11 @@ import sys import click -from ape import accounts, project -from ape.cli import NetworkBoundCommand, account_option, network_option -from ape.utils import ZERO_ADDRESS +from eth.constants import ZERO_ADDRESS from rich.console import Console as RichConsole +from tests.utils import get_deployed_contract + RICH_CONSOLE = RichConsole(file=sys.stdout) ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" @@ -140,36 +140,22 @@ def cli(): def main(network: str, account: str): # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: - address_provider = project.AddressProvider.at(ADDRESS_PROVIDER) + address_provider = get_deployed_contract('AddressProvider', ADDRESS_PROVIDER) address_provider_admin = address_provider.admin() - proxy_admin = project.ProxyAdmin.at(address_provider_admin) + proxy_admin = get_deployed_contract('ProxyAdmin', address_provider_admin) if network == "ethereum:mainnet-fork": RICH_CONSOLE.log("Simulation mode.") account = accounts[proxy_admin.admins(1)] # deployed contracts: - base_pool_registry = project.BasePoolRegistry.at( - "0xDE3eAD9B2145bBA2EB74007e58ED07308716B725" - ) - crypto_registry = project.CryptoRegistryV1.at( - "0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0" - ) - stable_registry_handler = project.StableRegistryHandler.at( - "0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68" - ) - stable_factory_handler = project.StableFactoryHandler.at( - "0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9" - ) - crypto_registry_handler = project.CryptoRegistryHandler.at( - "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94" - ) - crypto_factory_handler = project.CryptoFactoryHandler.at( - "0xC4F389020002396143B863F6325aA6ae481D19CE" - ) - metaregistry = project.MetaRegistry.at( - "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC" - ) + base_pool_registry = get_deployed_contract('BasePoolRegistry', "0xDE3eAD9B2145bBA2EB74007e58ED07308716B725") + crypto_registry = get_deployed_contract('CryptoRegistryV1', "0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0") + stable_registry_handler = get_deployed_contract('StableRegistryHandler', "0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68") + stable_factory_handler = get_deployed_contract('StableFactoryHandler', "0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9") + crypto_registry_handler = get_deployed_contract('CryptoRegistryHandler', "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94") + crypto_factory_handler = get_deployed_contract('CryptoFactoryHandler', "0xC4F389020002396143B863F6325aA6ae481D19CE") + metaregistry = get_deployed_contract('MetaRegistry', "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC") registry_handlers = [ stable_registry_handler, stable_factory_handler, diff --git a/tests/conftest.py b/tests/conftest.py index 2c4f61e..bd9aa58 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -1,6 +1,9 @@ -import pytest +from os import environ + import boa -from boa.network import NetworkEnv +import pytest + +from tests.utils import get_contract_pools pytest_plugins = [ "fixtures.accounts", @@ -25,15 +28,15 @@ def pytest_sessionstart(): global STABLE_REGISTRY_POOLS global ALL_POOLS - boa.env.fork("https://mainnet.infura.io/v3/84842078b09946638c03157f83405213") + # connect to the network. TODO: use Drpc-Key header instead of GET param + boa.env.fork(f"https://lb.drpc.org/ogrpc?network=ethereum&dkey={environ['DRPC_KEY']}") - # store instance of registries globally, so we don't have to recreate multiple times - # when generating tests: - - STABLE_REGISTRY_POOLS = get_pools("StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5") - STABLE_FACTORY_POOLS = get_pools("StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4") - CRYPTO_REGISTRY_POOLS = get_pools("CryptoRegistry", "0x8F942C20D02bEfc377D41445793068908E2250D0") - CRYPTO_FACTORY_POOLS = get_pools("CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99") + # store instance of registries globally, so we don't have to recreate multiple times when generating tests. + # TODO: Can we move these to fixtures? + STABLE_REGISTRY_POOLS = get_contract_pools("StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5") + STABLE_FACTORY_POOLS = get_contract_pools("StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4") + CRYPTO_REGISTRY_POOLS = get_contract_pools("CryptoRegistry", "0x8F942C20D02bEfc377D41445793068908E2250D0") + CRYPTO_FACTORY_POOLS = get_contract_pools("CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99") ALL_POOLS = ( STABLE_REGISTRY_POOLS @@ -43,12 +46,6 @@ def pytest_sessionstart(): ) -def get_pools(registryName, registryAddress): - deployer = boa.load_partial(f"contracts/mainnet/mocks/{registryName}", registryName) - registry = deployer.at(registryAddress) - return [registry.pool_list(i) for i in range(registry.pool_count())] - - def pytest_generate_tests(metafunc): if "stable_registry_pool" in metafunc.fixturenames: metafunc.parametrize("stable_registry_pool", STABLE_REGISTRY_POOLS) diff --git a/tests/fixtures/accounts.py b/tests/fixtures/accounts.py index 5708cff..d4b5a7d 100644 --- a/tests/fixtures/accounts.py +++ b/tests/fixtures/accounts.py @@ -1,12 +1,13 @@ +import logging from collections import namedtuple import pytest from eth_account import Account from eth_account.hdaccount import HDPath from eth_account.hdaccount.mnemonic import Mnemonic -from ethpm_types import HexBytes +from eth_account.signers.local import LocalAccount -GeneratedDevAccount = namedtuple("GeneratedDevAccount", ("address", "private_key")) +from tests.utils import get_deployed_contract @pytest.fixture(scope="session") @@ -14,38 +15,35 @@ def seed() -> bytes: return Mnemonic.to_seed("test") @pytest.fixture(scope="session") -def accounts(seed) -> list[GeneratedDevAccount]: +def accounts(seed) -> list[LocalAccount]: """ Generate 10 dev accounts from a seed. Based on ape's `generate_test_accounts` method: https://github.com/ApeWorX/ape/blob/9d4b66786/src/ape/utils/testing.py#L28 """ - def generate_account(index: int, hd_path_format="m/44'/60'/0'/{}") -> GeneratedDevAccount: + def generate_account(index: int, hd_path_format="m/44'/60'/0'/{}") -> LocalAccount: hd_path = HDPath(hd_path_format.format(index)) - private_key = HexBytes(hd_path.derive(seed)).hex() - address = Account.from_key(private_key).address - return GeneratedDevAccount(address, private_key) + private_key = f"0x{hd_path.derive(seed).hex()}" + return Account.from_key(private_key) return [generate_account(index) for index in range(10)] @pytest.fixture(scope="session") -def alice(accounts): - return accounts[0] +def alice_address(accounts): + return accounts[0].address @pytest.fixture(scope="session") -def unauthorised_account(accounts): - return accounts[1] +def unauthorised_address(accounts): + return accounts[1].address @pytest.fixture(scope="session") def random_address(accounts): - return accounts[2] + return accounts[2].address @pytest.fixture(scope="module") def owner(accounts): - address_provider = ape.project.AddressProvider.at( - "0x0000000022D53366457F9d5E68Ec105046FC4383" - ) - return accounts[address_provider.admin()] + address_provider = get_deployed_contract('AddressProvider', "0x0000000022D53366457F9d5E68Ec105046FC4383") + return address_provider.admin() diff --git a/tests/fixtures/constants.py b/tests/fixtures/constants.py index 1aeaeb2..5001718 100644 --- a/tests/fixtures/constants.py +++ b/tests/fixtures/constants.py @@ -1,7 +1,9 @@ -import ape import pytest +ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" + + @pytest.fixture(scope="module") def base_pools(): @@ -47,7 +49,7 @@ def crypto_registry_pools(base_pools): "zap": "0x3993d34e7e99Abf6B6f367309975d1360222D446", "num_coins": 3, "name": "tricrypto2", - "base_pool": ape.utils.ZERO_ADDRESS, + "base_pool": ZERO_ADDRESS, "has_positive_rebasing_tokens": False, } @@ -66,10 +68,10 @@ def crypto_registry_pools(base_pools): "pool": "0x98a7F18d4E56Cfe84E3D081B40001B3d5bD3eB8B", "lp_token": "0x3D229E1B4faab62F621eF2F6A610961f7BD7b23B", "gauge": "0x65CA7Dc5CB661fC58De57B1E1aF404649a27AD35", - "zap": ape.utils.ZERO_ADDRESS, + "zap": ZERO_ADDRESS, "num_coins": 2, "name": "eursusd", - "base_pool": ape.utils.ZERO_ADDRESS, + "base_pool": ZERO_ADDRESS, "has_positive_rebasing_tokens": False, } @@ -77,10 +79,10 @@ def crypto_registry_pools(base_pools): "pool": "0x8301AE4fc9c624d1D396cbDAa1ed877821D7C511", "lp_token": "0xEd4064f376cB8d68F770FB1Ff088a3d0F3FF5c4d", "gauge": "0x1cEBdB0856dd985fAe9b8fEa2262469360B8a3a6", - "zap": ape.utils.ZERO_ADDRESS, + "zap": ZERO_ADDRESS, "num_coins": 2, "name": "crveth", - "base_pool": ape.utils.ZERO_ADDRESS, + "base_pool": ZERO_ADDRESS, "has_positive_rebasing_tokens": False, } @@ -88,10 +90,10 @@ def crypto_registry_pools(base_pools): "pool": "0xB576491F1E6e5E62f1d8F26062Ee822B40B0E0d4", "lp_token": "0x3A283D9c08E8b55966afb64C515f5143cf907611", "gauge": "0x7E1444BA99dcdFfE8fBdb42C02F0005D14f13BE1", - "zap": ape.utils.ZERO_ADDRESS, + "zap": ZERO_ADDRESS, "num_coins": 2, "name": "cvxeth", - "base_pool": ape.utils.ZERO_ADDRESS, + "base_pool": ZERO_ADDRESS, "has_positive_rebasing_tokens": False, } @@ -110,10 +112,10 @@ def crypto_registry_pools(base_pools): "pool": "0x98638FAcf9a3865cd033F36548713183f6996122", "lp_token": "0x8282BD15dcA2EA2bDf24163E8f2781B30C43A2ef", "gauge": "0x08380a4999Be1a958E2abbA07968d703C7A3027C", - "zap": ape.utils.ZERO_ADDRESS, + "zap": ZERO_ADDRESS, "num_coins": 2, "name": "spelleth", - "base_pool": ape.utils.ZERO_ADDRESS, + "base_pool": ZERO_ADDRESS, "has_positive_rebasing_tokens": False, } @@ -121,10 +123,10 @@ def crypto_registry_pools(base_pools): "pool": "0x752eBeb79963cf0732E9c0fec72a49FD1DEfAEAC", "lp_token": "0xCb08717451aaE9EF950a2524E33B6DCaBA60147B", "gauge": "0x6070fBD4E608ee5391189E7205d70cc4A274c017", - "zap": ape.utils.ZERO_ADDRESS, + "zap": ZERO_ADDRESS, "num_coins": 2, "name": "teth", - "base_pool": ape.utils.ZERO_ADDRESS, + "base_pool": ZERO_ADDRESS, "has_positive_rebasing_tokens": False, } diff --git a/tests/fixtures/contracts.py b/tests/fixtures/contracts.py index 96e39d0..b7192f2 100644 --- a/tests/fixtures/contracts.py +++ b/tests/fixtures/contracts.py @@ -3,7 +3,7 @@ @pytest.fixture(scope="module") def address_provider_contract(accounts): - address_provider = ape.project.AddressProvider.at( + address_provider = get_deployed_contract('AddressProvider', "0x0000000022D53366457F9d5E68Ec105046FC4383" ) return accounts[address_provider.admin()] diff --git a/tests/fixtures/deployments.py b/tests/fixtures/deployments.py index ef57cd1..51d9fa4 100644 --- a/tests/fixtures/deployments.py +++ b/tests/fixtures/deployments.py @@ -1,45 +1,41 @@ +import boa import pytest +from boa.vyper.contract import VyperContract + +from tests.utils import get_deployed_contract, deploy_contract ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" @pytest.fixture(scope="module", autouse=True) -def gauge_controller() -> ape.Contract: - return ape.project.GaugeController.at( - "0x2F50D538606Fa9EDD2B11E2446BEb18C9D5846bB" - ) +def gauge_controller() -> VyperContract: + return get_deployed_contract('GaugeController', "0x2F50D538606Fa9EDD2B11E2446BEb18C9D5846bB") @pytest.fixture(scope="module", autouse=True) -def stable_registry() -> ape.Contract: - return ape.project.StableRegistry.at( - "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" - ) +def stable_registry() -> VyperContract: + return get_deployed_contract('StableRegistry', "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5") @pytest.fixture(scope="module", autouse=True) -def stable_factory() -> ape.Contract: - return ape.project.StableFactory.at( - "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" - ) +def stable_factory() -> VyperContract: + return get_deployed_contract('StableFactory', "0xB9fC157394Af804a3578134A6585C0dc9cc990d4") @pytest.fixture(scope="module", autouse=True) -def crypto_factory() -> ape.Contract: - return ape.project.CryptoFactory.at( - "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" - ) +def crypto_factory() -> VyperContract: + return get_deployed_contract('CryptoFactory', "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99") @pytest.fixture(scope="module", autouse=True) -def base_pool_registry(alice, project): - return project.BasePoolRegistry.deploy(sender=alice) +def base_pool_registry(alice_address): + return deploy_contract("BasePoolRegistry", sender=alice_address, directory="registries") @pytest.fixture(scope="module", autouse=True) def populated_base_pool_registry(base_pool_registry, owner, base_pools): - - for _, data in base_pools.items(): + for data in base_pools.values(): + boa.env.eoa = owner base_pool_registry.add_base_pool( data["pool"], data["lp_token"], @@ -47,9 +43,7 @@ def populated_base_pool_registry(base_pool_registry, owner, base_pools): data["is_legacy"], data["is_lending"], data["is_v2"], - sender=owner, ) - return base_pool_registry @@ -57,10 +51,8 @@ def populated_base_pool_registry(base_pool_registry, owner, base_pools): def crypto_registry( populated_base_pool_registry, owner, crypto_registry_pools ): - - crypto_registry = ape.project.CryptoRegistryV1.deploy( - ADDRESS_PROVIDER, populated_base_pool_registry, sender=owner - ) + crypto_registry = deploy_contract("CryptoRegistryV1", ADDRESS_PROVIDER, populated_base_pool_registry, + directory="registries", sender=owner) for _, pool in crypto_registry_pools.items(): crypto_registry.add_pool( @@ -80,78 +72,61 @@ def crypto_registry( @pytest.fixture(scope="module", autouse=True) def address_provider(crypto_registry, owner): - contract = ape.project.AddressProvider.at(ADDRESS_PROVIDER) + contract = get_deployed_contract('AddressProvider', ADDRESS_PROVIDER) contract.set_address(5, crypto_registry, sender=owner) return contract @pytest.fixture(scope="module", autouse=True) -def metaregistry(address_provider, owner, project): - return project.MetaRegistry.deploy(address_provider, sender=owner) +def metaregistry(address_provider, owner): + return deploy_contract("MetaRegistry", address_provider, sender=owner) @pytest.fixture(scope="module", autouse=True) -def stable_registry_handler(stable_registry, owner, project): - return project.StableRegistryHandler.deploy( - stable_registry.address, sender=owner +def stable_registry_handler(stable_registry, owner): + return deploy_contract( + "StableRegistryHandler", stable_registry.address, + sender=owner, directory="registry_handlers", override_address=stable_registry.address, ) @pytest.fixture(scope="module", autouse=True) -def stable_factory_handler( - populated_base_pool_registry, stable_factory, owner, project -): - return project.StableFactoryHandler.deploy( - stable_factory.address, populated_base_pool_registry, sender=owner +def stable_factory_handler(populated_base_pool_registry, stable_factory, owner): + return deploy_contract( + "StableFactoryHandler", stable_factory.address, populated_base_pool_registry.address, + sender=owner, directory="registry_handlers", override_address=stable_factory.address, ) @pytest.fixture(scope="module", autouse=True) -def crypto_registry_handler(owner, crypto_registry, project): - return project.CryptoRegistryHandler.deploy(crypto_registry, sender=owner) +def crypto_registry_handler(owner, crypto_registry): + return deploy_contract( + "CryptoRegistryHandler", crypto_registry.address, sender=owner, directory="registry_handlers", + ) @pytest.fixture(scope="module", autouse=True) -def crypto_factory_handler( - populated_base_pool_registry, crypto_factory, owner, project -): - return project.CryptoFactoryHandler.deploy( - crypto_factory.address, populated_base_pool_registry, sender=owner +def crypto_factory_handler(populated_base_pool_registry, crypto_factory, owner): + return deploy_contract( + "CryptoFactoryHandler", crypto_factory.address, populated_base_pool_registry.address, + sender=owner, directory="registry_handlers", override_address=crypto_factory.address, ) @pytest.fixture(scope="module") -def registries( - stable_registry, stable_factory, crypto_registry, crypto_factory -): - return [ - stable_registry, - stable_factory, - crypto_registry, - crypto_factory, - ] +def registries(stable_registry, stable_factory, crypto_registry, crypto_factory): + return [stable_registry, stable_factory, crypto_registry, crypto_factory] @pytest.fixture(scope="module") -def handlers( - stable_registry_handler, - stable_factory_handler, - crypto_registry_handler, - crypto_factory_handler, -): - return [ - stable_registry_handler, - stable_factory_handler, - crypto_registry_handler, - crypto_factory_handler, - ] +def handlers(stable_registry_handler, stable_factory_handler, crypto_registry_handler, crypto_factory_handler): + return [stable_registry_handler, stable_factory_handler, crypto_registry_handler, crypto_factory_handler] @pytest.fixture(scope="module", autouse=True) def populated_metaregistry(metaregistry, handlers, owner): for handler in handlers: metaregistry.add_registry_handler(handler.address, sender=owner) - return metaregistry diff --git a/tests/fixtures/functions.py b/tests/fixtures/functions.py index 706e5a3..0acbddd 100644 --- a/tests/fixtures/functions.py +++ b/tests/fixtures/functions.py @@ -1,30 +1,33 @@ from typing import Callable -import ape import pytest +from boa.vyper.contract import VyperContract + +from tests.utils import get_deployed_contract + # ---- Factories ---- @pytest.fixture(scope="module") def curve_pool(project) -> Callable: - def _initialise(_pool: str) -> ape.Contract: - return project.CurvePool.at(_pool) + def _initialise(_pool: str) -> VyperContract: + return get_deployed_contract('CurvePool', _pool) return _initialise @pytest.fixture(scope="module") def curve_pool_v2(project) -> Callable: - def _initialise(_pool: str) -> ape.Contract: - return project.CurvePoolV2.at(_pool) + def _initialise(_pool: str) -> VyperContract: + return get_deployed_contract('CurvePoolV2', _pool) return _initialise @pytest.fixture(scope="module") def liquidity_gauge(project) -> Callable: - def _initialise(_gauge: str) -> ape.Contract: - return project.LiquidityGauge.at(_gauge) + def _initialise(_gauge: str) -> VyperContract: + return get_deployed_contract('LiquidityGauge', _gauge) return _initialise diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index cd28d04..2346257 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -8,7 +8,7 @@ def pre_test_checks(metaregistry, pool): pytest.skip("empty pool: skipping") try: - if ape.Contract(metaregistry.get_lp_token(pool)).totalSupply() == 0: + if VyperContract(metaregistry.get_lp_token(pool)).totalSupply() == 0: pytest.skip("lp token supply is zero") except ape.exceptions.SignatureError: pytest.skip( @@ -50,14 +50,14 @@ def test_stable_factory_pools( def _get_crypto_pool_admin_fees( - populated_metaregistry, pool, fee_receiver, project, alice, chain + populated_metaregistry, pool, fee_receiver, project, alice_address, chain ): - lp_token = ape.Contract(populated_metaregistry.get_lp_token(pool)) + lp_token = VyperContract(populated_metaregistry.get_lp_token(pool)) fee_receiver_token_balance_before = lp_token.balanceOf(fee_receiver) chain.snapshot() - pool.claim_admin_fees(sender=alice) + pool.claim_admin_fees(sender=alice_address) claimed_lp_token_as_fee = ( lp_token.balanceOf(fee_receiver) - fee_receiver_token_balance_before @@ -81,7 +81,7 @@ def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, curve_pool_v2, - alice, + alice_address, chain, project, ): @@ -91,7 +91,7 @@ def test_crypto_registry_pools( pool = curve_pool_v2(crypto_registry_pool) fee_receiver = pool.admin_fee_receiver() admin_balances = _get_crypto_pool_admin_fees( - populated_metaregistry, pool, fee_receiver, project, alice, chain + populated_metaregistry, pool, fee_receiver, project, alice_address, chain ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) @@ -104,7 +104,7 @@ def test_crypto_factory_pools( crypto_factory_pool, crypto_factory, curve_pool_v2, - alice, + alice_address, chain, project, ): @@ -114,7 +114,7 @@ def test_crypto_factory_pools( pool = curve_pool_v2(crypto_factory_pool) fee_receiver = crypto_factory.fee_receiver() admin_balances = _get_crypto_pool_admin_fees( - populated_metaregistry, pool, fee_receiver, project, alice, chain + populated_metaregistry, pool, fee_receiver, project, alice_address, chain ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) diff --git a/tests/mainnet/metaregistry/api/test_get_pool_name.py b/tests/mainnet/metaregistry/api/test_get_pool_name.py index b95d3d1..a1fca59 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_name.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_name.py @@ -29,7 +29,7 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): assert ( populated_metaregistry.get_pool_name(stable_factory_pool) - == ape.Contract(stable_factory_pool).name() + == VyperContract(stable_factory_pool).name() ) elif num_registry_handlers == 2: @@ -38,12 +38,12 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): assert ( populated_metaregistry.get_pool_name(stable_factory_pool) - == ape.Contract(stable_factory_pool).name() + == VyperContract(stable_factory_pool).name() ) assert ( populated_metaregistry.get_pool_name(stable_factory_pool, 1) - == ape.Contract(stable_factory_pool).name() + == VyperContract(stable_factory_pool).name() ) else: @@ -66,5 +66,5 @@ def test_crypto_factory_pools( assert ( populated_metaregistry.get_pool_name(crypto_factory_pool) - == ape.Contract(crypto_factory.get_token(crypto_factory_pool)).name() + == VyperContract(crypto_factory.get_token(crypto_factory_pool)).name() ) diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index dd22621..e413fd8 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -34,7 +34,7 @@ def _get_underlying_balances( if base_pool != ape.utils.ZERO_ADDRESS: basepool_lp_token_balance = balances[idx] - coin_contract = ape.Contract(coin) + coin_contract = VyperContract(coin) try: lp_token_supply = coin_contract.totalSupply() except (ape.exceptions.SignatureError, AttributeError): diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index 4824ede..ef101f1 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -32,7 +32,7 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): continue try: - token_contract = ape.Contract(underlying_coins[i]) + token_contract = VyperContract(underlying_coins[i]) actual_output.append(token_contract.decimals()) except ape.exceptions.ChainError: pytest.skip("Unverified contract. Skipping test.") diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index b92b9b1..594dc4c 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -39,7 +39,7 @@ def _check_skem_tokens_with_weird_decimals( if ( coin_decimals[i] == 0 - and ape.Contract(metaregistry.get_coins(pool)[0]).decimals() == 0 + and VyperContract(metaregistry.get_coins(pool)[0]).decimals() == 0 ): with ape.reverts(): metaregistry.get_virtual_price_from_lp_token(lp_token) diff --git a/tests/mainnet/metaregistry/test_add_remove_update_registry.py b/tests/mainnet/metaregistry/test_add_remove_update_registry.py index 4844c5e..f5a81ab 100644 --- a/tests/mainnet/metaregistry/test_add_remove_update_registry.py +++ b/tests/mainnet/metaregistry/test_add_remove_update_registry.py @@ -1,22 +1,22 @@ -import ape +import boa def test_revert_unauthorised_add_registry_handler( - metaregistry, unauthorised_account, random_address + metaregistry, unauthorised_address, random_address ): - with ape.reverts(): + with boa.reverts(): tx = metaregistry.add_registry_handler( - random_address, sender=unauthorised_account + random_address, sender=unauthorised_address ) assert tx.revert_msg == "dev: only owner" def test_revert_unauthorised_update_registry_handler( - populated_metaregistry, unauthorised_account, random_address + populated_metaregistry, unauthorised_address, random_address ): - with ape.reverts(): + with boa.reverts(): tx = populated_metaregistry.update_registry_handler( - 0, random_address, sender=unauthorised_account + 0, random_address, sender=unauthorised_address ) assert tx.revert_msg == "dev: only owner" @@ -24,7 +24,7 @@ def test_revert_unauthorised_update_registry_handler( def test_update_registry_handler_invalid_registry( populated_metaregistry, random_address, owner ): - with ape.reverts(): + with boa.reverts(): populated_metaregistry.update_registry_handler( 10, random_address, sender=owner ) diff --git a/tests/mainnet/metaregistry/test_base_registry_tracking.py b/tests/mainnet/metaregistry/test_base_registry_tracking.py index 6e716ce..557cf76 100644 --- a/tests/mainnet/metaregistry/test_base_registry_tracking.py +++ b/tests/mainnet/metaregistry/test_base_registry_tracking.py @@ -2,7 +2,7 @@ def test_new_crypto_factory_pool( - metaregistry, crypto_factory, tokens, lp_tokens, alice + metaregistry, crypto_factory, tokens, lp_tokens, alice_address ): test_pool_name = "test_pool" @@ -27,7 +27,7 @@ def test_new_crypto_factory_pool( 5000000000, 600, 994000214704046300, - sender=alice, + sender=alice_address, ) new_pool = crypto_factory.pool_list(crypto_factory.pool_count() - 1) lp_token = crypto_factory.get_token(new_pool) @@ -48,7 +48,7 @@ def test_new_crypto_factory_pool( def test_new_stable_factory_pool( - metaregistry, stable_factory, lp_tokens, alice + metaregistry, stable_factory, lp_tokens, alice_address ): test_pool_name = "test_pool" @@ -72,7 +72,7 @@ def test_new_stable_factory_pool( 4000000, 0, 0, - sender=alice, + sender=alice_address, ) new_pool = stable_factory.pool_list(stable_factory.pool_count() - 1) diff --git a/tests/mainnet/registries/test_add_remove_basepool.py b/tests/mainnet/registries/test_add_remove_basepool.py index 85bbbf0..2747749 100644 --- a/tests/mainnet/registries/test_add_remove_basepool.py +++ b/tests/mainnet/registries/test_add_remove_basepool.py @@ -2,7 +2,7 @@ def test_revert_unauthorised_add_base_pool( - owner, unauthorised_account, base_pools + owner, unauthorised_address, base_pools ): base_pool_registry = ape.project.BasePoolRegistry.deploy(sender=owner) @@ -16,7 +16,7 @@ def test_revert_unauthorised_add_base_pool( base_pool_data["is_legacy"], base_pool_data["is_lending"], base_pool_data["is_v2"], - sender=unauthorised_account, + sender=unauthorised_address, ) @@ -92,7 +92,7 @@ def test_add_basepool_with_legacy_abi(owner, base_pools, tokens): def test_revert_unauthorised_remove_base_pool( - populated_base_pool_registry, unauthorised_account, base_pools + populated_base_pool_registry, unauthorised_address, base_pools ): tripool_address = base_pools["tripool"]["pool"] @@ -103,7 +103,7 @@ def test_revert_unauthorised_remove_base_pool( ) with ape.reverts(): populated_base_pool_registry.remove_base_pool( - tripool_address, sender=unauthorised_account + tripool_address, sender=unauthorised_address ) diff --git a/tests/mainnet/registries/test_add_remove_pool.py b/tests/mainnet/registries/test_add_remove_pool.py index 5b42fd1..bb2653b 100644 --- a/tests/mainnet/registries/test_add_remove_pool.py +++ b/tests/mainnet/registries/test_add_remove_pool.py @@ -2,7 +2,7 @@ def test_revert_unauthorised_add_pool( - crypto_registry, unauthorised_account, crypto_registry_pools + crypto_registry, unauthorised_address, crypto_registry_pools ): pool_data = crypto_registry_pools["tricrypto2"] @@ -17,7 +17,7 @@ def test_revert_unauthorised_add_pool( pool_data["name"], pool_data["base_pool"], pool_data["has_positive_rebasing_tokens"], - sender=unauthorised_account, + sender=unauthorised_address, ) @@ -140,13 +140,13 @@ def test_add_pool( def test_revert_unauthorised_remove_pool( - crypto_registry, unauthorised_account, crypto_registry_pools + crypto_registry, unauthorised_address, crypto_registry_pools ): with ape.reverts(): crypto_registry.remove_pool( crypto_registry_pools["tricrypto2"]["pool"], - sender=unauthorised_account, + sender=unauthorised_address, ) diff --git a/tests/utils.py b/tests/utils.py new file mode 100644 index 0000000..5e7ff62 --- /dev/null +++ b/tests/utils.py @@ -0,0 +1,35 @@ +from os import path +from typing import Union + +import boa +from boa.vyper.contract import VyperContract +from eth_account.signers.local import LocalAccount + +BASE_DIR = path.join(path.dirname(path.abspath(__file__)), "..") + + +def get_contract_pools(contract: str, address: str) -> list[str]: + """ + Retrieves the list of pools from a deployed contract with the given address. + :param contract: The name of the contract to load. + :param address: The address of the deployed contract. + """ + registry = get_deployed_contract(contract, address) + return [registry.pool_list(i) for i in range(registry.pool_count())] + + +def get_deployed_contract(contract_abi: str, address: str) -> VyperContract: + """ + Loads a contract and retrieves a deployed instance of it with the given address. + TODO: Refactor calls to use fixtures instead of re-loading multiple times. + :param contract_abi: The name of the contract to load. + :param address: The address of the deployed contract. + """ + file_name = path.join(BASE_DIR, f"contracts/mainnet/abi/{contract_abi}.json") + return boa.load_abi(file_name).at(address) + + +def deploy_contract(contract: str, *args, sender: Union[LocalAccount, str], directory: str = ".", **kwargs): + file_name = path.join(BASE_DIR, f"contracts/mainnet/{directory}/{contract}.vy") + boa.env.eoa = sender if isinstance(sender, str) else sender.address + return boa.load(file_name, *args, **kwargs) From eeacdb7279985b41b89c923163365754e0f758d2 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Wed, 22 Nov 2023 10:11:34 +0100 Subject: [PATCH 05/19] Fix circular fixtures --- .github/workflows/main.yaml | 4 +-- Dockerfile | 4 +-- contracts/mainnet/MetaRegistry.vy | 4 +-- .../mainnet/registries/BasePoolRegistry.vy | 2 +- .../mainnet/registries/CryptoRegistryV1.vy | 2 +- .../registry_handlers/CryptoFactoryHandler.vy | 2 +- .../CryptoRegistryHandler.vy | 2 +- .../registry_handlers/StableFactoryHandler.vy | 2 +- .../StableRegistryHandler.vy | 2 +- requirements.in | 2 +- requirements.txt | 14 +++++---- scripts/print_missing.py | 3 +- scripts/setup_metaregistry.py | 4 +-- tests/fixtures/accounts.py | 4 +-- tests/fixtures/deployments.py | 12 ++++---- .../api/test_find_pool_for_coins.py | 7 +++-- .../api/test_get_admin_balances.py | 3 +- .../metaregistry/api/test_get_balances.py | 7 ++--- .../metaregistry/api/test_get_base_pool.py | 6 ++-- .../metaregistry/api/test_get_coin_indices.py | 12 ++++---- .../mainnet/metaregistry/api/test_get_fees.py | 10 +++---- .../metaregistry/api/test_get_gauge.py | 9 +++--- .../metaregistry/api/test_get_n_coins.py | 6 ++-- .../api/test_get_n_underlying_coins.py | 8 ++--- .../metaregistry/api/test_get_pool_name.py | 4 +-- .../api/test_get_underlying_balances.py | 7 +++-- .../api/test_get_underlying_coins.py | 14 +++++---- .../api/test_get_underlying_decimals.py | 5 ++-- .../api/test_get_virtual_price.py | 6 ++-- .../metaregistry/api/test_pool_is_metapool.py | 4 +-- .../test_base_registry_tracking.py | 14 ++++----- .../registries/test_add_remove_basepool.py | 13 +++++---- .../registries/test_add_remove_metapool.py | 29 ++++++++++--------- .../registries/test_add_remove_pool.py | 17 ++++++----- tests/utils.py | 3 +- 35 files changed, 127 insertions(+), 120 deletions(-) diff --git a/.github/workflows/main.yaml b/.github/workflows/main.yaml index e97f134..8e2ea13 100644 --- a/.github/workflows/main.yaml +++ b/.github/workflows/main.yaml @@ -1,6 +1,6 @@ name: unitary -on: ["push", "pull_request"] +on: ["push"] jobs: unitary: @@ -21,7 +21,7 @@ jobs: python-version: 3.11.6 - name: Install Requirements - run: pip install -r requirements.txt + run: pip install --upgrade pip && pip install --no-cache-dir -r requirements.txt - name: Run Tests run: pytest diff --git a/Dockerfile b/Dockerfile index 82d6aca..38c6a94 100644 --- a/Dockerfile +++ b/Dockerfile @@ -2,9 +2,9 @@ FROM python:3.11-slim WORKDIR /usr/app RUN pip cache purge -COPY requirements.in ./ +COPY requirements.txt ./ RUN pip install --upgrade pip && \ - pip install --no-cache-dir -r requirements.in + pip install --no-cache-dir -r requirements.txt COPY . . CMD pytest diff --git a/contracts/mainnet/MetaRegistry.vy b/contracts/mainnet/MetaRegistry.vy index 71f4d0a..8660464 100644 --- a/contracts/mainnet/MetaRegistry.vy +++ b/contracts/mainnet/MetaRegistry.vy @@ -1,4 +1,4 @@ -# @version 0.3.10 +#pragma version ^0.3.7 """ @title Curve Meta Registry @license MIT @@ -122,7 +122,7 @@ def _get_registry_handlers_from_pool(_pool: address) -> address[MAX_REGISTRIES]: c += 1 if pool_registry_handler[0] == empty(address): - raise("no registry") + raise "no registry" return pool_registry_handler diff --git a/contracts/mainnet/registries/BasePoolRegistry.vy b/contracts/mainnet/registries/BasePoolRegistry.vy index 9332a83..1f5535b 100644 --- a/contracts/mainnet/registries/BasePoolRegistry.vy +++ b/contracts/mainnet/registries/BasePoolRegistry.vy @@ -1,4 +1,4 @@ -# @version 0.3.10 +#pragma version ^0.3.7 """ @title Curve BasePool Registry @license MIT diff --git a/contracts/mainnet/registries/CryptoRegistryV1.vy b/contracts/mainnet/registries/CryptoRegistryV1.vy index d88d089..ef1690a 100644 --- a/contracts/mainnet/registries/CryptoRegistryV1.vy +++ b/contracts/mainnet/registries/CryptoRegistryV1.vy @@ -1,4 +1,4 @@ -# @version 0.3.10 +#pragma version ^0.3.7 """ @title Curve CryptoSwap Registry @license MIT diff --git a/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy b/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy index 6a42afc..8cf6d1b 100644 --- a/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy +++ b/contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.10 +#pragma version ^0.3.7 """ @title Curve Registry Handler for v2 Factory @license MIT diff --git a/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy b/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy index 3a2d33e..a008331 100644 --- a/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy +++ b/contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.10 +#pragma version ^0.3.7 """ @title Curve Registry Handler for v2 Crypto Registry @license MIT diff --git a/contracts/mainnet/registry_handlers/StableFactoryHandler.vy b/contracts/mainnet/registry_handlers/StableFactoryHandler.vy index 4710c93..32d1fe1 100644 --- a/contracts/mainnet/registry_handlers/StableFactoryHandler.vy +++ b/contracts/mainnet/registry_handlers/StableFactoryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.10 +#pragma version ^0.3.7 """ @title Curve Registry Handler for v1 Factory (latest) @license MIT diff --git a/contracts/mainnet/registry_handlers/StableRegistryHandler.vy b/contracts/mainnet/registry_handlers/StableRegistryHandler.vy index 521a3f6..80c0ad8 100644 --- a/contracts/mainnet/registry_handlers/StableRegistryHandler.vy +++ b/contracts/mainnet/registry_handlers/StableRegistryHandler.vy @@ -1,4 +1,4 @@ -# @version 0.3.10 +#pragma version ^0.3.7 """ @title Curve Registry Handler for v1 Registry @license MIT diff --git a/requirements.in b/requirements.in index 7aea6c1..478b710 100644 --- a/requirements.in +++ b/requirements.in @@ -1,4 +1,4 @@ -titanoboa==0.1.8 +titanoboa[forking-recommended]==0.1.8 black flake8 isort diff --git a/requirements.txt b/requirements.txt index 96190f3..221dcb9 100644 --- a/requirements.txt +++ b/requirements.txt @@ -126,7 +126,7 @@ pathspec==0.11.2 # via black pip-tools==7.3.0 # via -r requirements.in -platformdirs==3.11.0 +platformdirs==4.0.0 # via # black # virtualenv @@ -148,7 +148,7 @@ pycryptodome==3.19.0 # vyper pyflakes==3.1.0 # via flake8 -pygments==2.17.1 +pygments==2.17.2 # via rich pyproject-hooks==1.0.0 # via build @@ -178,17 +178,21 @@ sortedcontainers==2.4.0 # trie tabulate==0.9.0 # via -r requirements.in -titanoboa==0.1.8 - # via -r requirements.in +titanoboa[forking-recommended]==0.1.8 + # via + # -r requirements.in + # titanoboa toolz==0.12.0 # via cytoolz trie==2.2.0 # via py-evm typing-extensions==4.8.0 # via eth-typing +ujson==5.8.0 + # via titanoboa urllib3==2.1.0 # via requests -virtualenv==20.24.6 +virtualenv==20.24.7 # via pre-commit vyper==0.3.10 # via titanoboa diff --git a/scripts/print_missing.py b/scripts/print_missing.py index ac8172d..82d75e5 100644 --- a/scripts/print_missing.py +++ b/scripts/print_missing.py @@ -1,4 +1,3 @@ -import ape from tabulate import tabulate MISSING = "\033[33m✖\033[0m" @@ -22,7 +21,7 @@ def get_non_indexed_view_functions( } function_index = get_non_indexed_view_functions( - ape.project.MetaRegistry.selectors, ape.project.MetaRegistry.abi, {} + MetaRegistry.selectors, MetaRegistry.abi, {} ) registry_coverage = [[PRESENT] * len(function_index)] registry_names = [ diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index 820e783..4e41fe8 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -1,7 +1,7 @@ import sys import click -from eth.constants import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS from rich.console import Console as RichConsole from tests.utils import get_deployed_contract @@ -163,7 +163,7 @@ def main(network: str, account: str): crypto_factory_handler, ] - # setup the metaregistry: + # set up the metaregistry: total_gas_used = ( 0 # gets total gas used for setting up. should be about 5mil gas. diff --git a/tests/fixtures/accounts.py b/tests/fixtures/accounts.py index d4b5a7d..2119c8e 100644 --- a/tests/fixtures/accounts.py +++ b/tests/fixtures/accounts.py @@ -1,6 +1,3 @@ -import logging -from collections import namedtuple - import pytest from eth_account import Account from eth_account.hdaccount import HDPath @@ -20,6 +17,7 @@ def accounts(seed) -> list[LocalAccount]: Generate 10 dev accounts from a seed. Based on ape's `generate_test_accounts` method: https://github.com/ApeWorX/ape/blob/9d4b66786/src/ape/utils/testing.py#L28 + TODO: replace by boa.env.generate_address()? """ def generate_account(index: int, hd_path_format="m/44'/60'/0'/{}") -> LocalAccount: hd_path = HDPath(hd_path_format.format(index)) diff --git a/tests/fixtures/deployments.py b/tests/fixtures/deployments.py index 51d9fa4..e393835 100644 --- a/tests/fixtures/deployments.py +++ b/tests/fixtures/deployments.py @@ -34,8 +34,8 @@ def base_pool_registry(alice_address): @pytest.fixture(scope="module", autouse=True) def populated_base_pool_registry(base_pool_registry, owner, base_pools): + boa.env.eoa = owner for data in base_pools.values(): - boa.env.eoa = owner base_pool_registry.add_base_pool( data["pool"], data["lp_token"], @@ -54,6 +54,7 @@ def crypto_registry( crypto_registry = deploy_contract("CryptoRegistryV1", ADDRESS_PROVIDER, populated_base_pool_registry, directory="registries", sender=owner) + boa.env.eoa = owner for _, pool in crypto_registry_pools.items(): crypto_registry.add_pool( pool["pool"], @@ -64,7 +65,6 @@ def crypto_registry( pool["name"], pool["base_pool"], pool["has_positive_rebasing_tokens"], - sender=owner, ) return crypto_registry @@ -85,8 +85,7 @@ def metaregistry(address_provider, owner): @pytest.fixture(scope="module", autouse=True) def stable_registry_handler(stable_registry, owner): return deploy_contract( - "StableRegistryHandler", stable_registry.address, - sender=owner, directory="registry_handlers", override_address=stable_registry.address, + "StableRegistryHandler", stable_registry.address, sender=owner, directory="registry_handlers", ) @@ -94,7 +93,7 @@ def stable_registry_handler(stable_registry, owner): def stable_factory_handler(populated_base_pool_registry, stable_factory, owner): return deploy_contract( "StableFactoryHandler", stable_factory.address, populated_base_pool_registry.address, - sender=owner, directory="registry_handlers", override_address=stable_factory.address, + sender=owner, directory="registry_handlers", ) @@ -109,7 +108,7 @@ def crypto_registry_handler(owner, crypto_registry): def crypto_factory_handler(populated_base_pool_registry, crypto_factory, owner): return deploy_contract( "CryptoFactoryHandler", crypto_factory.address, populated_base_pool_registry.address, - sender=owner, directory="registry_handlers", override_address=crypto_factory.address, + sender=owner, directory="registry_handlers", ) @@ -123,6 +122,7 @@ def handlers(stable_registry_handler, stable_factory_handler, crypto_registry_ha return [stable_registry_handler, stable_factory_handler, crypto_registry_handler, crypto_factory_handler] +# TODO: Get rid of the autouse, it might make some tests slower than needed @pytest.fixture(scope="module", autouse=True) def populated_metaregistry(metaregistry, handlers, owner): for handler in handlers: diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index daad272..5222659 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -1,6 +1,7 @@ import itertools -import ape +from tests.utils import ZERO_ADDRESS + # NOTE: This is the most important method in the metaregistry contract since it will be used # by integrators to find pools for coin pairs. It finds pools even if the coin pair is not @@ -12,7 +13,7 @@ def _get_all_combinations(metaregistry, pool): pool_coins = [ coin for coin in metaregistry.get_coins(pool) - if coin != ape.utils.ZERO_ADDRESS + if coin != ZERO_ADDRESS ] base_combinations = list(itertools.combinations(pool_coins, 2)) all_combinations = base_combinations @@ -21,7 +22,7 @@ def _get_all_combinations(metaregistry, pool): underlying_coins = [ coin for coin in metaregistry.get_underlying_coins(pool) - if coin != ape.utils.ZERO_ADDRESS + if coin != ZERO_ADDRESS ] all_combinations = all_combinations + [ (pool_coins[0], coin) diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 2346257..7c4e131 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -1,4 +1,3 @@ -import ape import pytest @@ -10,7 +9,7 @@ def pre_test_checks(metaregistry, pool): try: if VyperContract(metaregistry.get_lp_token(pool)).totalSupply() == 0: pytest.skip("lp token supply is zero") - except ape.exceptions.SignatureError: + except SignatureError: pytest.skip( f"SignatureError for token {metaregistry.get_lp_token(pool)}: skipping" ) diff --git a/tests/mainnet/metaregistry/api/test_get_balances.py b/tests/mainnet/metaregistry/api/test_get_balances.py index 1df5696..5f437b1 100644 --- a/tests/mainnet/metaregistry/api/test_get_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_balances.py @@ -1,6 +1,3 @@ -import ape - - def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): @@ -34,7 +31,7 @@ def test_crypto_registry_pools( try: actual_output = crypto_registry.get_balances(crypto_registry_pool) - except ape.exceptions.ContractLogicError: + except ContractLogicError: actual_output = [] pool = curve_pool_v2(crypto_registry_pool) for i in range( @@ -55,7 +52,7 @@ def test_crypto_factory_pools( try: actual_output = crypto_factory.get_balances(crypto_factory_pool) - except ape.exceptions.ContractLogicError: + except ContractLogicError: actual_output = [] pool = curve_pool_v2(crypto_factory_pool) for i in range(2): diff --git a/tests/mainnet/metaregistry/api/test_get_base_pool.py b/tests/mainnet/metaregistry/api/test_get_base_pool.py index d89bcb7..02cd692 100644 --- a/tests/mainnet/metaregistry/api/test_get_base_pool.py +++ b/tests/mainnet/metaregistry/api/test_get_base_pool.py @@ -1,15 +1,15 @@ -import ape +from tests.utils import ZERO_ADDRESS def test_all(populated_metaregistry, populated_base_pool_registry, pool): coins = populated_metaregistry.get_coins(pool) - actual_output = ape.utils.ZERO_ADDRESS + actual_output = ZERO_ADDRESS for coin in coins: actual_output = ( populated_base_pool_registry.get_base_pool_for_lp_token(coin) ) - if actual_output != ape.utils.ZERO_ADDRESS: + if actual_output != ZERO_ADDRESS: break metaregistry_output = populated_metaregistry.get_base_pool(pool) diff --git a/tests/mainnet/metaregistry/api/test_get_coin_indices.py b/tests/mainnet/metaregistry/api/test_get_coin_indices.py index be06921..f4b7e59 100644 --- a/tests/mainnet/metaregistry/api/test_get_coin_indices.py +++ b/tests/mainnet/metaregistry/api/test_get_coin_indices.py @@ -1,8 +1,8 @@ import itertools import warnings -import ape import pytest +from tests.utils import ZERO_ADDRESS def _reject_pools_with_one_coin(metaregistry, pool): @@ -10,7 +10,7 @@ def _reject_pools_with_one_coin(metaregistry, pool): pool_coins = [ coin for coin in metaregistry.get_coins(pool) - if coin != ape.utils.ZERO_ADDRESS + if coin != ZERO_ADDRESS ] if len(list(set(pool_coins))) == 1: warnings.warn(f"Pool {pool} has only one coin!") @@ -26,7 +26,7 @@ def _get_coin_combinations(metaregistry, pool): pool_coins = [ coin for coin in metaregistry.get_coins(pool) - if coin != ape.utils.ZERO_ADDRESS + if coin != ZERO_ADDRESS ] base_combinations = list(itertools.combinations(pool_coins, 2)) @@ -35,7 +35,7 @@ def _get_coin_combinations(metaregistry, pool): underlying_coins = [ coin for coin in metaregistry.get_underlying_coins(pool) - if coin != ape.utils.ZERO_ADDRESS + if coin != ZERO_ADDRESS ] all_combinations = all_combinations + [ (pool_coins[0], coin) for coin in underlying_coins @@ -54,7 +54,7 @@ def _get_coin_indices(pool, coin_a, coin_b, metaregistry, max_coins): # check coin markets for x in range(max_coins): coin = _coins[x] - if coin == ape.utils.ZERO_ADDRESS: + if coin == ZERO_ADDRESS: # if we reach the end of the coins, reset `found_market` and try again # with the underlying coins found_market = False @@ -79,7 +79,7 @@ def _get_coin_indices(pool, coin_a, coin_b, metaregistry, max_coins): for x in range(max_coins): coin = underlying_coins[x] - if coin == ape.utils.ZERO_ADDRESS: + if coin == ZERO_ADDRESS: raise "No available market" if coin == coin_a: result[0] = x diff --git a/tests/mainnet/metaregistry/api/test_get_fees.py b/tests/mainnet/metaregistry/api/test_get_fees.py index 1975485..18647f3 100644 --- a/tests/mainnet/metaregistry/api/test_get_fees.py +++ b/tests/mainnet/metaregistry/api/test_get_fees.py @@ -1,4 +1,4 @@ -import ape +import boa import pytest @@ -11,9 +11,8 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry, - stable_registry_handler, + stable_registry_handler, # TODO: Check if this is needed ): - actual_output = stable_registry.get_fees(stable_registry_pool) metaregistry_output = populated_metaregistry.get_fees(stable_registry_pool) _check_dissimilar_length_array_elements_are_equal( @@ -25,9 +24,8 @@ def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory, - stable_factory_handler, + stable_factory_handler, # TODO: Check if this is needed ): - actual_output = stable_factory.get_fees(stable_factory_pool) metaregistry_output = populated_metaregistry.get_fees(stable_factory_pool) _check_dissimilar_length_array_elements_are_equal( @@ -43,7 +41,7 @@ def test_crypto_registry_pools( ): if sum(crypto_registry.get_balances(crypto_registry_pool)) == 0: - with ape.reverts(): + with boa.reverts(): curve_pool_v2(crypto_registry_pool).fee() pytest.skip( f"crypto factory pool {crypto_registry_pool} is empty and factory pools tend to " diff --git a/tests/mainnet/metaregistry/api/test_get_gauge.py b/tests/mainnet/metaregistry/api/test_get_gauge.py index a3e58ce..08e0230 100644 --- a/tests/mainnet/metaregistry/api/test_get_gauge.py +++ b/tests/mainnet/metaregistry/api/test_get_gauge.py @@ -1,4 +1,5 @@ -import ape +import boa +from tests.utils import ZERO_ADDRESS def _is_dao_onboarded_gauge(_gauge, gauge_controller, liquidity_gauge): @@ -29,12 +30,12 @@ def _get_factory_gauge( # as gauge type is zero. This slows down tests significantly if _is_dao_onboarded_gauge(gauge, gauge_controller, liquidity_gauge): return ( - [gauge] + [ape.utils.ZERO_ADDRESS] * 9, + [gauge] + [ZERO_ADDRESS] * 9, [gauge_controller.gauge_types(gauge)] + [0] * 9, ) else: return ( - [gauge] + [ape.utils.ZERO_ADDRESS] * 9, + [gauge] + [ZERO_ADDRESS] * 9, [default_gauge_type] * 10, ) @@ -81,7 +82,7 @@ def test_stable_factory_pools( ) ) num_registry_handlers = len( - list(filter((ape.utils.ZERO_ADDRESS).__ne__, pool_registry_handlers)) + list(filter((ZERO_ADDRESS).__ne__, pool_registry_handlers)) ) metaregistry_output_gauge = populated_metaregistry.get_gauge( diff --git a/tests/mainnet/metaregistry/api/test_get_n_coins.py b/tests/mainnet/metaregistry/api/test_get_n_coins.py index 9916605..f858a95 100644 --- a/tests/mainnet/metaregistry/api/test_get_n_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_n_coins.py @@ -1,4 +1,4 @@ -import ape +from tests.utils import ZERO_ADDRESS def _get_n_coins_for_pool(registry, pool): @@ -16,7 +16,7 @@ def _get_n_coins_for_pool(registry, pool): coins = registry.get_coins(pool) actual_output = sum( - [1 for coin in coins if coin != ape.utils.ZERO_ADDRESS] + [1 for coin in coins if coin != ZERO_ADDRESS] ) return actual_output @@ -68,7 +68,7 @@ def test_crypto_factory_pools( coins = crypto_factory.get_coins(crypto_factory_pool) actual_output = sum( - [1 for coin in coins if coin != ape.utils.ZERO_ADDRESS] + [1 for coin in coins if coin != ZERO_ADDRESS] ) metaregistry_output = populated_metaregistry.get_n_coins( crypto_factory_pool diff --git a/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py index 136a8a7..7933411 100644 --- a/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py @@ -1,4 +1,4 @@ -import ape +from tests.utils import ZERO_ADDRESS def _get_num_coins(registry, pool, base_pool_registry): @@ -7,16 +7,16 @@ def _get_num_coins(registry, pool, base_pool_registry): num_coins = 0 for coin in coins: - if coin == ape.utils.ZERO_ADDRESS: + if coin == ZERO_ADDRESS: break base_pool = base_pool_registry.get_base_pool_for_lp_token(coin) - if base_pool != ape.utils.ZERO_ADDRESS: + if base_pool != ZERO_ADDRESS: basepool_coins = base_pool_registry.get_coins(base_pool) num_bp_coins = sum( - [1 for i in basepool_coins if i != ape.utils.ZERO_ADDRESS] + [1 for i in basepool_coins if i != ZERO_ADDRESS] ) num_coins += num_bp_coins diff --git a/tests/mainnet/metaregistry/api/test_get_pool_name.py b/tests/mainnet/metaregistry/api/test_get_pool_name.py index a1fca59..1c4018b 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_name.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_name.py @@ -1,5 +1,5 @@ -import ape import pytest +from tests.utils import ZERO_ADDRESS def test_stable_registry_pools( @@ -22,7 +22,7 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): ) ) num_registry_handlers = len( - list(filter((ape.utils.ZERO_ADDRESS).__ne__, pool_registry_handlers)) + list(filter((ZERO_ADDRESS).__ne__, pool_registry_handlers)) ) if num_registry_handlers == 1: diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index e413fd8..cd1b041 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -1,7 +1,8 @@ import warnings -import ape +import boa import pytest +from tests.utils import ZERO_ADDRESS EXCEPTION_POOLS = ["0x79a8C46DeA5aDa233ABaFFD40F3A0A2B1e5A4F27"] @@ -31,7 +32,7 @@ def _get_underlying_balances( base_pool = base_pool_registry.get_base_pool_for_lp_token(coin) - if base_pool != ape.utils.ZERO_ADDRESS: + if base_pool != ZERO_ADDRESS: basepool_lp_token_balance = balances[idx] coin_contract = VyperContract(coin) @@ -52,7 +53,7 @@ def _get_underlying_balances( for idy, balance in enumerate(base_pool_balances): - if coin == ape.utils.ZERO_ADDRESS: + if coin == ZERO_ADDRESS: break actual_output[idx] = balance * ratio_in_pool diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py index a63681b..4146bcd 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py @@ -1,6 +1,8 @@ import warnings -import ape +import boa +from boa import BoaError +from tests.utils import ZERO_ADDRESS def _get_underlying_coins( @@ -8,13 +10,13 @@ def _get_underlying_coins( ): coins = registry.get_coins(pool) - underlying_coins = [ape.utils.ZERO_ADDRESS] * max_coins + underlying_coins = [ZERO_ADDRESS] * max_coins for idx, coin in enumerate(coins): base_pool = base_pool_registry_updated.get_base_pool_for_lp_token(coin) - if base_pool == ape.utils.ZERO_ADDRESS: + if base_pool == ZERO_ADDRESS: underlying_coins[idx] = coin @@ -24,7 +26,7 @@ def _get_underlying_coins( for bp_coin in basepool_coins: - if bp_coin == ape.utils.ZERO_ADDRESS: + if bp_coin == ZERO_ADDRESS: break underlying_coins[idx] = bp_coin @@ -44,7 +46,7 @@ def _check_fetched_underlying_coins(registry, pool, underlying_coins): warnings.warn(f"Pool {pool} might be a lending pool.") return registry_underlying_coins - except ape.exceptions.VirtualMachineError: + except BoaError: # TODO: Make error more specific # virtual machine errors prop up for registry.get_underlying_coins if pool # is completely depegged. We check this by setting up a revert check and # then returning underlying_coins:git @@ -55,7 +57,7 @@ def _check_fetched_underlying_coins(registry, pool, underlying_coins): balances[i] / 10 ** decimals[i] for i in range(len(decimals)) ] if min(float_balances) < 1: - with ape.reverts(): + with boa.reverts(): registry.get_underlying_coins(pool) return underlying_coins diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index ef101f1..97e0383 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -1,5 +1,6 @@ -import ape +import boa import pytest +from tests.utils import ZERO_ADDRESS EXCEPTIONS = { # eth: ankreth pool returns [18, 0] when it should return: @@ -27,7 +28,7 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): actual_output = [] for i in range(len(underlying_coins)): - if underlying_coins[i] == ape.utils.ZERO_ADDRESS: + if underlying_coins[i] == ZERO_ADDRESS: actual_output.append(0) continue diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index 594dc4c..5fe807a 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -1,7 +1,9 @@ import warnings -import ape +import boa import pytest +from tests.utils import ZERO_ADDRESS + # ---- sanity checks since vprice getters can revert for specific pools states ---- @@ -32,7 +34,7 @@ def _check_skem_tokens_with_weird_decimals( pool_balances_float = [] for i in range(len(pool_balances)): - if coins[i] == ape.utils.ZERO_ADDRESS: + if coins[i] == ZERO_ADDRESS: break pool_balances_float.append(pool_balances[i] / 10 ** coin_decimals[i]) diff --git a/tests/mainnet/metaregistry/api/test_pool_is_metapool.py b/tests/mainnet/metaregistry/api/test_pool_is_metapool.py index d3b0b39..5393737 100644 --- a/tests/mainnet/metaregistry/api/test_pool_is_metapool.py +++ b/tests/mainnet/metaregistry/api/test_pool_is_metapool.py @@ -1,4 +1,4 @@ -import ape +from tests.utils import ZERO_ADDRESS def test_stable_registry_pools( @@ -39,7 +39,7 @@ def test_crypto_factory_pools( for i in range(len(coins)): if ( populated_base_pool_registry.get_base_pool_for_lp_token(coins[i]) - != ape.utils.ZERO_ADDRESS + != ZERO_ADDRESS ): actual_output = True break diff --git a/tests/mainnet/metaregistry/test_base_registry_tracking.py b/tests/mainnet/metaregistry/test_base_registry_tracking.py index 557cf76..93cbcc8 100644 --- a/tests/mainnet/metaregistry/test_base_registry_tracking.py +++ b/tests/mainnet/metaregistry/test_base_registry_tracking.py @@ -1,4 +1,4 @@ -import ape +from tests.utils import ZERO_ADDRESS def test_new_crypto_factory_pool( @@ -10,7 +10,7 @@ def test_new_crypto_factory_pool( metaregistry.find_pool_for_coins( tokens["dai"], lp_tokens["cvxFXSFXS-f"], 0 ) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) crypto_factory.deploy_pool( @@ -35,7 +35,7 @@ def test_new_crypto_factory_pool( assert ( metaregistry.get_coins(new_pool) == [tokens["dai"], lp_tokens["cvxFXSFXS-f"]] - + [ape.utils.ZERO_ADDRESS] * 6 + + [ZERO_ADDRESS] * 6 ) assert test_pool_name in metaregistry.get_pool_name(new_pool) assert metaregistry.get_pool_from_lp_token(lp_token) == new_pool @@ -56,7 +56,7 @@ def test_new_stable_factory_pool( metaregistry.find_pool_for_coins( lp_tokens["bveCVX-CVX-f"], lp_tokens["cvxFXSFXS-f"], 0 ) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) stable_factory.deploy_plain_pool( @@ -65,8 +65,8 @@ def test_new_stable_factory_pool( [ lp_tokens["bveCVX-CVX-f"], lp_tokens["cvxFXSFXS-f"], - ape.utils.ZERO_ADDRESS, - ape.utils.ZERO_ADDRESS, + ZERO_ADDRESS, + ZERO_ADDRESS, ], 10000, 4000000, @@ -81,7 +81,7 @@ def test_new_stable_factory_pool( assert ( metaregistry.get_coins(new_pool) == [lp_tokens["bveCVX-CVX-f"], lp_tokens["cvxFXSFXS-f"]] - + [ape.utils.ZERO_ADDRESS] * 6 + + [ZERO_ADDRESS] * 6 ) assert test_pool_name in metaregistry.get_pool_name(new_pool) assert metaregistry.get_pool_from_lp_token(lp_token) == new_pool diff --git a/tests/mainnet/registries/test_add_remove_basepool.py b/tests/mainnet/registries/test_add_remove_basepool.py index 2747749..abe0e06 100644 --- a/tests/mainnet/registries/test_add_remove_basepool.py +++ b/tests/mainnet/registries/test_add_remove_basepool.py @@ -1,4 +1,5 @@ -import ape +import boa +from tests.utils import ZERO_ADDRESS def test_revert_unauthorised_add_base_pool( @@ -53,7 +54,7 @@ def test_add_basepool(owner, base_pools, tokens): assert base_pool_coins[0].lower() == tokens["dai"].lower() assert base_pool_coins[1].lower() == tokens["usdc"].lower() assert base_pool_coins[2].lower() == tokens["usdt"].lower() - assert base_pool_coins[3] == ape.utils.ZERO_ADDRESS + assert base_pool_coins[3] == ZERO_ADDRESS assert base_pool_registry.get_n_coins(tripool) == 3 base_pool_coin_decimals = base_pool_registry.get_decimals(tripool) @@ -87,7 +88,7 @@ def test_add_basepool_with_legacy_abi(owner, base_pools, tokens): assert base_pool_coins[0].lower() == tokens["renbtc"].lower() assert base_pool_coins[1].lower() == tokens["wbtc"].lower() assert base_pool_coins[2].lower() == tokens["sbtc"].lower() - assert base_pool_coins[3] == ape.utils.ZERO_ADDRESS + assert base_pool_coins[3] == ZERO_ADDRESS assert base_pool_registry.get_n_coins(btc_basepool) == 3 @@ -99,7 +100,7 @@ def test_revert_unauthorised_remove_base_pool( assert ( populated_base_pool_registry.get_lp_token(tripool_address) - != ape.utils.ZERO_ADDRESS + != ZERO_ADDRESS ) with ape.reverts(): populated_base_pool_registry.remove_base_pool( @@ -128,13 +129,13 @@ def test_remove_base_pool(populated_base_pool_registry, owner, base_pools): ) assert ( populated_base_pool_registry.get_lp_token(tripool_address) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert ( populated_base_pool_registry.get_base_pool_for_lp_token( tripool_lp_token ) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert ( populated_base_pool_registry.base_pool_list(base_pool_location) diff --git a/tests/mainnet/registries/test_add_remove_metapool.py b/tests/mainnet/registries/test_add_remove_metapool.py index d38d9af..ae12b1c 100644 --- a/tests/mainnet/registries/test_add_remove_metapool.py +++ b/tests/mainnet/registries/test_add_remove_metapool.py @@ -1,4 +1,5 @@ -import ape +import boa +from tests.utils import ZERO_ADDRESS def test_add_metapool( @@ -91,7 +92,7 @@ def test_add_metapool( tokens["eurt"].lower(), base_pools["tripool"]["lp_token"].lower(), ] + [ - ape.utils.ZERO_ADDRESS + ZERO_ADDRESS ] * 6 assert [ i.lower() @@ -102,7 +103,7 @@ def test_add_metapool( tokens["usdc"].lower(), tokens["usdt"].lower(), ] + [ - ape.utils.ZERO_ADDRESS + ZERO_ADDRESS ] * 4 assert crypto_registry.get_coin_indices( @@ -164,7 +165,7 @@ def test_add_metapool( if coin_a == coin_b: assert ( crypto_registry.find_pool_for_coins(coin_a, coin_b, 0) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) # if basepool lp token <> underlying, then it should return ZERO_ADDRESS: @@ -178,14 +179,14 @@ def test_add_metapool( ): crypto_registry.find_pool_for_coins( coin_a, coin_b, 0 - ) == ape.utils.ZERO_ADDRESS + ) == ZERO_ADDRESS elif not set( [tokens["dai"], tokens["usdc"], tokens["usdt"]] ).isdisjoint([coin_a, coin_b]): crypto_registry.find_pool_for_coins( coin_a, coin_b, 0 - ) == ape.utils.ZERO_ADDRESS + ) == ZERO_ADDRESS # everything else should go to EURTUSD pool: else: @@ -251,18 +252,18 @@ def test_remove_metapool( crypto_registry.pool_count() == pool_count - 1 ) # one pool should be gone - assert crypto_registry.get_zap(eurt3crv["pool"]) == ape.utils.ZERO_ADDRESS + assert crypto_registry.get_zap(eurt3crv["pool"]) == ZERO_ADDRESS assert ( crypto_registry.get_lp_token(eurt3crv["pool"]) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert ( crypto_registry.get_pool_from_lp_token(eurt3crv["lp_token"]) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert ( crypto_registry.get_base_pool(eurt3crv["pool"]) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert not crypto_registry.is_meta(eurt3crv["pool"]) assert crypto_registry.get_pool_name(eurt3crv["pool"]) == "" @@ -275,18 +276,18 @@ def test_remove_metapool( # gauge checks: assert ( crypto_registry.get_gauges(eurt3crv["pool"])[0][0] - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert crypto_registry.get_gauges(eurt3crv["pool"])[1][0] == 0 # coin checks: assert ( crypto_registry.get_coins(eurt3crv["pool"]) - == [ape.utils.ZERO_ADDRESS] * 8 + == [ZERO_ADDRESS] * 8 ) assert ( crypto_registry.get_underlying_coins(eurt3crv["pool"]) - == [ape.utils.ZERO_ADDRESS] * 8 + == [ZERO_ADDRESS] * 8 ) coins = [ @@ -310,5 +311,5 @@ def test_remove_metapool( assert ( crypto_registry.find_pool_for_coins(coin_a, coin_b, 0) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) diff --git a/tests/mainnet/registries/test_add_remove_pool.py b/tests/mainnet/registries/test_add_remove_pool.py index bb2653b..08cf4d3 100644 --- a/tests/mainnet/registries/test_add_remove_pool.py +++ b/tests/mainnet/registries/test_add_remove_pool.py @@ -1,4 +1,5 @@ -import ape +import boa +from tests.utils import ZERO_ADDRESS def test_revert_unauthorised_add_pool( @@ -83,7 +84,7 @@ def test_add_pool( ) assert ( crypto_registry.get_base_pool(pool_data["pool"]) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert not crypto_registry.is_meta(pool_data["pool"]) assert crypto_registry.get_pool_name(pool_data["pool"]) == "tricrypto2" @@ -113,7 +114,7 @@ def test_add_pool( tokens["wbtc"].lower(), tokens["weth"].lower(), ] + [ - ape.utils.ZERO_ADDRESS + ZERO_ADDRESS ] * 5 # check if coins and underlying coins (if any) are added to the underlying market: @@ -205,15 +206,15 @@ def test_remove_pool( crypto_registry.pool_count() == pool_count - 1 ) # one pool should be gone assert ( - crypto_registry.get_zap(tricrypto2["pool"]) == ape.utils.ZERO_ADDRESS + crypto_registry.get_zap(tricrypto2["pool"]) == ZERO_ADDRESS ) assert ( crypto_registry.get_lp_token(tricrypto2["pool"]) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert ( crypto_registry.get_pool_from_lp_token(tricrypto2["lp_token"]) - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert crypto_registry.get_pool_name(tricrypto2["pool"]) == "" @@ -221,13 +222,13 @@ def test_remove_pool( assert crypto_registry.get_decimals(tricrypto2["pool"]) == [0] * max_coins assert ( crypto_registry.get_gauges(tricrypto2["pool"])[0][0] - == ape.utils.ZERO_ADDRESS + == ZERO_ADDRESS ) assert crypto_registry.get_gauges(tricrypto2["pool"])[1][0] == 0 assert ( crypto_registry.get_coins(tricrypto2["pool"]) - == [ape.utils.ZERO_ADDRESS] * max_coins + == [ZERO_ADDRESS] * max_coins ) for coin_i in [tokens["usdt"], tokens["wbtc"], tokens["weth"]]: diff --git a/tests/utils.py b/tests/utils.py index 5e7ff62..d445a28 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -5,6 +5,7 @@ from boa.vyper.contract import VyperContract from eth_account.signers.local import LocalAccount +ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" BASE_DIR = path.join(path.dirname(path.abspath(__file__)), "..") @@ -29,7 +30,7 @@ def get_deployed_contract(contract_abi: str, address: str) -> VyperContract: return boa.load_abi(file_name).at(address) -def deploy_contract(contract: str, *args, sender: Union[LocalAccount, str], directory: str = ".", **kwargs): +def deploy_contract(contract: str, *args, sender: Union[LocalAccount, str], directory: str = ".", **kwargs) -> VyperContract: file_name = path.join(BASE_DIR, f"contracts/mainnet/{directory}/{contract}.vy") boa.env.eoa = sender if isinstance(sender, str) else sender.address return boa.load(file_name, *args, **kwargs) From 4cc75a13b37529666c75c7a5592f17321631e3d2 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Wed, 22 Nov 2023 10:46:00 +0100 Subject: [PATCH 06/19] Install pre-commit via docker --- .dockerignore | 78 +++++++++++++++++ .gitignore | 2 +- .pre-commit-config.yaml | 2 +- Dockerfile | 8 +- contracts/mainnet/abi/AddressProvider.json | 2 +- contracts/mainnet/abi/CryptoFactory.json | 2 +- contracts/mainnet/abi/CryptoRegistry.json | 2 +- contracts/mainnet/abi/GaugeController.json | 2 +- contracts/mainnet/abi/ProxyAdmin.json | 2 +- contracts/mainnet/abi/StableFactory.json | 2 +- contracts/mainnet/abi/StableRegistry.json | 2 +- docker-compose.yaml | 13 ++- scripts/boa_scripts/set_up_registries.py | 22 +++-- scripts/change_registry_handler.py | 1 - scripts/deploy.py | 1 - scripts/deploy_crypto_registry_handler.py | 1 - scripts/setup_metaregistry.py | 41 +++++---- tests/conftest.py | 20 +++-- tests/fixtures/accounts.py | 11 ++- tests/fixtures/constants.py | 3 - tests/fixtures/contracts.py | 4 +- tests/fixtures/deployments.py | 83 ++++++++++++++----- tests/fixtures/functions.py | 7 +- .../api/test_find_pool_for_coins.py | 7 +- .../api/test_get_admin_balances.py | 20 +++-- .../metaregistry/api/test_get_balances.py | 4 - .../metaregistry/api/test_get_base_pool.py | 1 - .../metaregistry/api/test_get_coin_indices.py | 18 +--- .../metaregistry/api/test_get_coins.py | 4 - .../metaregistry/api/test_get_decimals.py | 4 - .../mainnet/metaregistry/api/test_get_fees.py | 2 - .../metaregistry/api/test_get_gauge.py | 7 +- .../metaregistry/api/test_get_lp_token.py | 4 - .../metaregistry/api/test_get_n_coins.py | 15 +--- .../api/test_get_n_underlying_coins.py | 8 -- .../api/test_get_pool_asset_type.py | 3 - .../metaregistry/api/test_get_pool_name.py | 9 +- .../metaregistry/api/test_get_pool_params.py | 4 - .../api/test_get_underlying_balances.py | 14 +--- .../api/test_get_underlying_coins.py | 12 +-- .../api/test_get_underlying_decimals.py | 3 +- .../api/test_get_virtual_price.py | 16 +--- .../metaregistry/api/test_pool_is_metapool.py | 3 - .../test_base_registry_tracking.py | 3 +- .../registries/test_add_remove_basepool.py | 6 +- .../registries/test_add_remove_metapool.py | 25 ++---- .../registries/test_add_remove_pool.py | 26 ++---- tests/utils.py | 16 +++- 48 files changed, 290 insertions(+), 255 deletions(-) create mode 100644 .dockerignore diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 0000000..09362ae --- /dev/null +++ b/.dockerignore @@ -0,0 +1,78 @@ +# Git +.gitignore +.gitattributes + + +# CI +.codeclimate.yml +.travis.yml +.taskcluster.yml + +# Docker +docker-compose.yml +Dockerfile +.docker +.dockerignore + +# Byte-compiled / optimized / DLL files +**/__pycache__/ +**/*.py[cod] + +# C extensions +*.so + +# Distribution / packaging +.Python +env/ +build/ +develop-eggs/ +dist/ +downloads/ +eggs/ +lib/ +lib64/ +parts/ +sdist/ +var/ +*.egg-info/ +.installed.cfg +*.egg + +# PyInstaller +# Usually these files are written by a python script from a template +# before PyInstaller builds the exe, so as to inject date/other infos into it. +*.manifest +*.spec + +# Installer logs +pip-log.txt +pip-delete-this-directory.txt + +# Unit test / coverage reports +htmlcov/ +.tox/ +.coverage +.cache +nosetests.xml +coverage.xml + +# PyBuilder +target/ + +# Virtual environment +.env +.venv/ +venv/ + +# PyCharm +.idea + +# Python mode for VIM +.ropeproject +**/.ropeproject + +# Vim swap files +**/*.swp + +# VS Code +.vscode/ diff --git a/.gitignore b/.gitignore index 500de94..866cf27 100644 --- a/.gitignore +++ b/.gitignore @@ -7,4 +7,4 @@ __pycache__/ .DS_Store venv/ bvenv/ -.env \ No newline at end of file +.env diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 7d6119c..b3cc8b0 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -23,4 +23,4 @@ repos: args: ["--profile", "black", --line-length=79] default_language_version: - python: python3.10 + python: python3.11 diff --git a/Dockerfile b/Dockerfile index 38c6a94..d00544c 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM python:3.11-slim +FROM python:3.11-slim as base WORKDIR /usr/app RUN pip cache purge @@ -6,5 +6,11 @@ COPY requirements.txt ./ RUN pip install --upgrade pip && \ pip install --no-cache-dir -r requirements.txt +FROM base as pre-commit +RUN apt-get update && apt-get install git +COPY . . +CMD pre-commit run --all-files + +FROM base as test COPY . . CMD pytest diff --git a/contracts/mainnet/abi/AddressProvider.json b/contracts/mainnet/abi/AddressProvider.json index 734cd08..d5a3cca 100644 --- a/contracts/mainnet/abi/AddressProvider.json +++ b/contracts/mainnet/abi/AddressProvider.json @@ -306,4 +306,4 @@ "type": "function", "gas": 12168 } -] \ No newline at end of file +] diff --git a/contracts/mainnet/abi/CryptoFactory.json b/contracts/mainnet/abi/CryptoFactory.json index f8c5747..951ef0d 100644 --- a/contracts/mainnet/abi/CryptoFactory.json +++ b/contracts/mainnet/abi/CryptoFactory.json @@ -632,4 +632,4 @@ } ] } -] \ No newline at end of file +] diff --git a/contracts/mainnet/abi/CryptoRegistry.json b/contracts/mainnet/abi/CryptoRegistry.json index 486ef19..fb0feba 100644 --- a/contracts/mainnet/abi/CryptoRegistry.json +++ b/contracts/mainnet/abi/CryptoRegistry.json @@ -598,4 +598,4 @@ ], "gas": 3366 } -] \ No newline at end of file +] diff --git a/contracts/mainnet/abi/GaugeController.json b/contracts/mainnet/abi/GaugeController.json index 12179c6..669aecb 100644 --- a/contracts/mainnet/abi/GaugeController.json +++ b/contracts/mainnet/abi/GaugeController.json @@ -819,4 +819,4 @@ "type": "function", "gas": 2490 } -] \ No newline at end of file +] diff --git a/contracts/mainnet/abi/ProxyAdmin.json b/contracts/mainnet/abi/ProxyAdmin.json index d4bc6c0..a2f15e2 100644 --- a/contracts/mainnet/abi/ProxyAdmin.json +++ b/contracts/mainnet/abi/ProxyAdmin.json @@ -201,4 +201,4 @@ } ] } -] \ No newline at end of file +] diff --git a/contracts/mainnet/abi/StableFactory.json b/contracts/mainnet/abi/StableFactory.json index d6697ca..ca8bfd7 100644 --- a/contracts/mainnet/abi/StableFactory.json +++ b/contracts/mainnet/abi/StableFactory.json @@ -1060,4 +1060,4 @@ ], "gas": 3708 } -] \ No newline at end of file +] diff --git a/contracts/mainnet/abi/StableRegistry.json b/contracts/mainnet/abi/StableRegistry.json index ac50894..0dd9b2c 100644 --- a/contracts/mainnet/abi/StableRegistry.json +++ b/contracts/mainnet/abi/StableRegistry.json @@ -937,4 +937,4 @@ ], "gas": 2288 } -] \ No newline at end of file +] diff --git a/docker-compose.yaml b/docker-compose.yaml index 385d6ca..c1dd6ef 100644 --- a/docker-compose.yaml +++ b/docker-compose.yaml @@ -1,7 +1,18 @@ -version: '3.1' +version: '3.8' services: test: build: ./ container_name: metaregistry-test env_file: .env + volumes: + - ./:/usr/app + + pre-commit: + build: + context: ./ + target: pre-commit + container_name: metaregistry-pre-commit + command: pre-commit run --all-files + volumes: + - ./:/usr/app diff --git a/scripts/boa_scripts/set_up_registries.py b/scripts/boa_scripts/set_up_registries.py index 1a3cb6b..d6c56c4 100644 --- a/scripts/boa_scripts/set_up_registries.py +++ b/scripts/boa_scripts/set_up_registries.py @@ -18,11 +18,12 @@ def deploy_factory_handler(): - pass -def set_up_registries(network: str, url: str, account: str, fork: bool = False): +def set_up_registries( + network: str, url: str, account: str, fork: bool = False +): """ Set up registries for the Curve StableSwapNG factory. :param network: Network to deploy to. @@ -41,8 +42,14 @@ def set_up_registries(network: str, url: str, account: str, fork: bool = False): boa.set_env(NetworkEnv(url)) boa.env.add_account(Account.from_key(os.environ[account])) - data = next((data for _network, data in deploy_utils.curve_dao_network_settings.items() - if _network in network), None) + data = next( + ( + data + for _network, data in deploy_utils.curve_dao_network_settings.items() + if _network in network + ), + None, + ) owner = data.dao_ownership_contract fee_receiver = data.fee_receiver_address @@ -68,8 +75,9 @@ def set_up_registries(network: str, url: str, account: str, fork: bool = False): ) if is_new_deployment: - - logger.info(f"Adding a new registry provider entry at id: {max_id + 1}") + logger.info( + f"Adding a new registry provider entry at id: {max_id + 1}" + ) # we're adding a new id with accounts.use_sender(account) as account: @@ -81,7 +89,6 @@ def set_up_registries(network: str, url: str, account: str, fork: bool = False): ) else: - assert address_provider.get_id_info(index).description == description logger.info( @@ -111,7 +118,6 @@ def set_up_registries(network: str, url: str, account: str, fork: bool = False): ].base_pool_registry_address if metaregistry_address: - metaregistry = Contract(metaregistry_address) boss = Contract(metaregistry.owner()) diff --git a/scripts/change_registry_handler.py b/scripts/change_registry_handler.py index a68f2fe..7896e61 100644 --- a/scripts/change_registry_handler.py +++ b/scripts/change_registry_handler.py @@ -39,7 +39,6 @@ def main(): - # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: address_provider = AddressProvider.at(ADDRESS_PROVIDER) address_provider_admin = address_provider.admin() diff --git a/scripts/deploy.py b/scripts/deploy.py index 76cdf05..51cfc6e 100644 --- a/scripts/deploy.py +++ b/scripts/deploy.py @@ -19,7 +19,6 @@ def cli(): @network_option() @account_option() def main(network, account): - # deploy basepool registry: base_pool_registry = account.deploy(project.BasePoolRegistry) diff --git a/scripts/deploy_crypto_registry_handler.py b/scripts/deploy_crypto_registry_handler.py index 8ca850c..0c25040 100644 --- a/scripts/deploy_crypto_registry_handler.py +++ b/scripts/deploy_crypto_registry_handler.py @@ -15,7 +15,6 @@ def cli(): @network_option() @account_option() def main(network, account): - print( "Crypto Registry Handler constructor arguments: ", encode(["address"], [CRYPTO_REGISTRY_ADDRESS]).hex(), diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index 4e41fe8..b86af5c 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -1,10 +1,9 @@ import sys import click -from tests.utils import ZERO_ADDRESS from rich.console import Console as RichConsole -from tests.utils import get_deployed_contract +from tests.utils import ZERO_ADDRESS, get_deployed_contract RICH_CONSOLE = RichConsole(file=sys.stdout) @@ -138,24 +137,39 @@ def cli(): @network_option() @account_option() def main(network: str, account: str): - # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: - address_provider = get_deployed_contract('AddressProvider', ADDRESS_PROVIDER) + address_provider = get_deployed_contract( + "AddressProvider", ADDRESS_PROVIDER + ) address_provider_admin = address_provider.admin() - proxy_admin = get_deployed_contract('ProxyAdmin', address_provider_admin) + proxy_admin = get_deployed_contract("ProxyAdmin", address_provider_admin) if network == "ethereum:mainnet-fork": RICH_CONSOLE.log("Simulation mode.") account = accounts[proxy_admin.admins(1)] # deployed contracts: - base_pool_registry = get_deployed_contract('BasePoolRegistry', "0xDE3eAD9B2145bBA2EB74007e58ED07308716B725") - crypto_registry = get_deployed_contract('CryptoRegistryV1', "0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0") - stable_registry_handler = get_deployed_contract('StableRegistryHandler', "0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68") - stable_factory_handler = get_deployed_contract('StableFactoryHandler', "0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9") - crypto_registry_handler = get_deployed_contract('CryptoRegistryHandler', "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94") - crypto_factory_handler = get_deployed_contract('CryptoFactoryHandler', "0xC4F389020002396143B863F6325aA6ae481D19CE") - metaregistry = get_deployed_contract('MetaRegistry', "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC") + base_pool_registry = get_deployed_contract( + "BasePoolRegistry", "0xDE3eAD9B2145bBA2EB74007e58ED07308716B725" + ) + crypto_registry = get_deployed_contract( + "CryptoRegistryV1", "0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0" + ) + stable_registry_handler = get_deployed_contract( + "StableRegistryHandler", "0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68" + ) + stable_factory_handler = get_deployed_contract( + "StableFactoryHandler", "0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9" + ) + crypto_registry_handler = get_deployed_contract( + "CryptoRegistryHandler", "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94" + ) + crypto_factory_handler = get_deployed_contract( + "CryptoFactoryHandler", "0xC4F389020002396143B863F6325aA6ae481D19CE" + ) + metaregistry = get_deployed_contract( + "MetaRegistry", "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC" + ) registry_handlers = [ stable_registry_handler, stable_factory_handler, @@ -172,7 +186,6 @@ def main(network: str, account: str): # populate base pool registry: base_pool_index = 0 for _, data in BASE_POOLS.items(): - # check if base pool already exists in the registry: entry_at_index = base_pool_registry.base_pool_list( base_pool_index @@ -210,7 +223,6 @@ def main(network: str, account: str): # populate crypto registry: crypto_pool_index = 0 for _, pool in CRYPTO_REGISTRY_POOLS.items(): - # check if base pool already exists in the registry: entry_at_index = crypto_registry.pool_list(crypto_pool_index).lower() if entry_at_index == pool["pool"].lower(): @@ -248,7 +260,6 @@ def main(network: str, account: str): # populate metaregistry: registry_handler_index = 0 for registry_handler in registry_handlers: - # check if base pool already exists in the registry: entry_at_index = metaregistry.get_registry( registry_handler_index diff --git a/tests/conftest.py b/tests/conftest.py index bd9aa58..1c83303 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -29,14 +29,24 @@ def pytest_sessionstart(): global ALL_POOLS # connect to the network. TODO: use Drpc-Key header instead of GET param - boa.env.fork(f"https://lb.drpc.org/ogrpc?network=ethereum&dkey={environ['DRPC_KEY']}") + boa.env.fork( + f"https://lb.drpc.org/ogrpc?network=ethereum&dkey={environ['DRPC_KEY']}" + ) # store instance of registries globally, so we don't have to recreate multiple times when generating tests. # TODO: Can we move these to fixtures? - STABLE_REGISTRY_POOLS = get_contract_pools("StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5") - STABLE_FACTORY_POOLS = get_contract_pools("StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4") - CRYPTO_REGISTRY_POOLS = get_contract_pools("CryptoRegistry", "0x8F942C20D02bEfc377D41445793068908E2250D0") - CRYPTO_FACTORY_POOLS = get_contract_pools("CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99") + STABLE_REGISTRY_POOLS = get_contract_pools( + "StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" + ) + STABLE_FACTORY_POOLS = get_contract_pools( + "StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" + ) + CRYPTO_REGISTRY_POOLS = get_contract_pools( + "CryptoRegistry", "0x8F942C20D02bEfc377D41445793068908E2250D0" + ) + CRYPTO_FACTORY_POOLS = get_contract_pools( + "CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" + ) ALL_POOLS = ( STABLE_REGISTRY_POOLS diff --git a/tests/fixtures/accounts.py b/tests/fixtures/accounts.py index 2119c8e..99775b3 100644 --- a/tests/fixtures/accounts.py +++ b/tests/fixtures/accounts.py @@ -11,6 +11,7 @@ def seed() -> bytes: return Mnemonic.to_seed("test") + @pytest.fixture(scope="session") def accounts(seed) -> list[LocalAccount]: """ @@ -19,13 +20,17 @@ def accounts(seed) -> list[LocalAccount]: https://github.com/ApeWorX/ape/blob/9d4b66786/src/ape/utils/testing.py#L28 TODO: replace by boa.env.generate_address()? """ - def generate_account(index: int, hd_path_format="m/44'/60'/0'/{}") -> LocalAccount: + + def generate_account( + index: int, hd_path_format="m/44'/60'/0'/{}" + ) -> LocalAccount: hd_path = HDPath(hd_path_format.format(index)) private_key = f"0x{hd_path.derive(seed).hex()}" return Account.from_key(private_key) return [generate_account(index) for index in range(10)] + @pytest.fixture(scope="session") def alice_address(accounts): return accounts[0].address @@ -43,5 +48,7 @@ def random_address(accounts): @pytest.fixture(scope="module") def owner(accounts): - address_provider = get_deployed_contract('AddressProvider', "0x0000000022D53366457F9d5E68Ec105046FC4383") + address_provider = get_deployed_contract( + "AddressProvider", "0x0000000022D53366457F9d5E68Ec105046FC4383" + ) return address_provider.admin() diff --git a/tests/fixtures/constants.py b/tests/fixtures/constants.py index 5001718..a6a3920 100644 --- a/tests/fixtures/constants.py +++ b/tests/fixtures/constants.py @@ -1,12 +1,10 @@ import pytest - ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" @pytest.fixture(scope="module") def base_pools(): - base_pool_data = {} base_pool_data["tripool"] = { "pool": "0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7", @@ -40,7 +38,6 @@ def base_pools(): @pytest.fixture(scope="module") def crypto_registry_pools(base_pools): - pool_data = {} pool_data["tricrypto2"] = { "pool": "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46", diff --git a/tests/fixtures/contracts.py b/tests/fixtures/contracts.py index b7192f2..f0a2522 100644 --- a/tests/fixtures/contracts.py +++ b/tests/fixtures/contracts.py @@ -3,7 +3,7 @@ @pytest.fixture(scope="module") def address_provider_contract(accounts): - address_provider = get_deployed_contract('AddressProvider', - "0x0000000022D53366457F9d5E68Ec105046FC4383" + address_provider = get_deployed_contract( + "AddressProvider", "0x0000000022D53366457F9d5E68Ec105046FC4383" ) return accounts[address_provider.admin()] diff --git a/tests/fixtures/deployments.py b/tests/fixtures/deployments.py index e393835..9b4027e 100644 --- a/tests/fixtures/deployments.py +++ b/tests/fixtures/deployments.py @@ -2,34 +2,44 @@ import pytest from boa.vyper.contract import VyperContract -from tests.utils import get_deployed_contract, deploy_contract +from tests.utils import deploy_contract, get_deployed_contract ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" @pytest.fixture(scope="module", autouse=True) def gauge_controller() -> VyperContract: - return get_deployed_contract('GaugeController', "0x2F50D538606Fa9EDD2B11E2446BEb18C9D5846bB") + return get_deployed_contract( + "GaugeController", "0x2F50D538606Fa9EDD2B11E2446BEb18C9D5846bB" + ) @pytest.fixture(scope="module", autouse=True) def stable_registry() -> VyperContract: - return get_deployed_contract('StableRegistry', "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5") + return get_deployed_contract( + "StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" + ) @pytest.fixture(scope="module", autouse=True) def stable_factory() -> VyperContract: - return get_deployed_contract('StableFactory', "0xB9fC157394Af804a3578134A6585C0dc9cc990d4") + return get_deployed_contract( + "StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" + ) @pytest.fixture(scope="module", autouse=True) def crypto_factory() -> VyperContract: - return get_deployed_contract('CryptoFactory', "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99") + return get_deployed_contract( + "CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" + ) @pytest.fixture(scope="module", autouse=True) def base_pool_registry(alice_address): - return deploy_contract("BasePoolRegistry", sender=alice_address, directory="registries") + return deploy_contract( + "BasePoolRegistry", sender=alice_address, directory="registries" + ) @pytest.fixture(scope="module", autouse=True) @@ -51,8 +61,13 @@ def populated_base_pool_registry(base_pool_registry, owner, base_pools): def crypto_registry( populated_base_pool_registry, owner, crypto_registry_pools ): - crypto_registry = deploy_contract("CryptoRegistryV1", ADDRESS_PROVIDER, populated_base_pool_registry, - directory="registries", sender=owner) + crypto_registry = deploy_contract( + "CryptoRegistryV1", + ADDRESS_PROVIDER, + populated_base_pool_registry, + directory="registries", + sender=owner, + ) boa.env.eoa = owner for _, pool in crypto_registry_pools.items(): @@ -72,7 +87,7 @@ def crypto_registry( @pytest.fixture(scope="module", autouse=True) def address_provider(crypto_registry, owner): - contract = get_deployed_contract('AddressProvider', ADDRESS_PROVIDER) + contract = get_deployed_contract("AddressProvider", ADDRESS_PROVIDER) contract.set_address(5, crypto_registry, sender=owner) return contract @@ -85,41 +100,69 @@ def metaregistry(address_provider, owner): @pytest.fixture(scope="module", autouse=True) def stable_registry_handler(stable_registry, owner): return deploy_contract( - "StableRegistryHandler", stable_registry.address, sender=owner, directory="registry_handlers", + "StableRegistryHandler", + stable_registry.address, + sender=owner, + directory="registry_handlers", ) @pytest.fixture(scope="module", autouse=True) -def stable_factory_handler(populated_base_pool_registry, stable_factory, owner): +def stable_factory_handler( + populated_base_pool_registry, stable_factory, owner +): return deploy_contract( - "StableFactoryHandler", stable_factory.address, populated_base_pool_registry.address, - sender=owner, directory="registry_handlers", + "StableFactoryHandler", + stable_factory.address, + populated_base_pool_registry.address, + sender=owner, + directory="registry_handlers", ) @pytest.fixture(scope="module", autouse=True) def crypto_registry_handler(owner, crypto_registry): return deploy_contract( - "CryptoRegistryHandler", crypto_registry.address, sender=owner, directory="registry_handlers", + "CryptoRegistryHandler", + crypto_registry.address, + sender=owner, + directory="registry_handlers", ) @pytest.fixture(scope="module", autouse=True) -def crypto_factory_handler(populated_base_pool_registry, crypto_factory, owner): +def crypto_factory_handler( + populated_base_pool_registry, crypto_factory, owner +): return deploy_contract( - "CryptoFactoryHandler", crypto_factory.address, populated_base_pool_registry.address, - sender=owner, directory="registry_handlers", + "CryptoFactoryHandler", + crypto_factory.address, + populated_base_pool_registry.address, + sender=owner, + directory="registry_handlers", ) @pytest.fixture(scope="module") -def registries(stable_registry, stable_factory, crypto_registry, crypto_factory): +def registries( + stable_registry, stable_factory, crypto_registry, crypto_factory +): return [stable_registry, stable_factory, crypto_registry, crypto_factory] @pytest.fixture(scope="module") -def handlers(stable_registry_handler, stable_factory_handler, crypto_registry_handler, crypto_factory_handler): - return [stable_registry_handler, stable_factory_handler, crypto_registry_handler, crypto_factory_handler] +def handlers( + stable_registry_handler, + stable_factory_handler, + crypto_registry_handler, + crypto_factory_handler, +): + return [ + stable_registry_handler, + stable_factory_handler, + crypto_registry_handler, + crypto_factory_handler, + ] # TODO: Get rid of the autouse, it might make some tests slower than needed diff --git a/tests/fixtures/functions.py b/tests/fixtures/functions.py index 0acbddd..0d2f0ce 100644 --- a/tests/fixtures/functions.py +++ b/tests/fixtures/functions.py @@ -5,14 +5,13 @@ from tests.utils import get_deployed_contract - # ---- Factories ---- @pytest.fixture(scope="module") def curve_pool(project) -> Callable: def _initialise(_pool: str) -> VyperContract: - return get_deployed_contract('CurvePool', _pool) + return get_deployed_contract("CurvePool", _pool) return _initialise @@ -20,7 +19,7 @@ def _initialise(_pool: str) -> VyperContract: @pytest.fixture(scope="module") def curve_pool_v2(project) -> Callable: def _initialise(_pool: str) -> VyperContract: - return get_deployed_contract('CurvePoolV2', _pool) + return get_deployed_contract("CurvePoolV2", _pool) return _initialise @@ -28,6 +27,6 @@ def _initialise(_pool: str) -> VyperContract: @pytest.fixture(scope="module") def liquidity_gauge(project) -> Callable: def _initialise(_gauge: str) -> VyperContract: - return get_deployed_contract('LiquidityGauge', _gauge) + return get_deployed_contract("LiquidityGauge", _gauge) return _initialise diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index 5222659..db8f661 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -2,18 +2,14 @@ from tests.utils import ZERO_ADDRESS - # NOTE: This is the most important method in the metaregistry contract since it will be used # by integrators to find pools for coin pairs. It finds pools even if the coin pair is not # a direct coin pair, but has a path through a metapool. def _get_all_combinations(metaregistry, pool): - pool_coins = [ - coin - for coin in metaregistry.get_coins(pool) - if coin != ZERO_ADDRESS + coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS ] base_combinations = list(itertools.combinations(pool_coins, 2)) all_combinations = base_combinations @@ -34,7 +30,6 @@ def _get_all_combinations(metaregistry, pool): def test_all(populated_metaregistry, pool): - combinations = _get_all_combinations(populated_metaregistry, pool) for combination in combinations: pools_containing_pair = populated_metaregistry.find_pools_for_coins( diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 7c4e131..2cd30bc 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -2,7 +2,6 @@ def pre_test_checks(metaregistry, pool): - if sum(metaregistry.get_balances(pool)) == 0: pytest.skip("empty pool: skipping") @@ -18,7 +17,6 @@ def pre_test_checks(metaregistry, pool): def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - pre_test_checks(populated_metaregistry, stable_registry_pool) actual_output = stable_registry.get_admin_balances(stable_registry_pool) @@ -34,7 +32,6 @@ def test_stable_factory_pools( stable_factory_pool, curve_pool, ): - pre_test_checks(populated_metaregistry, stable_factory_pool) pool = curve_pool(stable_factory_pool) @@ -51,7 +48,6 @@ def test_stable_factory_pools( def _get_crypto_pool_admin_fees( populated_metaregistry, pool, fee_receiver, project, alice_address, chain ): - lp_token = VyperContract(populated_metaregistry.get_lp_token(pool)) fee_receiver_token_balance_before = lp_token.balanceOf(fee_receiver) @@ -84,13 +80,17 @@ def test_crypto_registry_pools( chain, project, ): - pre_test_checks(populated_metaregistry, crypto_registry_pool) pool = curve_pool_v2(crypto_registry_pool) fee_receiver = pool.admin_fee_receiver() admin_balances = _get_crypto_pool_admin_fees( - populated_metaregistry, pool, fee_receiver, project, alice_address, chain + populated_metaregistry, + pool, + fee_receiver, + project, + alice_address, + chain, ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) @@ -107,13 +107,17 @@ def test_crypto_factory_pools( chain, project, ): - pre_test_checks(populated_metaregistry, crypto_factory_pool) pool = curve_pool_v2(crypto_factory_pool) fee_receiver = crypto_factory.fee_receiver() admin_balances = _get_crypto_pool_admin_fees( - populated_metaregistry, pool, fee_receiver, project, alice_address, chain + populated_metaregistry, + pool, + fee_receiver, + project, + alice_address, + chain, ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) diff --git a/tests/mainnet/metaregistry/api/test_get_balances.py b/tests/mainnet/metaregistry/api/test_get_balances.py index 5f437b1..ebb5631 100644 --- a/tests/mainnet/metaregistry/api/test_get_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_balances.py @@ -1,7 +1,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - actual_output = stable_registry.get_balances(stable_registry_pool) metaregistry_output = populated_metaregistry.get_balances( stable_registry_pool @@ -13,7 +12,6 @@ def test_stable_registry_pools( def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory ): - actual_output = stable_factory.get_balances(stable_factory_pool) metaregistry_output = populated_metaregistry.get_balances( stable_factory_pool @@ -28,7 +26,6 @@ def test_crypto_registry_pools( crypto_registry, curve_pool_v2, ): - try: actual_output = crypto_registry.get_balances(crypto_registry_pool) except ContractLogicError: @@ -49,7 +46,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory, curve_pool_v2 ): - try: actual_output = crypto_factory.get_balances(crypto_factory_pool) except ContractLogicError: diff --git a/tests/mainnet/metaregistry/api/test_get_base_pool.py b/tests/mainnet/metaregistry/api/test_get_base_pool.py index 02cd692..7aca16c 100644 --- a/tests/mainnet/metaregistry/api/test_get_base_pool.py +++ b/tests/mainnet/metaregistry/api/test_get_base_pool.py @@ -2,7 +2,6 @@ def test_all(populated_metaregistry, populated_base_pool_registry, pool): - coins = populated_metaregistry.get_coins(pool) actual_output = ZERO_ADDRESS for coin in coins: diff --git a/tests/mainnet/metaregistry/api/test_get_coin_indices.py b/tests/mainnet/metaregistry/api/test_get_coin_indices.py index f4b7e59..83c4efe 100644 --- a/tests/mainnet/metaregistry/api/test_get_coin_indices.py +++ b/tests/mainnet/metaregistry/api/test_get_coin_indices.py @@ -2,15 +2,13 @@ import warnings import pytest + from tests.utils import ZERO_ADDRESS def _reject_pools_with_one_coin(metaregistry, pool): - pool_coins = [ - coin - for coin in metaregistry.get_coins(pool) - if coin != ZERO_ADDRESS + coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS ] if len(list(set(pool_coins))) == 1: warnings.warn(f"Pool {pool} has only one coin!") @@ -18,15 +16,12 @@ def _reject_pools_with_one_coin(metaregistry, pool): def _get_coin_combinations(metaregistry, pool): - # skip tests if pool has only one coin: _reject_pools_with_one_coin(metaregistry, pool) is_meta = metaregistry.is_meta(pool) pool_coins = [ - coin - for coin in metaregistry.get_coins(pool) - if coin != ZERO_ADDRESS + coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS ] base_combinations = list(itertools.combinations(pool_coins, 2)) @@ -73,7 +68,6 @@ def _get_coin_indices(pool, coin_a, coin_b, metaregistry, max_coins): found_market = True if not found_market and metaregistry.is_meta(pool): - # check underlying coin markets underlying_coins = metaregistry.get_underlying_coins(pool) @@ -97,9 +91,7 @@ def _get_coin_indices(pool, coin_a, coin_b, metaregistry, max_coins): def _test_coin_indices(coin_a, coin_b, metaregistry, pool, max_coins): - if coin_a != coin_b: - metaregistry_output = metaregistry.get_coin_indices( pool, coin_a, coin_b ) @@ -118,7 +110,6 @@ def _test_coin_indices(coin_a, coin_b, metaregistry, pool, max_coins): def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, max_coins ): - all_combinations = _get_coin_combinations( populated_metaregistry, stable_registry_pool ) @@ -138,7 +129,6 @@ def test_stable_registry_pools( def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, max_coins ): - all_combinations = _get_coin_combinations( populated_metaregistry, stable_factory_pool ) @@ -158,7 +148,6 @@ def test_stable_factory_pools( def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, max_coins ): - all_combinations = _get_coin_combinations( populated_metaregistry, crypto_registry_pool ) @@ -178,7 +167,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, max_coins ): - all_combinations = _get_coin_combinations( populated_metaregistry, crypto_factory_pool ) diff --git a/tests/mainnet/metaregistry/api/test_get_coins.py b/tests/mainnet/metaregistry/api/test_get_coins.py index 30c164e..2ca2a65 100644 --- a/tests/mainnet/metaregistry/api/test_get_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_coins.py @@ -1,7 +1,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - metaregistry_output = populated_metaregistry.get_coins( stable_registry_pool ) @@ -13,7 +12,6 @@ def test_stable_registry_pools( def test_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory ): - metaregistry_output = populated_metaregistry.get_coins(stable_factory_pool) actual_output = list(stable_factory.get_coins(stable_factory_pool)) for idx, coin in enumerate(actual_output): @@ -23,7 +21,6 @@ def test_factory_pools( def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - metaregistry_output = populated_metaregistry.get_coins( crypto_registry_pool ) @@ -35,7 +32,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory ): - metaregistry_output = populated_metaregistry.get_coins(crypto_factory_pool) actual_output = list(crypto_factory.get_coins(crypto_factory_pool)) for idx, coin in enumerate(actual_output): diff --git a/tests/mainnet/metaregistry/api/test_get_decimals.py b/tests/mainnet/metaregistry/api/test_get_decimals.py index 780da92..242258d 100644 --- a/tests/mainnet/metaregistry/api/test_get_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_decimals.py @@ -1,7 +1,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - metaregistry_output = populated_metaregistry.get_decimals( stable_registry_pool ) @@ -13,7 +12,6 @@ def test_stable_registry_pools( def test_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory ): - metaregistry_output = populated_metaregistry.get_decimals( stable_factory_pool ) @@ -25,7 +23,6 @@ def test_factory_pools( def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - metaregistry_output = populated_metaregistry.get_decimals( crypto_registry_pool ) @@ -37,7 +34,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory ): - metaregistry_output = populated_metaregistry.get_decimals( crypto_factory_pool ) diff --git a/tests/mainnet/metaregistry/api/test_get_fees.py b/tests/mainnet/metaregistry/api/test_get_fees.py index 18647f3..255d5be 100644 --- a/tests/mainnet/metaregistry/api/test_get_fees.py +++ b/tests/mainnet/metaregistry/api/test_get_fees.py @@ -39,7 +39,6 @@ def test_crypto_registry_pools( crypto_registry, curve_pool_v2, ): - if sum(crypto_registry.get_balances(crypto_registry_pool)) == 0: with boa.reverts(): curve_pool_v2(crypto_registry_pool).fee() @@ -62,7 +61,6 @@ def test_crypto_factory_pools( crypto_factory, curve_pool_v2, ): - if sum(crypto_factory.get_balances(crypto_factory_pool)) == 0: with ape.reverts(): curve_pool_v2(crypto_factory_pool).fee() diff --git a/tests/mainnet/metaregistry/api/test_get_gauge.py b/tests/mainnet/metaregistry/api/test_get_gauge.py index 08e0230..ddc1a9a 100644 --- a/tests/mainnet/metaregistry/api/test_get_gauge.py +++ b/tests/mainnet/metaregistry/api/test_get_gauge.py @@ -1,9 +1,9 @@ import boa + from tests.utils import ZERO_ADDRESS def _is_dao_onboarded_gauge(_gauge, gauge_controller, liquidity_gauge): - try: gauge_controller.gauge_types(_gauge) except ape.exceptions.VirtualMachineError: @@ -22,7 +22,6 @@ def _get_factory_gauge( liquidity_gauge, default_gauge_type: int = 0, ): - gauge = registry.get_gauge(pool) # we check if the gauge is dao onboarded, else @@ -45,7 +44,6 @@ def test_stable_registry_pools( stable_registry_pool, stable_registry, ): - actual_output = stable_registry.get_gauges(stable_registry_pool) metaregistry_output_gauge = populated_metaregistry.get_gauge( stable_registry_pool @@ -65,7 +63,6 @@ def test_stable_factory_pools( gauge_controller, liquidity_gauge, ): - actual_output = _get_factory_gauge( stable_factory, stable_factory_pool, gauge_controller, liquidity_gauge ) @@ -99,7 +96,6 @@ def test_stable_factory_pools( def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - actual_output = crypto_registry.get_gauges(crypto_registry_pool) metaregistry_output_gauge = populated_metaregistry.get_gauge( crypto_registry_pool @@ -119,7 +115,6 @@ def test_crypto_factory_pools( gauge_controller, liquidity_gauge, ): - # warning: gauge_type == 5 : this is true only for crypto pools on ethereum actual_output = _get_factory_gauge( crypto_factory, diff --git a/tests/mainnet/metaregistry/api/test_get_lp_token.py b/tests/mainnet/metaregistry/api/test_get_lp_token.py index 351b6bc..1d9e47c 100644 --- a/tests/mainnet/metaregistry/api/test_get_lp_token.py +++ b/tests/mainnet/metaregistry/api/test_get_lp_token.py @@ -1,7 +1,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - actual_output = stable_registry.get_lp_token(stable_registry_pool) metaregistry_output = populated_metaregistry.get_lp_token( stable_registry_pool @@ -10,7 +9,6 @@ def test_stable_registry_pools( def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): - metaregistry_output = populated_metaregistry.get_lp_token( stable_factory_pool ) @@ -22,7 +20,6 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - actual_output = crypto_registry.get_lp_token(crypto_registry_pool) metaregistry_output = populated_metaregistry.get_lp_token( crypto_registry_pool @@ -33,7 +30,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory ): - actual_output = crypto_factory.get_token(crypto_factory_pool) metaregistry_output = populated_metaregistry.get_lp_token( crypto_factory_pool diff --git a/tests/mainnet/metaregistry/api/test_get_n_coins.py b/tests/mainnet/metaregistry/api/test_get_n_coins.py index f858a95..0c35d2b 100644 --- a/tests/mainnet/metaregistry/api/test_get_n_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_n_coins.py @@ -2,22 +2,17 @@ def _get_n_coins_for_pool(registry, pool): - actual_output = registry.get_n_coins(pool) # registry returns tuple, we want the first one (since the second) # index is about basepool n coins if not isinstance(actual_output, int): - actual_output = registry.get_n_coins(pool)[0] # registry returns 0 value for n coins: something's not right on the # registry's side. find n_coins via registry.get_coins: elif actual_output == 0: - coins = registry.get_coins(pool) - actual_output = sum( - [1 for coin in coins if coin != ZERO_ADDRESS] - ) + actual_output = sum([1 for coin in coins if coin != ZERO_ADDRESS]) return actual_output @@ -25,7 +20,6 @@ def _get_n_coins_for_pool(registry, pool): def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - actual_output = _get_n_coins_for_pool( stable_registry, stable_registry_pool ) @@ -39,7 +33,6 @@ def test_stable_registry_pools( def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory ): - actual_output = _get_n_coins_for_pool(stable_factory, stable_factory_pool) metaregistry_output = populated_metaregistry.get_n_coins( @@ -51,7 +44,6 @@ def test_stable_factory_pools( def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - actual_output = _get_n_coins_for_pool( crypto_registry, crypto_registry_pool ) @@ -65,11 +57,8 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory ): - coins = crypto_factory.get_coins(crypto_factory_pool) - actual_output = sum( - [1 for coin in coins if coin != ZERO_ADDRESS] - ) + actual_output = sum([1 for coin in coins if coin != ZERO_ADDRESS]) metaregistry_output = populated_metaregistry.get_n_coins( crypto_factory_pool ) diff --git a/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py index 7933411..9b042af 100644 --- a/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py @@ -2,18 +2,15 @@ def _get_num_coins(registry, pool, base_pool_registry): - coins = registry.get_coins(pool) num_coins = 0 for coin in coins: - if coin == ZERO_ADDRESS: break base_pool = base_pool_registry.get_base_pool_for_lp_token(coin) if base_pool != ZERO_ADDRESS: - basepool_coins = base_pool_registry.get_coins(base_pool) num_bp_coins = sum( [1 for i in basepool_coins if i != ZERO_ADDRESS] @@ -21,7 +18,6 @@ def _get_num_coins(registry, pool, base_pool_registry): num_coins += num_bp_coins else: - num_coins += 1 return num_coins @@ -33,7 +29,6 @@ def test_stable_registry_pools( stable_registry, populated_base_pool_registry, ): - metaregistry_output = populated_metaregistry.get_n_underlying_coins( stable_registry_pool ) @@ -50,7 +45,6 @@ def test_stable_factory_pools( stable_factory, populated_base_pool_registry, ): - metaregistry_output = populated_metaregistry.get_n_underlying_coins( stable_factory_pool ) @@ -67,7 +61,6 @@ def test_crypto_registry_pools( crypto_registry, populated_base_pool_registry, ): - metaregistry_output = populated_metaregistry.get_n_underlying_coins( crypto_registry_pool ) @@ -84,7 +77,6 @@ def test_crypto_factory_pools( crypto_factory, populated_base_pool_registry, ): - metaregistry_output = populated_metaregistry.get_n_underlying_coins( crypto_factory_pool ) diff --git a/tests/mainnet/metaregistry/api/test_get_pool_asset_type.py b/tests/mainnet/metaregistry/api/test_get_pool_asset_type.py index 73909ee..706bf87 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_asset_type.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_asset_type.py @@ -6,7 +6,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - assert populated_metaregistry.get_pool_asset_type( stable_registry_pool ) == stable_registry.get_pool_asset_type(stable_registry_pool) @@ -26,12 +25,10 @@ def test_stable_factory_pools( def test_crypto_registry_pools(populated_metaregistry, crypto_registry_pool): - assert ( populated_metaregistry.get_pool_asset_type(crypto_registry_pool) == 4 ) def test_crypto_factory_pools(populated_metaregistry, crypto_factory_pool): - assert populated_metaregistry.get_pool_asset_type(crypto_factory_pool) == 4 diff --git a/tests/mainnet/metaregistry/api/test_get_pool_name.py b/tests/mainnet/metaregistry/api/test_get_pool_name.py index 1c4018b..1e7df87 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_name.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_name.py @@ -1,18 +1,17 @@ import pytest + from tests.utils import ZERO_ADDRESS def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - assert populated_metaregistry.get_pool_name( stable_registry_pool ) == stable_registry.get_pool_name(stable_registry_pool) def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): - # same issues where a pool that was first in a registry got ported over to the # factory incorrectly. so we try different handler indices to check if we get # the right result: @@ -26,16 +25,13 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): ) if num_registry_handlers == 1: - assert ( populated_metaregistry.get_pool_name(stable_factory_pool) == VyperContract(stable_factory_pool).name() ) elif num_registry_handlers == 2: - with pytest.raises(AssertionError): - assert ( populated_metaregistry.get_pool_name(stable_factory_pool) == VyperContract(stable_factory_pool).name() @@ -47,14 +43,12 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): ) else: - raise def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - assert populated_metaregistry.get_pool_name( crypto_registry_pool ) == crypto_registry.get_pool_name(crypto_registry_pool) @@ -63,7 +57,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory ): - assert ( populated_metaregistry.get_pool_name(crypto_factory_pool) == VyperContract(crypto_factory.get_token(crypto_factory_pool)).name() diff --git a/tests/mainnet/metaregistry/api/test_get_pool_params.py b/tests/mainnet/metaregistry/api/test_get_pool_params.py index f8c96f0..43fd164 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_params.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_params.py @@ -1,7 +1,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - actual_pool_params = [0] * 20 actual_pool_params[0] = stable_registry.get_A(stable_registry_pool) metaregistry_output = populated_metaregistry.get_pool_params( @@ -14,7 +13,6 @@ def test_stable_registry_pools( def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory ): - metaregistry_output = populated_metaregistry.get_pool_params( stable_factory_pool ) @@ -30,7 +28,6 @@ def test_crypto_registry_pools( crypto_registry, curve_pool_v2, ): - metaregistry_output = populated_metaregistry.get_pool_params( crypto_registry_pool ) @@ -50,7 +47,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, curve_pool_v2 ): - metaregistry_output = populated_metaregistry.get_pool_params( crypto_factory_pool ) diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index cd1b041..9205e4f 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -2,13 +2,13 @@ import boa import pytest + from tests.utils import ZERO_ADDRESS EXCEPTION_POOLS = ["0x79a8C46DeA5aDa233ABaFFD40F3A0A2B1e5A4F27"] def pre_test_checks(metaregistry, pool): - if sum(metaregistry.get_balances(pool)) == 0: pytest.skip(f"Empty pool: {pool}") @@ -16,24 +16,19 @@ def pre_test_checks(metaregistry, pool): def _get_underlying_balances( metaregistry, pool, registry, base_pool_registry, max_coins ): - actual_output = [0] * max_coins try: - actual_output = registry.get_underlying_balances(pool) # registry getter borks, so we need to get balances the hard way: except (ape.exceptions.ContractLogicError, AttributeError): - coins = metaregistry.get_coins(pool) balances = metaregistry.get_balances(pool) for idx, coin in enumerate(coins): - base_pool = base_pool_registry.get_base_pool_for_lp_token(coin) if base_pool != ZERO_ADDRESS: - basepool_lp_token_balance = balances[idx] coin_contract = VyperContract(coin) try: @@ -52,7 +47,6 @@ def _get_underlying_balances( base_pool_balances = metaregistry.get_balances(base_pool) for idy, balance in enumerate(base_pool_balances): - if coin == ZERO_ADDRESS: break actual_output[idx] = balance * ratio_in_pool @@ -67,7 +61,6 @@ def _get_underlying_balances( def _test_underlying_balances_getter( metaregistry, pool, registry, base_pool_registry, max_coins ): - actual_output = _get_underlying_balances( metaregistry, pool, registry, base_pool_registry, max_coins ) @@ -75,18 +68,14 @@ def _test_underlying_balances_getter( underlying_decimals = metaregistry.get_underlying_decimals(pool) for idx, registry_value in enumerate(actual_output): - try: - assert registry_value == pytest.approx( metaregistry_output[idx] * 10 ** (18 - underlying_decimals[idx]) ) except AssertionError: - if pool in EXCEPTION_POOLS: - warnings.warn("Skipping test for pool: {}".format(pool)) pytest.skip( "Unresolved output from Borky pool: {}".format(pool) @@ -151,7 +140,6 @@ def test_crypto_factory_pools( crypto_factory, max_coins, ): - pre_test_checks(populated_metaregistry, crypto_factory_pool) _test_underlying_balances_getter( diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py index 4146bcd..e57af26 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py @@ -2,30 +2,26 @@ import boa from boa import BoaError + from tests.utils import ZERO_ADDRESS def _get_underlying_coins( registry, base_pool_registry_updated, pool, max_coins ): - coins = registry.get_coins(pool) underlying_coins = [ZERO_ADDRESS] * max_coins for idx, coin in enumerate(coins): - base_pool = base_pool_registry_updated.get_base_pool_for_lp_token(coin) if base_pool == ZERO_ADDRESS: - underlying_coins[idx] = coin else: - basepool_coins = base_pool_registry_updated.get_coins(base_pool) for bp_coin in basepool_coins: - if bp_coin == ZERO_ADDRESS: break @@ -38,9 +34,7 @@ def _get_underlying_coins( def _check_fetched_underlying_coins(registry, pool, underlying_coins): - try: - registry_underlying_coins = registry.get_underlying_coins(pool) if registry_underlying_coins != underlying_coins: warnings.warn(f"Pool {pool} might be a lending pool.") @@ -71,7 +65,6 @@ def test_stable_registry_pools( stable_registry, max_coins, ): - metaregistry_output = populated_metaregistry.get_underlying_coins( stable_registry_pool ) @@ -96,7 +89,6 @@ def test_stable_factory_pools( stable_factory, max_coins, ): - metaregistry_output = populated_metaregistry.get_underlying_coins( stable_factory_pool ) @@ -121,7 +113,6 @@ def test_crypto_registry_pools( crypto_registry, max_coins, ): - metaregistry_output = populated_metaregistry.get_underlying_coins( crypto_registry_pool ) @@ -146,7 +137,6 @@ def test_crypto_factory_pools( crypto_factory, max_coins, ): - metaregistry_output = populated_metaregistry.get_underlying_coins( crypto_factory_pool ) diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index 97e0383..c4f23bf 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -1,5 +1,6 @@ import boa import pytest + from tests.utils import ZERO_ADDRESS EXCEPTIONS = { @@ -16,7 +17,6 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): - metaregistry_output = metaregistry.get_underlying_decimals(pool) assert metaregistry_output[1] != 0 # there has to be a second coin! @@ -27,7 +27,6 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): underlying_coins = metaregistry.get_underlying_coins(pool) actual_output = [] for i in range(len(underlying_coins)): - if underlying_coins[i] == ZERO_ADDRESS: actual_output.append(0) continue diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index 5fe807a..b7ca097 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -2,17 +2,15 @@ import boa import pytest -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS # ---- sanity checks since vprice getters can revert for specific pools states ---- def _check_pool_has_no_liquidity(metaregistry, pool, pool_balances, lp_token): - # skip if pool has little to no liquidity, since vprice queries will most likely bork: if sum(pool_balances) == 0: - with ape.reverts(): metaregistry.get_virtual_price_from_lp_token(lp_token) @@ -28,12 +26,10 @@ def _check_pool_has_no_liquidity(metaregistry, pool, pool_balances, lp_token): def _check_skem_tokens_with_weird_decimals( metaregistry, pool, lp_token, pool_balances, coins, coin_decimals ): - # check if pool balances after accounting for decimals is legible. # some scam tokens can have weird token properties (e.g. ELONX) pool_balances_float = [] for i in range(len(pool_balances)): - if coins[i] == ZERO_ADDRESS: break @@ -60,7 +56,6 @@ def _check_pool_is_depegged( coin_decimals, lp_token, ): - for i in range(len(pool_balances)): # check if pool balances are skewed: vprice calc will bork if one of the coin # balances is close to zero. @@ -77,14 +72,15 @@ def _check_pool_is_depegged( f"skewed pool: {pool} as num coins (decimals divided) at index {i} is " f"{pool_balances[i] / 10 ** coin_decimals[i]}" ) - except AssertionError: # ok to catch this assertion error since we continue testing + except ( + AssertionError + ): # ok to catch this assertion error since we continue testing warnings.warn( "pool virtual price getter did not revert. continuing test" ) def pre_test_checks(metaregistry, pool): - pool_balances = metaregistry.get_balances(pool) lp_token = metaregistry.get_lp_token(pool) @@ -115,7 +111,6 @@ def pre_test_checks(metaregistry, pool): def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - # if checks fail, pytest skips, else lp_token is returned: lp_token = pre_test_checks(populated_metaregistry, stable_registry_pool) actual_output = stable_registry.get_virtual_price_from_lp_token(lp_token) @@ -128,7 +123,6 @@ def test_stable_registry_pools( def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, curve_pool ): - # if checks fail, pytest skips, else lp_token is returned: lp_token = pre_test_checks(populated_metaregistry, stable_factory_pool) @@ -146,7 +140,6 @@ def test_stable_factory_pools( def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - # if checks fail, pytest skips, else lp_token is returned: lp_token = pre_test_checks(populated_metaregistry, crypto_registry_pool) actual_output = crypto_registry.get_virtual_price_from_lp_token(lp_token) @@ -159,7 +152,6 @@ def test_crypto_registry_pools( def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, curve_pool ): - # if checks fail, pytest skips, else lp_token is returned: lp_token = pre_test_checks(populated_metaregistry, crypto_factory_pool) actual_output = curve_pool(crypto_factory_pool).get_virtual_price() diff --git a/tests/mainnet/metaregistry/api/test_pool_is_metapool.py b/tests/mainnet/metaregistry/api/test_pool_is_metapool.py index 5393737..4847596 100644 --- a/tests/mainnet/metaregistry/api/test_pool_is_metapool.py +++ b/tests/mainnet/metaregistry/api/test_pool_is_metapool.py @@ -4,7 +4,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): - actual_output = stable_registry.is_meta(stable_registry_pool) metaregistry_output = populated_metaregistry.is_meta(stable_registry_pool) assert actual_output == metaregistry_output @@ -13,7 +12,6 @@ def test_stable_registry_pools( def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory ): - actual_output = stable_factory.is_meta(stable_factory_pool) metaregistry_output = populated_metaregistry.is_meta(stable_factory_pool) assert actual_output == metaregistry_output @@ -22,7 +20,6 @@ def test_stable_factory_pools( def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - actual_output = crypto_registry.is_meta(crypto_registry_pool) metaregistry_output = populated_metaregistry.is_meta(crypto_registry_pool) assert actual_output == metaregistry_output diff --git a/tests/mainnet/metaregistry/test_base_registry_tracking.py b/tests/mainnet/metaregistry/test_base_registry_tracking.py index 93cbcc8..20e6ee2 100644 --- a/tests/mainnet/metaregistry/test_base_registry_tracking.py +++ b/tests/mainnet/metaregistry/test_base_registry_tracking.py @@ -34,8 +34,7 @@ def test_new_crypto_factory_pool( assert ( metaregistry.get_coins(new_pool) - == [tokens["dai"], lp_tokens["cvxFXSFXS-f"]] - + [ZERO_ADDRESS] * 6 + == [tokens["dai"], lp_tokens["cvxFXSFXS-f"]] + [ZERO_ADDRESS] * 6 ) assert test_pool_name in metaregistry.get_pool_name(new_pool) assert metaregistry.get_pool_from_lp_token(lp_token) == new_pool diff --git a/tests/mainnet/registries/test_add_remove_basepool.py b/tests/mainnet/registries/test_add_remove_basepool.py index abe0e06..516d55c 100644 --- a/tests/mainnet/registries/test_add_remove_basepool.py +++ b/tests/mainnet/registries/test_add_remove_basepool.py @@ -1,11 +1,11 @@ import boa + from tests.utils import ZERO_ADDRESS def test_revert_unauthorised_add_base_pool( owner, unauthorised_address, base_pools ): - base_pool_registry = ape.project.BasePoolRegistry.deploy(sender=owner) base_pool_data = base_pools["tripool"] @@ -22,7 +22,6 @@ def test_revert_unauthorised_add_base_pool( def test_add_basepool(owner, base_pools, tokens): - base_pool_registry = ape.project.BasePoolRegistry.deploy(sender=owner) base_pool_count = base_pool_registry.base_pool_count() @@ -64,7 +63,6 @@ def test_add_basepool(owner, base_pools, tokens): def test_add_basepool_with_legacy_abi(owner, base_pools, tokens): - base_pool_registry = ape.project.BasePoolRegistry.deploy(sender=owner) base_pool_data = base_pools["sbtc"] @@ -95,7 +93,6 @@ def test_add_basepool_with_legacy_abi(owner, base_pools, tokens): def test_revert_unauthorised_remove_base_pool( populated_base_pool_registry, unauthorised_address, base_pools ): - tripool_address = base_pools["tripool"]["pool"] assert ( @@ -109,7 +106,6 @@ def test_revert_unauthorised_remove_base_pool( def test_remove_base_pool(populated_base_pool_registry, owner, base_pools): - tripool_address = base_pools["tripool"]["pool"] tripool_lp_token = base_pools["tripool"]["lp_token"] diff --git a/tests/mainnet/registries/test_add_remove_metapool.py b/tests/mainnet/registries/test_add_remove_metapool.py index ae12b1c..d127c40 100644 --- a/tests/mainnet/registries/test_add_remove_metapool.py +++ b/tests/mainnet/registries/test_add_remove_metapool.py @@ -1,4 +1,5 @@ import boa + from tests.utils import ZERO_ADDRESS @@ -11,7 +12,6 @@ def test_add_metapool( base_pools, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( address_provider, populated_base_pool_registry, sender=owner ) @@ -160,7 +160,6 @@ def test_add_metapool( ] for coin_a in coins: for coin_b in coins: - # if both coins are the same, then it should return ZERO_ADDRESS: if coin_a == coin_b: assert ( @@ -207,7 +206,6 @@ def test_remove_metapool( base_pools, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( address_provider, populated_base_pool_registry, sender=owner ) @@ -253,18 +251,12 @@ def test_remove_metapool( ) # one pool should be gone assert crypto_registry.get_zap(eurt3crv["pool"]) == ZERO_ADDRESS - assert ( - crypto_registry.get_lp_token(eurt3crv["pool"]) - == ZERO_ADDRESS - ) + assert crypto_registry.get_lp_token(eurt3crv["pool"]) == ZERO_ADDRESS assert ( crypto_registry.get_pool_from_lp_token(eurt3crv["lp_token"]) == ZERO_ADDRESS ) - assert ( - crypto_registry.get_base_pool(eurt3crv["pool"]) - == ZERO_ADDRESS - ) + assert crypto_registry.get_base_pool(eurt3crv["pool"]) == ZERO_ADDRESS assert not crypto_registry.is_meta(eurt3crv["pool"]) assert crypto_registry.get_pool_name(eurt3crv["pool"]) == "" @@ -274,17 +266,11 @@ def test_remove_metapool( assert crypto_registry.get_underlying_decimals(eurt3crv["pool"]) == [0] * 8 # gauge checks: - assert ( - crypto_registry.get_gauges(eurt3crv["pool"])[0][0] - == ZERO_ADDRESS - ) + assert crypto_registry.get_gauges(eurt3crv["pool"])[0][0] == ZERO_ADDRESS assert crypto_registry.get_gauges(eurt3crv["pool"])[1][0] == 0 # coin checks: - assert ( - crypto_registry.get_coins(eurt3crv["pool"]) - == [ZERO_ADDRESS] * 8 - ) + assert crypto_registry.get_coins(eurt3crv["pool"]) == [ZERO_ADDRESS] * 8 assert ( crypto_registry.get_underlying_coins(eurt3crv["pool"]) == [ZERO_ADDRESS] * 8 @@ -300,7 +286,6 @@ def test_remove_metapool( # find pool for coins: for coin_a in coins: for coin_b in coins: - assert crypto_registry.get_coin_indices( eurt3crv["pool"], coin_a, coin_b ) == ( diff --git a/tests/mainnet/registries/test_add_remove_pool.py b/tests/mainnet/registries/test_add_remove_pool.py index 08cf4d3..ce0ffe8 100644 --- a/tests/mainnet/registries/test_add_remove_pool.py +++ b/tests/mainnet/registries/test_add_remove_pool.py @@ -1,11 +1,11 @@ import boa + from tests.utils import ZERO_ADDRESS def test_revert_unauthorised_add_pool( crypto_registry, unauthorised_address, crypto_registry_pools ): - pool_data = crypto_registry_pools["tricrypto2"] with ape.reverts(): @@ -25,7 +25,6 @@ def test_revert_unauthorised_add_pool( def test_revert_add_existing_pool( crypto_registry, owner, crypto_registry_pools ): - pool_data = crypto_registry_pools["tricrypto2"] with ape.reverts(): @@ -49,7 +48,6 @@ def test_add_pool( owner, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( address_provider.address, populated_base_pool_registry, sender=owner ) @@ -82,10 +80,7 @@ def test_add_pool( crypto_registry.get_pool_from_lp_token(pool_data["lp_token"]) == pool_data["pool"] ) - assert ( - crypto_registry.get_base_pool(pool_data["pool"]) - == ZERO_ADDRESS - ) + assert crypto_registry.get_base_pool(pool_data["pool"]) == ZERO_ADDRESS assert not crypto_registry.is_meta(pool_data["pool"]) assert crypto_registry.get_pool_name(pool_data["pool"]) == "tricrypto2" @@ -143,7 +138,6 @@ def test_add_pool( def test_revert_unauthorised_remove_pool( crypto_registry, unauthorised_address, crypto_registry_pools ): - with ape.reverts(): crypto_registry.remove_pool( crypto_registry_pools["tricrypto2"]["pool"], @@ -159,7 +153,6 @@ def test_remove_pool( max_coins, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( address_provider.address, populated_base_pool_registry, sender=owner ) @@ -205,13 +198,8 @@ def test_remove_pool( assert ( crypto_registry.pool_count() == pool_count - 1 ) # one pool should be gone - assert ( - crypto_registry.get_zap(tricrypto2["pool"]) == ZERO_ADDRESS - ) - assert ( - crypto_registry.get_lp_token(tricrypto2["pool"]) - == ZERO_ADDRESS - ) + assert crypto_registry.get_zap(tricrypto2["pool"]) == ZERO_ADDRESS + assert crypto_registry.get_lp_token(tricrypto2["pool"]) == ZERO_ADDRESS assert ( crypto_registry.get_pool_from_lp_token(tricrypto2["lp_token"]) == ZERO_ADDRESS @@ -220,10 +208,7 @@ def test_remove_pool( assert crypto_registry.get_n_coins(tricrypto2["pool"]) == 0 assert crypto_registry.get_decimals(tricrypto2["pool"]) == [0] * max_coins - assert ( - crypto_registry.get_gauges(tricrypto2["pool"])[0][0] - == ZERO_ADDRESS - ) + assert crypto_registry.get_gauges(tricrypto2["pool"])[0][0] == ZERO_ADDRESS assert crypto_registry.get_gauges(tricrypto2["pool"])[1][0] == 0 assert ( @@ -233,7 +218,6 @@ def test_remove_pool( for coin_i in [tokens["usdt"], tokens["wbtc"], tokens["weth"]]: for coin_j in [tokens["usdt"], tokens["wbtc"], tokens["weth"]]: - assert crypto_registry.get_coin_indices( tricrypto2["pool"], coin_i, coin_j ) == ( diff --git a/tests/utils.py b/tests/utils.py index d445a28..4583640 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -26,11 +26,21 @@ def get_deployed_contract(contract_abi: str, address: str) -> VyperContract: :param contract_abi: The name of the contract to load. :param address: The address of the deployed contract. """ - file_name = path.join(BASE_DIR, f"contracts/mainnet/abi/{contract_abi}.json") + file_name = path.join( + BASE_DIR, f"contracts/mainnet/abi/{contract_abi}.json" + ) return boa.load_abi(file_name).at(address) -def deploy_contract(contract: str, *args, sender: Union[LocalAccount, str], directory: str = ".", **kwargs) -> VyperContract: - file_name = path.join(BASE_DIR, f"contracts/mainnet/{directory}/{contract}.vy") +def deploy_contract( + contract: str, + *args, + sender: Union[LocalAccount, str], + directory: str = ".", + **kwargs, +) -> VyperContract: + file_name = path.join( + BASE_DIR, f"contracts/mainnet/{directory}/{contract}.vy" + ) boa.env.eoa = sender if isinstance(sender, str) else sender.address return boa.load(file_name, *args, **kwargs) From e9eaabefadfa561f80b8ebe9266a1ede911be939 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Wed, 22 Nov 2023 11:02:41 +0100 Subject: [PATCH 07/19] Build fixes --- .github/workflows/.pre-commit-config.yaml | 4 ++-- .github/workflows/main.yaml | 2 +- Dockerfile | 4 ++-- docker-compose.yaml | 1 - tests/conftest.py | 4 +--- 5 files changed, 6 insertions(+), 9 deletions(-) diff --git a/.github/workflows/.pre-commit-config.yaml b/.github/workflows/.pre-commit-config.yaml index f0da0b1..0ae2959 100644 --- a/.github/workflows/.pre-commit-config.yaml +++ b/.github/workflows/.pre-commit-config.yaml @@ -9,10 +9,10 @@ jobs: - name: Checkout uses: actions/checkout@v4 - - name: Setup Python 3.10.13 + - name: Setup Python uses: actions/setup-python@v4 with: - python-version: 3.10.13 + python-version: 3.11 - name: Pre-commit checks uses: pre-commit/action@v3.0.0 diff --git a/.github/workflows/main.yaml b/.github/workflows/main.yaml index 8e2ea13..205d557 100644 --- a/.github/workflows/main.yaml +++ b/.github/workflows/main.yaml @@ -26,4 +26,4 @@ jobs: - name: Run Tests run: pytest env: - DRPC_KEY: ${{ secrets.DRPC_KEY }} + RPC_ETHEREUM: ${{ secrets.RPC_ETHEREUM }} diff --git a/Dockerfile b/Dockerfile index d00544c..c1ffcff 100644 --- a/Dockerfile +++ b/Dockerfile @@ -7,9 +7,9 @@ RUN pip install --upgrade pip && \ pip install --no-cache-dir -r requirements.txt FROM base as pre-commit -RUN apt-get update && apt-get install git +RUN apt-get update && apt-get install -y git COPY . . -CMD pre-commit run --all-files +CMD git add . && pre-commit run --all-files FROM base as test COPY . . diff --git a/docker-compose.yaml b/docker-compose.yaml index c1dd6ef..646c066 100644 --- a/docker-compose.yaml +++ b/docker-compose.yaml @@ -13,6 +13,5 @@ services: context: ./ target: pre-commit container_name: metaregistry-pre-commit - command: pre-commit run --all-files volumes: - ./:/usr/app diff --git a/tests/conftest.py b/tests/conftest.py index 1c83303..2874ba5 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -29,9 +29,7 @@ def pytest_sessionstart(): global ALL_POOLS # connect to the network. TODO: use Drpc-Key header instead of GET param - boa.env.fork( - f"https://lb.drpc.org/ogrpc?network=ethereum&dkey={environ['DRPC_KEY']}" - ) + boa.env.fork(url=environ["RPC_ETHEREUM"]) # store instance of registries globally, so we don't have to recreate multiple times when generating tests. # TODO: Can we move these to fixtures? From 3589c72a06ec817b74e48099cbc691d24a052e06 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Wed, 22 Nov 2023 16:29:44 +0100 Subject: [PATCH 08/19] Fix more tests --- .github/workflows/.pre-commit-config.yaml | 2 +- .../abi => interfaces}/AddressProvider.json | 0 .../abi => interfaces}/CryptoFactory.json | 0 .../abi => interfaces}/CryptoRegistry.json | 0 contracts/interfaces/ERC20.vy | 148 ------- .../abi => interfaces}/GaugeController.json | 0 contracts/interfaces/ProxyAdmin.json | 413 +++++++++--------- .../abi => interfaces}/StableFactory.json | 0 .../abi => interfaces}/StableRegistry.json | 0 contracts/mainnet/abi/ProxyAdmin.json | 204 --------- scripts/boa_scripts/set_up_registries.py | 2 +- tests/fixtures/deployments.py | 44 +- tests/fixtures/functions.py | 6 +- .../api/test_find_pool_for_coins.py | 3 + .../api/test_get_admin_balances.py | 60 ++- .../metaregistry/api/test_get_balances.py | 2 +- .../mainnet/metaregistry/api/test_get_fees.py | 2 +- .../metaregistry/api/test_get_gauge.py | 2 +- .../api/test_get_underlying_balances.py | 4 +- .../api/test_get_underlying_decimals.py | 4 +- .../api/test_get_virtual_price.py | 12 +- .../registries/test_add_remove_basepool.py | 15 +- .../registries/test_add_remove_metapool.py | 14 +- .../registries/test_add_remove_pool.py | 18 +- tests/utils.py | 42 +- 25 files changed, 323 insertions(+), 674 deletions(-) rename contracts/{mainnet/abi => interfaces}/AddressProvider.json (100%) rename contracts/{mainnet/abi => interfaces}/CryptoFactory.json (100%) rename contracts/{mainnet/abi => interfaces}/CryptoRegistry.json (100%) delete mode 100644 contracts/interfaces/ERC20.vy rename contracts/{mainnet/abi => interfaces}/GaugeController.json (100%) rename contracts/{mainnet/abi => interfaces}/StableFactory.json (100%) rename contracts/{mainnet/abi => interfaces}/StableRegistry.json (100%) delete mode 100644 contracts/mainnet/abi/ProxyAdmin.json diff --git a/.github/workflows/.pre-commit-config.yaml b/.github/workflows/.pre-commit-config.yaml index 0ae2959..fdce9f3 100644 --- a/.github/workflows/.pre-commit-config.yaml +++ b/.github/workflows/.pre-commit-config.yaml @@ -1,6 +1,6 @@ name: pre-commit -on: [pull_request, push] +on: [push] jobs: pre-commit: diff --git a/contracts/mainnet/abi/AddressProvider.json b/contracts/interfaces/AddressProvider.json similarity index 100% rename from contracts/mainnet/abi/AddressProvider.json rename to contracts/interfaces/AddressProvider.json diff --git a/contracts/mainnet/abi/CryptoFactory.json b/contracts/interfaces/CryptoFactory.json similarity index 100% rename from contracts/mainnet/abi/CryptoFactory.json rename to contracts/interfaces/CryptoFactory.json diff --git a/contracts/mainnet/abi/CryptoRegistry.json b/contracts/interfaces/CryptoRegistry.json similarity index 100% rename from contracts/mainnet/abi/CryptoRegistry.json rename to contracts/interfaces/CryptoRegistry.json diff --git a/contracts/interfaces/ERC20.vy b/contracts/interfaces/ERC20.vy deleted file mode 100644 index 28ce1eb..0000000 --- a/contracts/interfaces/ERC20.vy +++ /dev/null @@ -1,148 +0,0 @@ -# @version 0.3.3 -# @dev Implementation of ERC-20 token standard. -# @author Takayuki Jimba (@yudetamago) -# https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md - -from vyper.interfaces import ERC20 -from vyper.interfaces import ERC20Detailed - -implements: ERC20 -implements: ERC20Detailed - -event Transfer: - sender: indexed(address) - receiver: indexed(address) - value: uint256 - -event Approval: - owner: indexed(address) - spender: indexed(address) - value: uint256 - -name: public(String[32]) -symbol: public(String[32]) -decimals: public(uint8) - -# NOTE: By declaring `balanceOf` as public, vyper automatically generates a 'balanceOf()' getter -# method to allow access to account balances. -# The _KeyType will become a required parameter for the getter and it will return _ValueType. -# See: https://vyper.readthedocs.io/en/v0.1.0-beta.8/types.html?highlight=getter#mappings -balanceOf: public(HashMap[address, uint256]) -# By declaring `allowance` as public, vyper automatically generates the `allowance()` getter -allowance: public(HashMap[address, HashMap[address, uint256]]) -# By declaring `totalSupply` as public, we automatically create the `totalSupply()` getter -totalSupply: public(uint256) -minter: address - - -@external -def __init__(_name: String[32], _symbol: String[32], _decimals: uint8, _supply: uint256): - init_supply: uint256 = _supply * 10 ** convert(_decimals, uint256) - self.name = _name - self.symbol = _symbol - self.decimals = _decimals - self.balanceOf[msg.sender] = init_supply - self.totalSupply = init_supply - self.minter = msg.sender - log Transfer(ZERO_ADDRESS, msg.sender, init_supply) - - - -@external -def transfer(_to : address, _value : uint256) -> bool: - """ - @dev Transfer token for a specified address - @param _to The address to transfer to. - @param _value The amount to be transferred. - """ - # NOTE: vyper does not allow underflows - # so the following subtraction would revert on insufficient balance - self.balanceOf[msg.sender] -= _value - self.balanceOf[_to] += _value - log Transfer(msg.sender, _to, _value) - return True - - -@external -def transferFrom(_from : address, _to : address, _value : uint256) -> bool: - """ - @dev Transfer tokens from one address to another. - @param _from address The address which you want to send tokens from - @param _to address The address which you want to transfer to - @param _value uint256 the amount of tokens to be transferred - """ - # NOTE: vyper does not allow underflows - # so the following subtraction would revert on insufficient balance - self.balanceOf[_from] -= _value - self.balanceOf[_to] += _value - # NOTE: vyper does not allow underflows - # so the following subtraction would revert on insufficient allowance - self.allowance[_from][msg.sender] -= _value - log Transfer(_from, _to, _value) - return True - - -@external -def approve(_spender : address, _value : uint256) -> bool: - """ - @dev Approve the passed address to spend the specified amount of tokens on behalf of msg.sender. - Beware that changing an allowance with this method brings the risk that someone may use both the old - and the new allowance by unfortunate transaction ordering. One possible solution to mitigate this - race condition is to first reduce the spender's allowance to 0 and set the desired value afterwards: - https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 - @param _spender The address which will spend the funds. - @param _value The amount of tokens to be spent. - """ - self.allowance[msg.sender][_spender] = _value - log Approval(msg.sender, _spender, _value) - return True - - -@external -def mint(_to: address, _value: uint256): - """ - @dev Mint an amount of the token and assigns it to an account. - This encapsulates the modification of balances such that the - proper events are emitted. - @param _to The account that will receive the created tokens. - @param _value The amount that will be created. - """ - assert msg.sender == self.minter - assert _to != ZERO_ADDRESS - self.totalSupply += _value - self.balanceOf[_to] += _value - log Transfer(ZERO_ADDRESS, _to, _value) - - -@internal -def _burn(_to: address, _value: uint256): - """ - @dev Internal function that burns an amount of the token of a given - account. - @param _to The account whose tokens will be burned. - @param _value The amount that will be burned. - """ - assert _to != ZERO_ADDRESS - self.totalSupply -= _value - self.balanceOf[_to] -= _value - log Transfer(_to, ZERO_ADDRESS, _value) - - -@external -def burn(_value: uint256): - """ - @dev Burn an amount of the token of msg.sender. - @param _value The amount that will be burned. - """ - self._burn(msg.sender, _value) - - -@external -def burnFrom(_to: address, _value: uint256): - """ - @dev Burn an amount of the token from a given account. - @param _to The account whose tokens will be burned. - @param _value The amount that will be burned. - """ - self.allowance[_to][msg.sender] -= _value - self._burn(_to, _value) diff --git a/contracts/mainnet/abi/GaugeController.json b/contracts/interfaces/GaugeController.json similarity index 100% rename from contracts/mainnet/abi/GaugeController.json rename to contracts/interfaces/GaugeController.json diff --git a/contracts/interfaces/ProxyAdmin.json b/contracts/interfaces/ProxyAdmin.json index d0a1de2..a2f15e2 100644 --- a/contracts/interfaces/ProxyAdmin.json +++ b/contracts/interfaces/ProxyAdmin.json @@ -1,211 +1,204 @@ [ - { - "name": "TransactionExecuted", - "inputs": [ - { - "name": "admin", - "type": "address", - "indexed": true - }, - { - "name": "target", - "type": "address", - "indexed": true - }, - { - "name": "calldata", - "type": "bytes", - "indexed": false - }, - { - "name": "value", - "type": "uint256", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "RequestAdminChange", - "inputs": [ - { - "name": "current_admin", - "type": "address", - "indexed": false - }, - { - "name": "future_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "RevokeAdminChange", - "inputs": [ - { - "name": "current_admin", - "type": "address", - "indexed": false - }, - { - "name": "future_admin", - "type": "address", - "indexed": false - }, - { - "name": "calling_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "ApproveAdminChange", - "inputs": [ - { - "name": "current_admin", - "type": "address", - "indexed": false - }, - { - "name": "future_admin", - "type": "address", - "indexed": false - }, - { - "name": "calling_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "AcceptAdminChange", - "inputs": [ - { - "name": "previous_admin", - "type": "address", - "indexed": false - }, - { - "name": "current_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "stateMutability": "nonpayable", - "type": "constructor", - "inputs": [ - { - "name": "_authorized", - "type": "address[2]" - } - ], - "outputs": [] - }, - { - "stateMutability": "payable", - "type": "function", - "name": "execute", - "inputs": [ - { - "name": "_target", - "type": "address" - }, - { - "name": "_calldata", - "type": "bytes" - } - ], - "outputs": [], - "gas": 1168658 - }, - { - "stateMutability": "view", - "type": "function", - "name": "get_admin_change_status", - "inputs": [], - "outputs": [ - { - "name": "", - "type": "address" - }, - { - "name": "", - "type": "address" - }, - { - "name": "", - "type": "bool" - } - ], - "gas": 4202 - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "request_admin_change", - "inputs": [ - { - "name": "_new_admin", - "type": "address" - } - ], - "outputs": [], - "gas": 148342 - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "approve_admin_change", - "inputs": [], - "outputs": [], - "gas": 41716 - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "revoke_admin_change", - "inputs": [], - "outputs": [], - "gas": 67885 - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "accept_admin_change", - "inputs": [], - "outputs": [], - "gas": 101134 - }, - { - "stateMutability": "view", - "type": "function", - "name": "admins", - "inputs": [ - { - "name": "arg0", - "type": "uint256" - } - ], - "outputs": [ - { - "name": "", - "type": "address" - } - ], - "gas": 1377 - } - ] + { + "name": "TransactionExecuted", + "inputs": [ + { + "name": "admin", + "type": "address", + "indexed": true + }, + { + "name": "target", + "type": "address", + "indexed": true + }, + { + "name": "calldata", + "type": "bytes", + "indexed": false + }, + { + "name": "value", + "type": "uint256", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "RequestAdminChange", + "inputs": [ + { + "name": "current_admin", + "type": "address", + "indexed": false + }, + { + "name": "future_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "RevokeAdminChange", + "inputs": [ + { + "name": "current_admin", + "type": "address", + "indexed": false + }, + { + "name": "future_admin", + "type": "address", + "indexed": false + }, + { + "name": "calling_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "ApproveAdminChange", + "inputs": [ + { + "name": "current_admin", + "type": "address", + "indexed": false + }, + { + "name": "future_admin", + "type": "address", + "indexed": false + }, + { + "name": "calling_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "name": "AcceptAdminChange", + "inputs": [ + { + "name": "previous_admin", + "type": "address", + "indexed": false + }, + { + "name": "current_admin", + "type": "address", + "indexed": false + } + ], + "anonymous": false, + "type": "event" + }, + { + "stateMutability": "nonpayable", + "type": "constructor", + "inputs": [ + { + "name": "_authorized", + "type": "address[2]" + } + ], + "outputs": [] + }, + { + "stateMutability": "payable", + "type": "function", + "name": "execute", + "inputs": [ + { + "name": "_target", + "type": "address" + }, + { + "name": "_calldata", + "type": "bytes" + } + ], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "get_admin_change_status", + "inputs": [], + "outputs": [ + { + "name": "", + "type": "address" + }, + { + "name": "", + "type": "address" + }, + { + "name": "", + "type": "bool" + } + ] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "request_admin_change", + "inputs": [ + { + "name": "_new_admin", + "type": "address" + } + ], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "approve_admin_change", + "inputs": [], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "revoke_admin_change", + "inputs": [], + "outputs": [] + }, + { + "stateMutability": "nonpayable", + "type": "function", + "name": "accept_admin_change", + "inputs": [], + "outputs": [] + }, + { + "stateMutability": "view", + "type": "function", + "name": "admins", + "inputs": [ + { + "name": "arg0", + "type": "uint256" + } + ], + "outputs": [ + { + "name": "", + "type": "address" + } + ] + } +] diff --git a/contracts/mainnet/abi/StableFactory.json b/contracts/interfaces/StableFactory.json similarity index 100% rename from contracts/mainnet/abi/StableFactory.json rename to contracts/interfaces/StableFactory.json diff --git a/contracts/mainnet/abi/StableRegistry.json b/contracts/interfaces/StableRegistry.json similarity index 100% rename from contracts/mainnet/abi/StableRegistry.json rename to contracts/interfaces/StableRegistry.json diff --git a/contracts/mainnet/abi/ProxyAdmin.json b/contracts/mainnet/abi/ProxyAdmin.json deleted file mode 100644 index a2f15e2..0000000 --- a/contracts/mainnet/abi/ProxyAdmin.json +++ /dev/null @@ -1,204 +0,0 @@ -[ - { - "name": "TransactionExecuted", - "inputs": [ - { - "name": "admin", - "type": "address", - "indexed": true - }, - { - "name": "target", - "type": "address", - "indexed": true - }, - { - "name": "calldata", - "type": "bytes", - "indexed": false - }, - { - "name": "value", - "type": "uint256", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "RequestAdminChange", - "inputs": [ - { - "name": "current_admin", - "type": "address", - "indexed": false - }, - { - "name": "future_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "RevokeAdminChange", - "inputs": [ - { - "name": "current_admin", - "type": "address", - "indexed": false - }, - { - "name": "future_admin", - "type": "address", - "indexed": false - }, - { - "name": "calling_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "ApproveAdminChange", - "inputs": [ - { - "name": "current_admin", - "type": "address", - "indexed": false - }, - { - "name": "future_admin", - "type": "address", - "indexed": false - }, - { - "name": "calling_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "name": "AcceptAdminChange", - "inputs": [ - { - "name": "previous_admin", - "type": "address", - "indexed": false - }, - { - "name": "current_admin", - "type": "address", - "indexed": false - } - ], - "anonymous": false, - "type": "event" - }, - { - "stateMutability": "nonpayable", - "type": "constructor", - "inputs": [ - { - "name": "_authorized", - "type": "address[2]" - } - ], - "outputs": [] - }, - { - "stateMutability": "payable", - "type": "function", - "name": "execute", - "inputs": [ - { - "name": "_target", - "type": "address" - }, - { - "name": "_calldata", - "type": "bytes" - } - ], - "outputs": [] - }, - { - "stateMutability": "view", - "type": "function", - "name": "get_admin_change_status", - "inputs": [], - "outputs": [ - { - "name": "", - "type": "address" - }, - { - "name": "", - "type": "address" - }, - { - "name": "", - "type": "bool" - } - ] - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "request_admin_change", - "inputs": [ - { - "name": "_new_admin", - "type": "address" - } - ], - "outputs": [] - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "approve_admin_change", - "inputs": [], - "outputs": [] - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "revoke_admin_change", - "inputs": [], - "outputs": [] - }, - { - "stateMutability": "nonpayable", - "type": "function", - "name": "accept_admin_change", - "inputs": [], - "outputs": [] - }, - { - "stateMutability": "view", - "type": "function", - "name": "admins", - "inputs": [ - { - "name": "arg0", - "type": "uint256" - } - ], - "outputs": [ - { - "name": "", - "type": "address" - } - ] - } -] diff --git a/scripts/boa_scripts/set_up_registries.py b/scripts/boa_scripts/set_up_registries.py index d6c56c4..3fcf880 100644 --- a/scripts/boa_scripts/set_up_registries.py +++ b/scripts/boa_scripts/set_up_registries.py @@ -40,7 +40,7 @@ def set_up_registries( else: logger.log("Prodmode") boa.set_env(NetworkEnv(url)) - boa.env.add_account(Account.from_key(os.environ[account])) + boa.env.eoa = Account.from_key(os.environ[account]) data = next( ( diff --git a/tests/fixtures/deployments.py b/tests/fixtures/deployments.py index 9b4027e..89dd44b 100644 --- a/tests/fixtures/deployments.py +++ b/tests/fixtures/deployments.py @@ -44,16 +44,16 @@ def base_pool_registry(alice_address): @pytest.fixture(scope="module", autouse=True) def populated_base_pool_registry(base_pool_registry, owner, base_pools): - boa.env.eoa = owner - for data in base_pools.values(): - base_pool_registry.add_base_pool( - data["pool"], - data["lp_token"], - data["num_coins"], - data["is_legacy"], - data["is_lending"], - data["is_v2"], - ) + with boa.env.sender(owner): + for data in base_pools.values(): + base_pool_registry.add_base_pool( + data["pool"], + data["lp_token"], + data["num_coins"], + data["is_legacy"], + data["is_lending"], + data["is_v2"], + ) return base_pool_registry @@ -69,18 +69,18 @@ def crypto_registry( sender=owner, ) - boa.env.eoa = owner - for _, pool in crypto_registry_pools.items(): - crypto_registry.add_pool( - pool["pool"], - pool["lp_token"], - pool["gauge"], - pool["zap"], - pool["num_coins"], - pool["name"], - pool["base_pool"], - pool["has_positive_rebasing_tokens"], - ) + with boa.env.sender(owner): + for _, pool in crypto_registry_pools.items(): + crypto_registry.add_pool( + pool["pool"], + pool["lp_token"], + pool["gauge"], + pool["zap"], + pool["num_coins"], + pool["name"], + pool["base_pool"], + pool["has_positive_rebasing_tokens"], + ) return crypto_registry diff --git a/tests/fixtures/functions.py b/tests/fixtures/functions.py index 0d2f0ce..bdd8e15 100644 --- a/tests/fixtures/functions.py +++ b/tests/fixtures/functions.py @@ -9,7 +9,7 @@ @pytest.fixture(scope="module") -def curve_pool(project) -> Callable: +def curve_pool() -> Callable: def _initialise(_pool: str) -> VyperContract: return get_deployed_contract("CurvePool", _pool) @@ -17,7 +17,7 @@ def _initialise(_pool: str) -> VyperContract: @pytest.fixture(scope="module") -def curve_pool_v2(project) -> Callable: +def curve_pool_v2() -> Callable: def _initialise(_pool: str) -> VyperContract: return get_deployed_contract("CurvePoolV2", _pool) @@ -25,7 +25,7 @@ def _initialise(_pool: str) -> VyperContract: @pytest.fixture(scope="module") -def liquidity_gauge(project) -> Callable: +def liquidity_gauge() -> Callable: def _initialise(_gauge: str) -> VyperContract: return get_deployed_contract("LiquidityGauge", _gauge) diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index db8f661..7ef82fd 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -1,5 +1,7 @@ import itertools +import pytest + from tests.utils import ZERO_ADDRESS # NOTE: This is the most important method in the metaregistry contract since it will be used @@ -29,6 +31,7 @@ def _get_all_combinations(metaregistry, pool): return all_combinations +@pytest.mark.skip() # TODO: This test is spawning a lot of test cases and takes >1:30h to run def test_all(populated_metaregistry, pool): combinations = _get_all_combinations(populated_metaregistry, pool) for combination in combinations: diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 2cd30bc..2c52fbc 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -1,4 +1,8 @@ +import boa import pytest +from eth.codecs.abi.exceptions import DecodeError + +from tests.utils import get_lp_contract def pre_test_checks(metaregistry, pool): @@ -6,14 +10,13 @@ def pre_test_checks(metaregistry, pool): pytest.skip("empty pool: skipping") try: - if VyperContract(metaregistry.get_lp_token(pool)).totalSupply() == 0: - pytest.skip("lp token supply is zero") - except SignatureError: + if get_lp_contract(metaregistry.get_lp_token(pool)).totalSupply() == 0: + pytest.skip("LP token supply is zero") + except DecodeError as err: # TODO: Document why this happens pytest.skip( - f"SignatureError for token {metaregistry.get_lp_token(pool)}: skipping" + f"{type(err).__name__} for token {metaregistry.get_lp_token(pool)}: Skipping because of {err.msg}" ) - def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): @@ -27,11 +30,7 @@ def test_stable_registry_pools( assert output == metaregistry_output[i] -def test_stable_factory_pools( - populated_metaregistry, - stable_factory_pool, - curve_pool, -): +def test_stable_factory_pools(populated_metaregistry, stable_factory_pool, curve_pool): pre_test_checks(populated_metaregistry, stable_factory_pool) pool = curve_pool(stable_factory_pool) @@ -46,29 +45,28 @@ def test_stable_factory_pools( def _get_crypto_pool_admin_fees( - populated_metaregistry, pool, fee_receiver, project, alice_address, chain + populated_metaregistry, pool, fee_receiver, alice_address ): - lp_token = VyperContract(populated_metaregistry.get_lp_token(pool)) + lp_token = get_lp_contract(populated_metaregistry.get_lp_token(pool)) fee_receiver_token_balance_before = lp_token.balanceOf(fee_receiver) - chain.snapshot() - pool.claim_admin_fees(sender=alice_address) + with boa.env.anchor(): + pool.claim_admin_fees(sender=alice_address) - claimed_lp_token_as_fee = ( - lp_token.balanceOf(fee_receiver) - fee_receiver_token_balance_before - ) - total_supply_lp_token = lp_token.totalSupply() - frac_admin_fee = int( - claimed_lp_token_as_fee * 10**18 / total_supply_lp_token - ) + claimed_lp_token_as_fee = ( + lp_token.balanceOf(fee_receiver) - fee_receiver_token_balance_before + ) + total_supply_lp_token = lp_token.totalSupply() + frac_admin_fee = int( + claimed_lp_token_as_fee * 10**18 / total_supply_lp_token + ) - # get admin balances in individual assets: - reserves = populated_metaregistry.get_balances(pool) - admin_balances = [0] * 8 - for i in range(8): - admin_balances[i] = int(frac_admin_fee * reserves[i] / 10**18) + # get admin balances in individual assets: + reserves = populated_metaregistry.get_balances(pool) + admin_balances = [0] * 8 + for i in range(8): + admin_balances[i] = int(frac_admin_fee * reserves[i] / 10**18) - chain.restore() return admin_balances @@ -77,8 +75,6 @@ def test_crypto_registry_pools( crypto_registry_pool, curve_pool_v2, alice_address, - chain, - project, ): pre_test_checks(populated_metaregistry, crypto_registry_pool) @@ -88,9 +84,7 @@ def test_crypto_registry_pools( populated_metaregistry, pool, fee_receiver, - project, alice_address, - chain, ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) @@ -104,8 +98,6 @@ def test_crypto_factory_pools( crypto_factory, curve_pool_v2, alice_address, - chain, - project, ): pre_test_checks(populated_metaregistry, crypto_factory_pool) @@ -115,9 +107,7 @@ def test_crypto_factory_pools( populated_metaregistry, pool, fee_receiver, - project, alice_address, - chain, ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) diff --git a/tests/mainnet/metaregistry/api/test_get_balances.py b/tests/mainnet/metaregistry/api/test_get_balances.py index ebb5631..e45b290 100644 --- a/tests/mainnet/metaregistry/api/test_get_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_balances.py @@ -48,7 +48,7 @@ def test_crypto_factory_pools( ): try: actual_output = crypto_factory.get_balances(crypto_factory_pool) - except ContractLogicError: + except KeyError: # TODO: Pick right exception actual_output = [] pool = curve_pool_v2(crypto_factory_pool) for i in range(2): diff --git a/tests/mainnet/metaregistry/api/test_get_fees.py b/tests/mainnet/metaregistry/api/test_get_fees.py index 255d5be..5dbfdce 100644 --- a/tests/mainnet/metaregistry/api/test_get_fees.py +++ b/tests/mainnet/metaregistry/api/test_get_fees.py @@ -62,7 +62,7 @@ def test_crypto_factory_pools( curve_pool_v2, ): if sum(crypto_factory.get_balances(crypto_factory_pool)) == 0: - with ape.reverts(): + with boa.env.anchor(): curve_pool_v2(crypto_factory_pool).fee() pytest.skip( f"crypto factory pool {crypto_factory_pool} is empty and factory pools tend to " diff --git a/tests/mainnet/metaregistry/api/test_get_gauge.py b/tests/mainnet/metaregistry/api/test_get_gauge.py index ddc1a9a..f0d2eed 100644 --- a/tests/mainnet/metaregistry/api/test_get_gauge.py +++ b/tests/mainnet/metaregistry/api/test_get_gauge.py @@ -6,7 +6,7 @@ def _is_dao_onboarded_gauge(_gauge, gauge_controller, liquidity_gauge): try: gauge_controller.gauge_types(_gauge) - except ape.exceptions.VirtualMachineError: + except KeyError: # TODO: Pick the right exception return False if liquidity_gauge(_gauge).is_killed(): diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index 9205e4f..abfa92e 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -22,7 +22,7 @@ def _get_underlying_balances( actual_output = registry.get_underlying_balances(pool) # registry getter borks, so we need to get balances the hard way: - except (ape.exceptions.ContractLogicError, AttributeError): + except (KeyError, AttributeError): # TODO: Pick the right exception coins = metaregistry.get_coins(pool) balances = metaregistry.get_balances(pool) for idx, coin in enumerate(coins): @@ -33,7 +33,7 @@ def _get_underlying_balances( coin_contract = VyperContract(coin) try: lp_token_supply = coin_contract.totalSupply() - except (ape.exceptions.SignatureError, AttributeError): + except (KeyError, AttributeError): # TODO: Pick the right exception assert "totalSupply" not in [ i.name for i in coin_contract.contract_type.view_methods diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index c4f23bf..2f9c670 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -34,9 +34,9 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): try: token_contract = VyperContract(underlying_coins[i]) actual_output.append(token_contract.decimals()) - except ape.exceptions.ChainError: + except KeyError: # TODO: Pick the right exception pytest.skip("Unverified contract. Skipping test.") - except ape.exceptions.SignatureError: + except ZeroDivisionError: # TODO: Pick the right exception if ( underlying_coins[i] == "0x6810e776880C02933D47DB1b9fc05908e5386b96" diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index b7ca097..81ab84b 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -11,13 +11,13 @@ def _check_pool_has_no_liquidity(metaregistry, pool, pool_balances, lp_token): # skip if pool has little to no liquidity, since vprice queries will most likely bork: if sum(pool_balances) == 0: - with ape.reverts(): + with boa.env.anchor(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip(f"empty pool: {pool}") elif sum(pool_balances) < 100: # tiny pool - with ape.reverts(): + with boa.env.anchor(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip(f"tiny pool: {pool}") @@ -39,7 +39,7 @@ def _check_skem_tokens_with_weird_decimals( coin_decimals[i] == 0 and VyperContract(metaregistry.get_coins(pool)[0]).decimals() == 0 ): - with ape.reverts(): + with boa.env.anchor(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip( f"skem token {coins[i]} in pool {pool} with zero decimals" @@ -65,7 +65,7 @@ def _check_pool_is_depegged( and min(pool_balances_float) < 1 ): try: - with ape.reverts(): + with boa.env.anchor(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip( @@ -132,8 +132,8 @@ def test_stable_factory_pools( populated_metaregistry.get_virtual_price_from_lp_token(lp_token) ) assert actual_output == metaregistry_output - except ape.exceptions.ContractLogicError: - with ape.reverts(): + except KeyError: # TODO: Pick the right exception + with boa.env.anchor(): populated_metaregistry.get_virtual_price_from_lp_token(lp_token) diff --git a/tests/mainnet/registries/test_add_remove_basepool.py b/tests/mainnet/registries/test_add_remove_basepool.py index 516d55c..eb2f1e6 100644 --- a/tests/mainnet/registries/test_add_remove_basepool.py +++ b/tests/mainnet/registries/test_add_remove_basepool.py @@ -1,15 +1,14 @@ import boa -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS, deploy_contract def test_revert_unauthorised_add_base_pool( owner, unauthorised_address, base_pools ): - base_pool_registry = ape.project.BasePoolRegistry.deploy(sender=owner) - + base_pool_registry = deploy_contract("BasePoolRegistry", directory="registries", sender=owner) base_pool_data = base_pools["tripool"] - with ape.reverts(): + with boa.reverts(): base_pool_registry.add_base_pool( base_pool_data["pool"], base_pool_data["lp_token"], @@ -17,13 +16,11 @@ def test_revert_unauthorised_add_base_pool( base_pool_data["is_legacy"], base_pool_data["is_lending"], base_pool_data["is_v2"], - sender=unauthorised_address, ) def test_add_basepool(owner, base_pools, tokens): - base_pool_registry = ape.project.BasePoolRegistry.deploy(sender=owner) - + base_pool_registry = deploy_contract("BasePoolRegistry", directory="registries", sender=owner) base_pool_count = base_pool_registry.base_pool_count() base_pool_data = base_pools["tripool"] tripool = base_pool_data["pool"] @@ -63,7 +60,7 @@ def test_add_basepool(owner, base_pools, tokens): def test_add_basepool_with_legacy_abi(owner, base_pools, tokens): - base_pool_registry = ape.project.BasePoolRegistry.deploy(sender=owner) + base_pool_registry = deploy_contract("BasePoolRegistry", directory="registries", sender=owner) base_pool_data = base_pools["sbtc"] assert base_pool_data["is_legacy"] @@ -99,7 +96,7 @@ def test_revert_unauthorised_remove_base_pool( populated_base_pool_registry.get_lp_token(tripool_address) != ZERO_ADDRESS ) - with ape.reverts(): + with boa.reverts(): populated_base_pool_registry.remove_base_pool( tripool_address, sender=unauthorised_address ) diff --git a/tests/mainnet/registries/test_add_remove_metapool.py b/tests/mainnet/registries/test_add_remove_metapool.py index d127c40..db56752 100644 --- a/tests/mainnet/registries/test_add_remove_metapool.py +++ b/tests/mainnet/registries/test_add_remove_metapool.py @@ -1,6 +1,6 @@ import boa -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS, deploy_contract def test_add_metapool( @@ -12,9 +12,8 @@ def test_add_metapool( base_pools, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( - address_provider, populated_base_pool_registry, sender=owner - ) + crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, + directory="registries", sender=owner) pool_count = crypto_registry.pool_count() assert pool_count == 0 @@ -145,7 +144,7 @@ def test_add_metapool( ) # the following should revert since we didn't add any basepool lp token <> coin pairs: for coin in [tokens["dai"], tokens["usdc"], tokens["usdt"]]: - with ape.reverts(): + with boa.reverts(): crypto_registry.get_coin_indices( pool_data["pool"], base_pools["tripool"]["lp_token"], coin ) @@ -206,9 +205,8 @@ def test_remove_metapool( base_pools, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( - address_provider, populated_base_pool_registry, sender=owner - ) + crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, + directory="registries", sender=owner) # add EURT3CRV pool eurt3crv = crypto_registry_pools["eurt3crv"] diff --git a/tests/mainnet/registries/test_add_remove_pool.py b/tests/mainnet/registries/test_add_remove_pool.py index ce0ffe8..4bc4021 100644 --- a/tests/mainnet/registries/test_add_remove_pool.py +++ b/tests/mainnet/registries/test_add_remove_pool.py @@ -1,6 +1,6 @@ import boa -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS, deploy_contract def test_revert_unauthorised_add_pool( @@ -8,7 +8,7 @@ def test_revert_unauthorised_add_pool( ): pool_data = crypto_registry_pools["tricrypto2"] - with ape.reverts(): + with boa.reverts(): crypto_registry.add_pool( pool_data["pool"], pool_data["lp_token"], @@ -27,7 +27,7 @@ def test_revert_add_existing_pool( ): pool_data = crypto_registry_pools["tricrypto2"] - with ape.reverts(): + with boa.reverts(): crypto_registry.add_pool( pool_data["pool"], pool_data["lp_token"], @@ -48,9 +48,8 @@ def test_add_pool( owner, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( - address_provider.address, populated_base_pool_registry, sender=owner - ) + crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, + directory="registries", sender=owner) pool_count = crypto_registry.pool_count() assert pool_count == 0 @@ -138,7 +137,7 @@ def test_add_pool( def test_revert_unauthorised_remove_pool( crypto_registry, unauthorised_address, crypto_registry_pools ): - with ape.reverts(): + with boa.reverts(): crypto_registry.remove_pool( crypto_registry_pools["tricrypto2"]["pool"], sender=unauthorised_address, @@ -153,9 +152,8 @@ def test_remove_pool( max_coins, tokens, ): - crypto_registry = ape.project.CryptoRegistryV1.deploy( - address_provider.address, populated_base_pool_registry, sender=owner - ) + crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, + directory="registries", sender=owner) # add pool to be removed: tricrypto2 = crypto_registry_pools["tricrypto2"] diff --git a/tests/utils.py b/tests/utils.py index 4583640..f54655d 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -1,3 +1,4 @@ +import json from os import path from typing import Union @@ -9,26 +10,24 @@ BASE_DIR = path.join(path.dirname(path.abspath(__file__)), "..") -def get_contract_pools(contract: str, address: str) -> list[str]: +def get_contract_pools(contract_name: str, address: str) -> list[str]: """ Retrieves the list of pools from a deployed contract with the given address. - :param contract: The name of the contract to load. + :param contract_name: The name of the contract to load. :param address: The address of the deployed contract. """ - registry = get_deployed_contract(contract, address) + registry = get_deployed_contract(contract_name, address) return [registry.pool_list(i) for i in range(registry.pool_count())] -def get_deployed_contract(contract_abi: str, address: str) -> VyperContract: +def get_deployed_contract(contract_name: str, address: str) -> VyperContract: """ Loads a contract and retrieves a deployed instance of it with the given address. TODO: Refactor calls to use fixtures instead of re-loading multiple times. - :param contract_abi: The name of the contract to load. + :param contract_name: The name of the contract ABI to load. :param address: The address of the deployed contract. """ - file_name = path.join( - BASE_DIR, f"contracts/mainnet/abi/{contract_abi}.json" - ) + file_name = path.join(BASE_DIR, f"contracts/interfaces/{contract_name}.json") return boa.load_abi(file_name).at(address) @@ -42,5 +41,28 @@ def deploy_contract( file_name = path.join( BASE_DIR, f"contracts/mainnet/{directory}/{contract}.vy" ) - boa.env.eoa = sender if isinstance(sender, str) else sender.address - return boa.load(file_name, *args, **kwargs) + with boa.env.sender(sender): + return boa.load(file_name, *args, **kwargs) + + +def get_lp_contract(address: str) -> VyperContract: + """ + Gets the LP token contract at the given address. + :param address: The address of the LP token contract. + """ + abi = json.dumps([{ + "name": "totalSupply", + "constant": True, + "inputs": [], + "outputs": [{"name": "", "type": "uint256"}], + "payable": False, + "stateMutability": "view", + "type": "function" + }, { + "inputs": [{ "internalType": "address", "name": "account", "type": "address" }], + "name": "balanceOf", + "outputs": [{ "internalType": "uint256", "name": "", "type": "uint256" }], + "stateMutability": "view", + "type": "function" + }]) + return boa.loads_abi(abi).at(address) From 40a298a996505735fa0d61affd310b6541f49e6b Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Wed, 22 Nov 2023 16:55:29 +0100 Subject: [PATCH 09/19] Fix pre-commit and more tests --- scripts/print_missing.py | 4 +- scripts/setup_metaregistry.py | 5 +- tests/conftest.py | 2 +- tests/fixtures/contracts.py | 9 --- .../api/test_get_admin_balances.py | 24 +++++-- .../metaregistry/api/test_get_balances.py | 2 +- .../metaregistry/api/test_get_gauge.py | 2 - .../metaregistry/api/test_get_pool_name.py | 36 +++++----- .../api/test_get_underlying_balances.py | 10 +-- .../api/test_get_underlying_decimals.py | 7 +- .../api/test_get_virtual_price.py | 7 +- .../registries/test_add_remove_basepool.py | 12 +++- .../registries/test_add_remove_metapool.py | 18 +++-- .../registries/test_add_remove_pool.py | 18 +++-- tests/utils.py | 69 ++++++++++++++----- 15 files changed, 144 insertions(+), 81 deletions(-) delete mode 100644 tests/fixtures/contracts.py diff --git a/scripts/print_missing.py b/scripts/print_missing.py index 82d75e5..3fbb4a1 100644 --- a/scripts/print_missing.py +++ b/scripts/print_missing.py @@ -1,3 +1,4 @@ +import boa from tabulate import tabulate MISSING = "\033[33m✖\033[0m" @@ -20,8 +21,9 @@ def get_non_indexed_view_functions( if registry_selectors[k] in view_fns } + metaregistry = boa.load_partial("contracts/mainnet/MetaRegistry.vy") function_index = get_non_indexed_view_functions( - MetaRegistry.selectors, MetaRegistry.abi, {} + metaregistry.selectors, metaregistry.abi, {} ) registry_coverage = [[PRESENT] * len(function_index)] registry_names = [ diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index b86af5c..b0f8a6d 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -133,9 +133,6 @@ def cli(): pass -@cli.command(cls=NetworkBoundCommand) -@network_option() -@account_option() def main(network: str, account: str): # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: address_provider = get_deployed_contract( @@ -146,7 +143,7 @@ def main(network: str, account: str): if network == "ethereum:mainnet-fork": RICH_CONSOLE.log("Simulation mode.") - account = accounts[proxy_admin.admins(1)] + account = proxy_admin.admins(1) # deployed contracts: base_pool_registry = get_deployed_contract( diff --git a/tests/conftest.py b/tests/conftest.py index 2874ba5..40fea7b 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -31,7 +31,7 @@ def pytest_sessionstart(): # connect to the network. TODO: use Drpc-Key header instead of GET param boa.env.fork(url=environ["RPC_ETHEREUM"]) - # store instance of registries globally, so we don't have to recreate multiple times when generating tests. + # store registries globally, so we don't have to recreate multiple times when generating tests. # TODO: Can we move these to fixtures? STABLE_REGISTRY_POOLS = get_contract_pools( "StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" diff --git a/tests/fixtures/contracts.py b/tests/fixtures/contracts.py deleted file mode 100644 index f0a2522..0000000 --- a/tests/fixtures/contracts.py +++ /dev/null @@ -1,9 +0,0 @@ -import pytest - - -@pytest.fixture(scope="module") -def address_provider_contract(accounts): - address_provider = get_deployed_contract( - "AddressProvider", "0x0000000022D53366457F9d5E68Ec105046FC4383" - ) - return accounts[address_provider.admin()] diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 2c52fbc..c35ecb8 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -2,7 +2,7 @@ import pytest from eth.codecs.abi.exceptions import DecodeError -from tests.utils import get_lp_contract +from tests.utils import get_deployed_token_contract def pre_test_checks(metaregistry, pool): @@ -10,13 +10,20 @@ def pre_test_checks(metaregistry, pool): pytest.skip("empty pool: skipping") try: - if get_lp_contract(metaregistry.get_lp_token(pool)).totalSupply() == 0: + if ( + get_deployed_token_contract( + metaregistry.get_lp_token(pool) + ).totalSupply() + == 0 + ): pytest.skip("LP token supply is zero") except DecodeError as err: # TODO: Document why this happens pytest.skip( - f"{type(err).__name__} for token {metaregistry.get_lp_token(pool)}: Skipping because of {err.msg}" + f"{type(err).__name__} for token {metaregistry.get_lp_token(pool)}: " + f"Skipping because of {err.msg}" ) + def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): @@ -30,7 +37,9 @@ def test_stable_registry_pools( assert output == metaregistry_output[i] -def test_stable_factory_pools(populated_metaregistry, stable_factory_pool, curve_pool): +def test_stable_factory_pools( + populated_metaregistry, stable_factory_pool, curve_pool +): pre_test_checks(populated_metaregistry, stable_factory_pool) pool = curve_pool(stable_factory_pool) @@ -47,14 +56,17 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool, curve def _get_crypto_pool_admin_fees( populated_metaregistry, pool, fee_receiver, alice_address ): - lp_token = get_lp_contract(populated_metaregistry.get_lp_token(pool)) + lp_token = get_deployed_token_contract( + populated_metaregistry.get_lp_token(pool) + ) fee_receiver_token_balance_before = lp_token.balanceOf(fee_receiver) with boa.env.anchor(): pool.claim_admin_fees(sender=alice_address) claimed_lp_token_as_fee = ( - lp_token.balanceOf(fee_receiver) - fee_receiver_token_balance_before + lp_token.balanceOf(fee_receiver) + - fee_receiver_token_balance_before ) total_supply_lp_token = lp_token.totalSupply() frac_admin_fee = int( diff --git a/tests/mainnet/metaregistry/api/test_get_balances.py b/tests/mainnet/metaregistry/api/test_get_balances.py index e45b290..470aa70 100644 --- a/tests/mainnet/metaregistry/api/test_get_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_balances.py @@ -28,7 +28,7 @@ def test_crypto_registry_pools( ): try: actual_output = crypto_registry.get_balances(crypto_registry_pool) - except ContractLogicError: + except KeyError: # TODO: Pick right exception actual_output = [] pool = curve_pool_v2(crypto_registry_pool) for i in range( diff --git a/tests/mainnet/metaregistry/api/test_get_gauge.py b/tests/mainnet/metaregistry/api/test_get_gauge.py index f0d2eed..cedbdba 100644 --- a/tests/mainnet/metaregistry/api/test_get_gauge.py +++ b/tests/mainnet/metaregistry/api/test_get_gauge.py @@ -1,5 +1,3 @@ -import boa - from tests.utils import ZERO_ADDRESS diff --git a/tests/mainnet/metaregistry/api/test_get_pool_name.py b/tests/mainnet/metaregistry/api/test_get_pool_name.py index 1e7df87..9eed3ab 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_name.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_name.py @@ -1,6 +1,6 @@ import pytest -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS, get_deployed_token_contract def test_stable_registry_pools( @@ -24,40 +24,38 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): list(filter((ZERO_ADDRESS).__ne__, pool_registry_handlers)) ) + name = populated_metaregistry.get_pool_name(stable_factory_pool) if num_registry_handlers == 1: - assert ( - populated_metaregistry.get_pool_name(stable_factory_pool) - == VyperContract(stable_factory_pool).name() - ) - - elif num_registry_handlers == 2: + assert name == get_deployed_token_contract(stable_factory_pool).name() + else: with pytest.raises(AssertionError): assert ( - populated_metaregistry.get_pool_name(stable_factory_pool) - == VyperContract(stable_factory_pool).name() + name == get_deployed_token_contract(stable_factory_pool).name() ) + pool_name2 = populated_metaregistry.get_pool_name( + stable_factory_pool, 1 + ) assert ( - populated_metaregistry.get_pool_name(stable_factory_pool, 1) - == VyperContract(stable_factory_pool).name() + pool_name2 + == get_deployed_token_contract(stable_factory_pool).name() ) - else: - raise + assert num_registry_handlers in (1, 2) def test_crypto_registry_pools( populated_metaregistry, crypto_registry_pool, crypto_registry ): - assert populated_metaregistry.get_pool_name( - crypto_registry_pool - ) == crypto_registry.get_pool_name(crypto_registry_pool) + pool_name = populated_metaregistry.get_pool_name(crypto_registry_pool) + assert pool_name == crypto_registry.get_pool_name(crypto_registry_pool) def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory ): - assert ( - populated_metaregistry.get_pool_name(crypto_factory_pool) - == VyperContract(crypto_factory.get_token(crypto_factory_pool)).name() + pool_name = populated_metaregistry.get_pool_name(crypto_factory_pool) + contract = get_deployed_token_contract( + crypto_factory.get_token(crypto_factory_pool) ) + assert pool_name == contract.name() diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index abfa92e..2255473 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -1,9 +1,8 @@ import warnings -import boa import pytest -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS, get_deployed_token_contract EXCEPTION_POOLS = ["0x79a8C46DeA5aDa233ABaFFD40F3A0A2B1e5A4F27"] @@ -30,10 +29,13 @@ def _get_underlying_balances( if base_pool != ZERO_ADDRESS: basepool_lp_token_balance = balances[idx] - coin_contract = VyperContract(coin) + coin_contract = get_deployed_token_contract(coin) try: lp_token_supply = coin_contract.totalSupply() - except (KeyError, AttributeError): # TODO: Pick the right exception + except ( + KeyError, + AttributeError, + ): # TODO: Pick the right exception assert "totalSupply" not in [ i.name for i in coin_contract.contract_type.view_methods diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index 2f9c670..6c6b2b2 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -1,7 +1,6 @@ -import boa import pytest -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS, get_deployed_token_contract EXCEPTIONS = { # eth: ankreth pool returns [18, 0] when it should return: @@ -32,7 +31,9 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): continue try: - token_contract = VyperContract(underlying_coins[i]) + token_contract = get_deployed_token_contract( + underlying_coins[i] + ) actual_output.append(token_contract.decimals()) except KeyError: # TODO: Pick the right exception pytest.skip("Unverified contract. Skipping test.") diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index 81ab84b..e52a765 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -3,7 +3,7 @@ import boa import pytest -from tests.utils import ZERO_ADDRESS +from tests.utils import ZERO_ADDRESS, get_deployed_token_contract # ---- sanity checks since vprice getters can revert for specific pools states ---- @@ -37,7 +37,10 @@ def _check_skem_tokens_with_weird_decimals( if ( coin_decimals[i] == 0 - and VyperContract(metaregistry.get_coins(pool)[0]).decimals() == 0 + and get_deployed_token_contract( + metaregistry.get_coins(pool)[0] + ).decimals() + == 0 ): with boa.env.anchor(): metaregistry.get_virtual_price_from_lp_token(lp_token) diff --git a/tests/mainnet/registries/test_add_remove_basepool.py b/tests/mainnet/registries/test_add_remove_basepool.py index eb2f1e6..6812be7 100644 --- a/tests/mainnet/registries/test_add_remove_basepool.py +++ b/tests/mainnet/registries/test_add_remove_basepool.py @@ -6,7 +6,9 @@ def test_revert_unauthorised_add_base_pool( owner, unauthorised_address, base_pools ): - base_pool_registry = deploy_contract("BasePoolRegistry", directory="registries", sender=owner) + base_pool_registry = deploy_contract( + "BasePoolRegistry", directory="registries", sender=owner + ) base_pool_data = base_pools["tripool"] with boa.reverts(): base_pool_registry.add_base_pool( @@ -20,7 +22,9 @@ def test_revert_unauthorised_add_base_pool( def test_add_basepool(owner, base_pools, tokens): - base_pool_registry = deploy_contract("BasePoolRegistry", directory="registries", sender=owner) + base_pool_registry = deploy_contract( + "BasePoolRegistry", directory="registries", sender=owner + ) base_pool_count = base_pool_registry.base_pool_count() base_pool_data = base_pools["tripool"] tripool = base_pool_data["pool"] @@ -60,7 +64,9 @@ def test_add_basepool(owner, base_pools, tokens): def test_add_basepool_with_legacy_abi(owner, base_pools, tokens): - base_pool_registry = deploy_contract("BasePoolRegistry", directory="registries", sender=owner) + base_pool_registry = deploy_contract( + "BasePoolRegistry", directory="registries", sender=owner + ) base_pool_data = base_pools["sbtc"] assert base_pool_data["is_legacy"] diff --git a/tests/mainnet/registries/test_add_remove_metapool.py b/tests/mainnet/registries/test_add_remove_metapool.py index db56752..fa3b5ee 100644 --- a/tests/mainnet/registries/test_add_remove_metapool.py +++ b/tests/mainnet/registries/test_add_remove_metapool.py @@ -12,8 +12,13 @@ def test_add_metapool( base_pools, tokens, ): - crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, - directory="registries", sender=owner) + crypto_registry = deploy_contract( + "CryptoRegistryV1", + address_provider, + populated_base_pool_registry, + directory="registries", + sender=owner, + ) pool_count = crypto_registry.pool_count() assert pool_count == 0 @@ -205,8 +210,13 @@ def test_remove_metapool( base_pools, tokens, ): - crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, - directory="registries", sender=owner) + crypto_registry = deploy_contract( + "CryptoRegistryV1", + address_provider, + populated_base_pool_registry, + directory="registries", + sender=owner, + ) # add EURT3CRV pool eurt3crv = crypto_registry_pools["eurt3crv"] diff --git a/tests/mainnet/registries/test_add_remove_pool.py b/tests/mainnet/registries/test_add_remove_pool.py index 4bc4021..ce70a49 100644 --- a/tests/mainnet/registries/test_add_remove_pool.py +++ b/tests/mainnet/registries/test_add_remove_pool.py @@ -48,8 +48,13 @@ def test_add_pool( owner, tokens, ): - crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, - directory="registries", sender=owner) + crypto_registry = deploy_contract( + "CryptoRegistryV1", + address_provider, + populated_base_pool_registry, + directory="registries", + sender=owner, + ) pool_count = crypto_registry.pool_count() assert pool_count == 0 @@ -152,8 +157,13 @@ def test_remove_pool( max_coins, tokens, ): - crypto_registry = deploy_contract("CryptoRegistryV1", address_provider, populated_base_pool_registry, - directory="registries", sender=owner) + crypto_registry = deploy_contract( + "CryptoRegistryV1", + address_provider, + populated_base_pool_registry, + directory="registries", + sender=owner, + ) # add pool to be removed: tricrypto2 = crypto_registry_pools["tricrypto2"] diff --git a/tests/utils.py b/tests/utils.py index f54655d..e888a45 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -27,7 +27,9 @@ def get_deployed_contract(contract_name: str, address: str) -> VyperContract: :param contract_name: The name of the contract ABI to load. :param address: The address of the deployed contract. """ - file_name = path.join(BASE_DIR, f"contracts/interfaces/{contract_name}.json") + file_name = path.join( + BASE_DIR, f"contracts/interfaces/{contract_name}.json" + ) return boa.load_abi(file_name).at(address) @@ -45,24 +47,55 @@ def deploy_contract( return boa.load(file_name, *args, **kwargs) -def get_lp_contract(address: str) -> VyperContract: +def get_deployed_token_contract(address: str) -> VyperContract: """ - Gets the LP token contract at the given address. + Gets the LP token contract at the given address. This uses a subset of the ERC20 ABI. :param address: The address of the LP token contract. """ - abi = json.dumps([{ - "name": "totalSupply", - "constant": True, - "inputs": [], - "outputs": [{"name": "", "type": "uint256"}], - "payable": False, - "stateMutability": "view", - "type": "function" - }, { - "inputs": [{ "internalType": "address", "name": "account", "type": "address" }], - "name": "balanceOf", - "outputs": [{ "internalType": "uint256", "name": "", "type": "uint256" }], - "stateMutability": "view", - "type": "function" - }]) + abi = json.dumps( + [ + { + "constant": True, + "inputs": [], + "name": "name", + "outputs": [{"name": "", "type": "string"}], + "payable": False, + "stateMutability": "view", + "type": "function", + }, + { + "constant": True, + "inputs": [], + "name": "decimals", + "outputs": [{"name": "", "type": "uint8"}], + "payable": False, + "stateMutability": "view", + "type": "function", + }, + { + "name": "totalSupply", + "constant": True, + "inputs": [], + "outputs": [{"name": "", "type": "uint256"}], + "payable": False, + "stateMutability": "view", + "type": "function", + }, + { + "inputs": [ + { + "internalType": "address", + "name": "account", + "type": "address", + } + ], + "name": "balanceOf", + "outputs": [ + {"internalType": "uint256", "name": "", "type": "uint256"} + ], + "stateMutability": "view", + "type": "function", + }, + ] + ) return boa.loads_abi(abi).at(address) From ffba98535434aacb2f9a70f1f4aec479a95674e2 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Fri, 24 Nov 2023 13:47:52 +0100 Subject: [PATCH 10/19] Test updates, fix print_missing --- scripts/print_missing.py | 117 ++++++++++-------- tests/conftest.py | 1 - .../api/test_find_pool_for_coins.py | 10 +- .../api/test_get_admin_balances.py | 11 +- .../metaregistry/api/test_get_balances.py | 7 +- .../mainnet/metaregistry/api/test_get_fees.py | 2 +- .../metaregistry/api/test_get_gauge.py | 4 +- .../api/test_get_underlying_balances.py | 8 +- .../api/test_get_underlying_coins.py | 2 +- .../api/test_get_underlying_decimals.py | 8 +- .../api/test_get_virtual_price.py | 13 +- 11 files changed, 101 insertions(+), 82 deletions(-) diff --git a/scripts/print_missing.py b/scripts/print_missing.py index 3fbb4a1..8a4aa9e 100644 --- a/scripts/print_missing.py +++ b/scripts/print_missing.py @@ -1,56 +1,75 @@ +import json + import boa -from tabulate import tabulate - -MISSING = "\033[33m✖\033[0m" -PRESENT = "\033[32m✓\033[0m" - - -def main(): - def get_non_indexed_view_functions( - registry_selectors, registry_abi, fn_index - ): - view_fns = { - d["name"] - for d in registry_abi - if d.get("stateMutability") == "view" - } - non_indexed_fns = dict(registry_selectors.items() - fn_index.items()) - return { - k: registry_selectors[k] - for k, v in non_indexed_fns.items() - if registry_selectors[k] in view_fns - } - - metaregistry = boa.load_partial("contracts/mainnet/MetaRegistry.vy") - function_index = get_non_indexed_view_functions( - metaregistry.selectors, metaregistry.abi, {} +from rich.console import Console +from rich.table import Table +from vyper.compiler.output import build_abi_output + +MISSING = "[red]✖[/red]" +PRESENT = "[green]✓[/green]" +META_NAME = "MetaRegistry" + + +def get_view_functions(abi: list[dict]) -> set[str]: + """ + Get the view functions from an ABI. + :param abi: the ABI to get the view functions from + """ + return {d["name"] for d in abi if d.get("stateMutability") == "view"} + + +def main() -> None: + """ + Calculate the missing functions from the registry and print them in a table. + """ + console = Console() + metaregistry = boa.load_partial(f"contracts/mainnet/{META_NAME}.vy") + meta_functions = get_view_functions( + abi=build_abi_output(metaregistry.compiler_data) ) - registry_coverage = [[PRESENT] * len(function_index)] registry_names = [ - f"{a}{b}" - for a in ["Crypto", "Stable"] - for b in ["Factory", "Registry"] + "CryptoFactory", + "CryptoRegistry", + "StableFactory", + "StableRegistry", ] + registry_functions = {META_NAME: meta_functions} for registry_name in registry_names: - # registry = getattr(interface, registry_name) # TODO: fix this! - registry = None - non_indexed_view_fns = get_non_indexed_view_functions( - registry.selectors, registry.abi, function_index - ) - function_index.update(non_indexed_view_fns) - registry_coverage.append( - [ - PRESENT if fn in registry.selectors else MISSING - for fn in function_index.keys() - ] - ) - - registry_coverage = [ - coverage + [MISSING] * (len(function_index) - len(coverage)) - for coverage in registry_coverage - ] - res = sorted(zip(function_index.values(), *registry_coverage)) - print( - tabulate(res, headers=["Functions", "MetaRegistry"] + registry_names) + with open(f"contracts/interfaces/{registry_name}.json") as f: + registry_abi = json.load(f) + registry_functions[registry_name] = get_view_functions(registry_abi) + + table = create_table(registry_functions) + return console.print(table) + + +def create_table(registry_functions: dict[str, set[str]]) -> Table: + """ + Create a table with the missing functions. + :param registry_functions: the functions from the registries + :return: the table with the missing functions + """ + table = Table(title="Missing Functions") + all_functions = set.union(*registry_functions.values()) + registries = [META_NAME] + sorted( + registry_name + for registry_name in registry_functions + if registry_name != META_NAME ) + table.add_column("Function Name") + for registry_name in registries: + table.add_column(registry_name) + for function_name in sorted(all_functions): + cells = [ + PRESENT + if function_name in registry_functions[registry_name] + else MISSING + for registry_name in registries + ] + table.add_row(function_name, *cells) + return table + + +if __name__ == "__main__": + main() diff --git a/tests/conftest.py b/tests/conftest.py index 40fea7b..afc28ca 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -8,7 +8,6 @@ pytest_plugins = [ "fixtures.accounts", "fixtures.constants", - "fixtures.contracts", "fixtures.deployments", "fixtures.functions", ] diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index 7ef82fd..9f9d004 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -13,8 +13,8 @@ def _get_all_combinations(metaregistry, pool): pool_coins = [ coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS ] - base_combinations = list(itertools.combinations(pool_coins, 2)) - all_combinations = base_combinations + all_combinations = list(itertools.combinations(pool_coins, 2)) + first_coin = pool_coins[0] if metaregistry.is_meta(pool): underlying_coins = [ @@ -22,10 +22,10 @@ def _get_all_combinations(metaregistry, pool): for coin in metaregistry.get_underlying_coins(pool) if coin != ZERO_ADDRESS ] - all_combinations = all_combinations + [ - (pool_coins[0], coin) + all_combinations += [ + (first_coin, coin) for coin in underlying_coins - if pool_coins[0] != coin + if first_coin != coin ] return all_combinations diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index c35ecb8..65cbb28 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -1,5 +1,6 @@ import boa import pytest +from boa import BoaError from eth.codecs.abi.exceptions import DecodeError from tests.utils import get_deployed_token_contract @@ -10,14 +11,10 @@ def pre_test_checks(metaregistry, pool): pytest.skip("empty pool: skipping") try: - if ( - get_deployed_token_contract( - metaregistry.get_lp_token(pool) - ).totalSupply() - == 0 - ): + contract = get_deployed_token_contract(metaregistry.get_lp_token(pool)) + if contract.totalSupply() == 0: pytest.skip("LP token supply is zero") - except DecodeError as err: # TODO: Document why this happens + except (BoaError, DecodeError) as err: # TODO: Document why this happens pytest.skip( f"{type(err).__name__} for token {metaregistry.get_lp_token(pool)}: " f"Skipping because of {err.msg}" diff --git a/tests/mainnet/metaregistry/api/test_get_balances.py b/tests/mainnet/metaregistry/api/test_get_balances.py index 470aa70..96df2c2 100644 --- a/tests/mainnet/metaregistry/api/test_get_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_balances.py @@ -1,3 +1,6 @@ +from boa import BoaError + + def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): @@ -28,7 +31,7 @@ def test_crypto_registry_pools( ): try: actual_output = crypto_registry.get_balances(crypto_registry_pool) - except KeyError: # TODO: Pick right exception + except BoaError: actual_output = [] pool = curve_pool_v2(crypto_registry_pool) for i in range( @@ -48,7 +51,7 @@ def test_crypto_factory_pools( ): try: actual_output = crypto_factory.get_balances(crypto_factory_pool) - except KeyError: # TODO: Pick right exception + except BoaError: actual_output = [] pool = curve_pool_v2(crypto_factory_pool) for i in range(2): diff --git a/tests/mainnet/metaregistry/api/test_get_fees.py b/tests/mainnet/metaregistry/api/test_get_fees.py index 5dbfdce..05acef9 100644 --- a/tests/mainnet/metaregistry/api/test_get_fees.py +++ b/tests/mainnet/metaregistry/api/test_get_fees.py @@ -62,7 +62,7 @@ def test_crypto_factory_pools( curve_pool_v2, ): if sum(crypto_factory.get_balances(crypto_factory_pool)) == 0: - with boa.env.anchor(): + with boa.reverts(): curve_pool_v2(crypto_factory_pool).fee() pytest.skip( f"crypto factory pool {crypto_factory_pool} is empty and factory pools tend to " diff --git a/tests/mainnet/metaregistry/api/test_get_gauge.py b/tests/mainnet/metaregistry/api/test_get_gauge.py index cedbdba..43b4ebc 100644 --- a/tests/mainnet/metaregistry/api/test_get_gauge.py +++ b/tests/mainnet/metaregistry/api/test_get_gauge.py @@ -1,10 +1,12 @@ +from boa import BoaError + from tests.utils import ZERO_ADDRESS def _is_dao_onboarded_gauge(_gauge, gauge_controller, liquidity_gauge): try: gauge_controller.gauge_types(_gauge) - except KeyError: # TODO: Pick the right exception + except BoaError: return False if liquidity_gauge(_gauge).is_killed(): diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index 2255473..dc2a290 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -1,6 +1,7 @@ import warnings import pytest +from boa import BoaError from tests.utils import ZERO_ADDRESS, get_deployed_token_contract @@ -21,7 +22,7 @@ def _get_underlying_balances( actual_output = registry.get_underlying_balances(pool) # registry getter borks, so we need to get balances the hard way: - except (KeyError, AttributeError): # TODO: Pick the right exception + except (BoaError, AttributeError): coins = metaregistry.get_coins(pool) balances = metaregistry.get_balances(pool) for idx, coin in enumerate(coins): @@ -32,10 +33,7 @@ def _get_underlying_balances( coin_contract = get_deployed_token_contract(coin) try: lp_token_supply = coin_contract.totalSupply() - except ( - KeyError, - AttributeError, - ): # TODO: Pick the right exception + except (BoaError, AttributeError): assert "totalSupply" not in [ i.name for i in coin_contract.contract_type.view_methods diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py index e57af26..4c5a64e 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py @@ -40,7 +40,7 @@ def _check_fetched_underlying_coins(registry, pool, underlying_coins): warnings.warn(f"Pool {pool} might be a lending pool.") return registry_underlying_coins - except BoaError: # TODO: Make error more specific + except BoaError: # virtual machine errors prop up for registry.get_underlying_coins if pool # is completely depegged. We check this by setting up a revert check and # then returning underlying_coins:git diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index 6c6b2b2..264ef97 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -1,4 +1,5 @@ import pytest +from boa import BoaError from tests.utils import ZERO_ADDRESS, get_deployed_token_contract @@ -7,8 +8,7 @@ "0xA96A65c051bF88B4095Ee1f2451C2A9d43F53Ae2": [18, 18], # compound pools. ctokens are 8 decimals. underlying is dai usdc: "0xA2B47E3D5c44877cca798226B7B8118F9BFb7A56": [18, 6], - # cream-yearn cytokens are 8 decimals, whereas underlying is - # dai usdc usdt: + # cream-yearn cytokens are 8 decimals, whereas underlying is dai usdc usdt: "0x2dded6Da1BF5DBdF597C45fcFaa3194e53EcfeAF": [18, 6, 6], # usdt pool has cDAI, cUSDC and USDT (which is [8, 8, 6]): "0x52EA46506B9CC5Ef470C5bf89f17Dc28bB35D85C": [18, 6, 6], @@ -35,9 +35,9 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): underlying_coins[i] ) actual_output.append(token_contract.decimals()) - except KeyError: # TODO: Pick the right exception + except BoaError: pytest.skip("Unverified contract. Skipping test.") - except ZeroDivisionError: # TODO: Pick the right exception + except ZeroDivisionError: if ( underlying_coins[i] == "0x6810e776880C02933D47DB1b9fc05908e5386b96" diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index e52a765..cc6c858 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -2,6 +2,7 @@ import boa import pytest +from boa import BoaError from tests.utils import ZERO_ADDRESS, get_deployed_token_contract @@ -11,13 +12,13 @@ def _check_pool_has_no_liquidity(metaregistry, pool, pool_balances, lp_token): # skip if pool has little to no liquidity, since vprice queries will most likely bork: if sum(pool_balances) == 0: - with boa.env.anchor(): + with boa.reverts(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip(f"empty pool: {pool}") elif sum(pool_balances) < 100: # tiny pool - with boa.env.anchor(): + with boa.reverts(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip(f"tiny pool: {pool}") @@ -42,7 +43,7 @@ def _check_skem_tokens_with_weird_decimals( ).decimals() == 0 ): - with boa.env.anchor(): + with boa.reverts(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip( f"skem token {coins[i]} in pool {pool} with zero decimals" @@ -68,7 +69,7 @@ def _check_pool_is_depegged( and min(pool_balances_float) < 1 ): try: - with boa.env.anchor(): + with boa.reverts(): metaregistry.get_virtual_price_from_lp_token(lp_token) pytest.skip( @@ -135,8 +136,8 @@ def test_stable_factory_pools( populated_metaregistry.get_virtual_price_from_lp_token(lp_token) ) assert actual_output == metaregistry_output - except KeyError: # TODO: Pick the right exception - with boa.env.anchor(): + except BoaError: + with boa.reverts(): populated_metaregistry.get_virtual_price_from_lp_token(lp_token) From 7f78b3023fb8e8488c96646401624b16421d8e30 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Mon, 27 Nov 2023 16:00:11 +0100 Subject: [PATCH 11/19] Script and test updates --- scripts/change_registry_handler.py | 69 +++++----- scripts/class_diagram.py | 119 ++++++++++++++++++ scripts/deploy.py | 83 +++++++----- scripts/deploy_crypto_registry_handler.py | 38 +++--- scripts/deployment_utils.py | 34 +++++ scripts/print_missing.py | 90 +++++++------ scripts/setup_metaregistry.py | 35 ++++-- tests/conftest.py | 9 ++ .../api/test_find_pool_for_coins.py | 3 - .../api/test_get_admin_balances.py | 53 ++++++-- tests/utils.py | 11 +- 11 files changed, 392 insertions(+), 152 deletions(-) create mode 100644 scripts/class_diagram.py create mode 100644 scripts/deployment_utils.py diff --git a/scripts/change_registry_handler.py b/scripts/change_registry_handler.py index 7896e61..6bcbfad 100644 --- a/scripts/change_registry_handler.py +++ b/scripts/change_registry_handler.py @@ -1,52 +1,42 @@ import sys -from brownie import ( - AddressProvider, - CryptoRegistry, - MetaRegistry, - ProxyAdmin, - accounts, - network, -) -from brownie.network.gas.strategies import GasNowScalingStrategy +import boa from rich.console import Console as RichConsole +from scripts.deployment_utils import setup_environment +from tests.utils import ZERO_ADDRESS, get_deployed_contract + RICH_CONSOLE = RichConsole(file=sys.stdout) ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" CRYPTO_REGISTRY_HANDLER = "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94" CRYPTO_REGISTRY_HANDLER_ID = 2 OLD_CRYPTO_REGISTRY_HANDLER = "0x22ceb131d3170f9f2FeA6b4b1dE1B45fcfC86E56" CRYPTO_REGISTRY = "0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0" -ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" - +METAREGISTRY = "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC" -if network.show_active() == "mainnet": - RICH_CONSOLE.log("Writing on mainnet") - accounts.load("babe") - txparams = {"from": accounts[0], "required_confs": 5} - try: - network.gas_price(GasNowScalingStrategy("slow", "fast")) - except ConnectionError: - pass -else: - RICH_CONSOLE.log("Simulation Mode. Writing to mainnet-fork.") - txparams = { - "from": accounts.at( - "0xbabe61887f1de2713c6f97e567623453d3C79f67", force=True - ) - } +def setup(): + """ + Sets up the environment for deployment scripts. + :return: txparams for deployment. + """ + if setup_environment(RICH_CONSOLE): + return {"from": "0xbabe61887f1de2713c6f97e567623453d3C79f67"} + return {"from": boa.env.eoa, "required_confs": 5} -def main(): +def main(txparams) -> None: + """ + Change the registry handler of the metaregistry to the new crypto registry handler. + :param txparams: txparams argument for the proxy admin. + """ # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: - address_provider = AddressProvider.at(ADDRESS_PROVIDER) - address_provider_admin = address_provider.admin() - proxy_admin = ProxyAdmin.at(address_provider_admin) - - metaregistry = MetaRegistry.at( - "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC" + address_provider = get_deployed_contract( + "AddressProvider", ADDRESS_PROVIDER ) + address_provider_admin = address_provider.admin() + proxy_admin = get_deployed_contract("ProxyAdmin", address_provider_admin) + metaregistry = get_deployed_contract("MetaRegistry", METAREGISTRY) assert ( metaregistry.get_registry(CRYPTO_REGISTRY_HANDLER_ID) @@ -54,9 +44,8 @@ def main(): ) num_pools = metaregistry.pool_count() num_registries = metaregistry.registry_length() - num_pools_in_crypto_registry = CryptoRegistry.at( - CRYPTO_REGISTRY - ).pool_count() + crypto_registry = get_deployed_contract("CryptoRegistry", CRYPTO_REGISTRY) + num_pools_in_crypto_registry = crypto_registry.pool_count() call_data = metaregistry.update_registry_handler.encode_input( CRYPTO_REGISTRY_HANDLER_ID, @@ -68,11 +57,11 @@ def main(): metaregistry.pool_count() == num_pools + num_pools_in_crypto_registry ) assert metaregistry.registry_length() == num_registries - assert ( - metaregistry.get_gauge("0xD51a44d3FaE010294C616388b506AcdA1bfAAE46") - != ZERO_ADDRESS + gauge = metaregistry.get_gauge( + "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46" ) + assert gauge != ZERO_ADDRESS if __name__ == "__main__": - main() + main(setup()) diff --git a/scripts/class_diagram.py b/scripts/class_diagram.py new file mode 100644 index 0000000..19ea47a --- /dev/null +++ b/scripts/class_diagram.py @@ -0,0 +1,119 @@ +""" +Generates a mermaid class diagram with the contract selectors and + the dependencies between contracts. +Usage: + python scripts/class_diagram.py [glob_pattern] (--internal) (--members) +""" +import sys +from base64 import b64encode +from dataclasses import dataclass +from glob import glob +from pathlib import Path + +import boa +from vyper import ast + + +@dataclass +class ContractDependencies: + """ + Describes the information extracted from each vyper contract in order to generate + the class diagram. + """ + + # the name of the contract (file) + contract: str + # a dict of the interface name to a list of the selectors where it's used + interfaces: dict[str, set[str]] + functions: list[str] + variables: list[str] + + +def get_function_descriptor(node: ast.FunctionDef) -> str: + """Returns a string describing the function signature.""" + args_descriptor = ", ".join(a.node_source_code for a in node.args.args) + return f"({node.returns} {node.name} {args_descriptor})" + + +def parse_contract(filename: str) -> ContractDependencies: + """ + The interfaces used in a contract and a list of the slots where it's used. + :param filename: The path to the Vyper source code. + :return: a list of the interface names used in the contract + """ + module = boa.load_partial(filename).compiler_data.vyper_module + interfaces = module.get_children(ast.InterfaceDef) + return ContractDependencies( + contract=Path(filename).stem, + interfaces={ + i.name: { + node.get_ancestor(ast.FunctionDef).name + for node in module.get_descendants(ast.Call) + if getattr(node.func, "id", None) == i.name + } + for i in interfaces + }, + functions=sorted( + { + get_function_descriptor(node) + for node in module.get_children(ast.FunctionDef) + } + ), + variables=sorted( + { + node.node_source_code.replace("(", " ").replace(")", "") + for node in module.get_children(ast.VariableDecl) + } + ), + ) + + +def main(pattern: str, internal=True, members=True) -> None: + """ + Generates a mermaid graph of the dependencies between contracts. + Prints the graph and a link to the image via the Mermaid Live Editor. + :param pattern: a glob pattern to match the contracts + :param internal: whether to include internal dependencies + :param members: whether to include the members of each contract + """ + contracts = [ + parse_contract(filename) for filename in glob(pattern, recursive=True) + ] + names = {c.contract for c in contracts} + + classes = ( + [ + line + for contract in contracts + for line in [f" class {contract.contract} {{"] + + contract.variables + + contract.functions + + [" }"] + ] + if members + else [] + ) + + connections = [ + f" {contract.contract} --> {interface}: " + f"{', '.join(selectors) if 0 < len(selectors) < 3 else f'{len(selectors)} selectors'}" + for contract in contracts + for interface, selectors in contract.interfaces.items() + if not internal or interface in names + ] + + graph = "\n".join(["classDiagram"] + classes + connections) + + print(graph) + print( + f"https://mermaid.ink/img/{b64encode(graph.encode()).decode('ascii')}" + ) + + +if __name__ == "__main__": + args = sys.argv[1:] + main( + pattern=args[0] if args else "contracts/**/*.vy", + internal="--internal" in args, + members="--members" in args, + ) diff --git a/scripts/deploy.py b/scripts/deploy.py index 51cfc6e..18d6dc6 100644 --- a/scripts/deploy.py +++ b/scripts/deploy.py @@ -1,83 +1,110 @@ -import click -from ape import project -from ape.cli import NetworkBoundCommand, account_option, network_option +""" +Deploy the contracts to the network. +Usage for fork mode: + scripts/deploy.py + requires the RPC_ETHEREUM environment variable to be set +Usage for prod mode: + scripts/deploy.py --prod + requires the URL and ACCOUNT environment variables to be set +""" +import boa from eth_abi import encode +from rich import Console as RichConsole + +from scripts.deployment_utils import setup_environment ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" STABLE_REGISTRY_ADDRESS = "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" STABLE_FACTORY_ADDRESS = "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" -CRYPTO_REGISTRY_ADDRESS = "" # left blank because a new one gets deployed CRYPTO_FACTORY_ADDRESS = "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" -@click.group(short_help="Deploy the project") -def cli(): - pass - +def main(): + """ + Deploy the contracts to the network. + It does the following: + 1. deploys the base pool registry + 2. deploys the crypto registry + 3. deploys the stable registry handler + 4. deploys the stable factory handler + 5. deploys the crypto registry handler + 6. deploys the crypto factory handler + 7. deploys the metaregistry + """ + console = RichConsole() + setup_environment(console) -@cli.command(cls=NetworkBoundCommand) -@network_option() -@account_option() -def main(network, account): # deploy basepool registry: - base_pool_registry = account.deploy(project.BasePoolRegistry) + base_pool_registry = boa.load( + "contracts/mainnet/registries/BasePoolRegistry.vy" + ) # deploy crypto registry: - print( + console.log( "Crypto Registry constructor arguments: ", encode(["address", "address"], [ADDRESS_PROVIDER, base_pool_registry]), ) - crypto_registry = account.deploy( - project.CryptoRegistryV1, + crypto_registry = boa.load( + "contracts/mainnet/registries/CryptoRegistryV1.vy", ADDRESS_PROVIDER, base_pool_registry, ) # deploy stable registry handler: - print( + console.log( "Stable Registry Handler constructor arguments: ", encode(["address"], [STABLE_REGISTRY_ADDRESS]).hex(), ) - account.deploy(project.StableRegistryHandler, STABLE_REGISTRY_ADDRESS) + boa.load( + "contracts/mainnet/registry_handlers/StableRegistryHandler.vy", + STABLE_REGISTRY_ADDRESS, + ) # deploy stable factory handler: - print( + console.log( "Stable Factory Handler constructor arguments: ", encode( ["address", "address"], [STABLE_FACTORY_ADDRESS, base_pool_registry], ).hex(), ) - account.deploy( - project.StableFactoryHandler, + boa.load( + "contracts/mainnet/registry_handlers/StableFactoryHandler.vy", STABLE_FACTORY_ADDRESS, base_pool_registry, ) # deploy crypto registry handler: - print( + console.log( "Crypto Registry Handler constructor arguments: ", encode(["address"], [crypto_registry]).hex(), ) - account.deploy(project.CryptoRegistryHandler, crypto_registry) + boa.load( + "contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy", + crypto_registry, + ) # deploy crypto factory handler: - print( + console.log( "Crypto Factory Handler constructor arguments: ", encode( ["address", "address"], [CRYPTO_FACTORY_ADDRESS, base_pool_registry], ).hex(), ) - account.deploy( - project.CryptoFactoryHandler, + boa.load( + "contracts/mainnet/registry_handlers/CryptoFactoryHandler.vy", CRYPTO_FACTORY_ADDRESS, base_pool_registry, ) # deploy metaregistry: - print( + console.log( "MetaRegistry constructor arguments: ", encode(["address"], [ADDRESS_PROVIDER]).hex(), ) - account.deploy(project.MetaRegistry, ADDRESS_PROVIDER) + boa.load("contracts/mainnet/MetaRegistry.vy", ADDRESS_PROVIDER) + + +if __name__ == "__main__": + main() diff --git a/scripts/deploy_crypto_registry_handler.py b/scripts/deploy_crypto_registry_handler.py index 0c25040..5a9cc3c 100644 --- a/scripts/deploy_crypto_registry_handler.py +++ b/scripts/deploy_crypto_registry_handler.py @@ -1,22 +1,28 @@ -import click -from ape import project -from ape.cli import NetworkBoundCommand, account_option, network_option -from eth_abi import encode +""" +Deploy the Crypto Registry Handler contract +Requires the Crypto Registry contract to be deployed first. + +Usage for fork mode: + scripts/deploy_crypto_registry_handler.py + requires the RPC_ETHEREUM environment variable to be set +Usage for prod mode: + scripts/deploy_crypto_registry_handler.py --prod + requires the URL and ACCOUNT environment variables to be set +""" +import boa +from rich import Console as RichConsole + +from scripts.deployment_utils import setup_environment CRYPTO_REGISTRY_ADDRESS = "0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0" -@click.group(short_help="Deploy the registry handler") -def cli(): - pass +def main(): + console = RichConsole() + console.log("Deploying Crypto Registry Handler contract...") + setup_environment(console) + boa.load("contracts/mainnet/registry_handlers/CryptoRegistryHandler.vy") -@cli.command(cls=NetworkBoundCommand) -@network_option() -@account_option() -def main(network, account): - print( - "Crypto Registry Handler constructor arguments: ", - encode(["address"], [CRYPTO_REGISTRY_ADDRESS]).hex(), - ) - account.deploy(project.CryptoRegistryHandler, CRYPTO_REGISTRY_ADDRESS) +if __name__ == "__main__": + main() diff --git a/scripts/deployment_utils.py b/scripts/deployment_utils.py new file mode 100644 index 0000000..969b01b --- /dev/null +++ b/scripts/deployment_utils.py @@ -0,0 +1,34 @@ +import sys +from os import environ + +import boa +from boa.network import NetworkEnv +from eth_account import Account +from rich.console import Console as RichConsole + +FIDDYDEPLOYER = "0x2d12D0907A388811e3AA855A550F959501d303EE" + + +def setup_environment(console: RichConsole): + """ + Sets up the environment for deployment scripts. + Requires the following environment variables: + For forks (default): + - RPC_ETHEREUM: URL to fork from. + For prod (script called with --prod argument): + - URL: URL to connect to. + - ACCOUNT: Private key of account to use. + + :param console: RichConsole instance to log to. + :return: Whether the environment is in prod mode. + """ + if "--prod" in sys.argv: + console.log("Running script in prod mode...") + boa.set_env(NetworkEnv(environ["URL"])) + boa.env.add_account(Account.from_key(environ["ACCOUNT"])) + return True + + console.log("Simulation Mode. Writing to mainnet-fork.") + boa.env.fork(url=environ["RPC_ETHEREUM"]) + boa.env.eoa = FIDDYDEPLOYER + return False diff --git a/scripts/print_missing.py b/scripts/print_missing.py index 8a4aa9e..21dab1c 100644 --- a/scripts/print_missing.py +++ b/scripts/print_missing.py @@ -3,11 +3,10 @@ import boa from rich.console import Console from rich.table import Table +from sortedcontainers import SortedDict from vyper.compiler.output import build_abi_output -MISSING = "[red]✖[/red]" -PRESENT = "[green]✓[/green]" -META_NAME = "MetaRegistry" +CELL_VALUES = {True: "[green]✓[/green]", False: "[red]✖[/red]"} def get_view_functions(abi: list[dict]) -> set[str]: @@ -18,56 +17,67 @@ def get_view_functions(abi: list[dict]) -> set[str]: return {d["name"] for d in abi if d.get("stateMutability") == "view"} -def main() -> None: +def get_functions_from_abi_json(contract_name: str) -> set[str]: """ - Calculate the missing functions from the registry and print them in a table. + Get the view functions from an ABI JSON file. + :param contract_name: the name of the contract + :return: the view functions from the ABI JSON file """ - console = Console() - metaregistry = boa.load_partial(f"contracts/mainnet/{META_NAME}.vy") + with open(f"contracts/interfaces/{contract_name}.json") as f: + abi = json.load(f) + return get_view_functions(abi) + + +def get_functions_from_source(name: str) -> set[str]: + """ + Get the view functions from a Vyper source file. + :param name: the name of the source file + :return: the view functions from the source file + """ + deployer = boa.load_partial(f"contracts/mainnet/{name}.vy") meta_functions = get_view_functions( - abi=build_abi_output(metaregistry.compiler_data) + abi=build_abi_output(deployer.compiler_data) ) - registry_names = [ - "CryptoFactory", - "CryptoRegistry", - "StableFactory", - "StableRegistry", - ] + return meta_functions - registry_functions = {META_NAME: meta_functions} - for registry_name in registry_names: - with open(f"contracts/interfaces/{registry_name}.json") as f: - registry_abi = json.load(f) - registry_functions[registry_name] = get_view_functions(registry_abi) - table = create_table(registry_functions) - return console.print(table) +def main() -> None: + """ + Calculate the missing functions from the registry and print them in a table. + """ + registry_functions = SortedDict( + [ + ("MetaRegistry", get_functions_from_source("MetaRegistry")), + ("CryptoFactory", get_functions_from_abi_json("CryptoFactory")), + ("CryptoRegistry", get_functions_from_abi_json("CryptoRegistry")), + ("StableFactory", get_functions_from_abi_json("StableFactory")), + ("StableRegistry", get_functions_from_abi_json("StableRegistry")), + ] + ) + table = compare_contracts(registry_functions) + return Console().print(table) -def create_table(registry_functions: dict[str, set[str]]) -> Table: +def compare_contracts(contract_functions: dict[str, set[str]]) -> Table: """ Create a table with the missing functions. - :param registry_functions: the functions from the registries + :param contract_functions: A dictionary with the contract name as key and a set of the + view functions as value :return: the table with the missing functions """ - table = Table(title="Missing Functions") - all_functions = set.union(*registry_functions.values()) - registries = [META_NAME] + sorted( - registry_name - for registry_name in registry_functions - if registry_name != META_NAME + table = Table( + "Function Name", + *contract_functions, + title="Comparison between the contract view functions", ) - table.add_column("Function Name") - for registry_name in registries: - table.add_column(registry_name) - for function_name in sorted(all_functions): - cells = [ - PRESENT - if function_name in registry_functions[registry_name] - else MISSING - for registry_name in registries - ] - table.add_row(function_name, *cells) + for function_name in sorted(set.union(*contract_functions.values())): + table.add_row( + function_name, + *[ + CELL_VALUES[function_name in functions] + for functions in contract_functions.values() + ], + ) return table diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index b0f8a6d..5fad82d 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -1,8 +1,19 @@ +""" +Sets up the metaregistry. + +Usage for fork mode: + scripts/setup_metaregistry.py + requires the RPC_ETHEREUM environment variable to be set +Usage for prod mode: + scripts/setup_metaregistry.py --prod + requires the URL and ACCOUNT environment variables to be set +""" import sys -import click +import boa from rich.console import Console as RichConsole +from scripts.deployment_utils import setup_environment from tests.utils import ZERO_ADDRESS, get_deployed_contract RICH_CONSOLE = RichConsole(file=sys.stdout) @@ -128,12 +139,18 @@ } -@click.group(short_help="Deploy the project") -def cli(): - pass +def main(): + """ + This script sets up the metaregistry. It does the following: + 1. Adds base pools to base pool registry. + 2. Adds crypto pools to crypto registry. + 3. Adds registry handlers to metaregistry. + 4. Adds metaregistry to address provider. + """ + setup_environment(RICH_CONSOLE) + account = boa.env.eoa -def main(network: str, account: str): # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: address_provider = get_deployed_contract( "AddressProvider", ADDRESS_PROVIDER @@ -141,10 +158,6 @@ def main(network: str, account: str): address_provider_admin = address_provider.admin() proxy_admin = get_deployed_contract("ProxyAdmin", address_provider_admin) - if network == "ethereum:mainnet-fork": - RICH_CONSOLE.log("Simulation mode.") - account = proxy_admin.admins(1) - # deployed contracts: base_pool_registry = get_deployed_contract( "BasePoolRegistry", "0xDE3eAD9B2145bBA2EB74007e58ED07308716B725" @@ -323,3 +336,7 @@ def main(network: str, account: str): "0x853d955aCEf822Db058eb8505911ED77F175b99e", ) ) + + +if __name__ == "__main__": + main() diff --git a/tests/conftest.py b/tests/conftest.py index afc28ca..26565f4 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -1,3 +1,4 @@ +import logging from os import environ import boa @@ -27,20 +28,28 @@ def pytest_sessionstart(): global STABLE_REGISTRY_POOLS global ALL_POOLS + logging.info("Connecting to Ethereum fork") # connect to the network. TODO: use Drpc-Key header instead of GET param boa.env.fork(url=environ["RPC_ETHEREUM"]) # store registries globally, so we don't have to recreate multiple times when generating tests. # TODO: Can we move these to fixtures? + logging.info("Retrieving stable registry pools") STABLE_REGISTRY_POOLS = get_contract_pools( "StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" ) + + logging.info("Retrieving stable factory pools") STABLE_FACTORY_POOLS = get_contract_pools( "StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" ) + + logging.info("Retrieving crypto registry pools") CRYPTO_REGISTRY_POOLS = get_contract_pools( "CryptoRegistry", "0x8F942C20D02bEfc377D41445793068908E2250D0" ) + + logging.info("Retrieving crypto factory pools") CRYPTO_FACTORY_POOLS = get_contract_pools( "CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" ) diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index 9f9d004..fce1773 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -1,7 +1,5 @@ import itertools -import pytest - from tests.utils import ZERO_ADDRESS # NOTE: This is the most important method in the metaregistry contract since it will be used @@ -31,7 +29,6 @@ def _get_all_combinations(metaregistry, pool): return all_combinations -@pytest.mark.skip() # TODO: This test is spawning a lot of test cases and takes >1:30h to run def test_all(populated_metaregistry, pool): combinations = _get_all_combinations(populated_metaregistry, pool) for combination in combinations: diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 65cbb28..32f4122 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -1,26 +1,59 @@ import boa import pytest from boa import BoaError -from eth.codecs.abi.exceptions import DecodeError +from eth.codecs.abi.exceptions import DecodeError as ABIDecodeError -from tests.utils import get_deployed_token_contract +from tests.utils import ZERO_ADDRESS, get_deployed_token_contract def pre_test_checks(metaregistry, pool): - if sum(metaregistry.get_balances(pool)) == 0: - pytest.skip("empty pool: skipping") + """ + Checks whether the pool is in a state that allows the test to run. + Otherwise, skips the test. + + The checks are: + - the pool has a balance + - the LP token has a supply + - the coin balances are not lower than the admin balances + """ + try: + if sum(metaregistry.get_balances(pool)) == 0: + return pytest.skip(f"Pool {pool} has no balance") + except BoaError: + assert_negative_coin_balance(metaregistry, pool) + return pytest.skip(f"Pool {pool} has coin balances lower than admin") + lp_token = metaregistry.get_lp_token(pool) try: - contract = get_deployed_token_contract(metaregistry.get_lp_token(pool)) + contract = get_deployed_token_contract(lp_token) if contract.totalSupply() == 0: - pytest.skip("LP token supply is zero") - except (BoaError, DecodeError) as err: # TODO: Document why this happens - pytest.skip( - f"{type(err).__name__} for token {metaregistry.get_lp_token(pool)}: " - f"Skipping because of {err.msg}" + return pytest.skip("LP token supply is zero") + except ABIDecodeError as e: + assert e.msg == "Value length is not the expected size of 32 bytes" + assert len(e.value) == 4096 + return pytest.skip( + f"Pool {pool} cannot decode the total supply of its LP token {lp_token}" ) +def assert_negative_coin_balance(metaregistry, pool): + """ + The implementation of get_balance calculates (balance - admin_balance) but sometimes the coin + balance might be lower than the admin balance, resulting in an uint underflow. + """ + coins = [ + coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS + ] + coin_balances = [ + get_deployed_token_contract(coin).balanceOf(pool) for coin in coins + ] + admin_balances = metaregistry.get_admin_balances(pool) + assert any( + coin_balance < admin_balance + for coin_balance, admin_balance in zip(coin_balances, admin_balances) + ) + + def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): diff --git a/tests/utils.py b/tests/utils.py index e888a45..57ced7c 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -55,18 +55,18 @@ def get_deployed_token_contract(address: str) -> VyperContract: abi = json.dumps( [ { + "name": "name", "constant": True, "inputs": [], - "name": "name", "outputs": [{"name": "", "type": "string"}], "payable": False, "stateMutability": "view", "type": "function", }, { + "name": "decimals", "constant": True, "inputs": [], - "name": "decimals", "outputs": [{"name": "", "type": "uint8"}], "payable": False, "stateMutability": "view", @@ -74,14 +74,14 @@ def get_deployed_token_contract(address: str) -> VyperContract: }, { "name": "totalSupply", - "constant": True, "inputs": [], - "outputs": [{"name": "", "type": "uint256"}], - "payable": False, + "outputs": [{"type": "uint256", "name": ""}], "stateMutability": "view", "type": "function", + "gas": 2531, }, { + "name": "balanceOf", "inputs": [ { "internalType": "address", @@ -89,7 +89,6 @@ def get_deployed_token_contract(address: str) -> VyperContract: "type": "address", } ], - "name": "balanceOf", "outputs": [ {"internalType": "uint256", "name": "", "type": "uint256"} ], From 8883c78315a17178ee5c3d859dc89b258da1311b Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Mon, 27 Nov 2023 16:46:21 +0100 Subject: [PATCH 12/19] Don't use test utils for deployment --- scripts/change_registry_handler.py | 4 +--- scripts/class_diagram.py | 3 +++ scripts/deployment_utils.py | 16 ++++++++++++++-- scripts/print_missing.py | 3 +++ scripts/setup_metaregistry.py | 3 +-- 5 files changed, 22 insertions(+), 7 deletions(-) diff --git a/scripts/change_registry_handler.py b/scripts/change_registry_handler.py index 6bcbfad..7da239b 100644 --- a/scripts/change_registry_handler.py +++ b/scripts/change_registry_handler.py @@ -3,11 +3,9 @@ import boa from rich.console import Console as RichConsole -from scripts.deployment_utils import setup_environment -from tests.utils import ZERO_ADDRESS, get_deployed_contract +from scripts.deployment_utils import setup_environment, ZERO_ADDRESS, get_deployed_contract RICH_CONSOLE = RichConsole(file=sys.stdout) -ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" CRYPTO_REGISTRY_HANDLER = "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94" CRYPTO_REGISTRY_HANDLER_ID = 2 OLD_CRYPTO_REGISTRY_HANDLER = "0x22ceb131d3170f9f2FeA6b4b1dE1B45fcfC86E56" diff --git a/scripts/class_diagram.py b/scripts/class_diagram.py index 19ea47a..909c2b1 100644 --- a/scripts/class_diagram.py +++ b/scripts/class_diagram.py @@ -3,6 +3,9 @@ the dependencies between contracts. Usage: python scripts/class_diagram.py [glob_pattern] (--internal) (--members) + +Unfortunately, rich doesn't support images in the terminal yet, so you'll have to +copy the source or link to the image and paste it in your browser. """ import sys from base64 import b64encode diff --git a/scripts/deployment_utils.py b/scripts/deployment_utils.py index 969b01b..7a4362b 100644 --- a/scripts/deployment_utils.py +++ b/scripts/deployment_utils.py @@ -3,10 +3,13 @@ import boa from boa.network import NetworkEnv +from boa.vyper.contract import VyperContract from eth_account import Account from rich.console import Console as RichConsole -FIDDYDEPLOYER = "0x2d12D0907A388811e3AA855A550F959501d303EE" +ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" +FIDDY_DEPLOYER = "0x2d12D0907A388811e3AA855A550F959501d303EE" +ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" def setup_environment(console: RichConsole): @@ -30,5 +33,14 @@ def setup_environment(console: RichConsole): console.log("Simulation Mode. Writing to mainnet-fork.") boa.env.fork(url=environ["RPC_ETHEREUM"]) - boa.env.eoa = FIDDYDEPLOYER + boa.env.eoa = FIDDY_DEPLOYER return False + +def get_deployed_contract(contract_name: str, address: str) -> VyperContract: + """ + Loads a contract and retrieves a deployed instance of it with the given address. + :param contract_name: The name of the contract ABI to load. + :param address: The address of the deployed contract. + """ + file_name = f"contracts/interfaces/{contract_name}.json" + return boa.load_abi(file_name).at(address) diff --git a/scripts/print_missing.py b/scripts/print_missing.py index 21dab1c..e7630d8 100644 --- a/scripts/print_missing.py +++ b/scripts/print_missing.py @@ -1,3 +1,6 @@ +""" +Print the missing functions from the registry. +""" import json import boa diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index 5fad82d..20e72bd 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -13,8 +13,7 @@ import boa from rich.console import Console as RichConsole -from scripts.deployment_utils import setup_environment -from tests.utils import ZERO_ADDRESS, get_deployed_contract +from scripts.deployment_utils import ZERO_ADDRESS, get_deployed_contract, setup_environment RICH_CONSOLE = RichConsole(file=sys.stdout) From 620bfe4062e3dbd14f5a7d70a66b00f8d1891bef Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Wed, 29 Nov 2023 16:48:53 +0100 Subject: [PATCH 13/19] Handle more test errors --- .pre-commit-config.yaml | 3 - README.md | 10 +-- scripts/change_registry_handler.py | 7 ++- scripts/deployment_utils.py | 1 + scripts/setup_metaregistry.py | 6 +- .../api/test_find_pool_for_coins.py | 29 ++++++--- .../api/test_get_admin_balances.py | 27 ++------ .../api/test_get_underlying_decimals.py | 1 - .../api/test_get_virtual_price.py | 61 ++++++++++++------- tests/utils.py | 29 +++++++++ 10 files changed, 110 insertions(+), 64 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index b3cc8b0..cd36aa9 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -21,6 +21,3 @@ repos: hooks: - id: isort args: ["--profile", "black", --line-length=79] - -default_language_version: - python: python3.11 diff --git a/README.md b/README.md index 6c788ee..957f2de 100644 --- a/README.md +++ b/README.md @@ -8,7 +8,7 @@ Mainnet: 1. Curve Stable Registry: A registry of custom pool implementations deployed by Curve Core. 2. Curve Stable Factory: A permissionless [StableSwap](https://curve.fi/files/stableswap-paper.pdf) pool factory, which also acts as a registry for pools that its users create. -3. Curve Crypto Registry: A registry of custom CryptoSwap pool implementaions deployed by Curve Core. +3. Curve Crypto Registry: A registry of custom CryptoSwap pool implementations deployed by Curve Core. 4. Curve Crypto Factory: A permissionless [CryptoSwap](https://curve.fi/files/crypto-pools-paper.pdf) pool factory, which also acts as a registry for pools that its users create. Each of the child registries are accompanied by a RegistryHandler, which is a contract that wraps around the child registry and enforces the abi implemented in the MetaRegistry. These registry handlers are then added to the MetaRegistry using the `MetaRegistry.add_registry_handler` method. @@ -67,9 +67,9 @@ Out[1]: '3pool' #### `MetaRegistry.is_meta` -Metapools are pools that pair a coin to a base pool comprising of multiple coins. +Meta-pools are pools that pair a coin to a base pool comprising multiple coins. -An example is the [`LUSD-3CRV`](https://etherscan.io/address/0xed279fdd11ca84beef15af5d39bb4d4bee23f0ca) pool which pairs [Liquity's](https://www.liquity.org/) [`LUSD`](https://etherscan.io/address/0x5f98805a4e8be255a32880fdec7f6728c6568ba0) against [`3CRV`](https://etherscan.io/address/0x6c3f90f043a72fa612cbac8115ee7e52bde6e490), where `3CRV` is a liquidity pool token that represents a share of a pool containing `DAI`, `USDC` and `USDT`: +An example is the [`LUSD-3CRV`](https://etherscan.io/address/0xed279fdd11ca84beef15af5d39bb4d4bee23f0ca) pool which pairs [Liquidity's](https://www.liquity.org/) [`LUSD`](https://etherscan.io/address/0x5f98805a4e8be255a32880fdec7f6728c6568ba0) against [`3CRV`](https://etherscan.io/address/0x6c3f90f043a72fa612cbac8115ee7e52bde6e490), where `3CRV` is a liquidity pool token that represents a share of a pool containing `DAI`, `USDC` and `USDT`: ``` In [1]: metaregistry.is_meta("0xed279fdd11ca84beef15af5d39bb4d4bee23f0ca") @@ -294,7 +294,7 @@ For CryptoSwap, the getter returns: 4. Allowed extra profit 5. Fee gamma 6. Adjustment step -7. MA (moving average) half time +7. MA (moving average) half-time ``` @@ -338,7 +338,7 @@ Out[1]: '0xc4AD29ba4B3c580e6D59105FFf484999997675Ff' #### `MetaRegistry.get_pool_asset_type` -Gets the asset type of a pool. `0` = `USD`, `1` = `ETH`, `2` = `BTC`, `3` = Other, `4` = CryptoPool token. The asset type is a property of StableSwaps, and is not enforced in CryptoSwap pools (which always return `4`). +Gets the asset type of pool. `0` = `USD`, `1` = `ETH`, `2` = `BTC`, `3` = Other, `4` = CryptoPool token. The asset type is a property of StableSwaps, and is not enforced in CryptoSwap pools (which always return `4`). StableSwap pool example for `LUSD-3CRV` pool which is a `USD` stablecoin pool: diff --git a/scripts/change_registry_handler.py b/scripts/change_registry_handler.py index 7da239b..205afde 100644 --- a/scripts/change_registry_handler.py +++ b/scripts/change_registry_handler.py @@ -3,7 +3,12 @@ import boa from rich.console import Console as RichConsole -from scripts.deployment_utils import setup_environment, ZERO_ADDRESS, get_deployed_contract +from scripts.deployment_utils import ( + ADDRESS_PROVIDER, + ZERO_ADDRESS, + get_deployed_contract, + setup_environment, +) RICH_CONSOLE = RichConsole(file=sys.stdout) CRYPTO_REGISTRY_HANDLER = "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94" diff --git a/scripts/deployment_utils.py b/scripts/deployment_utils.py index 7a4362b..b7e01f7 100644 --- a/scripts/deployment_utils.py +++ b/scripts/deployment_utils.py @@ -36,6 +36,7 @@ def setup_environment(console: RichConsole): boa.env.eoa = FIDDY_DEPLOYER return False + def get_deployed_contract(contract_name: str, address: str) -> VyperContract: """ Loads a contract and retrieves a deployed instance of it with the given address. diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index 20e72bd..6427bbe 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -13,7 +13,11 @@ import boa from rich.console import Console as RichConsole -from scripts.deployment_utils import ZERO_ADDRESS, get_deployed_contract, setup_environment +from scripts.deployment_utils import ( + ZERO_ADDRESS, + get_deployed_contract, + setup_environment, +) RICH_CONSOLE = RichConsole(file=sys.stdout) diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index fce1773..35e1ef4 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -1,4 +1,7 @@ -import itertools +from itertools import combinations +from os import environ + +import pytest from tests.utils import ZERO_ADDRESS @@ -11,10 +14,14 @@ def _get_all_combinations(metaregistry, pool): pool_coins = [ coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS ] - all_combinations = list(itertools.combinations(pool_coins, 2)) + all_combinations = list(combinations(pool_coins, 2)) first_coin = pool_coins[0] - if metaregistry.is_meta(pool): + # there exist some pools with an LP token as the first coin, that's incorrect + # example: 0xf5d5305790c1af08e9df44b30a1afe56ccda72df + is_first_coin_lp_token = metaregistry.get_pool_from_lp_token(first_coin) + + if metaregistry.is_meta(pool) and not is_first_coin_lp_token: underlying_coins = [ coin for coin in metaregistry.get_underlying_coins(pool) @@ -29,16 +36,18 @@ def _get_all_combinations(metaregistry, pool): return all_combinations +@pytest.mark.skipif( + condition=environ.get("TEST_ALL") == "False", + reason="This test is too slow, don't run it locally every time.", +) def test_all(populated_metaregistry, pool): - combinations = _get_all_combinations(populated_metaregistry, pool) - for combination in combinations: + all_combinations = _get_all_combinations(populated_metaregistry, pool) + for coin1, coin2 in all_combinations: pools_containing_pair = populated_metaregistry.find_pools_for_coins( - *combination + coin1, coin2 ) assert pool in pools_containing_pair for i, found_pool in enumerate(pools_containing_pair): - assert ( - populated_metaregistry.find_pool_for_coins(*combination, i) - == found_pool - ) + pool = populated_metaregistry.find_pool_for_coins(coin1, coin2, i) + assert pool == found_pool diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 32f4122..7798571 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -3,7 +3,11 @@ from boa import BoaError from eth.codecs.abi.exceptions import DecodeError as ABIDecodeError -from tests.utils import ZERO_ADDRESS, get_deployed_token_contract +from tests.utils import ( + assert_negative_coin_balance, + check_decode_error, + get_deployed_token_contract, +) def pre_test_checks(metaregistry, pool): @@ -29,31 +33,12 @@ def pre_test_checks(metaregistry, pool): if contract.totalSupply() == 0: return pytest.skip("LP token supply is zero") except ABIDecodeError as e: - assert e.msg == "Value length is not the expected size of 32 bytes" - assert len(e.value) == 4096 + check_decode_error(e) return pytest.skip( f"Pool {pool} cannot decode the total supply of its LP token {lp_token}" ) -def assert_negative_coin_balance(metaregistry, pool): - """ - The implementation of get_balance calculates (balance - admin_balance) but sometimes the coin - balance might be lower than the admin balance, resulting in an uint underflow. - """ - coins = [ - coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS - ] - coin_balances = [ - get_deployed_token_contract(coin).balanceOf(pool) for coin in coins - ] - admin_balances = metaregistry.get_admin_balances(pool) - assert any( - coin_balance < admin_balance - for coin_balance, admin_balance in zip(coin_balances, admin_balances) - ) - - def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry ): diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index 264ef97..a46ae7d 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -17,7 +17,6 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): metaregistry_output = metaregistry.get_underlying_decimals(pool) - assert metaregistry_output[1] != 0 # there has to be a second coin! pool_is_metapool = metaregistry.is_meta(pool) if pool in EXCEPTIONS: diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index cc6c858..4c4c216 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -3,8 +3,14 @@ import boa import pytest from boa import BoaError +from eth.codecs.abi.exceptions import DecodeError as ABIDecodeError -from tests.utils import ZERO_ADDRESS, get_deployed_token_contract +from tests.utils import ( + ZERO_ADDRESS, + assert_negative_coin_balance, + check_decode_error, + get_deployed_token_contract, +) # ---- sanity checks since vprice getters can revert for specific pools states ---- @@ -36,18 +42,21 @@ def _check_skem_tokens_with_weird_decimals( pool_balances_float.append(pool_balances[i] / 10 ** coin_decimals[i]) - if ( - coin_decimals[i] == 0 - and get_deployed_token_contract( - metaregistry.get_coins(pool)[0] - ).decimals() - == 0 - ): - with boa.reverts(): + first_coin = metaregistry.get_coins(pool)[0] + coin_contract = get_deployed_token_contract(first_coin) + if coin_decimals[i] == 0 and coin_contract.decimals() == 0: + try: + virtual_price = metaregistry.get_virtual_price_from_lp_token( + lp_token + ) + warnings.warn( + f"Pool {pool} virtual price {virtual_price}. continuing test" + ) + except BoaError: metaregistry.get_virtual_price_from_lp_token(lp_token) - pytest.skip( - f"skem token {coins[i]} in pool {pool} with zero decimals" - ) + pytest.skip( + f"Skem token {coins[i]} in pool {pool} with zero decimals" + ) return pool_balances_float @@ -69,23 +78,26 @@ def _check_pool_is_depegged( and min(pool_balances_float) < 1 ): try: - with boa.reverts(): - metaregistry.get_virtual_price_from_lp_token(lp_token) - + virtual_price = metaregistry.get_virtual_price_from_lp_token( + lp_token + ) + warnings.warn( + f"Pool {pool} virtual price {virtual_price}. continuing test" + ) + except BoaError: pytest.skip( f"skewed pool: {pool} as num coins (decimals divided) at index {i} is " f"{pool_balances[i] / 10 ** coin_decimals[i]}" ) - except ( - AssertionError - ): # ok to catch this assertion error since we continue testing - warnings.warn( - "pool virtual price getter did not revert. continuing test" - ) def pre_test_checks(metaregistry, pool): - pool_balances = metaregistry.get_balances(pool) + try: + pool_balances = metaregistry.get_balances(pool) + except BoaError: + assert_negative_coin_balance(metaregistry, pool) + return pytest.skip(f"Pool {pool} has coin balances lower than admin") + lp_token = metaregistry.get_lp_token(pool) _check_pool_has_no_liquidity(metaregistry, pool, pool_balances, lp_token) @@ -139,6 +151,11 @@ def test_stable_factory_pools( except BoaError: with boa.reverts(): populated_metaregistry.get_virtual_price_from_lp_token(lp_token) + except ABIDecodeError as e: + check_decode_error(e) + return pytest.skip( + f"Pool {stable_factory_pool} cannot decode the virtual price" + ) def test_crypto_registry_pools( diff --git a/tests/utils.py b/tests/utils.py index 57ced7c..82c13ad 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -4,6 +4,7 @@ import boa from boa.vyper.contract import VyperContract +from eth.codecs.abi.exceptions import DecodeError as ABIDecodeError from eth_account.signers.local import LocalAccount ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" @@ -98,3 +99,31 @@ def get_deployed_token_contract(address: str) -> VyperContract: ] ) return boa.loads_abi(abi).at(address) + + +def check_decode_error(e: ABIDecodeError): + """ + Checks that the error message is the expected decode error. + This seems to be happening in some pools, but it's not clear if it's a boa or contract issue. + :param e: The error to check. + """ + assert e.msg == "Value length is not the expected size of 32 bytes" + assert len(e.value) == 4096 + + +def assert_negative_coin_balance(metaregistry, pool): + """ + The implementation of get_balance calculates (balance - admin_balance) but sometimes the coin + balance might be lower than the admin balance, resulting in an uint underflow. + """ + coins = [ + coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS + ] + coin_balances = [ + get_deployed_token_contract(coin).balanceOf(pool) for coin in coins + ] + admin_balances = metaregistry.get_admin_balances(pool) + assert any( + coin_balance < admin_balance + for coin_balance, admin_balance in zip(coin_balances, admin_balances) + ) From 1c7fce447ddff2829021a8627b78cedff10672c5 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Mon, 4 Dec 2023 12:38:40 +0100 Subject: [PATCH 14/19] Use boa from source, fix more tests --- README.md | 2 +- requirements.in | 2 +- requirements.txt | 22 +- scripts/boa_scripts/set_up_registries.py | 11 +- tests/fixtures/constants.py | 244 +++++++++--------- .../api/test_get_admin_balances.py | 64 +++-- .../metaregistry/api/test_get_balances.py | 14 +- .../api/test_get_underlying_balances.py | 29 ++- .../api/test_get_underlying_coins.py | 11 +- .../api/test_get_underlying_decimals.py | 5 +- 10 files changed, 233 insertions(+), 171 deletions(-) diff --git a/README.md b/README.md index 957f2de..b8cdc31 100644 --- a/README.md +++ b/README.md @@ -338,7 +338,7 @@ Out[1]: '0xc4AD29ba4B3c580e6D59105FFf484999997675Ff' #### `MetaRegistry.get_pool_asset_type` -Gets the asset type of pool. `0` = `USD`, `1` = `ETH`, `2` = `BTC`, `3` = Other, `4` = CryptoPool token. The asset type is a property of StableSwaps, and is not enforced in CryptoSwap pools (which always return `4`). +Gets the asset type of a pool. `0` = `USD`, `1` = `ETH`, `2` = `BTC`, `3` = Other, `4` = CryptoPool token. The asset type is a property of StableSwaps, and is not enforced in CryptoSwap pools (which always return `4`). StableSwap pool example for `LUSD-3CRV` pool which is a `USD` stablecoin pool: diff --git a/requirements.in b/requirements.in index 478b710..c26f02c 100644 --- a/requirements.in +++ b/requirements.in @@ -1,4 +1,4 @@ -titanoboa[forking-recommended]==0.1.8 +titanoboa[forking-recommended] @ git+https://github.com/vyperlang/titanoboa black flake8 isort diff --git a/requirements.txt b/requirements.txt index 221dcb9..c420804 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile with Python 3.11 +# This file is autogenerated by pip-compile with Python 3.10 # by the following command: # # pip-compile @@ -45,7 +45,6 @@ eth-bloom==3.0.0 eth-hash[pycryptodome]==0.5.2 # via # eth-bloom - # eth-hash # eth-utils # trie eth-keyfile==0.6.1 @@ -78,6 +77,10 @@ eth-utils==2.3.1 # py-evm # rlp # trie +exceptiongroup==1.2.0 + # via + # hypothesis + # pytest filelock==3.13.1 # via virtualenv flake8==6.1.0 @@ -178,16 +181,23 @@ sortedcontainers==2.4.0 # trie tabulate==0.9.0 # via -r requirements.in -titanoboa[forking-recommended]==0.1.8 +titanoboa[forking-recommended] @ git+https://github.com/vyperlang/titanoboa + # via -r requirements.in +tomli==2.0.1 # via - # -r requirements.in - # titanoboa + # black + # build + # pip-tools + # pyproject-hooks + # pytest toolz==0.12.0 # via cytoolz trie==2.2.0 # via py-evm typing-extensions==4.8.0 - # via eth-typing + # via + # black + # eth-typing ujson==5.8.0 # via titanoboa urllib3==2.1.0 diff --git a/scripts/boa_scripts/set_up_registries.py b/scripts/boa_scripts/set_up_registries.py index 3fcf880..a7e8c72 100644 --- a/scripts/boa_scripts/set_up_registries.py +++ b/scripts/boa_scripts/set_up_registries.py @@ -43,19 +43,16 @@ def set_up_registries( boa.env.eoa = Account.from_key(os.environ[account]) data = next( - ( - data - for _network, data in deploy_utils.curve_dao_network_settings.items() - if _network in network - ), - None, + data + for _network, data in deploy_utils.curve_dao_network_settings.items() + if _network in network ) owner = data.dao_ownership_contract fee_receiver = data.fee_receiver_address - address_provider = Contract(data.address_provider) assert owner, f"Curve's DAO contracts may not be on {network}." assert fee_receiver, f"Curve's DAO contracts may not be on {network}." + address_provider = Contract(data.address_provider) # -------------------------- Register into AddressProvider -------------------------- diff --git a/tests/fixtures/constants.py b/tests/fixtures/constants.py index a6a3920..7d147fb 100644 --- a/tests/fixtures/constants.py +++ b/tests/fixtures/constants.py @@ -5,141 +5,129 @@ @pytest.fixture(scope="module") def base_pools(): - base_pool_data = {} - base_pool_data["tripool"] = { - "pool": "0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7", - "lp_token": "0x6c3F90f043a72FA612cbac8115EE7e52BDe6E490", - "num_coins": 3, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - } - - base_pool_data["fraxusdc"] = { - "pool": "0xdcef968d416a41cdac0ed8702fac8128a64241a2", - "lp_token": "0x3175df0976dfa876431c2e9ee6bc45b65d3473cc", - "num_coins": 2, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - } - - base_pool_data["sbtc"] = { - "pool": "0x7fC77b5c7614E1533320Ea6DDc2Eb61fa00A9714", - "lp_token": "0x075b1bb99792c9E1041bA13afEf80C91a1e70fB3", - "num_coins": 3, - "is_legacy": True, - "is_lending": False, - "is_v2": False, + return { + "tripool": { + "pool": "0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7", + "lp_token": "0x6c3F90f043a72FA612cbac8115EE7e52BDe6E490", + "num_coins": 3, + "is_legacy": False, + "is_lending": False, + "is_v2": False, + }, + "fraxusdc": { + "pool": "0xdcef968d416a41cdac0ed8702fac8128a64241a2", + "lp_token": "0x3175df0976dfa876431c2e9ee6bc45b65d3473cc", + "num_coins": 2, + "is_legacy": False, + "is_lending": False, + "is_v2": False, + }, + "sbtc": { + "pool": "0x7fC77b5c7614E1533320Ea6DDc2Eb61fa00A9714", + "lp_token": "0x075b1bb99792c9E1041bA13afEf80C91a1e70fB3", + "num_coins": 3, + "is_legacy": True, + "is_lending": False, + "is_v2": False, + }, } - return base_pool_data - @pytest.fixture(scope="module") def crypto_registry_pools(base_pools): - pool_data = {} - pool_data["tricrypto2"] = { - "pool": "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46", - "lp_token": "0xc4AD29ba4B3c580e6D59105FFf484999997675Ff", - "gauge": "0xDeFd8FdD20e0f34115C7018CCfb655796F6B2168", - "zap": "0x3993d34e7e99Abf6B6f367309975d1360222D446", - "num_coins": 3, - "name": "tricrypto2", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - } - - pool_data["eurt3crv"] = { - "pool": "0x9838eccc42659fa8aa7daf2ad134b53984c9427b", - "lp_token": "0x3b6831c0077a1e44ed0a21841c3bc4dc11bce833", - "gauge": "0x4Fd86Ce7Ecea88F7E0aA78DC12625996Fb3a04bC", - "zap": "0x5D0F47B32fDd343BfA74cE221808e2abE4A53827", - "num_coins": 2, - "name": "eurtusd", - "base_pool": base_pools["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - } - - pool_data["eursusdc"] = { - "pool": "0x98a7F18d4E56Cfe84E3D081B40001B3d5bD3eB8B", - "lp_token": "0x3D229E1B4faab62F621eF2F6A610961f7BD7b23B", - "gauge": "0x65CA7Dc5CB661fC58De57B1E1aF404649a27AD35", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "eursusd", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - } - - pool_data["crveth"] = { - "pool": "0x8301AE4fc9c624d1D396cbDAa1ed877821D7C511", - "lp_token": "0xEd4064f376cB8d68F770FB1Ff088a3d0F3FF5c4d", - "gauge": "0x1cEBdB0856dd985fAe9b8fEa2262469360B8a3a6", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "crveth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - } - - pool_data["cvxeth"] = { - "pool": "0xB576491F1E6e5E62f1d8F26062Ee822B40B0E0d4", - "lp_token": "0x3A283D9c08E8b55966afb64C515f5143cf907611", - "gauge": "0x7E1444BA99dcdFfE8fBdb42C02F0005D14f13BE1", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "cvxeth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - } - - pool_data["xaut3crv"] = { - "pool": "0xAdCFcf9894335dC340f6Cd182aFA45999F45Fc44", - "lp_token": "0x8484673cA7BfF40F82B041916881aeA15ee84834", - "gauge": "0x1B3E14157ED33F60668f2103bCd5Db39a1573E5B", - "zap": "0xc5FA220347375ac4f91f9E4A4AAb362F22801504", - "num_coins": 2, - "name": "xaut3crv", - "base_pool": base_pools["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - } - - pool_data["spelleth"] = { - "pool": "0x98638FAcf9a3865cd033F36548713183f6996122", - "lp_token": "0x8282BD15dcA2EA2bDf24163E8f2781B30C43A2ef", - "gauge": "0x08380a4999Be1a958E2abbA07968d703C7A3027C", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "spelleth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - } - - pool_data["teth"] = { - "pool": "0x752eBeb79963cf0732E9c0fec72a49FD1DEfAEAC", - "lp_token": "0xCb08717451aaE9EF950a2524E33B6DCaBA60147B", - "gauge": "0x6070fBD4E608ee5391189E7205d70cc4A274c017", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "teth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - } - - pool_data["eurocusd"] = { - "pool": "0xE84f5b1582BA325fDf9cE6B0c1F087ccfC924e54", - "lp_token": "0x70fc957eb90e37af82acdbd12675699797745f68", - "gauge": "0x4329c8F09725c0e3b6884C1daB1771bcE17934F9", - "zap": "0xd446a98f88e1d053d1f64986e3ed083bb1ab7e5a", - "num_coins": 2, - "name": "eurocusd", - "base_pool": base_pools["tripool"]["pool"], - "has_positive_rebasing_tokens": False, + return { + "tricrypto2": { + "pool": "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46", + "lp_token": "0xc4AD29ba4B3c580e6D59105FFf484999997675Ff", + "gauge": "0xDeFd8FdD20e0f34115C7018CCfb655796F6B2168", + "zap": "0x3993d34e7e99Abf6B6f367309975d1360222D446", + "num_coins": 3, + "name": "tricrypto2", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "eurt3crv": { + "pool": "0x9838eccc42659fa8aa7daf2ad134b53984c9427b", + "lp_token": "0x3b6831c0077a1e44ed0a21841c3bc4dc11bce833", + "gauge": "0x4Fd86Ce7Ecea88F7E0aA78DC12625996Fb3a04bC", + "zap": "0x5D0F47B32fDd343BfA74cE221808e2abE4A53827", + "num_coins": 2, + "name": "eurtusd", + "base_pool": base_pools["tripool"]["pool"], + "has_positive_rebasing_tokens": False, + }, + "eursusdc": { + "pool": "0x98a7F18d4E56Cfe84E3D081B40001B3d5bD3eB8B", + "lp_token": "0x3D229E1B4faab62F621eF2F6A610961f7BD7b23B", + "gauge": "0x65CA7Dc5CB661fC58De57B1E1aF404649a27AD35", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "eursusd", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "crveth": { + "pool": "0x8301AE4fc9c624d1D396cbDAa1ed877821D7C511", + "lp_token": "0xEd4064f376cB8d68F770FB1Ff088a3d0F3FF5c4d", + "gauge": "0x1cEBdB0856dd985fAe9b8fEa2262469360B8a3a6", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "crveth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "cvxeth": { + "pool": "0xB576491F1E6e5E62f1d8F26062Ee822B40B0E0d4", + "lp_token": "0x3A283D9c08E8b55966afb64C515f5143cf907611", + "gauge": "0x7E1444BA99dcdFfE8fBdb42C02F0005D14f13BE1", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "cvxeth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "xaut3crv": { + "pool": "0xAdCFcf9894335dC340f6Cd182aFA45999F45Fc44", + "lp_token": "0x8484673cA7BfF40F82B041916881aeA15ee84834", + "gauge": "0x1B3E14157ED33F60668f2103bCd5Db39a1573E5B", + "zap": "0xc5FA220347375ac4f91f9E4A4AAb362F22801504", + "num_coins": 2, + "name": "xaut3crv", + "base_pool": base_pools["tripool"]["pool"], + "has_positive_rebasing_tokens": False, + }, + "spelleth": { + "pool": "0x98638FAcf9a3865cd033F36548713183f6996122", + "lp_token": "0x8282BD15dcA2EA2bDf24163E8f2781B30C43A2ef", + "gauge": "0x08380a4999Be1a958E2abbA07968d703C7A3027C", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "spelleth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "teth": { + "pool": "0x752eBeb79963cf0732E9c0fec72a49FD1DEfAEAC", + "lp_token": "0xCb08717451aaE9EF950a2524E33B6DCaBA60147B", + "gauge": "0x6070fBD4E608ee5391189E7205d70cc4A274c017", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "teth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "eurocusd": { + "pool": "0xE84f5b1582BA325fDf9cE6B0c1F087ccfC924e54", + "lp_token": "0x70fc957eb90e37af82acdbd12675699797745f68", + "gauge": "0x4329c8F09725c0e3b6884C1daB1771bcE17934F9", + "zap": "0xd446a98f88e1d053d1f64986e3ed083bb1ab7e5a", + "num_coins": 2, + "name": "eurocusd", + "base_pool": base_pools["tripool"]["pool"], + "has_positive_rebasing_tokens": False, + }, } - return pool_data - @pytest.fixture(scope="module") def max_coins(): diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 7798571..3923f57 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -1,3 +1,5 @@ +import logging + import boa import pytest from boa import BoaError @@ -58,9 +60,20 @@ def test_stable_factory_pools( pre_test_checks(populated_metaregistry, stable_factory_pool) pool = curve_pool(stable_factory_pool) - metaregistry_output = populated_metaregistry.get_admin_balances( - stable_factory_pool - ) + try: + metaregistry_output = populated_metaregistry.get_admin_balances( + stable_factory_pool + ) + except BoaError: + first_coin = pool.coins(0) + with boa.reverts(): + get_deployed_token_contract(first_coin).balanceOf( + stable_factory_pool + ) + return pytest.skip( + f"Pool {stable_factory_pool} cannot determine balance of {first_coin}" + ) + for i in range(populated_metaregistry.get_n_coins(pool)): assert pool.admin_balances(i) == metaregistry_output[i] @@ -79,22 +92,18 @@ def _get_crypto_pool_admin_fees( with boa.env.anchor(): pool.claim_admin_fees(sender=alice_address) + fee_receiver_balance_after = lp_token.balanceOf(fee_receiver) claimed_lp_token_as_fee = ( - lp_token.balanceOf(fee_receiver) - - fee_receiver_token_balance_before + fee_receiver_balance_after - fee_receiver_token_balance_before ) total_supply_lp_token = lp_token.totalSupply() frac_admin_fee = int( claimed_lp_token_as_fee * 10**18 / total_supply_lp_token ) - # get admin balances in individual assets: + # get admin balances in individual assets reserves = populated_metaregistry.get_balances(pool) - admin_balances = [0] * 8 - for i in range(8): - admin_balances[i] = int(frac_admin_fee * reserves[i] / 10**18) - - return admin_balances + return [int(frac_admin_fee * reserves[i] / 10**18) for i in range(8)] def test_crypto_registry_pools( @@ -107,12 +116,23 @@ def test_crypto_registry_pools( pool = curve_pool_v2(crypto_registry_pool) fee_receiver = pool.admin_fee_receiver() - admin_balances = _get_crypto_pool_admin_fees( - populated_metaregistry, - pool, - fee_receiver, - alice_address, - ) + try: + admin_balances = _get_crypto_pool_admin_fees( + populated_metaregistry, + pool, + fee_receiver, + alice_address, + ) + except BoaError: + balance_of_pool = get_deployed_token_contract(pool.coins(1)).balanceOf( + pool.address + ) + balance = pool.balances(1) + assert balance / balance_of_pool > 10**11 + return pytest.skip( + f"Pool {pool} cannot claim admin fees. " + f"Pool has {balance_of_pool} but thinks it has {balance}." + ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) for i, output in enumerate(admin_balances): @@ -139,4 +159,12 @@ def test_crypto_factory_pools( metaregistry_output = populated_metaregistry.get_admin_balances(pool) for i, output in enumerate(admin_balances): - assert output == pytest.approx(metaregistry_output[i]) + # TODO: Check if this level of difference is acceptable + try: + assert output == pytest.approx(metaregistry_output[i]) + except AssertionError: + assert output == pytest.approx(metaregistry_output[i], rel=0.009) + logging.warning( + f"Pool {pool} has a difference in admin balance {i}: " + f"{output} != {metaregistry_output[i]}" + ) diff --git a/tests/mainnet/metaregistry/api/test_get_balances.py b/tests/mainnet/metaregistry/api/test_get_balances.py index 96df2c2..ede3b39 100644 --- a/tests/mainnet/metaregistry/api/test_get_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_balances.py @@ -1,5 +1,8 @@ +import pytest from boa import BoaError +from tests.utils import assert_negative_coin_balance + def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry @@ -15,7 +18,16 @@ def test_stable_registry_pools( def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory ): - actual_output = stable_factory.get_balances(stable_factory_pool) + try: + actual_output = stable_factory.get_balances(stable_factory_pool) + except BoaError: + assert_negative_coin_balance( + populated_metaregistry, stable_factory_pool + ) + return pytest.skip( + f"Pool {stable_factory_pool} has coin balances lower than admin" + ) + metaregistry_output = populated_metaregistry.get_balances( stable_factory_pool ) diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index dc2a290..fa2da4a 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -3,14 +3,22 @@ import pytest from boa import BoaError -from tests.utils import ZERO_ADDRESS, get_deployed_token_contract +from tests.utils import ( + ZERO_ADDRESS, + assert_negative_coin_balance, + get_deployed_token_contract, +) EXCEPTION_POOLS = ["0x79a8C46DeA5aDa233ABaFFD40F3A0A2B1e5A4F27"] def pre_test_checks(metaregistry, pool): - if sum(metaregistry.get_balances(pool)) == 0: - pytest.skip(f"Empty pool: {pool}") + try: + if sum(metaregistry.get_balances(pool)) == 0: + pytest.skip(f"Empty pool: {pool}") + except BoaError: + assert_negative_coin_balance(metaregistry, pool) + pytest.skip(f"Pool {pool} has coin balances lower than admin") def _get_underlying_balances( @@ -64,7 +72,20 @@ def _test_underlying_balances_getter( actual_output = _get_underlying_balances( metaregistry, pool, registry, base_pool_registry, max_coins ) - metaregistry_output = metaregistry.get_underlying_balances(pool) + try: + metaregistry_output = metaregistry.get_underlying_balances(pool) + except BoaError: + registry_handler = metaregistry.get_registry_handlers_from_pool(pool)[ + 0 + ] + assert ( + metaregistry.get_base_registry(registry_handler) + == registry.address + ) + base_pool = registry.get_base_pool(pool) + assert base_pool_registry.get_lp_token(base_pool) == ZERO_ADDRESS + pytest.skip(f"Pool {pool} is meta pool but base pool has no LP token") + underlying_decimals = metaregistry.get_underlying_decimals(pool) for idx, registry_value in enumerate(actual_output): diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py index 4c5a64e..ef371fc 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py @@ -146,6 +146,11 @@ def test_crypto_factory_pools( crypto_factory_pool, max_coins, ) - - for idx, coin in enumerate(actual_output): - assert coin == metaregistry_output[idx] + try: + assert actual_output == metaregistry_output + except AssertionError: + # there exist some pools with an LP token as the first coin, that's incorrect + # example: 0xf5d5305790c1af08e9dF44b30A1afe56cCda72df + first_coin = metaregistry_output[0] + assert populated_metaregistry.get_pool_from_lp_token(first_coin) + assert actual_output == metaregistry_output[1:] + [ZERO_ADDRESS] diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index a46ae7d..76c9317 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -12,6 +12,8 @@ "0x2dded6Da1BF5DBdF597C45fcFaa3194e53EcfeAF": [18, 6, 6], # usdt pool has cDAI, cUSDC and USDT (which is [8, 8, 6]): "0x52EA46506B9CC5Ef470C5bf89f17Dc28bB35D85C": [18, 6, 6], + # pool has REUSD as first coin, which returns 0 decimals, but registry has 18: + "0x066B6e1E93FA7dcd3F0Eb7f8baC7D5A747CE0BF9": [18, 18, 6, 6], } @@ -60,8 +62,7 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): else: actual_output = list(registry.get_decimals(pool)) - for idx, decimals in enumerate(actual_output): - assert decimals == metaregistry_output[idx] + assert actual_output == metaregistry_output[: len(actual_output)] def test_stable_registry_pools( From 947bea8ada7815bf6d1ff7075fdc5d6453f71f60 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Tue, 5 Dec 2023 09:39:23 +0100 Subject: [PATCH 15/19] Include ERC20 ABI with changed "from" method --- contracts/interfaces/ERC20.json | 222 ++++++++++++++++++ tests/conftest.py | 1 + .../api/test_get_admin_balances.py | 22 +- .../metaregistry/api/test_get_pool_name.py | 24 +- .../api/test_get_underlying_balances.py | 4 +- .../api/test_get_underlying_decimals.py | 6 +- .../api/test_get_virtual_price.py | 4 +- tests/utils.py | 56 +---- 8 files changed, 249 insertions(+), 90 deletions(-) create mode 100644 contracts/interfaces/ERC20.json diff --git a/contracts/interfaces/ERC20.json b/contracts/interfaces/ERC20.json new file mode 100644 index 0000000..10c04af --- /dev/null +++ b/contracts/interfaces/ERC20.json @@ -0,0 +1,222 @@ +[ + { + "constant": true, + "inputs": [], + "name": "name", + "outputs": [ + { + "name": "", + "type": "string" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_spender", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "approve", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "totalSupply", + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_from", + "type": "address" + }, + { + "name": "_to", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "transferFrom", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "decimals", + "outputs": [ + { + "name": "", + "type": "uint8" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [ + { + "name": "_owner", + "type": "address" + } + ], + "name": "balanceOf", + "outputs": [ + { + "name": "balance", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": true, + "inputs": [], + "name": "symbol", + "outputs": [ + { + "name": "", + "type": "string" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "constant": false, + "inputs": [ + { + "name": "_to", + "type": "address" + }, + { + "name": "_value", + "type": "uint256" + } + ], + "name": "transfer", + "outputs": [ + { + "name": "", + "type": "bool" + } + ], + "payable": false, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": true, + "inputs": [ + { + "name": "_owner", + "type": "address" + }, + { + "name": "_spender", + "type": "address" + } + ], + "name": "allowance", + "outputs": [ + { + "name": "", + "type": "uint256" + } + ], + "payable": false, + "stateMutability": "view", + "type": "function" + }, + { + "payable": true, + "stateMutability": "payable", + "type": "fallback" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "name": "owner", + "type": "address" + }, + { + "indexed": true, + "name": "spender", + "type": "address" + }, + { + "indexed": false, + "name": "value", + "type": "uint256" + } + ], + "name": "Approval", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "name": "_from", + "type": "address" + }, + { + "indexed": true, + "name": "to", + "type": "address" + }, + { + "indexed": false, + "name": "value", + "type": "uint256" + } + ], + "name": "Transfer", + "type": "event" + } +] diff --git a/tests/conftest.py b/tests/conftest.py index 26565f4..b4b5e94 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -31,6 +31,7 @@ def pytest_sessionstart(): logging.info("Connecting to Ethereum fork") # connect to the network. TODO: use Drpc-Key header instead of GET param boa.env.fork(url=environ["RPC_ETHEREUM"]) + # TODO: boa.env.enable_fast_mode() # store registries globally, so we don't have to recreate multiple times when generating tests. # TODO: Can we move these to fixtures? diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index 3923f57..cbf5bbf 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -8,7 +8,7 @@ from tests.utils import ( assert_negative_coin_balance, check_decode_error, - get_deployed_token_contract, + get_deployed_contract, ) @@ -31,7 +31,7 @@ def pre_test_checks(metaregistry, pool): lp_token = metaregistry.get_lp_token(pool) try: - contract = get_deployed_token_contract(lp_token) + contract = get_deployed_contract("ERC20", lp_token) if contract.totalSupply() == 0: return pytest.skip("LP token supply is zero") except ABIDecodeError as e: @@ -67,7 +67,7 @@ def test_stable_factory_pools( except BoaError: first_coin = pool.coins(0) with boa.reverts(): - get_deployed_token_contract(first_coin).balanceOf( + get_deployed_contract("ERC20", first_coin).balanceOf( stable_factory_pool ) return pytest.skip( @@ -84,9 +84,8 @@ def test_stable_factory_pools( def _get_crypto_pool_admin_fees( populated_metaregistry, pool, fee_receiver, alice_address ): - lp_token = get_deployed_token_contract( - populated_metaregistry.get_lp_token(pool) - ) + lp_address = populated_metaregistry.get_lp_token(pool) + lp_token = get_deployed_contract("ERC20", lp_address) fee_receiver_token_balance_before = lp_token.balanceOf(fee_receiver) with boa.env.anchor(): @@ -124,19 +123,18 @@ def test_crypto_registry_pools( alice_address, ) except BoaError: - balance_of_pool = get_deployed_token_contract(pool.coins(1)).balanceOf( - pool.address - ) + balance_of_pool = get_deployed_contract( + "ERC20", pool.coins(1) + ).balanceOf(pool.address) balance = pool.balances(1) - assert balance / balance_of_pool > 10**11 + assert balance / balance_of_pool > 10**8 return pytest.skip( f"Pool {pool} cannot claim admin fees. " f"Pool has {balance_of_pool} but thinks it has {balance}." ) metaregistry_output = populated_metaregistry.get_admin_balances(pool) - for i, output in enumerate(admin_balances): - assert output == pytest.approx(metaregistry_output[i]) + assert admin_balances == pytest.approx(metaregistry_output) def test_crypto_factory_pools( diff --git a/tests/mainnet/metaregistry/api/test_get_pool_name.py b/tests/mainnet/metaregistry/api/test_get_pool_name.py index 9eed3ab..fbd0301 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_name.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_name.py @@ -1,6 +1,4 @@ -import pytest - -from tests.utils import ZERO_ADDRESS, get_deployed_token_contract +from tests.utils import ZERO_ADDRESS, get_deployed_contract def test_stable_registry_pools( @@ -21,25 +19,20 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): ) ) num_registry_handlers = len( - list(filter((ZERO_ADDRESS).__ne__, pool_registry_handlers)) + handler != ZERO_ADDRESS for handler in pool_registry_handlers ) name = populated_metaregistry.get_pool_name(stable_factory_pool) + token_contract = get_deployed_contract("ERC20", stable_factory_pool) if num_registry_handlers == 1: - assert name == get_deployed_token_contract(stable_factory_pool).name() + assert name == token_contract.name() else: - with pytest.raises(AssertionError): - assert ( - name == get_deployed_token_contract(stable_factory_pool).name() - ) + assert name != token_contract.name() pool_name2 = populated_metaregistry.get_pool_name( stable_factory_pool, 1 ) - assert ( - pool_name2 - == get_deployed_token_contract(stable_factory_pool).name() - ) + assert pool_name2 == token_contract.name() assert num_registry_handlers in (1, 2) @@ -55,7 +48,6 @@ def test_crypto_factory_pools( populated_metaregistry, crypto_factory_pool, crypto_factory ): pool_name = populated_metaregistry.get_pool_name(crypto_factory_pool) - contract = get_deployed_token_contract( - crypto_factory.get_token(crypto_factory_pool) - ) + lp_token = crypto_factory.get_token(crypto_factory_pool) + contract = get_deployed_contract("ERC20", lp_token) assert pool_name == contract.name() diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index fa2da4a..989ed4f 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -6,7 +6,7 @@ from tests.utils import ( ZERO_ADDRESS, assert_negative_coin_balance, - get_deployed_token_contract, + get_deployed_contract, ) EXCEPTION_POOLS = ["0x79a8C46DeA5aDa233ABaFFD40F3A0A2B1e5A4F27"] @@ -38,7 +38,7 @@ def _get_underlying_balances( if base_pool != ZERO_ADDRESS: basepool_lp_token_balance = balances[idx] - coin_contract = get_deployed_token_contract(coin) + coin_contract = get_deployed_contract("ERC20", coin) try: lp_token_supply = coin_contract.totalSupply() except (BoaError, AttributeError): diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index 76c9317..5491635 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -1,7 +1,7 @@ import pytest from boa import BoaError -from tests.utils import ZERO_ADDRESS, get_deployed_token_contract +from tests.utils import ZERO_ADDRESS, get_deployed_contract EXCEPTIONS = { # eth: ankreth pool returns [18, 0] when it should return: @@ -32,8 +32,8 @@ def _test_underlying_decimals_getter(metaregistry, registry, pool): continue try: - token_contract = get_deployed_token_contract( - underlying_coins[i] + token_contract = get_deployed_contract( + "ERC20", underlying_coins[i] ) actual_output.append(token_contract.decimals()) except BoaError: diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index 4c4c216..094b47f 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -9,7 +9,7 @@ ZERO_ADDRESS, assert_negative_coin_balance, check_decode_error, - get_deployed_token_contract, + get_deployed_contract, ) # ---- sanity checks since vprice getters can revert for specific pools states ---- @@ -43,7 +43,7 @@ def _check_skem_tokens_with_weird_decimals( pool_balances_float.append(pool_balances[i] / 10 ** coin_decimals[i]) first_coin = metaregistry.get_coins(pool)[0] - coin_contract = get_deployed_token_contract(first_coin) + coin_contract = get_deployed_contract("ERC20", first_coin) if coin_decimals[i] == 0 and coin_contract.decimals() == 0: try: virtual_price = metaregistry.get_virtual_price_from_lp_token( diff --git a/tests/utils.py b/tests/utils.py index 82c13ad..8779c0e 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -1,4 +1,3 @@ -import json from os import path from typing import Union @@ -48,59 +47,6 @@ def deploy_contract( return boa.load(file_name, *args, **kwargs) -def get_deployed_token_contract(address: str) -> VyperContract: - """ - Gets the LP token contract at the given address. This uses a subset of the ERC20 ABI. - :param address: The address of the LP token contract. - """ - abi = json.dumps( - [ - { - "name": "name", - "constant": True, - "inputs": [], - "outputs": [{"name": "", "type": "string"}], - "payable": False, - "stateMutability": "view", - "type": "function", - }, - { - "name": "decimals", - "constant": True, - "inputs": [], - "outputs": [{"name": "", "type": "uint8"}], - "payable": False, - "stateMutability": "view", - "type": "function", - }, - { - "name": "totalSupply", - "inputs": [], - "outputs": [{"type": "uint256", "name": ""}], - "stateMutability": "view", - "type": "function", - "gas": 2531, - }, - { - "name": "balanceOf", - "inputs": [ - { - "internalType": "address", - "name": "account", - "type": "address", - } - ], - "outputs": [ - {"internalType": "uint256", "name": "", "type": "uint256"} - ], - "stateMutability": "view", - "type": "function", - }, - ] - ) - return boa.loads_abi(abi).at(address) - - def check_decode_error(e: ABIDecodeError): """ Checks that the error message is the expected decode error. @@ -120,7 +66,7 @@ def assert_negative_coin_balance(metaregistry, pool): coin for coin in metaregistry.get_coins(pool) if coin != ZERO_ADDRESS ] coin_balances = [ - get_deployed_token_contract(coin).balanceOf(pool) for coin in coins + get_deployed_contract("ERC20", coin).balanceOf(pool) for coin in coins ] admin_balances = metaregistry.get_admin_balances(pool) assert any( From 91400bcd366cd57a7784d1c7f87379f755fa38ca Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Fri, 8 Dec 2023 09:48:11 +0100 Subject: [PATCH 16/19] Fix last tests --- README.md | 24 +++++--------- .../api/test_find_pool_for_coins.py | 16 ++++++--- .../metaregistry/api/test_get_pool_name.py | 33 +++++++++++-------- 3 files changed, 38 insertions(+), 35 deletions(-) diff --git a/README.md b/README.md index b8cdc31..c5fdccc 100644 --- a/README.md +++ b/README.md @@ -393,7 +393,7 @@ Set up the python environment using the following steps: ``` -This project uses `titanoboa`. +This project uses [`titanoboa`](https://github.com/vyperlang/titanoboa) for deployment and testing. ### Testing @@ -441,21 +441,13 @@ The following command simulates metaregistry setup. For Prod transactions, set n #### Deployments Ethereum Mainnet: - - -`base_pool_registry`: [0xDE3eAD9B2145bBA2EB74007e58ED07308716B725](https://etherscan.io/address/0xDE3eAD9B2145bBA2EB74007e58ED07308716B725#code) - -`crypto_registry`: [0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0](https://etherscan.io/address/0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0#code) - -`stable_registry_handler`: [0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68](https://etherscan.io/address/0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68#code) - -`stable_factory_handler`: [0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9](https://etherscan.io/address/0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9#code) - -`crypto_registry_handler`: [0x22ceb131d3170f9f2FeA6b4b1dE1B45fcfC86E56](https://etherscan.io/address/0x22ceb131d3170f9f2FeA6b4b1dE1B45fcfC86E56#code) - -`crypto_factory_handler`: [0xC4F389020002396143B863F6325aA6ae481D19CE](https://etherscan.io/address/0xC4F389020002396143B863F6325aA6ae481D19CE#code) - -`metaregistry`: [0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC](https://etherscan.io/address/0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC#code) +- `base_pool_registry`: [0xDE3eAD9B2145bBA2EB74007e58ED07308716B725](https://etherscan.io/address/0xDE3eAD9B2145bBA2EB74007e58ED07308716B725#code) +- `crypto_registry`: [0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0](https://etherscan.io/address/0x9a32aF1A11D9c937aEa61A3790C2983257eA8Bc0#code) +- `stable_registry_handler`: [0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68](https://etherscan.io/address/0x46a8a9CF4Fc8e99EC3A14558ACABC1D93A27de68#code) +- `stable_factory_handler`: [0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9](https://etherscan.io/address/0x127db66E7F0b16470Bec194d0f496F9Fa065d0A9#code) +- `crypto_registry_handler`: [0x22ceb131d3170f9f2FeA6b4b1dE1B45fcfC86E56](https://etherscan.io/address/0x22ceb131d3170f9f2FeA6b4b1dE1B45fcfC86E56#code) +- `crypto_factory_handler`: [0xC4F389020002396143B863F6325aA6ae481D19CE](https://etherscan.io/address/0xC4F389020002396143B863F6325aA6ae481D19CE#code) +- `metaregistry`: [0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC](https://etherscan.io/address/0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC#code) ### License diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index 35e1ef4..2d4d930 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -19,7 +19,8 @@ def _get_all_combinations(metaregistry, pool): # there exist some pools with an LP token as the first coin, that's incorrect # example: 0xf5d5305790c1af08e9df44b30a1afe56ccda72df - is_first_coin_lp_token = metaregistry.get_pool_from_lp_token(first_coin) + lp_token_pool = metaregistry.get_pool_from_lp_token(first_coin) + is_first_coin_lp_token = lp_token_pool and lp_token_pool != ZERO_ADDRESS if metaregistry.is_meta(pool) and not is_first_coin_lp_token: underlying_coins = [ @@ -46,8 +47,13 @@ def test_all(populated_metaregistry, pool): pools_containing_pair = populated_metaregistry.find_pools_for_coins( coin1, coin2 ) - assert pool in pools_containing_pair + assert pool in pools_containing_pair, ( + f"Cannot find pool {pool} for coin combination {coin1} and {coin2}. " + f"Pools found {pools_containing_pair}" + ) - for i, found_pool in enumerate(pools_containing_pair): - pool = populated_metaregistry.find_pool_for_coins(coin1, coin2, i) - assert pool == found_pool + # test with specified index + assert pools_containing_pair == [ + populated_metaregistry.find_pool_for_coins(coin1, coin2, i) + for i in range(len(pools_containing_pair)) + ] diff --git a/tests/mainnet/metaregistry/api/test_get_pool_name.py b/tests/mainnet/metaregistry/api/test_get_pool_name.py index fbd0301..b9fed83 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_name.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_name.py @@ -18,23 +18,28 @@ def test_stable_factory_pools(populated_metaregistry, stable_factory_pool): stable_factory_pool ) ) - num_registry_handlers = len( - handler != ZERO_ADDRESS for handler in pool_registry_handlers + pool_registry_handlers = [ + handler + for handler in pool_registry_handlers + if handler != ZERO_ADDRESS + ] + num_registry_handlers = len(pool_registry_handlers) + + pool_name = populated_metaregistry.get_pool_name(stable_factory_pool) + token_name = get_deployed_contract("ERC20", stable_factory_pool).name() + assert num_registry_handlers in (1, 2), ( + f"Invalid number of registry handlers for {stable_factory_pool}. " + f"Metaregistry returned {num_registry_handlers} handlers: {pool_registry_handlers}" ) - - name = populated_metaregistry.get_pool_name(stable_factory_pool) - token_contract = get_deployed_contract("ERC20", stable_factory_pool) if num_registry_handlers == 1: - assert name == token_contract.name() - else: - assert name != token_contract.name() - - pool_name2 = populated_metaregistry.get_pool_name( - stable_factory_pool, 1 - ) - assert pool_name2 == token_contract.name() + assert pool_name == token_name + return - assert num_registry_handlers in (1, 2) + assert pool_name != token_name + second_pool_name = populated_metaregistry.get_pool_name( + stable_factory_pool, 1 + ) + assert second_pool_name == token_name def test_crypto_registry_pools( From 95492256a7c06286f7e4738f9a2056c215227394 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Fri, 8 Dec 2023 10:58:38 +0100 Subject: [PATCH 17/19] Fix TODOs and run tests in parallel --- .github/workflows/main.yaml | 2 +- requirements.in | 2 + requirements.txt | 9 +- scripts/change_registry_handler.py | 28 ++-- scripts/constants.py | 132 ++++++++++++++++++ scripts/deploy.py | 11 +- scripts/deployment_utils.py | 10 +- scripts/setup_metaregistry.py | 129 +---------------- tests/conftest.py | 100 +++++++------ tests/fixtures/accounts.py | 35 ++--- tests/fixtures/constants.py | 122 +--------------- tests/fixtures/deployments.py | 32 ++--- tests/fixtures/functions.py | 2 +- .../api/test_find_pool_for_coins.py | 2 +- .../api/test_get_admin_balances.py | 11 +- .../metaregistry/api/test_get_base_pool.py | 2 +- .../metaregistry/api/test_get_coin_indices.py | 2 +- .../mainnet/metaregistry/api/test_get_fees.py | 2 - .../metaregistry/api/test_get_gauge.py | 2 +- .../metaregistry/api/test_get_n_coins.py | 2 +- .../api/test_get_n_underlying_coins.py | 2 +- .../metaregistry/api/test_get_pool_name.py | 3 +- .../api/test_get_underlying_balances.py | 8 +- .../api/test_get_underlying_coins.py | 2 +- .../api/test_get_underlying_decimals.py | 3 +- .../api/test_get_virtual_price.py | 11 +- .../metaregistry/api/test_pool_is_metapool.py | 2 +- .../test_base_registry_tracking.py | 64 +++------ .../registries/test_add_remove_basepool.py | 3 +- .../registries/test_add_remove_metapool.py | 3 +- .../registries/test_add_remove_pool.py | 3 +- tests/utils.py | 21 +-- 32 files changed, 309 insertions(+), 453 deletions(-) create mode 100644 scripts/constants.py diff --git a/.github/workflows/main.yaml b/.github/workflows/main.yaml index 205d557..7be19a1 100644 --- a/.github/workflows/main.yaml +++ b/.github/workflows/main.yaml @@ -24,6 +24,6 @@ jobs: run: pip install --upgrade pip && pip install --no-cache-dir -r requirements.txt - name: Run Tests - run: pytest + run: pytest -n 16 env: RPC_ETHEREUM: ${{ secrets.RPC_ETHEREUM }} diff --git a/requirements.in b/requirements.in index c26f02c..9b3c7f9 100644 --- a/requirements.in +++ b/requirements.in @@ -6,3 +6,5 @@ pip-tools pre-commit tabulate rich +pytest +pytest-xdist diff --git a/requirements.txt b/requirements.txt index c420804..8beecb4 100644 --- a/requirements.txt +++ b/requirements.txt @@ -81,6 +81,8 @@ exceptiongroup==1.2.0 # via # hypothesis # pytest +execnet==2.0.2 + # via pytest-xdist filelock==3.13.1 # via virtualenv flake8==6.1.0 @@ -156,7 +158,12 @@ pygments==2.17.2 pyproject-hooks==1.0.0 # via build pytest==7.4.3 - # via titanoboa + # via + # -r requirements.in + # pytest-xdist + # titanoboa +pytest-xdist==3.5.0 + # via -r requirements.in pyyaml==6.0.1 # via pre-commit regex==2023.10.3 diff --git a/scripts/change_registry_handler.py b/scripts/change_registry_handler.py index 205afde..38e25ae 100644 --- a/scripts/change_registry_handler.py +++ b/scripts/change_registry_handler.py @@ -3,12 +3,8 @@ import boa from rich.console import Console as RichConsole -from scripts.deployment_utils import ( - ADDRESS_PROVIDER, - ZERO_ADDRESS, - get_deployed_contract, - setup_environment, -) +from scripts.constants import ADDRESS_PROVIDER, ZERO_ADDRESS +from scripts.deployment_utils import get_deployed_contract, setup_environment RICH_CONSOLE = RichConsole(file=sys.stdout) CRYPTO_REGISTRY_HANDLER = "0x5f493fEE8D67D3AE3bA730827B34126CFcA0ae94" @@ -18,21 +14,17 @@ METAREGISTRY = "0xF98B45FA17DE75FB1aD0e7aFD971b0ca00e379fC" -def setup(): - """ - Sets up the environment for deployment scripts. - :return: txparams for deployment. - """ - if setup_environment(RICH_CONSOLE): - return {"from": "0xbabe61887f1de2713c6f97e567623453d3C79f67"} - return {"from": boa.env.eoa, "required_confs": 5} - - -def main(txparams) -> None: +def main() -> None: """ Change the registry handler of the metaregistry to the new crypto registry handler. :param txparams: txparams argument for the proxy admin. """ + txparams = ( + {"from": "0xbabe61887f1de2713c6f97e567623453d3C79f67"} + if setup_environment(RICH_CONSOLE) + else {"from": boa.env.eoa, "required_confs": 5} + ) + # admin only: only admin of ADDRESSPROVIDER's proxy admin can do the following: address_provider = get_deployed_contract( "AddressProvider", ADDRESS_PROVIDER @@ -67,4 +59,4 @@ def main(txparams) -> None: if __name__ == "__main__": - main(setup()) + main() diff --git a/scripts/constants.py b/scripts/constants.py new file mode 100644 index 0000000..e31be7f --- /dev/null +++ b/scripts/constants.py @@ -0,0 +1,132 @@ +from os.path import abspath, dirname, join + +BASE_DIR = join(dirname(abspath(__file__)), "..") + +ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" + +ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" +STABLE_REGISTRY_ADDRESS = "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" +STABLE_FACTORY_ADDRESS = "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" +CRYPTO_FACTORY_ADDRESS = "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" + +FIDDY_DEPLOYER = "0x2d12D0907A388811e3AA855A550F959501d303EE" + +BASE_POOLS = { + "tripool": { + "pool": "0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7", + "lp_token": "0x6c3F90f043a72FA612cbac8115EE7e52BDe6E490", + "num_coins": 3, + "is_legacy": False, + "is_lending": False, + "is_v2": False, + }, + "fraxusdc": { + "pool": "0xdcef968d416a41cdac0ed8702fac8128a64241a2", + "lp_token": "0x3175df0976dfa876431c2e9ee6bc45b65d3473cc", + "num_coins": 2, + "is_legacy": False, + "is_lending": False, + "is_v2": False, + }, + "sbtc": { + "pool": "0x7fC77b5c7614E1533320Ea6DDc2Eb61fa00A9714", + "lp_token": "0x075b1bb99792c9E1041bA13afEf80C91a1e70fB3", + "num_coins": 3, + "is_legacy": True, + "is_lending": False, + "is_v2": False, + }, +} + +CRYPTO_REGISTRY_POOLS = { + "tricrypto2": { + "pool": "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46", + "lp_token": "0xc4AD29ba4B3c580e6D59105FFf484999997675Ff", + "gauge": "0xDeFd8FdD20e0f34115C7018CCfb655796F6B2168", + "zap": "0x3993d34e7e99Abf6B6f367309975d1360222D446", + "num_coins": 3, + "name": "tricrypto2", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "eurt3crv": { + "pool": "0x9838eccc42659fa8aa7daf2ad134b53984c9427b", + "lp_token": "0x3b6831c0077a1e44ed0a21841c3bc4dc11bce833", + "gauge": "0x4Fd86Ce7Ecea88F7E0aA78DC12625996Fb3a04bC", + "zap": "0x5D0F47B32fDd343BfA74cE221808e2abE4A53827", + "num_coins": 2, + "name": "eurtusd", + "base_pool": BASE_POOLS["tripool"]["pool"], + "has_positive_rebasing_tokens": False, + }, + "eursusdc": { + "pool": "0x98a7F18d4E56Cfe84E3D081B40001B3d5bD3eB8B", + "lp_token": "0x3D229E1B4faab62F621eF2F6A610961f7BD7b23B", + "gauge": "0x65CA7Dc5CB661fC58De57B1E1aF404649a27AD35", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "eursusd", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "crveth": { + "pool": "0x8301AE4fc9c624d1D396cbDAa1ed877821D7C511", + "lp_token": "0xEd4064f376cB8d68F770FB1Ff088a3d0F3FF5c4d", + "gauge": "0x1cEBdB0856dd985fAe9b8fEa2262469360B8a3a6", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "crveth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "cvxeth": { + "pool": "0xB576491F1E6e5E62f1d8F26062Ee822B40B0E0d4", + "lp_token": "0x3A283D9c08E8b55966afb64C515f5143cf907611", + "gauge": "0x7E1444BA99dcdFfE8fBdb42C02F0005D14f13BE1", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "cvxeth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "xaut3crv": { + "pool": "0xAdCFcf9894335dC340f6Cd182aFA45999F45Fc44", + "lp_token": "0x8484673cA7BfF40F82B041916881aeA15ee84834", + "gauge": "0x1B3E14157ED33F60668f2103bCd5Db39a1573E5B", + "zap": "0xc5FA220347375ac4f91f9E4A4AAb362F22801504", + "num_coins": 2, + "name": "xaut3crv", + "base_pool": BASE_POOLS["tripool"]["pool"], + "has_positive_rebasing_tokens": False, + }, + "spelleth": { + "pool": "0x98638FAcf9a3865cd033F36548713183f6996122", + "lp_token": "0x8282BD15dcA2EA2bDf24163E8f2781B30C43A2ef", + "gauge": "0x08380a4999Be1a958E2abbA07968d703C7A3027C", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "spelleth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "teth": { + "pool": "0x752eBeb79963cf0732E9c0fec72a49FD1DEfAEAC", + "lp_token": "0xCb08717451aaE9EF950a2524E33B6DCaBA60147B", + "gauge": "0x6070fBD4E608ee5391189E7205d70cc4A274c017", + "zap": ZERO_ADDRESS, + "num_coins": 2, + "name": "teth", + "base_pool": ZERO_ADDRESS, + "has_positive_rebasing_tokens": False, + }, + "eurocusd": { + "pool": "0xE84f5b1582BA325fDf9cE6B0c1F087ccfC924e54", + "lp_token": "0x70fc957eb90e37af82acdbd12675699797745f68", + "gauge": "0x4329c8F09725c0e3b6884C1daB1771bcE17934F9", + "zap": "0xd446a98f88e1d053d1f64986e3ed083bb1ab7e5a", + "num_coins": 2, + "name": "eurocusd", + "base_pool": BASE_POOLS["tripool"]["pool"], + "has_positive_rebasing_tokens": False, + }, +} diff --git a/scripts/deploy.py b/scripts/deploy.py index 18d6dc6..15b8757 100644 --- a/scripts/deploy.py +++ b/scripts/deploy.py @@ -8,16 +8,17 @@ requires the URL and ACCOUNT environment variables to be set """ import boa +from constants import ( + ADDRESS_PROVIDER, + CRYPTO_FACTORY_ADDRESS, + STABLE_FACTORY_ADDRESS, + STABLE_REGISTRY_ADDRESS, +) from eth_abi import encode from rich import Console as RichConsole from scripts.deployment_utils import setup_environment -ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" -STABLE_REGISTRY_ADDRESS = "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" -STABLE_FACTORY_ADDRESS = "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" -CRYPTO_FACTORY_ADDRESS = "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" - def main(): """ diff --git a/scripts/deployment_utils.py b/scripts/deployment_utils.py index b7e01f7..e894cd6 100644 --- a/scripts/deployment_utils.py +++ b/scripts/deployment_utils.py @@ -1,5 +1,5 @@ import sys -from os import environ +from os import environ, path import boa from boa.network import NetworkEnv @@ -7,9 +7,7 @@ from eth_account import Account from rich.console import Console as RichConsole -ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" -FIDDY_DEPLOYER = "0x2d12D0907A388811e3AA855A550F959501d303EE" -ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" +from scripts.constants import BASE_DIR, FIDDY_DEPLOYER def setup_environment(console: RichConsole): @@ -43,5 +41,7 @@ def get_deployed_contract(contract_name: str, address: str) -> VyperContract: :param contract_name: The name of the contract ABI to load. :param address: The address of the deployed contract. """ - file_name = f"contracts/interfaces/{contract_name}.json" + file_name = path.join( + BASE_DIR, f"contracts/interfaces/{contract_name}.json" + ) return boa.load_abi(file_name).at(address) diff --git a/scripts/setup_metaregistry.py b/scripts/setup_metaregistry.py index 6427bbe..57674e5 100644 --- a/scripts/setup_metaregistry.py +++ b/scripts/setup_metaregistry.py @@ -13,134 +13,15 @@ import boa from rich.console import Console as RichConsole -from scripts.deployment_utils import ( - ZERO_ADDRESS, - get_deployed_contract, - setup_environment, +from scripts.constants import ( + ADDRESS_PROVIDER, + BASE_POOLS, + CRYPTO_REGISTRY_POOLS, ) +from scripts.deployment_utils import get_deployed_contract, setup_environment RICH_CONSOLE = RichConsole(file=sys.stdout) -ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" -BASE_POOLS = { - "tripool": { - "pool": "0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7", - "lp_token": "0x6c3F90f043a72FA612cbac8115EE7e52BDe6E490", - "num_coins": 3, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - }, - "fraxusdc": { - "pool": "0xdcef968d416a41cdac0ed8702fac8128a64241a2", - "lp_token": "0x3175df0976dfa876431c2e9ee6bc45b65d3473cc", - "num_coins": 2, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - }, - "sbtc": { - "pool": "0x7fC77b5c7614E1533320Ea6DDc2Eb61fa00A9714", - "lp_token": "0x075b1bb99792c9E1041bA13afEf80C91a1e70fB3", - "num_coins": 3, - "is_legacy": True, - "is_lending": False, - "is_v2": False, - }, -} -CRYPTO_REGISTRY_POOLS = { - "tricrypto2": { - "pool": "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46", - "lp_token": "0xc4AD29ba4B3c580e6D59105FFf484999997675Ff", - "gauge": "0xDeFd8FdD20e0f34115C7018CCfb655796F6B2168", - "zap": "0x3993d34e7e99Abf6B6f367309975d1360222D446", - "num_coins": 3, - "name": "tricrypto2", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "eurt3crv": { - "pool": "0x9838eccc42659fa8aa7daf2ad134b53984c9427b", - "lp_token": "0x3b6831c0077a1e44ed0a21841c3bc4dc11bce833", - "gauge": "0x4Fd86Ce7Ecea88F7E0aA78DC12625996Fb3a04bC", - "zap": "0x5D0F47B32fDd343BfA74cE221808e2abE4A53827", - "num_coins": 2, - "name": "eurtusd", - "base_pool": BASE_POOLS["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, - "eursusdc": { - "pool": "0x98a7F18d4E56Cfe84E3D081B40001B3d5bD3eB8B", - "lp_token": "0x3D229E1B4faab62F621eF2F6A610961f7BD7b23B", - "gauge": "0x65CA7Dc5CB661fC58De57B1E1aF404649a27AD35", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "eursusd", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "crveth": { - "pool": "0x8301AE4fc9c624d1D396cbDAa1ed877821D7C511", - "lp_token": "0xEd4064f376cB8d68F770FB1Ff088a3d0F3FF5c4d", - "gauge": "0x1cEBdB0856dd985fAe9b8fEa2262469360B8a3a6", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "crveth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "cvxeth": { - "pool": "0xB576491F1E6e5E62f1d8F26062Ee822B40B0E0d4", - "lp_token": "0x3A283D9c08E8b55966afb64C515f5143cf907611", - "gauge": "0x7E1444BA99dcdFfE8fBdb42C02F0005D14f13BE1", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "cvxeth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "xaut3crv": { - "pool": "0xAdCFcf9894335dC340f6Cd182aFA45999F45Fc44", - "lp_token": "0x8484673cA7BfF40F82B041916881aeA15ee84834", - "gauge": "0x1B3E14157ED33F60668f2103bCd5Db39a1573E5B", - "zap": "0xc5FA220347375ac4f91f9E4A4AAb362F22801504", - "num_coins": 2, - "name": "xaut3crv", - "base_pool": BASE_POOLS["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, - "spelleth": { - "pool": "0x98638FAcf9a3865cd033F36548713183f6996122", - "lp_token": "0x8282BD15dcA2EA2bDf24163E8f2781B30C43A2ef", - "gauge": "0x08380a4999Be1a958E2abbA07968d703C7A3027C", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "spelleth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "teth": { - "pool": "0x752eBeb79963cf0732E9c0fec72a49FD1DEfAEAC", - "lp_token": "0xCb08717451aaE9EF950a2524E33B6DCaBA60147B", - "gauge": "0x6070fBD4E608ee5391189E7205d70cc4A274c017", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "teth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "eurocusd": { - "pool": "0xE84f5b1582BA325fDf9cE6B0c1F087ccfC924e54", - "lp_token": "0x70fc957eb90e37af82acdbd12675699797745f68", - "gauge": "0x4329c8F09725c0e3b6884C1daB1771bcE17934F9", - "zap": "0xd446a98f88e1d053d1f64986e3ed083bb1ab7e5a", - "num_coins": 2, - "name": "eurocusd", - "base_pool": BASE_POOLS["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, -} - def main(): """ diff --git a/tests/conftest.py b/tests/conftest.py index b4b5e94..0d2b50a 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -1,5 +1,7 @@ import logging +from functools import cache from os import environ +from urllib.parse import urlparse import boa import pytest @@ -7,99 +9,109 @@ from tests.utils import get_contract_pools pytest_plugins = [ - "fixtures.accounts", - "fixtures.constants", - "fixtures.deployments", - "fixtures.functions", + "tests.fixtures.accounts", + "tests.fixtures.constants", + "tests.fixtures.deployments", + "tests.fixtures.functions", ] -CRYPTO_REGISTRY_POOLS = None -CRYPTO_FACTORY_POOLS = None -STABLE_REGISTRY_POOLS = None -STABLE_FACTORY_POOLS = None -ALL_POOLS = None - -def pytest_sessionstart(): - """Set up pools into global variables at session start""" - global CRYPTO_REGISTRY_POOLS - global CRYPTO_FACTORY_POOLS - global STABLE_FACTORY_POOLS - global STABLE_REGISTRY_POOLS - global ALL_POOLS - - logging.info("Connecting to Ethereum fork") - # connect to the network. TODO: use Drpc-Key header instead of GET param - boa.env.fork(url=environ["RPC_ETHEREUM"]) - # TODO: boa.env.enable_fast_mode() - - # store registries globally, so we don't have to recreate multiple times when generating tests. - # TODO: Can we move these to fixtures? +@cache +def _get_stable_registry_pools(): logging.info("Retrieving stable registry pools") - STABLE_REGISTRY_POOLS = get_contract_pools( + return get_contract_pools( "StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" ) + +@cache +def _get_stable_factory_pools(): logging.info("Retrieving stable factory pools") - STABLE_FACTORY_POOLS = get_contract_pools( + return get_contract_pools( "StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" ) + +@cache +def _get_crypto_registry_pools(): logging.info("Retrieving crypto registry pools") - CRYPTO_REGISTRY_POOLS = get_contract_pools( + return get_contract_pools( "CryptoRegistry", "0x8F942C20D02bEfc377D41445793068908E2250D0" ) + +@cache +def _get_crypto_factory_pools(): logging.info("Retrieving crypto factory pools") - CRYPTO_FACTORY_POOLS = get_contract_pools( + return get_contract_pools( "CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" ) - ALL_POOLS = ( - STABLE_REGISTRY_POOLS - + STABLE_FACTORY_POOLS - + CRYPTO_REGISTRY_POOLS - + CRYPTO_FACTORY_POOLS + +@cache +def _get_all_pools(): + return ( + _get_stable_registry_pools() + + _get_stable_factory_pools() + + _get_crypto_registry_pools() + + _get_crypto_factory_pools() + ) + + +def pytest_sessionstart(): + """Set up pools into global variables at session start""" + logging.info( + f"Connecting to fork at {urlparse(environ['RPC_ETHEREUM']).netloc}" ) + boa.env.fork(url=environ["RPC_ETHEREUM"]) + # TODO: boa.env.enable_fast_mode() def pytest_generate_tests(metafunc): if "stable_registry_pool" in metafunc.fixturenames: - metafunc.parametrize("stable_registry_pool", STABLE_REGISTRY_POOLS) + metafunc.parametrize( + "stable_registry_pool", _get_stable_registry_pools() + ) if "stable_factory_pool" in metafunc.fixturenames: - metafunc.parametrize("stable_factory_pool", STABLE_FACTORY_POOLS) + metafunc.parametrize( + "stable_factory_pool", _get_stable_factory_pools() + ) if "crypto_registry_pool" in metafunc.fixturenames: - metafunc.parametrize("crypto_registry_pool", CRYPTO_REGISTRY_POOLS) + metafunc.parametrize( + "crypto_registry_pool", _get_crypto_registry_pools() + ) if "crypto_factory_pool" in metafunc.fixturenames: - metafunc.parametrize("crypto_factory_pool", CRYPTO_FACTORY_POOLS) + metafunc.parametrize( + "crypto_factory_pool", _get_crypto_factory_pools() + ) if "pool" in metafunc.fixturenames: - metafunc.parametrize("pool", ALL_POOLS) + metafunc.parametrize("pool", _get_all_pools()) @pytest.fixture(scope="session") def stable_registry_pool(): - yield STABLE_REGISTRY_POOLS + yield _get_stable_registry_pools() @pytest.fixture(scope="session") def stable_factory_pool(): - yield STABLE_FACTORY_POOLS + yield _get_stable_factory_pools() @pytest.fixture(scope="session") def crypto_registry_pool(): - yield CRYPTO_REGISTRY_POOLS + yield _get_crypto_registry_pools() @pytest.fixture(scope="session") def crypto_factory_pool(): - yield CRYPTO_FACTORY_POOLS + yield _get_crypto_factory_pools() @pytest.fixture(scope="session") def pool(): - yield ALL_POOLS + yield _get_all_pools() diff --git a/tests/fixtures/accounts.py b/tests/fixtures/accounts.py index 99775b3..a14f5a1 100644 --- a/tests/fixtures/accounts.py +++ b/tests/fixtures/accounts.py @@ -1,54 +1,37 @@ +import boa import pytest -from eth_account import Account -from eth_account.hdaccount import HDPath -from eth_account.hdaccount.mnemonic import Mnemonic from eth_account.signers.local import LocalAccount -from tests.utils import get_deployed_contract +from scripts.constants import ADDRESS_PROVIDER +from scripts.deployment_utils import get_deployed_contract @pytest.fixture(scope="session") -def seed() -> bytes: - return Mnemonic.to_seed("test") - - -@pytest.fixture(scope="session") -def accounts(seed) -> list[LocalAccount]: +def accounts() -> list[LocalAccount]: """ Generate 10 dev accounts from a seed. - Based on ape's `generate_test_accounts` method: - https://github.com/ApeWorX/ape/blob/9d4b66786/src/ape/utils/testing.py#L28 - TODO: replace by boa.env.generate_address()? """ - - def generate_account( - index: int, hd_path_format="m/44'/60'/0'/{}" - ) -> LocalAccount: - hd_path = HDPath(hd_path_format.format(index)) - private_key = f"0x{hd_path.derive(seed).hex()}" - return Account.from_key(private_key) - - return [generate_account(index) for index in range(10)] + return [boa.env.generate_address(f"{i}") for i in range(10)] @pytest.fixture(scope="session") def alice_address(accounts): - return accounts[0].address + return accounts[0] @pytest.fixture(scope="session") def unauthorised_address(accounts): - return accounts[1].address + return accounts[1] @pytest.fixture(scope="session") def random_address(accounts): - return accounts[2].address + return accounts[2] @pytest.fixture(scope="module") def owner(accounts): address_provider = get_deployed_contract( - "AddressProvider", "0x0000000022D53366457F9d5E68Ec105046FC4383" + "AddressProvider", ADDRESS_PROVIDER ) return address_provider.admin() diff --git a/tests/fixtures/constants.py b/tests/fixtures/constants.py index 7d147fb..a58f123 100644 --- a/tests/fixtures/constants.py +++ b/tests/fixtures/constants.py @@ -1,132 +1,16 @@ import pytest -ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" +from scripts.constants import BASE_POOLS, CRYPTO_REGISTRY_POOLS @pytest.fixture(scope="module") def base_pools(): - return { - "tripool": { - "pool": "0xbEbc44782C7dB0a1A60Cb6fe97d0b483032FF1C7", - "lp_token": "0x6c3F90f043a72FA612cbac8115EE7e52BDe6E490", - "num_coins": 3, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - }, - "fraxusdc": { - "pool": "0xdcef968d416a41cdac0ed8702fac8128a64241a2", - "lp_token": "0x3175df0976dfa876431c2e9ee6bc45b65d3473cc", - "num_coins": 2, - "is_legacy": False, - "is_lending": False, - "is_v2": False, - }, - "sbtc": { - "pool": "0x7fC77b5c7614E1533320Ea6DDc2Eb61fa00A9714", - "lp_token": "0x075b1bb99792c9E1041bA13afEf80C91a1e70fB3", - "num_coins": 3, - "is_legacy": True, - "is_lending": False, - "is_v2": False, - }, - } + return BASE_POOLS @pytest.fixture(scope="module") def crypto_registry_pools(base_pools): - return { - "tricrypto2": { - "pool": "0xD51a44d3FaE010294C616388b506AcdA1bfAAE46", - "lp_token": "0xc4AD29ba4B3c580e6D59105FFf484999997675Ff", - "gauge": "0xDeFd8FdD20e0f34115C7018CCfb655796F6B2168", - "zap": "0x3993d34e7e99Abf6B6f367309975d1360222D446", - "num_coins": 3, - "name": "tricrypto2", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "eurt3crv": { - "pool": "0x9838eccc42659fa8aa7daf2ad134b53984c9427b", - "lp_token": "0x3b6831c0077a1e44ed0a21841c3bc4dc11bce833", - "gauge": "0x4Fd86Ce7Ecea88F7E0aA78DC12625996Fb3a04bC", - "zap": "0x5D0F47B32fDd343BfA74cE221808e2abE4A53827", - "num_coins": 2, - "name": "eurtusd", - "base_pool": base_pools["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, - "eursusdc": { - "pool": "0x98a7F18d4E56Cfe84E3D081B40001B3d5bD3eB8B", - "lp_token": "0x3D229E1B4faab62F621eF2F6A610961f7BD7b23B", - "gauge": "0x65CA7Dc5CB661fC58De57B1E1aF404649a27AD35", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "eursusd", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "crveth": { - "pool": "0x8301AE4fc9c624d1D396cbDAa1ed877821D7C511", - "lp_token": "0xEd4064f376cB8d68F770FB1Ff088a3d0F3FF5c4d", - "gauge": "0x1cEBdB0856dd985fAe9b8fEa2262469360B8a3a6", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "crveth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "cvxeth": { - "pool": "0xB576491F1E6e5E62f1d8F26062Ee822B40B0E0d4", - "lp_token": "0x3A283D9c08E8b55966afb64C515f5143cf907611", - "gauge": "0x7E1444BA99dcdFfE8fBdb42C02F0005D14f13BE1", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "cvxeth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "xaut3crv": { - "pool": "0xAdCFcf9894335dC340f6Cd182aFA45999F45Fc44", - "lp_token": "0x8484673cA7BfF40F82B041916881aeA15ee84834", - "gauge": "0x1B3E14157ED33F60668f2103bCd5Db39a1573E5B", - "zap": "0xc5FA220347375ac4f91f9E4A4AAb362F22801504", - "num_coins": 2, - "name": "xaut3crv", - "base_pool": base_pools["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, - "spelleth": { - "pool": "0x98638FAcf9a3865cd033F36548713183f6996122", - "lp_token": "0x8282BD15dcA2EA2bDf24163E8f2781B30C43A2ef", - "gauge": "0x08380a4999Be1a958E2abbA07968d703C7A3027C", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "spelleth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "teth": { - "pool": "0x752eBeb79963cf0732E9c0fec72a49FD1DEfAEAC", - "lp_token": "0xCb08717451aaE9EF950a2524E33B6DCaBA60147B", - "gauge": "0x6070fBD4E608ee5391189E7205d70cc4A274c017", - "zap": ZERO_ADDRESS, - "num_coins": 2, - "name": "teth", - "base_pool": ZERO_ADDRESS, - "has_positive_rebasing_tokens": False, - }, - "eurocusd": { - "pool": "0xE84f5b1582BA325fDf9cE6B0c1F087ccfC924e54", - "lp_token": "0x70fc957eb90e37af82acdbd12675699797745f68", - "gauge": "0x4329c8F09725c0e3b6884C1daB1771bcE17934F9", - "zap": "0xd446a98f88e1d053d1f64986e3ed083bb1ab7e5a", - "num_coins": 2, - "name": "eurocusd", - "base_pool": base_pools["tripool"]["pool"], - "has_positive_rebasing_tokens": False, - }, - } + return CRYPTO_REGISTRY_POOLS @pytest.fixture(scope="module") diff --git a/tests/fixtures/deployments.py b/tests/fixtures/deployments.py index 89dd44b..576d712 100644 --- a/tests/fixtures/deployments.py +++ b/tests/fixtures/deployments.py @@ -2,47 +2,48 @@ import pytest from boa.vyper.contract import VyperContract -from tests.utils import deploy_contract, get_deployed_contract +from scripts.deployment_utils import get_deployed_contract +from tests.utils import deploy_contract ADDRESS_PROVIDER = "0x0000000022D53366457F9d5E68Ec105046FC4383" -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def gauge_controller() -> VyperContract: return get_deployed_contract( "GaugeController", "0x2F50D538606Fa9EDD2B11E2446BEb18C9D5846bB" ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def stable_registry() -> VyperContract: return get_deployed_contract( "StableRegistry", "0x90E00ACe148ca3b23Ac1bC8C240C2a7Dd9c2d7f5" ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def stable_factory() -> VyperContract: return get_deployed_contract( "StableFactory", "0xB9fC157394Af804a3578134A6585C0dc9cc990d4" ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def crypto_factory() -> VyperContract: return get_deployed_contract( "CryptoFactory", "0xF18056Bbd320E96A48e3Fbf8bC061322531aac99" ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def base_pool_registry(alice_address): return deploy_contract( "BasePoolRegistry", sender=alice_address, directory="registries" ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def populated_base_pool_registry(base_pool_registry, owner, base_pools): with boa.env.sender(owner): for data in base_pools.values(): @@ -57,7 +58,7 @@ def populated_base_pool_registry(base_pool_registry, owner, base_pools): return base_pool_registry -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def crypto_registry( populated_base_pool_registry, owner, crypto_registry_pools ): @@ -85,19 +86,19 @@ def crypto_registry( return crypto_registry -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def address_provider(crypto_registry, owner): contract = get_deployed_contract("AddressProvider", ADDRESS_PROVIDER) contract.set_address(5, crypto_registry, sender=owner) return contract -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def metaregistry(address_provider, owner): return deploy_contract("MetaRegistry", address_provider, sender=owner) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def stable_registry_handler(stable_registry, owner): return deploy_contract( "StableRegistryHandler", @@ -107,7 +108,7 @@ def stable_registry_handler(stable_registry, owner): ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def stable_factory_handler( populated_base_pool_registry, stable_factory, owner ): @@ -120,7 +121,7 @@ def stable_factory_handler( ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def crypto_registry_handler(owner, crypto_registry): return deploy_contract( "CryptoRegistryHandler", @@ -130,7 +131,7 @@ def crypto_registry_handler(owner, crypto_registry): ) -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def crypto_factory_handler( populated_base_pool_registry, crypto_factory, owner ): @@ -165,8 +166,7 @@ def handlers( ] -# TODO: Get rid of the autouse, it might make some tests slower than needed -@pytest.fixture(scope="module", autouse=True) +@pytest.fixture(scope="module") def populated_metaregistry(metaregistry, handlers, owner): for handler in handlers: metaregistry.add_registry_handler(handler.address, sender=owner) diff --git a/tests/fixtures/functions.py b/tests/fixtures/functions.py index bdd8e15..904a0c1 100644 --- a/tests/fixtures/functions.py +++ b/tests/fixtures/functions.py @@ -3,7 +3,7 @@ import pytest from boa.vyper.contract import VyperContract -from tests.utils import get_deployed_contract +from scripts.deployment_utils import get_deployed_contract # ---- Factories ---- diff --git a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py index 2d4d930..81b77a6 100644 --- a/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py +++ b/tests/mainnet/metaregistry/api/test_find_pool_for_coins.py @@ -3,7 +3,7 @@ import pytest -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS # NOTE: This is the most important method in the metaregistry contract since it will be used # by integrators to find pools for coin pairs. It finds pools even if the coin pair is not diff --git a/tests/mainnet/metaregistry/api/test_get_admin_balances.py b/tests/mainnet/metaregistry/api/test_get_admin_balances.py index cbf5bbf..b16df4a 100644 --- a/tests/mainnet/metaregistry/api/test_get_admin_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_admin_balances.py @@ -5,11 +5,8 @@ from boa import BoaError from eth.codecs.abi.exceptions import DecodeError as ABIDecodeError -from tests.utils import ( - assert_negative_coin_balance, - check_decode_error, - get_deployed_contract, -) +from scripts.deployment_utils import get_deployed_contract +from tests.utils import assert_decode_error, assert_negative_coin_balance def pre_test_checks(metaregistry, pool): @@ -35,7 +32,7 @@ def pre_test_checks(metaregistry, pool): if contract.totalSupply() == 0: return pytest.skip("LP token supply is zero") except ABIDecodeError as e: - check_decode_error(e) + assert_decode_error(e) return pytest.skip( f"Pool {pool} cannot decode the total supply of its LP token {lp_token}" ) @@ -157,10 +154,10 @@ def test_crypto_factory_pools( metaregistry_output = populated_metaregistry.get_admin_balances(pool) for i, output in enumerate(admin_balances): - # TODO: Check if this level of difference is acceptable try: assert output == pytest.approx(metaregistry_output[i]) except AssertionError: + # TODO: Check if this level of difference is acceptable assert output == pytest.approx(metaregistry_output[i], rel=0.009) logging.warning( f"Pool {pool} has a difference in admin balance {i}: " diff --git a/tests/mainnet/metaregistry/api/test_get_base_pool.py b/tests/mainnet/metaregistry/api/test_get_base_pool.py index 7aca16c..f78e1b8 100644 --- a/tests/mainnet/metaregistry/api/test_get_base_pool.py +++ b/tests/mainnet/metaregistry/api/test_get_base_pool.py @@ -1,4 +1,4 @@ -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def test_all(populated_metaregistry, populated_base_pool_registry, pool): diff --git a/tests/mainnet/metaregistry/api/test_get_coin_indices.py b/tests/mainnet/metaregistry/api/test_get_coin_indices.py index 83c4efe..287b422 100644 --- a/tests/mainnet/metaregistry/api/test_get_coin_indices.py +++ b/tests/mainnet/metaregistry/api/test_get_coin_indices.py @@ -3,7 +3,7 @@ import pytest -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def _reject_pools_with_one_coin(metaregistry, pool): diff --git a/tests/mainnet/metaregistry/api/test_get_fees.py b/tests/mainnet/metaregistry/api/test_get_fees.py index 05acef9..0fba550 100644 --- a/tests/mainnet/metaregistry/api/test_get_fees.py +++ b/tests/mainnet/metaregistry/api/test_get_fees.py @@ -11,7 +11,6 @@ def test_stable_registry_pools( populated_metaregistry, stable_registry_pool, stable_registry, - stable_registry_handler, # TODO: Check if this is needed ): actual_output = stable_registry.get_fees(stable_registry_pool) metaregistry_output = populated_metaregistry.get_fees(stable_registry_pool) @@ -24,7 +23,6 @@ def test_stable_factory_pools( populated_metaregistry, stable_factory_pool, stable_factory, - stable_factory_handler, # TODO: Check if this is needed ): actual_output = stable_factory.get_fees(stable_factory_pool) metaregistry_output = populated_metaregistry.get_fees(stable_factory_pool) diff --git a/tests/mainnet/metaregistry/api/test_get_gauge.py b/tests/mainnet/metaregistry/api/test_get_gauge.py index 43b4ebc..9ea6a7f 100644 --- a/tests/mainnet/metaregistry/api/test_get_gauge.py +++ b/tests/mainnet/metaregistry/api/test_get_gauge.py @@ -1,6 +1,6 @@ from boa import BoaError -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def _is_dao_onboarded_gauge(_gauge, gauge_controller, liquidity_gauge): diff --git a/tests/mainnet/metaregistry/api/test_get_n_coins.py b/tests/mainnet/metaregistry/api/test_get_n_coins.py index 0c35d2b..20f24d2 100644 --- a/tests/mainnet/metaregistry/api/test_get_n_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_n_coins.py @@ -1,4 +1,4 @@ -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def _get_n_coins_for_pool(registry, pool): diff --git a/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py index 9b042af..16ad66d 100644 --- a/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_n_underlying_coins.py @@ -1,4 +1,4 @@ -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def _get_num_coins(registry, pool, base_pool_registry): diff --git a/tests/mainnet/metaregistry/api/test_get_pool_name.py b/tests/mainnet/metaregistry/api/test_get_pool_name.py index b9fed83..a17612a 100644 --- a/tests/mainnet/metaregistry/api/test_get_pool_name.py +++ b/tests/mainnet/metaregistry/api/test_get_pool_name.py @@ -1,4 +1,5 @@ -from tests.utils import ZERO_ADDRESS, get_deployed_contract +from scripts.constants import ZERO_ADDRESS +from scripts.deployment_utils import get_deployed_contract def test_stable_registry_pools( diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py index 989ed4f..8296927 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_balances.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_balances.py @@ -3,11 +3,9 @@ import pytest from boa import BoaError -from tests.utils import ( - ZERO_ADDRESS, - assert_negative_coin_balance, - get_deployed_contract, -) +from scripts.constants import ZERO_ADDRESS +from scripts.deployment_utils import get_deployed_contract +from tests.utils import assert_negative_coin_balance EXCEPTION_POOLS = ["0x79a8C46DeA5aDa233ABaFFD40F3A0A2B1e5A4F27"] diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py index ef371fc..91c990a 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_coins.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_coins.py @@ -3,7 +3,7 @@ import boa from boa import BoaError -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def _get_underlying_coins( diff --git a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py index 5491635..a4d9236 100644 --- a/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py +++ b/tests/mainnet/metaregistry/api/test_get_underlying_decimals.py @@ -1,7 +1,8 @@ import pytest from boa import BoaError -from tests.utils import ZERO_ADDRESS, get_deployed_contract +from scripts.constants import ZERO_ADDRESS +from scripts.deployment_utils import get_deployed_contract EXCEPTIONS = { # eth: ankreth pool returns [18, 0] when it should return: diff --git a/tests/mainnet/metaregistry/api/test_get_virtual_price.py b/tests/mainnet/metaregistry/api/test_get_virtual_price.py index 094b47f..e44aeee 100644 --- a/tests/mainnet/metaregistry/api/test_get_virtual_price.py +++ b/tests/mainnet/metaregistry/api/test_get_virtual_price.py @@ -5,12 +5,9 @@ from boa import BoaError from eth.codecs.abi.exceptions import DecodeError as ABIDecodeError -from tests.utils import ( - ZERO_ADDRESS, - assert_negative_coin_balance, - check_decode_error, - get_deployed_contract, -) +from scripts.constants import ZERO_ADDRESS +from scripts.deployment_utils import get_deployed_contract +from tests.utils import assert_decode_error, assert_negative_coin_balance # ---- sanity checks since vprice getters can revert for specific pools states ---- @@ -152,7 +149,7 @@ def test_stable_factory_pools( with boa.reverts(): populated_metaregistry.get_virtual_price_from_lp_token(lp_token) except ABIDecodeError as e: - check_decode_error(e) + assert_decode_error(e) return pytest.skip( f"Pool {stable_factory_pool} cannot decode the virtual price" ) diff --git a/tests/mainnet/metaregistry/api/test_pool_is_metapool.py b/tests/mainnet/metaregistry/api/test_pool_is_metapool.py index 4847596..3375ba8 100644 --- a/tests/mainnet/metaregistry/api/test_pool_is_metapool.py +++ b/tests/mainnet/metaregistry/api/test_pool_is_metapool.py @@ -1,4 +1,4 @@ -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def test_stable_registry_pools( diff --git a/tests/mainnet/metaregistry/test_base_registry_tracking.py b/tests/mainnet/metaregistry/test_base_registry_tracking.py index 20e6ee2..ca776b3 100644 --- a/tests/mainnet/metaregistry/test_base_registry_tracking.py +++ b/tests/mainnet/metaregistry/test_base_registry_tracking.py @@ -1,22 +1,19 @@ -from tests.utils import ZERO_ADDRESS +from scripts.constants import ZERO_ADDRESS def test_new_crypto_factory_pool( - metaregistry, crypto_factory, tokens, lp_tokens, alice_address + populated_metaregistry, crypto_factory, tokens, lp_tokens, alice_address ): - test_pool_name = "test_pool" + metaregistry, test_pool_name = populated_metaregistry, "test_pool" + dai_token, cvx_token = tokens["dai"], lp_tokens["cvxFXSFXS-f"] - assert ( - metaregistry.find_pool_for_coins( - tokens["dai"], lp_tokens["cvxFXSFXS-f"], 0 - ) - == ZERO_ADDRESS - ) + pool_before = metaregistry.find_pool_for_coins(dai_token, cvx_token, 0) + assert pool_before == ZERO_ADDRESS crypto_factory.deploy_pool( test_pool_name, test_pool_name, - [tokens["dai"], lp_tokens["cvxFXSFXS-f"]], + [dai_token, cvx_token], 200000000, 100000000000000, 1000000, @@ -32,38 +29,28 @@ def test_new_crypto_factory_pool( new_pool = crypto_factory.pool_list(crypto_factory.pool_count() - 1) lp_token = crypto_factory.get_token(new_pool) - assert ( - metaregistry.get_coins(new_pool) - == [tokens["dai"], lp_tokens["cvxFXSFXS-f"]] + [ZERO_ADDRESS] * 6 - ) + expected_coins = [dai_token, cvx_token] + [ZERO_ADDRESS] * 6 + assert metaregistry.get_coins(new_pool) == expected_coins assert test_pool_name in metaregistry.get_pool_name(new_pool) assert metaregistry.get_pool_from_lp_token(lp_token) == new_pool - assert ( - metaregistry.find_pool_for_coins( - tokens["dai"], lp_tokens["cvxFXSFXS-f"], 0 - ) - == new_pool - ) + pool_after = metaregistry.find_pool_for_coins(dai_token, cvx_token, 0) + assert pool_after == new_pool def test_new_stable_factory_pool( - metaregistry, stable_factory, lp_tokens, alice_address + populated_metaregistry, stable_factory, lp_tokens, alice_address ): - test_pool_name = "test_pool" - - assert ( - metaregistry.find_pool_for_coins( - lp_tokens["bveCVX-CVX-f"], lp_tokens["cvxFXSFXS-f"], 0 - ) - == ZERO_ADDRESS - ) + metaregistry, test_pool_name = populated_metaregistry, "test_pool" + bve_token, cvx_token = lp_tokens["bveCVX-CVX-f"], lp_tokens["cvxFXSFXS-f"] + pool_before = metaregistry.find_pool_for_coins(bve_token, cvx_token, 0) + assert pool_before == ZERO_ADDRESS stable_factory.deploy_plain_pool( test_pool_name, test_pool_name, [ - lp_tokens["bveCVX-CVX-f"], - lp_tokens["cvxFXSFXS-f"], + bve_token, + cvx_token, ZERO_ADDRESS, ZERO_ADDRESS, ], @@ -77,16 +64,9 @@ def test_new_stable_factory_pool( new_pool = stable_factory.pool_list(stable_factory.pool_count() - 1) lp_token = new_pool # pool == lp_token fot stable_factory - assert ( - metaregistry.get_coins(new_pool) - == [lp_tokens["bveCVX-CVX-f"], lp_tokens["cvxFXSFXS-f"]] - + [ZERO_ADDRESS] * 6 - ) + expected_coins = [bve_token, cvx_token] + [ZERO_ADDRESS] * 6 + assert metaregistry.get_coins(new_pool) == expected_coins assert test_pool_name in metaregistry.get_pool_name(new_pool) assert metaregistry.get_pool_from_lp_token(lp_token) == new_pool - assert ( - metaregistry.find_pool_for_coins( - lp_tokens["bveCVX-CVX-f"], lp_tokens["cvxFXSFXS-f"], 0 - ) - == new_pool - ) + pool_after = metaregistry.find_pool_for_coins(bve_token, cvx_token, 0) + assert pool_after == new_pool diff --git a/tests/mainnet/registries/test_add_remove_basepool.py b/tests/mainnet/registries/test_add_remove_basepool.py index 6812be7..f96f9ff 100644 --- a/tests/mainnet/registries/test_add_remove_basepool.py +++ b/tests/mainnet/registries/test_add_remove_basepool.py @@ -1,6 +1,7 @@ import boa -from tests.utils import ZERO_ADDRESS, deploy_contract +from scripts.constants import ZERO_ADDRESS +from tests.utils import deploy_contract def test_revert_unauthorised_add_base_pool( diff --git a/tests/mainnet/registries/test_add_remove_metapool.py b/tests/mainnet/registries/test_add_remove_metapool.py index fa3b5ee..fcc1918 100644 --- a/tests/mainnet/registries/test_add_remove_metapool.py +++ b/tests/mainnet/registries/test_add_remove_metapool.py @@ -1,6 +1,7 @@ import boa -from tests.utils import ZERO_ADDRESS, deploy_contract +from scripts.constants import ZERO_ADDRESS +from tests.utils import deploy_contract def test_add_metapool( diff --git a/tests/mainnet/registries/test_add_remove_pool.py b/tests/mainnet/registries/test_add_remove_pool.py index ce70a49..abac879 100644 --- a/tests/mainnet/registries/test_add_remove_pool.py +++ b/tests/mainnet/registries/test_add_remove_pool.py @@ -1,6 +1,7 @@ import boa -from tests.utils import ZERO_ADDRESS, deploy_contract +from scripts.constants import ZERO_ADDRESS +from tests.utils import deploy_contract def test_revert_unauthorised_add_pool( diff --git a/tests/utils.py b/tests/utils.py index 8779c0e..f8d6a55 100644 --- a/tests/utils.py +++ b/tests/utils.py @@ -6,8 +6,8 @@ from eth.codecs.abi.exceptions import DecodeError as ABIDecodeError from eth_account.signers.local import LocalAccount -ZERO_ADDRESS = "0x0000000000000000000000000000000000000000" -BASE_DIR = path.join(path.dirname(path.abspath(__file__)), "..") +from scripts.constants import BASE_DIR, ZERO_ADDRESS +from scripts.deployment_utils import get_deployed_contract def get_contract_pools(contract_name: str, address: str) -> list[str]: @@ -20,19 +20,6 @@ def get_contract_pools(contract_name: str, address: str) -> list[str]: return [registry.pool_list(i) for i in range(registry.pool_count())] -def get_deployed_contract(contract_name: str, address: str) -> VyperContract: - """ - Loads a contract and retrieves a deployed instance of it with the given address. - TODO: Refactor calls to use fixtures instead of re-loading multiple times. - :param contract_name: The name of the contract ABI to load. - :param address: The address of the deployed contract. - """ - file_name = path.join( - BASE_DIR, f"contracts/interfaces/{contract_name}.json" - ) - return boa.load_abi(file_name).at(address) - - def deploy_contract( contract: str, *args, @@ -47,10 +34,10 @@ def deploy_contract( return boa.load(file_name, *args, **kwargs) -def check_decode_error(e: ABIDecodeError): +def assert_decode_error(e: ABIDecodeError): """ Checks that the error message is the expected decode error. - This seems to be happening in some pools, but it's not clear if it's a boa or contract issue. + TODO: This happens in some pools, but it's not clear if it's a boa or contract issue. :param e: The error to check. """ assert e.msg == "Value length is not the expected size of 32 bytes" From a7fa74274b0f37e3644563ad8a68a1d7e6c10d38 Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Fri, 8 Dec 2023 16:43:58 +0100 Subject: [PATCH 18/19] Use my fork with #107 Based on https://github.com/vyperlang/titanoboa/pull/107 --- requirements.in | 2 +- requirements.txt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/requirements.in b/requirements.in index 9b3c7f9..d51bf37 100644 --- a/requirements.in +++ b/requirements.in @@ -1,4 +1,4 @@ -titanoboa[forking-recommended] @ git+https://github.com/vyperlang/titanoboa +titanoboa[forking-recommended] @ git+https://github.com/DanielSchiavini/titanoboa@a326e93 black flake8 isort diff --git a/requirements.txt b/requirements.txt index 8beecb4..ff32cb5 100644 --- a/requirements.txt +++ b/requirements.txt @@ -188,7 +188,7 @@ sortedcontainers==2.4.0 # trie tabulate==0.9.0 # via -r requirements.in -titanoboa[forking-recommended] @ git+https://github.com/vyperlang/titanoboa +titanoboa[forking-recommended] @ git+https://github.com/DanielSchiavini/titanoboa@a326e93 # via -r requirements.in tomli==2.0.1 # via From d45eec644130cdbe4e44779733f9d2c9e66aab1c Mon Sep 17 00:00:00 2001 From: Daniel Schiavini Date: Mon, 11 Dec 2023 09:09:25 +0100 Subject: [PATCH 19/19] Move to boa@master again --- requirements.in | 2 +- requirements.txt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/requirements.in b/requirements.in index d51bf37..12a8a59 100644 --- a/requirements.in +++ b/requirements.in @@ -1,4 +1,4 @@ -titanoboa[forking-recommended] @ git+https://github.com/DanielSchiavini/titanoboa@a326e93 +titanoboa[forking-recommended] @ git+https://github.com/vyperlang/titanoboa@e85ab24 black flake8 isort diff --git a/requirements.txt b/requirements.txt index ff32cb5..9e3c05c 100644 --- a/requirements.txt +++ b/requirements.txt @@ -188,7 +188,7 @@ sortedcontainers==2.4.0 # trie tabulate==0.9.0 # via -r requirements.in -titanoboa[forking-recommended] @ git+https://github.com/DanielSchiavini/titanoboa@a326e93 +titanoboa[forking-recommended] @ git+https://github.com/vyperlang/titanoboa@e85ab24 # via -r requirements.in tomli==2.0.1 # via