Compare commits

..

13 Commits

Author SHA1 Message Date
Github Actions
66edc60b3e Publish
- @0x/contracts-erc20@4.0.14
 - @0x/contracts-test-utils@5.4.60
 - @0x/contracts-treasury@1.4.54
 - @0x/contracts-utils@4.8.52
 - @0x/contracts-zero-ex@0.49.0
 - @0x/contract-addresses@8.13.0
 - @0x/contract-wrappers@13.23.8
 - @0x/protocol-utils@11.24.2
2023-11-16 00:36:47 +00:00
Github Actions
e28449e167 Updated CHANGELOGS & MD docs 2023-11-16 00:36:44 +00:00
Kyu
652d422622 Add Sepoia addresses (#761) 2023-11-15 15:24:11 -08:00
Kyu
5207565af8 Temporarily disable erc20 and governance in ci (#762) 2023-11-15 14:30:44 -08:00
wonge97
d982d75e2e Update docs with missing chains that 0x protocol is deployed on (#760)
* Update docs with missing chains that 0x protocol is deployed on
2023-11-13 12:58:46 -06:00
David Walsh
c5650da703 [contract-addresses] Add ChainId type predicate (#756) 2023-11-02 16:30:05 -06:00
github-actions[bot]
b19e29e03d Publish: CHANGELOG and Package Version Updates into development (#748)
* Updated CHANGELOGS & MD docs

* Publish

 - @0x/contracts-erc20@4.0.13
 - @0x/contracts-test-utils@5.4.59
 - @0x/contracts-treasury@1.4.53
 - @0x/contracts-utils@4.8.51
 - @0x/contracts-zero-ex@0.48.0
 - @0x/contract-addresses@8.12.0
 - @0x/contract-wrappers@13.23.7
 - @0x/protocol-utils@11.24.1

---------

Co-authored-by: Github Actions <github-actions@github.com>
2023-08-29 15:10:18 -07:00
Kyu
e5cbfd87bc Add Velodrome V2 support on Base (#747) 2023-08-29 14:43:23 -07:00
Savarn Dontamsetti (Sav)
5a49be1322 Create PRs to reflect publish changes (#743)
* Create PRs to reflect publish changes

* Using gh instead of third party action

* Adding github token
2023-08-24 16:35:11 -04:00
Github Actions
ec336b92aa Publish
- @0x/contracts-erc20@4.0.12
 - @0x/contracts-test-utils@5.4.58
 - @0x/contracts-treasury@1.4.52
 - @0x/contracts-utils@4.8.50
 - @0x/contracts-zero-ex@0.47.0
 - @0x/contract-addresses@8.11.0
 - @0x/contract-wrappers@13.23.6
 - @0x/protocol-utils@11.24.0
2023-08-18 14:24:32 +00:00
Github Actions
62a530d7ec Updated CHANGELOGS & MD docs 2023-08-18 14:24:27 +00:00
Savarn Dontamsetti (Sav)
09d6fbce81 Rename Maverick to MaverickV1 and add tests (#742)
* Renaming Maverick and adding tests

* Update Base chain ID
2023-08-17 17:11:05 -04:00
Savarn Dontamsetti (Sav)
7f324dd75d feat/Add Maverick V1 Support (#741)
* Add Maverick V1 Support for Ethereum, BSC, and Base
2023-08-17 12:59:38 -04:00
40 changed files with 644 additions and 88 deletions

View File

@@ -83,28 +83,30 @@ jobs:
-p @0x/order-utils \ -p @0x/order-utils \
-m --serial -c test:ci -m --serial -c test:ci
# NOTE: disabled as ZRXToken.sol did not compile with the latest forge.
# TODO: re-enable once the issue is resolved.
- name: Run Forge build for erc20 - name: Run Forge build for erc20
working-directory: contracts/erc20 working-directory: contracts/erc20
run: | run: |
forge --version forge --version
forge build --sizes forge build --sizes --skip ZRXToken
- name: Run Forge tests for erc20 # - name: Run Forge tests for erc20
working-directory: contracts/erc20 # working-directory: contracts/erc20
run: | # run: |
forge test -vvv --gas-report # forge test -vvv --gas-report
- name: Run Forge coverage for erc20 # - name: Run Forge coverage for erc20
working-directory: contracts/erc20 # working-directory: contracts/erc20
run: | # run: |
forge coverage --report summary --report lcov # forge coverage --report summary --report lcov
- name: Upload the coverage report to Coveralls # - name: Upload the coverage report to Coveralls
uses: coverallsapp/github-action@master # uses: coverallsapp/github-action@master
with: # with:
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
base-path: ./contracts/erc20/ # base-path: ./contracts/erc20/
path-to-lcov: ./contracts/erc20/lcov.info # path-to-lcov: ./contracts/erc20/lcov.info
- name: Run Forge build for zero-ex - name: Run Forge build for zero-ex
working-directory: contracts/zero-ex working-directory: contracts/zero-ex
@@ -142,19 +144,20 @@ jobs:
forge --version forge --version
forge build --sizes forge build --sizes
- name: Run Forge tests on governance contracts # TODO: re-enable once the issue is resolved.
working-directory: ./contracts/governance # - name: Run Forge tests on governance contracts
run: | # working-directory: ./contracts/governance
forge test -vvv --gas-report # run: |
# forge test -vvv --gas-report
- name: Run Forge coverage on governance contracts # - name: Run Forge coverage on governance contracts
working-directory: ./contracts/governance # working-directory: ./contracts/governance
run: | # run: |
forge coverage --report lcov # forge coverage --report lcov
- name: Upload the coverage report to Coveralls # - name: Upload the coverage report to Coveralls
uses: coverallsapp/github-action@master # uses: coverallsapp/github-action@master
with: # with:
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
base-path: ./contracts/governance/ # base-path: ./contracts/governance/
path-to-lcov: ./contracts/governance/lcov.info # path-to-lcov: ./contracts/governance/lcov.info

View File

@@ -1,19 +1,21 @@
name: publish name: publish
on: on:
workflow_dispatch: workflow_dispatch:
inputs: inputs:
ci_status: ci_status:
description: 'required CI status' description: 'required CI status'
default: 'success' default: 'success'
required: true required: true
prerelease: prerelease:
description: 'prerelease name' description: 'prerelease name'
required: false required: false
jobs: jobs:
publish: publish:
runs-on: ubuntu-latest runs-on: ubuntu-latest
env:
PublishBranch: publish/${{github.ref_name }}-${{ github.run_id }}-${{ github.run_number }}
steps: steps:
- name: 'check successful status' - name: 'check successful status'
run: | run: |
@@ -28,16 +30,20 @@ jobs:
version: nightly version: nightly
- uses: actions/checkout@v2 - uses: actions/checkout@v2
with: with:
ref: ${{ github.ref }} ref: ${{ github.ref }}
fetch-depth: 0 fetch-depth: 0
- uses: actions/setup-node@v1 - uses: actions/setup-node@v1
with: with:
node-version: 16 node-version: 16
- uses: actions/setup-python@v2 - uses: actions/setup-python@v2
- name: 'configure git' - name: 'configure git'
run: | run: |
git config --global user.email "github-actions@github.com" git config --global user.email "github-actions@github.com"
git config --global user.name "Github Actions" git config --global user.name "Github Actions"
- name: 'Checkout new branch'
run: |
git checkout -b $PublishBranch
git push -u origin $PublishBranch
- name: 'install dependencies' - name: 'install dependencies'
run: | run: |
yarn -D yarn -D
@@ -49,9 +55,23 @@ jobs:
NPM_TOKEN: ${{ secrets.NPM_PUBLISH_TOKEN }} NPM_TOKEN: ${{ secrets.NPM_PUBLISH_TOKEN }}
GITHUB_TOKEN: ${{ github.token }} GITHUB_TOKEN: ${{ github.token }}
PUBLISH_PRERELEASE: ${{ github.event.inputs.prerelease }} PUBLISH_PRERELEASE: ${{ github.event.inputs.prerelease }}
- name: 'merge into main branch' - name: 'Create PR to merge into ref branch'
if: github.event.inputs.prerelease == '' # unless it's a prerelease
run: | run: |
git checkout main && \ gh pr create \
git merge ${{ github.ref }} && \ -B ${{ github.ref_name }} \
git push -H $PublishBranch \
--title "Publish: CHANGELOG and Package Version Updates into ${{ github.ref_name }}" \
--body "Syncing CHANGELOG and package version updates from publish action ${{github.run_id}}-${{github.run_number}} into ${{ github.ref_name}} branch" \
--reviewer ${{ github.actor }}
env:
GITHUB_TOKEN: ${{ github.token }}
- name: 'Create PR to merge ref branch into main'
run: |
gh pr create \
-B main \
-H ${{ github.ref_name }} \
--title "Publish: Sync ${{ github.ref_name }} into main " \
--body "Syncing ${{ github.ref_name }} back into main after publish action. NOTE: this PR should be merged after CHANGELOG and package version updates have been merged into ${{ github.ref_name }}" \
--reviewer ${{ github.actor }}
env:
GITHUB_TOKEN: ${{ github.token }}

View File

@@ -1,4 +1,31 @@
[ [
{
"timestamp": 1700094997,
"version": "4.0.14",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1693346928,
"version": "4.0.13",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1692368658,
"version": "4.0.12",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{ {
"timestamp": 1691617396, "timestamp": 1691617396,
"version": "4.0.11", "version": "4.0.11",

View File

@@ -5,6 +5,18 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v4.0.14 - _November 16, 2023_
* Dependencies updated
## v4.0.13 - _August 29, 2023_
* Dependencies updated
## v4.0.12 - _August 18, 2023_
* Dependencies updated
## v4.0.11 - _August 9, 2023_ ## v4.0.11 - _August 9, 2023_
* Dependencies updated * Dependencies updated

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/contracts-erc20", "name": "@0x/contracts-erc20",
"version": "4.0.11", "version": "4.0.14",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },
@@ -24,7 +24,7 @@
}, },
"homepage": "https://github.com/0xProject/protocol", "homepage": "https://github.com/0xProject/protocol",
"devDependencies": { "devDependencies": {
"@0x/contracts-utils": "^4.8.49", "@0x/contracts-utils": "^4.8.52",
"@0x/ts-doc-gen": "^0.0.28", "@0x/ts-doc-gen": "^0.0.28",
"typedoc": "~0.16.11" "typedoc": "~0.16.11"
}, },

View File

@@ -1,4 +1,31 @@
[ [
{
"timestamp": 1700094997,
"version": "5.4.60",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1693346928,
"version": "5.4.59",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1692368658,
"version": "5.4.58",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{ {
"timestamp": 1691617396, "timestamp": 1691617396,
"version": "5.4.57", "version": "5.4.57",

View File

@@ -5,6 +5,18 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v5.4.60 - _November 16, 2023_
* Dependencies updated
## v5.4.59 - _August 29, 2023_
* Dependencies updated
## v5.4.58 - _August 18, 2023_
* Dependencies updated
## v5.4.57 - _August 9, 2023_ ## v5.4.57 - _August 9, 2023_
* Dependencies updated * Dependencies updated

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/contracts-test-utils", "name": "@0x/contracts-test-utils",
"version": "5.4.57", "version": "5.4.60",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },
@@ -41,7 +41,7 @@
"dependencies": { "dependencies": {
"@0x/assert": "^3.0.36", "@0x/assert": "^3.0.36",
"@0x/base-contract": "^7.0.0", "@0x/base-contract": "^7.0.0",
"@0x/contract-addresses": "^8.10.0", "@0x/contract-addresses": "^8.13.0",
"@0x/dev-utils": "^5.0.2", "@0x/dev-utils": "^5.0.2",
"@0x/json-schemas": "^6.4.4", "@0x/json-schemas": "^6.4.4",
"@0x/order-utils": "^10.4.28", "@0x/order-utils": "^10.4.28",

View File

@@ -1,4 +1,31 @@
[ [
{
"timestamp": 1700094997,
"version": "1.4.54",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1693346928,
"version": "1.4.53",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1692368658,
"version": "1.4.52",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{ {
"timestamp": 1691617396, "timestamp": 1691617396,
"version": "1.4.51", "version": "1.4.51",

View File

@@ -5,6 +5,18 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v1.4.54 - _November 16, 2023_
* Dependencies updated
## v1.4.53 - _August 29, 2023_
* Dependencies updated
## v1.4.52 - _August 18, 2023_
* Dependencies updated
## v1.4.51 - _August 9, 2023_ ## v1.4.51 - _August 9, 2023_
* Dependencies updated * Dependencies updated

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/contracts-treasury", "name": "@0x/contracts-treasury",
"version": "1.4.51", "version": "1.4.54",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },
@@ -46,12 +46,12 @@
"homepage": "https://github.com/0xProject/protocol/tree/main/contracts/treasury", "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/treasury",
"devDependencies": { "devDependencies": {
"@0x/abi-gen": "^5.8.5", "@0x/abi-gen": "^5.8.5",
"@0x/contract-addresses": "^8.10.0", "@0x/contract-addresses": "^8.13.0",
"@0x/contracts-asset-proxy": "^3.7.19", "@0x/contracts-asset-proxy": "^3.7.19",
"@0x/contracts-erc20": "3.3.57", "@0x/contracts-erc20": "3.3.57",
"@0x/contracts-gen": "^2.0.50", "@0x/contracts-gen": "^2.0.50",
"@0x/contracts-staking": "^2.0.45", "@0x/contracts-staking": "^2.0.45",
"@0x/contracts-test-utils": "^5.4.57", "@0x/contracts-test-utils": "^5.4.60",
"@0x/sol-compiler": "^4.8.2", "@0x/sol-compiler": "^4.8.2",
"@0x/ts-doc-gen": "^0.0.28", "@0x/ts-doc-gen": "^0.0.28",
"@types/isomorphic-fetch": "^0.0.35", "@types/isomorphic-fetch": "^0.0.35",
@@ -73,7 +73,7 @@
}, },
"dependencies": { "dependencies": {
"@0x/base-contract": "^7.0.0", "@0x/base-contract": "^7.0.0",
"@0x/protocol-utils": "^11.23.0", "@0x/protocol-utils": "^11.24.2",
"@0x/subproviders": "^8.0.1", "@0x/subproviders": "^8.0.1",
"@0x/types": "^3.3.7", "@0x/types": "^3.3.7",
"@0x/typescript-typings": "^5.3.1", "@0x/typescript-typings": "^5.3.1",

View File

@@ -1,4 +1,31 @@
[ [
{
"timestamp": 1700094997,
"version": "4.8.52",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1693346928,
"version": "4.8.51",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1692368658,
"version": "4.8.50",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{ {
"timestamp": 1691617396, "timestamp": 1691617396,
"version": "4.8.49", "version": "4.8.49",

View File

@@ -5,6 +5,18 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v4.8.52 - _November 16, 2023_
* Dependencies updated
## v4.8.51 - _August 29, 2023_
* Dependencies updated
## v4.8.50 - _August 18, 2023_
* Dependencies updated
## v4.8.49 - _August 9, 2023_ ## v4.8.49 - _August 9, 2023_
* Dependencies updated * Dependencies updated

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/contracts-utils", "name": "@0x/contracts-utils",
"version": "4.8.49", "version": "4.8.52",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },
@@ -45,7 +45,7 @@
"devDependencies": { "devDependencies": {
"@0x/abi-gen": "^5.8.5", "@0x/abi-gen": "^5.8.5",
"@0x/contracts-gen": "^2.0.50", "@0x/contracts-gen": "^2.0.50",
"@0x/contracts-test-utils": "^5.4.57", "@0x/contracts-test-utils": "^5.4.60",
"@0x/dev-utils": "^5.0.2", "@0x/dev-utils": "^5.0.2",
"@0x/order-utils": "^10.4.28", "@0x/order-utils": "^10.4.28",
"@0x/sol-compiler": "^4.8.2", "@0x/sol-compiler": "^4.8.2",

View File

@@ -1,4 +1,31 @@
[ [
{
"version": "0.49.0",
"changes": [
{
"note": "Allowlist Sepolia in AbstractBridgeAdapter"
}
],
"timestamp": 1700094997
},
{
"version": "0.48.0",
"changes": [
{
"note": "Add VelodromeV2 support on Base"
}
],
"timestamp": 1693346928
},
{
"version": "0.47.0",
"changes": [
{
"note": "Add MaverickV1 support on Ethereum, BSC, and Base"
}
],
"timestamp": 1692368658
},
{ {
"version": "0.46.0", "version": "0.46.0",
"changes": [ "changes": [

View File

@@ -5,6 +5,18 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v0.49.0 - _November 16, 2023_
* Allowlist Sepolia in AbstractBridgeAdapter
## v0.48.0 - _August 29, 2023_
* Add VelodromeV2 support on Base
## v0.47.0 - _August 18, 2023_
* Add MaverickV1 support on Ethereum, BSC, and Base
## v0.46.0 - _August 9, 2023_ ## v0.46.0 - _August 9, 2023_
* Add VelodromeV2 support on Optimism * Add VelodromeV2 support on Optimism

View File

@@ -23,12 +23,14 @@ abstract contract AbstractBridgeAdapter is IBridgeAdapter {
assembly { assembly {
chainId := chainid() chainId := chainid()
} }
// Skip chain id validation on Ganache (1337), Anvil (31337), Goerli (5), Mumbai (80001), Base Goerli (84531) // Skip chain id validation on Ganache (1337), Anvil (31337), Goerli (5), Mumbai (80001), Base Goerli (84531),
// Sepolia (11155111)
bool skipValidation = (chainId == 1337 || bool skipValidation = (chainId == 1337 ||
chainId == 31337 || chainId == 31337 ||
chainId == 5 || chainId == 5 ||
chainId == 80001 || chainId == 80001 ||
chainId == 84531); chainId == 84531 ||
chainId == 11155111);
if (chainId != expectedChainId && !skipValidation) { if (chainId != expectedChainId && !skipValidation) {
revert(string(abi.encodePacked(expectedChainName, "BridgeAdapter.constructor: wrong chain ID"))); revert(string(abi.encodePacked(expectedChainName, "BridgeAdapter.constructor: wrong chain ID")));

View File

@@ -22,6 +22,7 @@ import "./mixins/MixinDodo.sol";
import "./mixins/MixinDodoV2.sol"; import "./mixins/MixinDodoV2.sol";
import "./mixins/MixinKyberDmm.sol"; import "./mixins/MixinKyberDmm.sol";
import "./mixins/MixinKyberElastic.sol"; import "./mixins/MixinKyberElastic.sol";
import "./mixins/MixinMaverickV1.sol";
import "./mixins/MixinMooniswap.sol"; import "./mixins/MixinMooniswap.sol";
import "./mixins/MixinNerve.sol"; import "./mixins/MixinNerve.sol";
import "./mixins/MixinUniswapV2.sol"; import "./mixins/MixinUniswapV2.sol";
@@ -36,6 +37,7 @@ contract BSCBridgeAdapter is
MixinDodoV2, MixinDodoV2,
MixinKyberDmm, MixinKyberDmm,
MixinKyberElastic, MixinKyberElastic,
MixinMaverickV1,
MixinMooniswap, MixinMooniswap,
MixinNerve, MixinNerve,
MixinUniswapV2, MixinUniswapV2,
@@ -103,6 +105,11 @@ contract BSCBridgeAdapter is
return (0, true); return (0, true);
} }
boughtAmount = _tradeWOOFi(sellToken, buyToken, sellAmount, order.bridgeData); boughtAmount = _tradeWOOFi(sellToken, buyToken, sellAmount, order.bridgeData);
} else if (protocolId == BridgeProtocols.MAVERICKV1) {
if (dryRun) {
return (0, true);
}
boughtAmount = _tradeMaverickV1(sellToken, buyToken, sellAmount, order.bridgeData);
} else if (protocolId == BridgeProtocols.UNKNOWN) { } else if (protocolId == BridgeProtocols.UNKNOWN) {
if (dryRun) { if (dryRun) {
return (0, true); return (0, true);

View File

@@ -22,7 +22,9 @@ import "./mixins/MixinUniswapV2.sol";
import "./mixins/MixinBalancerV2Batch.sol"; import "./mixins/MixinBalancerV2Batch.sol";
import "./mixins/MixinCurve.sol"; import "./mixins/MixinCurve.sol";
import "./mixins/MixinCurveV2.sol"; import "./mixins/MixinCurveV2.sol";
import "./mixins/MixinMaverickV1.sol";
import "./mixins/MixinSolidly.sol"; import "./mixins/MixinSolidly.sol";
import "./mixins/MixinVelodromeV2.sol";
contract BaseBridgeAdapter is contract BaseBridgeAdapter is
AbstractBridgeAdapter(8453, "Base"), AbstractBridgeAdapter(8453, "Base"),
@@ -31,7 +33,9 @@ contract BaseBridgeAdapter is
MixinBalancerV2Batch, MixinBalancerV2Batch,
MixinCurve, MixinCurve,
MixinCurveV2, MixinCurveV2,
MixinSolidly MixinMaverickV1,
MixinSolidly,
MixinVelodromeV2
{ {
constructor(IEtherToken weth) public MixinCurve(weth) {} constructor(IEtherToken weth) public MixinCurve(weth) {}
@@ -73,6 +77,16 @@ contract BaseBridgeAdapter is
return (0, true); return (0, true);
} }
boughtAmount = _tradeBalancerV2Batch(sellAmount, order.bridgeData); boughtAmount = _tradeBalancerV2Batch(sellAmount, order.bridgeData);
} else if (protocolId == BridgeProtocols.MAVERICKV1) {
if (dryRun) {
return (0, true);
}
boughtAmount = _tradeMaverickV1(sellToken, buyToken, sellAmount, order.bridgeData);
} else if (protocolId == BridgeProtocols.VELODROMEV2) {
if (dryRun) {
return (0, true);
}
boughtAmount = _tradeVelodromeV2(sellToken, sellAmount, order.bridgeData);
} }
emit BridgeFill(order.source, sellToken, buyToken, sellAmount, boughtAmount); emit BridgeFill(order.source, sellToken, buyToken, sellAmount, boughtAmount);
} }

View File

@@ -58,4 +58,5 @@ library BridgeProtocols {
uint128 internal constant BARTER = 34; uint128 internal constant BARTER = 34;
uint128 internal constant TRADERJOEV2 = 35; uint128 internal constant TRADERJOEV2 = 35;
uint128 internal constant VELODROMEV2 = 36; uint128 internal constant VELODROMEV2 = 36;
uint128 internal constant MAVERICKV1 = 37;
} }

View File

@@ -32,6 +32,7 @@ import "./mixins/MixinKyberDmm.sol";
import "./mixins/MixinKyberElastic.sol"; import "./mixins/MixinKyberElastic.sol";
import "./mixins/MixinLido.sol"; import "./mixins/MixinLido.sol";
import "./mixins/MixinMakerPSM.sol"; import "./mixins/MixinMakerPSM.sol";
import "./mixins/MixinMaverickV1.sol";
import "./mixins/MixinNerve.sol"; import "./mixins/MixinNerve.sol";
import "./mixins/MixinSynthetix.sol"; import "./mixins/MixinSynthetix.sol";
import "./mixins/MixinUniswap.sol"; import "./mixins/MixinUniswap.sol";
@@ -56,6 +57,7 @@ contract EthereumBridgeAdapter is
MixinKyberElastic, MixinKyberElastic,
MixinLido, MixinLido,
MixinMakerPSM, MixinMakerPSM,
MixinMaverickV1,
MixinNerve, MixinNerve,
MixinSynthetix, MixinSynthetix,
MixinUniswap, MixinUniswap,
@@ -175,6 +177,11 @@ contract EthereumBridgeAdapter is
return (0, true); return (0, true);
} }
boughtAmount = _tradeBarter(sellToken, sellAmount, order.bridgeData); boughtAmount = _tradeBarter(sellToken, sellAmount, order.bridgeData);
} else if (protocolId == BridgeProtocols.MAVERICKV1) {
if (dryRun) {
return (0, true);
}
boughtAmount = _tradeMaverickV1(sellToken, buyToken, sellAmount, order.bridgeData);
} else if (protocolId == BridgeProtocols.UNKNOWN) { } else if (protocolId == BridgeProtocols.UNKNOWN) {
if (dryRun) { if (dryRun) {
return (0, true); return (0, true);

View File

@@ -0,0 +1,63 @@
// SPDX-License-Identifier: Apache-2.0
/*
Copyright 2023 ZeroEx Intl.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
pragma solidity ^0.6.5;
pragma experimental ABIEncoderV2;
import "@0x/contracts-erc20/src/v06/LibERC20TokenV06.sol";
import "@0x/contracts-erc20/src/IERC20Token.sol";
interface IMaverickV1Router {
struct ExactInputSingleParams {
address tokenIn;
address tokenOut;
address pool;
address recipient;
uint256 deadline;
uint256 amountIn;
uint256 amountOutMinimum;
uint256 sqrtPriceLimitD18;
}
function exactInputSingle(ExactInputSingleParams calldata params) external payable returns (uint256 amountOut);
}
contract MixinMaverickV1 {
using LibERC20TokenV06 for IERC20Token;
function _tradeMaverickV1(
IERC20Token sellToken,
IERC20Token buyToken,
uint256 sellAmount,
bytes memory bridgeData
) internal returns (uint256 boughtAmount) {
(IMaverickV1Router router, address pool) = abi.decode(bridgeData, (IMaverickV1Router, address));
// Grant the MaverickV1 router an allowance to sell the sellToken
sellToken.approveIfBelow(address(router), sellAmount);
boughtAmount = router.exactInputSingle(
IMaverickV1Router.ExactInputSingleParams({
tokenIn: address(sellToken),
tokenOut: address(buyToken),
pool: pool,
recipient: address(this),
deadline: block.timestamp,
amountIn: sellAmount,
amountOutMinimum: 1,
sqrtPriceLimitD18: 0
})
);
}
}

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/contracts-zero-ex", "name": "@0x/contracts-zero-ex",
"version": "0.46.0", "version": "0.49.0",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },
@@ -51,10 +51,10 @@
"homepage": "https://github.com/0xProject/protocol/tree/main/contracts/zero-ex", "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/zero-ex",
"devDependencies": { "devDependencies": {
"@0x/abi-gen": "^5.8.5", "@0x/abi-gen": "^5.8.5",
"@0x/contract-addresses": "^8.10.0", "@0x/contract-addresses": "^8.13.0",
"@0x/contracts-erc20": "^3.3.57", "@0x/contracts-erc20": "^3.3.57",
"@0x/contracts-gen": "^2.0.50", "@0x/contracts-gen": "^2.0.50",
"@0x/contracts-test-utils": "^5.4.57", "@0x/contracts-test-utils": "^5.4.60",
"@0x/dev-utils": "^5.0.2", "@0x/dev-utils": "^5.0.2",
"@0x/order-utils": "^10.4.28", "@0x/order-utils": "^10.4.28",
"@0x/sol-compiler": "^4.8.2", "@0x/sol-compiler": "^4.8.2",
@@ -80,7 +80,7 @@
}, },
"dependencies": { "dependencies": {
"@0x/base-contract": "^7.0.0", "@0x/base-contract": "^7.0.0",
"@0x/protocol-utils": "^11.23.0", "@0x/protocol-utils": "^11.24.2",
"@0x/subproviders": "^8.0.1", "@0x/subproviders": "^8.0.1",
"@0x/types": "^3.3.7", "@0x/types": "^3.3.7",
"@0x/typescript-typings": "^5.3.1", "@0x/typescript-typings": "^5.3.1",

View File

@@ -32,4 +32,8 @@ contract BSCBridgeAdapterTest is Test {
function testSupportsUniswapV3() public { function testSupportsUniswapV3() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.UNISWAPV3) << 128))); assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.UNISWAPV3) << 128)));
} }
function testSupportMaverickV1() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.MAVERICKV1) << 128)));
}
} }

View File

@@ -0,0 +1,47 @@
// SPDX-License-Identifier: Apache-2.0
/*
Copyright 2023 ZeroEx Intl.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
pragma solidity ^0.6.5;
pragma experimental ABIEncoderV2;
import "forge-std/Test.sol";
import "../../../contracts/src/transformers/bridges/BaseBridgeAdapter.sol";
import "../../../contracts/src/transformers/bridges/BridgeProtocols.sol";
contract BaseBridgeAdapterTest is Test {
address constant WETH = 0x4200000000000000000000000000000000000006;
BaseBridgeAdapter private adapter;
function setUp() public {
vm.chainId(8453);
adapter = new BaseBridgeAdapter(IEtherToken(WETH));
}
function testSupportsUniswapV3() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.UNISWAPV3) << 128)));
}
function testSupportMaverickV1() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.MAVERICKV1) << 128)));
}
function testSupportSolidly() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.SOLIDLY) << 128)));
}
function testSupportVelodromeV2() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.VELODROMEV2) << 128)));
}
}

View File

@@ -0,0 +1,39 @@
// SPDX-License-Identifier: Apache-2.0
/*
Copyright 2023 ZeroEx Intl.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
pragma solidity ^0.6.5;
pragma experimental ABIEncoderV2;
import "forge-std/Test.sol";
import "../../../contracts/src/transformers/bridges/EthereumBridgeAdapter.sol";
import "../../../contracts/src/transformers/bridges/BridgeProtocols.sol";
contract EthereumBridgeAdapterTest is Test {
address constant WETH = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2;
EthereumBridgeAdapter private adapter;
function setUp() public {
vm.chainId(1);
adapter = new EthereumBridgeAdapter(IEtherToken(WETH));
}
function testSupportsUniswapV3() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.UNISWAPV3) << 128)));
}
function testSupportMaverickV1() public {
assertTrue(adapter.isSupportedSource(bytes32(uint256(BridgeProtocols.MAVERICKV1) << 128)));
}
}

View File

@@ -66,3 +66,8 @@ Note: Some addresses have changed across various networks
Avalanche, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://snowtrace.io/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__ Avalanche, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://snowtrace.io/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__
Fantom, `0xdef189deaef76e379df891899eb5a00a94cbc250 <https://ftmscan.com/address/0xdef189deaef76e379df891899eb5a00a94cbc250>`__ Fantom, `0xdef189deaef76e379df891899eb5a00a94cbc250 <https://ftmscan.com/address/0xdef189deaef76e379df891899eb5a00a94cbc250>`__
Celo, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://explorer.celo.org/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__ Celo, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://explorer.celo.org/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__
Arbitrum, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://arbiscan.io/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__
Base, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://basescan.org/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__
zkEVM, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://zkevm.polygonscan.com/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__
Sepolia, `0xdef1c0ded9bec7f1a1670819833240f027b25eff <https://sepolia.etherscan.io/address/0xdef1c0ded9bec7f1a1670819833240f027b25eff>`__
Mumbai, `0xf471d32cb40837bf24529fcf17418fc1a4807626 <https://mumbai.polygonscan.com/address/0xf471d32cb40837bf24529fcf17418fc1a4807626>`__

View File

@@ -1,4 +1,31 @@
[ [
{
"version": "8.13.0",
"changes": [
{
"note": "Add Sepolia addresses"
}
],
"timestamp": 1700094997
},
{
"version": "8.12.0",
"changes": [
{
"note": "Add VelodromeV2 support on Base"
}
],
"timestamp": 1693346928
},
{
"version": "8.11.0",
"changes": [
{
"note": "Add MaverickV1 support on Ethereum, BSC, and Base"
}
],
"timestamp": 1692368658
},
{ {
"version": "8.10.0", "version": "8.10.0",
"changes": [ "changes": [

View File

@@ -6,6 +6,15 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v8.13.0 - _November 16, 2023_
* Add Sepolia addresses
## v8.12.0 - _August 29, 2023_
* Add VelodromeV2 support on Base
## v8.11.0 - _August 18, 2023_
* Add MaverickV1 support on Ethereum, BSC, and Base
## v8.10.0 - _August 9, 2023_ ## v8.10.0 - _August 9, 2023_
* Add VelodromeV2 support on Optimism * Add VelodromeV2 support on Optimism

View File

@@ -18,7 +18,7 @@
"wethTransformer": "0xb2bc06a4efb20fc6553a69dbfa49b7be938034a7", "wethTransformer": "0xb2bc06a4efb20fc6553a69dbfa49b7be938034a7",
"payTakerTransformer": "0xea500d073652336a58846ada15c25f2c6d2d241f", "payTakerTransformer": "0xea500d073652336a58846ada15c25f2c6d2d241f",
"affiliateFeeTransformer": "0x8146cbbe327364b13d0699f2ced39c637f92501a", "affiliateFeeTransformer": "0x8146cbbe327364b13d0699f2ced39c637f92501a",
"fillQuoteTransformer": "0x21c3bee93fad436dedd29f971dc4fdf82f3e3a3a", "fillQuoteTransformer": "0x2fd08c1f9fc8406c1d7e3a799a13883a7e7949f0",
"positiveSlippageFeeTransformer": "0x818a4a855bfeb16c305cb65e8d4fb239a308bc48" "positiveSlippageFeeTransformer": "0x818a4a855bfeb16c305cb65e8d4fb239a308bc48"
} }
}, },
@@ -64,7 +64,7 @@
"wethTransformer": "0xac3d95668c092e895cd83a9cbafe9c7d9906471f", "wethTransformer": "0xac3d95668c092e895cd83a9cbafe9c7d9906471f",
"payTakerTransformer": "0x7e788f3a3e39cdd1944ba111fafc5fb7e59b5e90", "payTakerTransformer": "0x7e788f3a3e39cdd1944ba111fafc5fb7e59b5e90",
"affiliateFeeTransformer": "0x043300d113de0c64684ab89c56a45cd94c7ef54c", "affiliateFeeTransformer": "0x043300d113de0c64684ab89c56a45cd94c7ef54c",
"fillQuoteTransformer": "0xa9c57c539690d4e1439411f648ead5b121b34a23", "fillQuoteTransformer": "0x6073f12fc63bcc64bd4fed5d44aa1035e37d68ee",
"positiveSlippageFeeTransformer": "0x6ff35e8cbaf56d8a8f6bf9963b902a4576243030" "positiveSlippageFeeTransformer": "0x6ff35e8cbaf56d8a8f6bf9963b902a4576243030"
} }
}, },
@@ -271,8 +271,31 @@
"wethTransformer": "0x63186ea36e78ecbf0128e448362f1b81e9bf7412", "wethTransformer": "0x63186ea36e78ecbf0128e448362f1b81e9bf7412",
"payTakerTransformer": "0x5cc22a0e06ea11097c612a962e63674b90e96099", "payTakerTransformer": "0x5cc22a0e06ea11097c612a962e63674b90e96099",
"affiliateFeeTransformer": "0x9e52d8b32d835206d09810c310593bcc77264066", "affiliateFeeTransformer": "0x9e52d8b32d835206d09810c310593bcc77264066",
"fillQuoteTransformer": "0x98b159db76c820dc877782f199e287a97420b1d2", "fillQuoteTransformer": "0x2c46d57bb5af87a13a51dd5b62ba7d3bc7e12e9c",
"positiveSlippageFeeTransformer": "0xf98a130d3b4029c70e6d93098cb82a003421341e" "positiveSlippageFeeTransformer": "0xf98a130d3b4029c70e6d93098cb82a003421341e"
} }
},
"11155111": {
"zrxToken": "0x0000000000000000000000000000000000000000",
"etherToken": "0xfff9976782d46cc05630d1f6ebab18b2324d6b14",
"zeroExGovernor": "0x5c1f7772ce24d942b85e9b6576f7b5ef70686f5a",
"zrxVault": "0x0000000000000000000000000000000000000000",
"staking": "0x0000000000000000000000000000000000000000",
"stakingProxy": "0x0000000000000000000000000000000000000000",
"erc20BridgeProxy": "0x0000000000000000000000000000000000000000",
"erc20BridgeSampler": "0x0000000000000000000000000000000000000000",
"exchangeProxyGovernor": "0x5c1f7772ce24d942b85e9b6576f7b5ef70686f5a",
"exchangeProxy": "0xdef1c0ded9bec7f1a1670819833240f027b25eff",
"exchangeProxyTransformerDeployer": "0x58bca53ebba1aaf25f0edcd8dad6421872fe20b2",
"exchangeProxyFlashWallet": "0xdb6f1920a889355780af7570773609bd8cb1f498",
"exchangeProxyLiquidityProviderSandbox": "0x0000000000000000000000000000000000000000",
"zrxTreasury": "0x0000000000000000000000000000000000000000",
"transformers": {
"wethTransformer": "0xf98a130d3b4029c70e6d93098cb82a003421341e",
"payTakerTransformer": "0x44e0f3975e95387f3866dd7cab1f51050394a3d1",
"affiliateFeeTransformer": "0x5cc22a0e06ea11097c612a962e63674b90e96099",
"fillQuoteTransformer": "0x63186ea36e78ecbf0128e448362f1b81e9bf7412",
"positiveSlippageFeeTransformer": "0x9e52d8b32d835206d09810c310593bcc77264066"
}
} }
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/contract-addresses", "name": "@0x/contract-addresses",
"version": "8.10.0", "version": "8.13.0",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },

View File

@@ -1,20 +1,16 @@
import addresses from '../addresses.json'; import addresses from '../addresses.json';
export interface ContractAddresses { export interface ContractAddresses {
zrxToken: string;
etherToken: string;
zeroExGovernor: string;
zrxVault: string;
staking: string;
stakingProxy: string;
erc20BridgeProxy: string; erc20BridgeProxy: string;
erc20BridgeSampler: string; erc20BridgeSampler: string;
exchangeProxyGovernor: string; etherToken: string;
exchangeProxy: string; exchangeProxy: string;
exchangeProxyTransformerDeployer: string;
exchangeProxyFlashWallet: string; exchangeProxyFlashWallet: string;
exchangeProxyGovernor: string;
exchangeProxyLiquidityProviderSandbox: string; exchangeProxyLiquidityProviderSandbox: string;
zrxTreasury: string; exchangeProxyTransformerDeployer: string;
staking: string;
stakingProxy: string;
transformers: { transformers: {
wethTransformer: string; wethTransformer: string;
payTakerTransformer: string; payTakerTransformer: string;
@@ -22,21 +18,33 @@ export interface ContractAddresses {
affiliateFeeTransformer: string; affiliateFeeTransformer: string;
positiveSlippageFeeTransformer: string; positiveSlippageFeeTransformer: string;
}; };
zeroExGovernor: string;
zrxToken: string;
zrxTreasury: string;
zrxVault: string;
} }
export enum ChainId { export enum ChainId {
Mainnet = 1, Mainnet = 1,
Goerli = 5, Goerli = 5,
Ganache = 1337, Optimism = 10,
BSC = 56, BSC = 56,
Polygon = 137, Polygon = 137,
PolygonMumbai = 80001,
Avalanche = 43114,
Fantom = 250, Fantom = 250,
Celo = 42220, Ganache = 1337,
Optimism = 10,
Arbitrum = 42161,
Base = 8453, Base = 8453,
Arbitrum = 42161,
Avalanche = 43114,
Celo = 42220,
PolygonMumbai = 80001,
Sepolia = 11155111
}
/**
* Narrow a JavaScript number to a Chain ID.
*/
export function isChainId(chainId: number): chainId is ChainId {
return Object.values(ChainId).includes(chainId);
} }
/** /**

View File

@@ -2,7 +2,7 @@ import * as chai from 'chai';
import { bufferToHex, rlphash } from 'ethereumjs-util'; import { bufferToHex, rlphash } from 'ethereumjs-util';
import 'mocha'; import 'mocha';
import { ChainId, getContractAddressesForChainOrThrow } from '../src'; import { ChainId, getContractAddressesForChainOrThrow, isChainId } from '../src';
const expect = chai.expect; const expect = chai.expect;
@@ -68,3 +68,12 @@ describe('addresses.json sanity test', () => {
}); });
}); });
}); });
describe("isChainId", () => {
it("should return true for existing chain ids", () => {
expect(isChainId(1)).to.be.true;
});
it("should return false for non-existing chain ids", () => {
expect(isChainId(666)).to.be.false;
});
});

View File

@@ -1,4 +1,31 @@
[ [
{
"timestamp": 1700094997,
"version": "13.23.8",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1693346928,
"version": "13.23.7",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1692368658,
"version": "13.23.6",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{ {
"timestamp": 1691617396, "timestamp": 1691617396,
"version": "13.23.5", "version": "13.23.5",

View File

@@ -6,6 +6,15 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v13.23.8 - _November 16, 2023_
* Dependencies updated
## v13.23.7 - _August 29, 2023_
* Dependencies updated
## v13.23.6 - _August 18, 2023_
* Dependencies updated
## v13.23.5 - _August 9, 2023_ ## v13.23.5 - _August 9, 2023_
* Dependencies updated * Dependencies updated

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/contract-wrappers", "name": "@0x/contract-wrappers",
"version": "13.23.5", "version": "13.23.8",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },
@@ -59,7 +59,7 @@
"dependencies": { "dependencies": {
"@0x/assert": "^3.0.36", "@0x/assert": "^3.0.36",
"@0x/base-contract": "^7.0.0", "@0x/base-contract": "^7.0.0",
"@0x/contract-addresses": "^8.10.0", "@0x/contract-addresses": "^8.13.0",
"@0x/json-schemas": "^6.4.4", "@0x/json-schemas": "^6.4.4",
"@0x/types": "^3.3.7", "@0x/types": "^3.3.7",
"@0x/utils": "^7.0.0", "@0x/utils": "^7.0.0",

View File

@@ -1,4 +1,31 @@
[ [
{
"timestamp": 1700094997,
"version": "11.24.2",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"timestamp": 1693346928,
"version": "11.24.1",
"changes": [
{
"note": "Dependencies updated"
}
]
},
{
"version": "11.24.0",
"changes": [
{
"note": "Add MaverickV1 support on Ethereum, BSC, and Base"
}
],
"timestamp": 1692368658
},
{ {
"version": "11.23.0", "version": "11.23.0",
"changes": [ "changes": [

View File

@@ -6,6 +6,15 @@ Edit the package's CHANGELOG.json file only.
CHANGELOG CHANGELOG
## v11.24.2 - _November 16, 2023_
* Dependencies updated
## v11.24.1 - _August 29, 2023_
* Dependencies updated
## v11.24.0 - _August 18, 2023_
* Add MaverickV1 support on Ethereum, BSC, and Base
## v11.23.0 - _August 9, 2023_ ## v11.23.0 - _August 9, 2023_
* Add VelodromeV2 support on Optimism * Add VelodromeV2 support on Optimism

View File

@@ -1,6 +1,6 @@
{ {
"name": "@0x/protocol-utils", "name": "@0x/protocol-utils",
"version": "11.23.0", "version": "11.24.2",
"engines": { "engines": {
"node": ">=6.12" "node": ">=6.12"
}, },
@@ -62,8 +62,8 @@
}, },
"dependencies": { "dependencies": {
"@0x/assert": "^3.0.36", "@0x/assert": "^3.0.36",
"@0x/contract-addresses": "^8.10.0", "@0x/contract-addresses": "^8.13.0",
"@0x/contract-wrappers": "^13.23.5", "@0x/contract-wrappers": "^13.23.8",
"@0x/json-schemas": "^6.4.4", "@0x/json-schemas": "^6.4.4",
"@0x/subproviders": "^8.0.1", "@0x/subproviders": "^8.0.1",
"@0x/utils": "^7.0.0", "@0x/utils": "^7.0.0",

View File

@@ -167,6 +167,7 @@ export enum BridgeProtocol {
Barter, Barter,
TraderJoeV2, TraderJoeV2,
VelodromeV2, VelodromeV2,
MaverickV1,
} }
/** /**