Compare commits
	
		
			37 Commits
		
	
	
		
			@0x/contra
			...
			protocol@8
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 859c36cb10 | ||
|  | 3e34386812 | ||
|  | a35af11981 | ||
|  | 59eabec71e | ||
|  | bf4c7e7d50 | ||
|  | fd098ca4df | ||
|  | c360f8d8fd | ||
|  | b358559421 | ||
|  | df5aad8e8e | ||
|  | 8dbf79db59 | ||
|  | 1839608e84 | ||
|  | 6e3e795b8b | ||
|  | d9c410a7e3 | ||
|  | 609727afe8 | ||
|  | 8a5c74c0b4 | ||
|  | cd93f3b07e | ||
|  | 8397b12de6 | ||
|  | 3f85acec3a | ||
|  | d6a9e3d600 | ||
|  | 361569ac2f | ||
|  | 719664c145 | ||
|  | f800d6c24c | ||
|  | a9a81bcafb | ||
|  | 4280307a15 | ||
|  | 7b57d3ae51 | ||
|  | 8a8a5bbda0 | ||
|  | 76987c8db1 | ||
|  | 6f8971cc42 | ||
|  | 71ab882143 | ||
|  | 5a4961c8d9 | ||
|  | 4c4fb99d87 | ||
|  | 872abf09e9 | ||
|  | f10bfe7d04 | ||
|  | a74d8deff3 | ||
|  | 835ee4e8de | ||
|  | 63ec42303f | ||
|  | f789aebddc | 
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "3.7.17", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "3.7.16", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v3.7.17 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v3.7.16 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-asset-proxy", | ||||
|     "version": "3.7.16", | ||||
|     "version": "3.7.17", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -52,10 +52,10 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/protocol", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contract-wrappers": "^13.17.2", | ||||
|         "@0x/contract-wrappers": "^13.17.3", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
| @@ -80,11 +80,11 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contracts-erc1155": "^2.1.34", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-erc721": "^3.1.34", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/contracts-erc1155": "^2.1.35", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-erc721": "^3.1.35", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "1.1.35", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "1.1.34", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v1.1.35 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.1.34 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-broker", | ||||
|     "version": "1.1.34", | ||||
|     "version": "1.1.35", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -52,14 +52,14 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-erc721": "^3.1.34", | ||||
|         "@0x/contracts-exchange": "^3.2.35", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-erc721": "^3.1.35", | ||||
|         "@0x/contracts-exchange": "^3.2.36", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
| @@ -85,7 +85,7 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|         "ethereum-types": "^3.5.0" | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "3.1.36", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "3.1.35", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v3.1.36 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v3.1.35 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-coordinator", | ||||
|     "version": "3.1.35", | ||||
|     "version": "3.1.36", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -53,12 +53,12 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-dev-utils": "^1.3.33", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-dev-utils": "^1.3.34", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
| @@ -84,10 +84,10 @@ | ||||
|     "dependencies": { | ||||
|         "@0x/assert": "^3.0.27", | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contracts-exchange": "^3.2.35", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contracts-exchange": "^3.2.36", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/json-schemas": "^6.1.3", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "1.3.34", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "1.3.33", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v1.3.34 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.3.33 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-dev-utils", | ||||
|     "version": "1.3.33", | ||||
|     "version": "1.3.34", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -43,10 +43,10 @@ | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/assert": "^3.0.27", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "2.1.35", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "2.1.34", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v2.1.35 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v2.1.34 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-erc1155", | ||||
|     "version": "2.1.34", | ||||
|     "version": "2.1.35", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -54,7 +54,7 @@ | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
| @@ -81,7 +81,7 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|         "@0x/web3-wrapper": "^7.5.3", | ||||
|         "lodash": "^4.17.11" | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "3.3.14", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "3.3.13", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v3.3.14 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v3.3.13 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-erc20", | ||||
|     "version": "3.3.13", | ||||
|     "version": "3.3.14", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -53,8 +53,8 @@ | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "3.1.35", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "3.1.34", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v3.1.35 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v3.1.34 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-erc721", | ||||
|     "version": "3.1.34", | ||||
|     "version": "3.1.35", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -54,8 +54,8 @@ | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "4.2.36", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "4.2.35", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v4.2.36 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v4.2.35 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-exchange-forwarder", | ||||
|     "version": "4.2.35", | ||||
|     "version": "4.2.36", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -53,18 +53,18 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-dev-utils": "^1.3.33", | ||||
|         "@0x/contracts-erc1155": "^2.1.34", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-erc721": "^3.1.34", | ||||
|         "@0x/contracts-exchange": "^3.2.35", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-dev-utils": "^1.3.34", | ||||
|         "@0x/contracts-erc1155": "^2.1.35", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-erc721": "^3.1.35", | ||||
|         "@0x/contracts-exchange": "^3.2.36", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "4.3.35", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "4.3.34", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v4.3.35 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v4.3.34 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-exchange-libs", | ||||
|     "version": "4.3.34", | ||||
|     "version": "4.3.35", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -81,9 +81,9 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "3.2.36", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "3.2.35", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v3.2.36 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v3.2.35 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-exchange", | ||||
|     "version": "3.2.35", | ||||
|     "version": "3.2.36", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -53,13 +53,13 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/protocol", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-multisig": "^4.1.35", | ||||
|         "@0x/contracts-staking": "^2.0.42", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-multisig": "^4.1.36", | ||||
|         "@0x/contracts-staking": "^2.0.43", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
| @@ -89,11 +89,11 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contracts-dev-utils": "^1.3.33", | ||||
|         "@0x/contracts-erc1155": "^2.1.34", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-erc721": "^3.1.34", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/contracts-dev-utils": "^1.3.34", | ||||
|         "@0x/contracts-erc1155": "^2.1.35", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-erc721": "^3.1.35", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|         "lodash": "^4.17.11" | ||||
|     }, | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "6.2.30", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "6.2.29", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v6.2.30 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v6.2.29 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-extensions", | ||||
|     "version": "6.2.29", | ||||
|     "version": "6.2.30", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -53,16 +53,16 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-dev-utils": "^1.3.33", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-erc721": "^3.1.34", | ||||
|         "@0x/contracts-exchange": "^3.2.35", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-dev-utils": "^1.3.34", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-erc721": "^3.1.35", | ||||
|         "@0x/contracts-exchange": "^3.2.36", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
| @@ -91,7 +91,7 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|         "ethereum-types": "^3.5.0" | ||||
|     }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-integrations", | ||||
|     "version": "2.7.52", | ||||
|     "version": "2.7.62", | ||||
|     "private": true, | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
| @@ -53,21 +53,21 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contract-wrappers": "^13.17.2", | ||||
|         "@0x/contracts-broker": "^1.1.34", | ||||
|         "@0x/contracts-coordinator": "^3.1.35", | ||||
|         "@0x/contracts-dev-utils": "^1.3.33", | ||||
|         "@0x/contracts-exchange-forwarder": "^4.2.35", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/contracts-extensions": "^6.2.29", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contract-wrappers": "^13.17.3", | ||||
|         "@0x/contracts-broker": "^1.1.35", | ||||
|         "@0x/contracts-coordinator": "^3.1.36", | ||||
|         "@0x/contracts-dev-utils": "^1.3.34", | ||||
|         "@0x/contracts-exchange-forwarder": "^4.2.36", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/contracts-extensions": "^6.2.30", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/coordinator-server": "^1.0.5", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/migrations": "^8.0.11", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/protocol-utils": "^1.7.2", | ||||
|         "@0x/migrations": "^8.0.12", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/protocol-utils": "^1.8.0", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
|         "@0x/web3-wrapper": "^7.5.3", | ||||
| @@ -93,17 +93,17 @@ | ||||
|         "typescript": "4.2.2" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/asset-swapper": "^6.18.1", | ||||
|         "@0x/asset-swapper": "^16.24.0", | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-erc1155": "^2.1.34", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-erc721": "^3.1.34", | ||||
|         "@0x/contracts-exchange": "^3.2.35", | ||||
|         "@0x/contracts-multisig": "^4.1.35", | ||||
|         "@0x/contracts-staking": "^2.0.42", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-zero-ex": "^0.26.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-erc1155": "^2.1.35", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-erc721": "^3.1.35", | ||||
|         "@0x/contracts-exchange": "^3.2.36", | ||||
|         "@0x/contracts-multisig": "^4.1.36", | ||||
|         "@0x/contracts-staking": "^2.0.43", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-zero-ex": "^0.27.0", | ||||
|         "@0x/subproviders": "^6.5.3", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "4.1.36", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "4.1.35", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v4.1.36 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v4.1.35 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-multisig", | ||||
|     "version": "4.1.35", | ||||
|     "version": "4.1.36", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -50,11 +50,11 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/multisig", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "2.0.43", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "2.0.42", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v2.0.43 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v2.0.42 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-staking", | ||||
|     "version": "2.0.42", | ||||
|     "version": "2.0.43", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -54,14 +54,14 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/tokens", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-dev-utils": "^1.3.33", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-dev-utils": "^1.3.34", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
| @@ -88,7 +88,7 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|         "ethereum-types": "^3.5.0", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "5.4.6", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "5.4.5", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v5.4.6 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v5.4.5 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-test-utils", | ||||
|     "version": "5.4.5", | ||||
|     "version": "5.4.6", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -44,10 +44,10 @@ | ||||
|     "dependencies": { | ||||
|         "@0x/assert": "^3.0.27", | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/json-schemas": "^6.1.3", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/sol-coverage": "^4.0.37", | ||||
|         "@0x/sol-profiler": "^4.1.27", | ||||
|         "@0x/sol-trace": "^3.0.37", | ||||
|   | ||||
| @@ -1,4 +1,14 @@ | ||||
| [ | ||||
|     { | ||||
|         "version": "1.3.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added proposal 1 params and test", | ||||
|                 "pr": 298 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1628225642 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "1.2.3", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v1.3.0 - _August 6, 2021_ | ||||
|  | ||||
|     * Added proposal 1 params and test (#298) | ||||
|  | ||||
| ## v1.2.3 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-treasury", | ||||
|     "version": "1.2.3", | ||||
|     "version": "1.3.0", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -47,12 +47,12 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/treasury", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-staking": "^2.0.42", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-staking": "^2.0.43", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
| @@ -73,7 +73,7 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/protocol-utils": "^1.7.2", | ||||
|         "@0x/protocol-utils": "^1.8.0", | ||||
|         "@0x/subproviders": "^6.5.3", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|   | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -151,4 +151,72 @@ blockchainTests.fork.skip('Treasury proposal mainnet fork tests', env => { | ||||
|             ); | ||||
|         }); | ||||
|     }); | ||||
|     describe('Proposal 1', () => { | ||||
|         it('works', async () => { | ||||
|             const proposal = proposals[1]; | ||||
|             let executionEpoch: BigNumber; | ||||
|             if (proposal.executionEpoch) { | ||||
|                 executionEpoch = proposal.executionEpoch; | ||||
|             } else { | ||||
|                 const currentEpoch = await staking.currentEpoch().callAsync(); | ||||
|                 executionEpoch = currentEpoch.plus(2); | ||||
|             } | ||||
|             const pools = await querySubgraphAsync(PROPOSER); | ||||
|             const proposeTx = treasury.propose(proposal.actions, executionEpoch, proposal.description, pools); | ||||
|  | ||||
|             const calldata = proposeTx.getABIEncodedTransactionData(); | ||||
|             logUtils.log('ZrxTreasury.propose calldata:'); | ||||
|             logUtils.log(calldata); | ||||
|  | ||||
|             const proposalId = await proposeTx.callAsync({ from: PROPOSER }); | ||||
|             const receipt = await proposeTx.awaitTransactionSuccessAsync({ from: PROPOSER }); | ||||
|             verifyEventsFromLogs( | ||||
|                 receipt.logs, | ||||
|                 [ | ||||
|                     { | ||||
|                         ...proposal, | ||||
|                         proposalId, | ||||
|                         executionEpoch, | ||||
|                         proposer: PROPOSER, | ||||
|                         operatedPoolIds: pools, | ||||
|                     }, | ||||
|                 ], | ||||
|                 ZrxTreasuryEvents.ProposalCreated, | ||||
|             ); | ||||
|             await fastForwardToNextEpochAsync(); | ||||
|             await fastForwardToNextEpochAsync(); | ||||
|             await treasury | ||||
|                 .castVote(proposalId, true, VOTER_OPERATED_POOLS) | ||||
|                 .awaitTransactionSuccessAsync({ from: VOTER }); | ||||
|             await env.web3Wrapper.increaseTimeAsync(votingPeriod.plus(1).toNumber()); | ||||
|             await env.web3Wrapper.mineBlockAsync(); | ||||
|             const executeTx = await treasury.execute(proposalId, proposal.actions).awaitTransactionSuccessAsync(); | ||||
|             verifyEventsFromLogs( | ||||
|                 executeTx.logs, | ||||
|                 [ | ||||
|                     { | ||||
|                         proposalId, | ||||
|                     }, | ||||
|                 ], | ||||
|                 ZrxTreasuryEvents.ProposalExecuted, | ||||
|             ); | ||||
|             const recipient = '0xab66cc8fd10457ebc9d13b9760c835f0a4cbc487'; | ||||
|             verifyEventsFromLogs( | ||||
|                 executeTx.logs, | ||||
|                 [ | ||||
|                     { | ||||
|                         _from: TREASURY_ADDRESS, | ||||
|                         _to: recipient, | ||||
|                         _value: new BigNumber(330_813).times('1e18'), | ||||
|                     }, | ||||
|                     { | ||||
|                         _from: TREASURY_ADDRESS, | ||||
|                         _to: recipient, | ||||
|                         _value: new BigNumber(420000).times('1e18'), | ||||
|                     }, | ||||
|                 ], | ||||
|                 ERC20TokenEvents.Transfer, | ||||
|             ); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "4.7.14", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "4.7.13", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v4.7.14 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v4.7.13 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-utils", | ||||
|     "version": "4.7.13", | ||||
|     "version": "4.7.14", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -52,9 +52,9 @@ | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
|         "@0x/types": "^3.3.3", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "version": "0.27.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add `Clipper` as a custom liquidity source" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1628225642 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.26.0", | ||||
|         "changes": [ | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.27.0 - _August 6, 2021_ | ||||
|  | ||||
|     * Add `Clipper` as a custom liquidity source | ||||
|  | ||||
| ## v0.26.0 - _June 22, 2021_ | ||||
|  | ||||
|     * Add Lido stETH deposit integration (#260) | ||||
|   | ||||
| @@ -25,6 +25,7 @@ import "./BridgeProtocols.sol"; | ||||
| import "./mixins/MixinBalancer.sol"; | ||||
| import "./mixins/MixinBalancerV2.sol"; | ||||
| import "./mixins/MixinBancor.sol"; | ||||
| import "./mixins/MixinClipper.sol"; | ||||
| import "./mixins/MixinCoFiX.sol"; | ||||
| import "./mixins/MixinCurve.sol"; | ||||
| import "./mixins/MixinCurveV2.sol"; | ||||
| @@ -50,6 +51,7 @@ contract BridgeAdapter is | ||||
|     MixinBalancer, | ||||
|     MixinBalancerV2, | ||||
|     MixinBancor, | ||||
|     MixinClipper, | ||||
|     MixinCoFiX, | ||||
|     MixinCurve, | ||||
|     MixinCurveV2, | ||||
| @@ -75,6 +77,7 @@ contract BridgeAdapter is | ||||
|         MixinBalancer() | ||||
|         MixinBalancerV2() | ||||
|         MixinBancor(weth) | ||||
|         MixinClipper(weth) | ||||
|         MixinCoFiX() | ||||
|         MixinCurve(weth) | ||||
|         MixinCurveV2() | ||||
| @@ -245,6 +248,13 @@ contract BridgeAdapter is | ||||
|                 sellAmount, | ||||
|                 order.bridgeData | ||||
|             ); | ||||
|         } else if (protocolId == BridgeProtocols.CLIPPER) { | ||||
|             boughtAmount = _tradeClipper( | ||||
|                 sellToken, | ||||
|                 buyToken, | ||||
|                 sellAmount, | ||||
|                 order.bridgeData | ||||
|             ); | ||||
|         } else { | ||||
|             boughtAmount = _tradeZeroExBridge( | ||||
|                 sellToken, | ||||
|   | ||||
| @@ -49,4 +49,5 @@ library BridgeProtocols { | ||||
|     uint128 internal constant KYBERDMM    = 19; | ||||
|     uint128 internal constant CURVEV2     = 20; | ||||
|     uint128 internal constant LIDO        = 21; | ||||
|     uint128 internal constant CLIPPER     = 22; | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,148 @@ | ||||
| // SPDX-License-Identifier: Apache-2.0 | ||||
|  | ||||
| /* | ||||
|  | ||||
|   Copyright 2021 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/contracts/src/v06/LibERC20TokenV06.sol"; | ||||
| import "@0x/contracts-erc20/contracts/src/v06/IERC20TokenV06.sol"; | ||||
| import "@0x/contracts-erc20/contracts/src/v06/IEtherTokenV06.sol"; | ||||
| import "../IBridgeAdapter.sol"; | ||||
| import "../../../vendor/ILiquidityProvider.sol"; | ||||
|  | ||||
| contract MixinClipper { | ||||
|  | ||||
|     using LibERC20TokenV06 for IERC20TokenV06; | ||||
|  | ||||
|     /// @dev Mainnet address of the WETH contract. | ||||
|     IEtherTokenV06 private immutable WETH; | ||||
|  | ||||
|     constructor(IEtherTokenV06 weth) | ||||
|         public | ||||
|     { | ||||
|         WETH = weth; | ||||
|     } | ||||
|  | ||||
|     function _tradeClipper( | ||||
|         IERC20TokenV06 sellToken, | ||||
|         IERC20TokenV06 buyToken, | ||||
|         uint256 sellAmount, | ||||
|         bytes memory bridgeData | ||||
|     ) | ||||
|         internal | ||||
|         returns (uint256 boughtAmount) | ||||
|     { | ||||
|         // We can only use ETH with Clipper, no WETH available | ||||
|         (ILiquidityProvider clipper, bytes memory auxiliaryData) = | ||||
|             abi.decode(bridgeData, (ILiquidityProvider, bytes)); | ||||
|  | ||||
|         if (sellToken == WETH) { | ||||
|             boughtAmount = _executeSellEthForToken( | ||||
|                 clipper, | ||||
|                 buyToken, | ||||
|                 sellAmount, | ||||
|                 auxiliaryData | ||||
|             ); | ||||
|         } else if (buyToken == WETH) { | ||||
|             boughtAmount = _executeSellTokenForEth( | ||||
|                 clipper, | ||||
|                 sellToken, | ||||
|                 sellAmount, | ||||
|                 auxiliaryData | ||||
|             ); | ||||
|         } else { | ||||
|             boughtAmount = _executeSellTokenForToken( | ||||
|                 clipper, | ||||
|                 sellToken, | ||||
|                 buyToken, | ||||
|                 sellAmount, | ||||
|                 auxiliaryData | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return boughtAmount; | ||||
|     } | ||||
|  | ||||
|     function _executeSellEthForToken( | ||||
|         ILiquidityProvider clipper, | ||||
|         IERC20TokenV06 buyToken, | ||||
|         uint256 sellAmount, | ||||
|         bytes memory auxiliaryData | ||||
|     ) | ||||
|         private | ||||
|         returns (uint256 boughtAmount) | ||||
|     { | ||||
|         // Clipper requires ETH and doesn't support WETH | ||||
|         WETH.withdraw(sellAmount); | ||||
|         boughtAmount = clipper.sellEthForToken{ value: sellAmount }( | ||||
|             buyToken, | ||||
|             address(this), | ||||
|             1, | ||||
|             auxiliaryData | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     function _executeSellTokenForEth( | ||||
|         ILiquidityProvider clipper, | ||||
|         IERC20TokenV06 sellToken, | ||||
|         uint256 sellAmount, | ||||
|         bytes memory auxiliaryData | ||||
|     ) | ||||
|         private | ||||
|         returns (uint256 boughtAmount) | ||||
|     { | ||||
|         // Optimization: We can transfer the tokens into clipper rather than | ||||
|         // have an allowance updated | ||||
|         sellToken.compatTransfer(address(clipper), sellAmount); | ||||
|  | ||||
|         boughtAmount = clipper.sellTokenForEth( | ||||
|             sellToken, | ||||
|             payable(address(this)), | ||||
|             1, | ||||
|             auxiliaryData | ||||
|         ); | ||||
|  | ||||
|         // we want WETH for possible future trades | ||||
|         WETH.deposit{ value: boughtAmount }(); | ||||
|     } | ||||
|  | ||||
|     function _executeSellTokenForToken( | ||||
|         ILiquidityProvider clipper, | ||||
|         IERC20TokenV06 sellToken, | ||||
|         IERC20TokenV06 buyToken, | ||||
|         uint256 sellAmount, | ||||
|         bytes memory auxiliaryData | ||||
|     ) | ||||
|         private | ||||
|         returns (uint256 boughtAmount) | ||||
|     { | ||||
|         // Optimization: We can transfer the tokens into clipper rather than | ||||
|         // have an allowance updated | ||||
|         sellToken.compatTransfer(address(clipper), sellAmount); | ||||
|  | ||||
|         boughtAmount = clipper.sellTokenForToken( | ||||
|             sellToken, | ||||
|             buyToken, | ||||
|             address(this), | ||||
|             1, | ||||
|             auxiliaryData | ||||
|         ); | ||||
|     } | ||||
| } | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contracts-zero-ex", | ||||
|     "version": "0.26.0", | ||||
|     "version": "0.27.0", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -43,7 +43,7 @@ | ||||
|     "config": { | ||||
|         "publicInterfaceContracts": "IZeroEx,ZeroEx,FullMigration,InitialMigration,IFlashWallet,IERC20Transformer,IOwnableFeature,ISimpleFunctionRegistryFeature,ITransformERC20Feature,FillQuoteTransformer,PayTakerTransformer,PositiveSlippageFeeTransformer,WethTransformer,OwnableFeature,SimpleFunctionRegistryFeature,TransformERC20Feature,AffiliateFeeTransformer,MetaTransactionsFeature,LogMetadataTransformer,BridgeAdapter,LiquidityProviderFeature,ILiquidityProviderFeature,NativeOrdersFeature,INativeOrdersFeature,FeeCollectorController,FeeCollector,CurveLiquidityProvider,BatchFillNativeOrdersFeature,IBatchFillNativeOrdersFeature,MultiplexFeature,IMultiplexFeature,OtcOrdersFeature,IOtcOrdersFeature", | ||||
|         "abis:comment": "This list is auto-generated by contracts-gen. Don't edit manually.", | ||||
|         "abis": "./test/generated-artifacts/@(AffiliateFeeTransformer|BatchFillNativeOrdersFeature|BootstrapFeature|BridgeAdapter|BridgeProtocols|CurveLiquidityProvider|FeeCollector|FeeCollectorController|FillQuoteTransformer|FixinCommon|FixinEIP712|FixinProtocolFees|FixinReentrancyGuard|FixinTokenSpender|FlashWallet|FullMigration|IBatchFillNativeOrdersFeature|IBootstrapFeature|IBridgeAdapter|IERC20Bridge|IERC20Transformer|IFeature|IFlashWallet|ILiquidityProvider|ILiquidityProviderFeature|ILiquidityProviderSandbox|IMetaTransactionsFeature|IMooniswapPool|IMultiplexFeature|INativeOrdersEvents|INativeOrdersFeature|IOtcOrdersFeature|IOwnableFeature|IPancakeSwapFeature|ISimpleFunctionRegistryFeature|IStaking|ITestSimpleFunctionRegistryFeature|ITokenSpenderFeature|ITransformERC20Feature|IUniswapFeature|IUniswapV2Pair|IUniswapV3Feature|IUniswapV3Pool|IZeroEx|InitialMigration|LibBootstrap|LibCommonRichErrors|LibERC20Transformer|LibFeeCollector|LibLiquidityProviderRichErrors|LibMetaTransactionsRichErrors|LibMetaTransactionsStorage|LibMigrate|LibNativeOrder|LibNativeOrdersRichErrors|LibNativeOrdersStorage|LibOtcOrdersStorage|LibOwnableRichErrors|LibOwnableStorage|LibProxyRichErrors|LibProxyStorage|LibReentrancyGuardStorage|LibSignature|LibSignatureRichErrors|LibSimpleFunctionRegistryRichErrors|LibSimpleFunctionRegistryStorage|LibStorage|LibTransformERC20RichErrors|LibTransformERC20Storage|LibWalletRichErrors|LiquidityProviderFeature|LiquidityProviderSandbox|LogMetadataTransformer|MetaTransactionsFeature|MixinBalancer|MixinBalancerV2|MixinBancor|MixinCoFiX|MixinCryptoCom|MixinCurve|MixinCurveV2|MixinDodo|MixinDodoV2|MixinKyber|MixinKyberDmm|MixinLido|MixinMStable|MixinMakerPSM|MixinMooniswap|MixinNerve|MixinOasis|MixinShell|MixinUniswap|MixinUniswapV2|MixinUniswapV3|MixinZeroExBridge|MooniswapLiquidityProvider|MultiplexFeature|NativeOrdersCancellation|NativeOrdersFeature|NativeOrdersInfo|NativeOrdersProtocolFees|NativeOrdersSettlement|OtcOrdersFeature|OwnableFeature|PancakeSwapFeature|PayTakerTransformer|PermissionlessTransformerDeployer|PositiveSlippageFeeTransformer|SimpleFunctionRegistryFeature|TestBridge|TestCallTarget|TestCurve|TestDelegateCaller|TestFeeCollectorController|TestFillQuoteTransformerBridge|TestFillQuoteTransformerExchange|TestFillQuoteTransformerHost|TestFixinProtocolFees|TestFixinTokenSpender|TestFullMigration|TestInitialMigration|TestLibNativeOrder|TestLibSignature|TestLiquidityProvider|TestMetaTransactionsNativeOrdersFeature|TestMetaTransactionsTransformERC20Feature|TestMigrator|TestMintTokenERC20Transformer|TestMintableERC20Token|TestMooniswap|TestNativeOrdersFeature|TestNoEthRecipient|TestOrderSignerRegistryWithContractWallet|TestPermissionlessTransformerDeployerSuicidal|TestPermissionlessTransformerDeployerTransformer|TestRfqOriginRegistration|TestSimpleFunctionRegistryFeatureImpl1|TestSimpleFunctionRegistryFeatureImpl2|TestStaking|TestTokenSpenderERC20Token|TestTransformERC20|TestTransformerBase|TestTransformerDeployerTransformer|TestTransformerHost|TestUniswapV3Factory|TestUniswapV3Feature|TestUniswapV3Pool|TestWeth|TestWethTransformerHost|TestZeroExFeature|TransformERC20Feature|Transformer|TransformerDeployer|UniswapFeature|UniswapV3Feature|WethTransformer|ZeroEx|ZeroExOptimized).json" | ||||
|         "abis": "./test/generated-artifacts/@(AffiliateFeeTransformer|BatchFillNativeOrdersFeature|BootstrapFeature|BridgeAdapter|BridgeProtocols|CurveLiquidityProvider|FeeCollector|FeeCollectorController|FillQuoteTransformer|FixinCommon|FixinEIP712|FixinProtocolFees|FixinReentrancyGuard|FixinTokenSpender|FlashWallet|FullMigration|IBatchFillNativeOrdersFeature|IBootstrapFeature|IBridgeAdapter|IERC20Bridge|IERC20Transformer|IFeature|IFlashWallet|ILiquidityProvider|ILiquidityProviderFeature|ILiquidityProviderSandbox|IMetaTransactionsFeature|IMooniswapPool|IMultiplexFeature|INativeOrdersEvents|INativeOrdersFeature|IOtcOrdersFeature|IOwnableFeature|IPancakeSwapFeature|ISimpleFunctionRegistryFeature|IStaking|ITestSimpleFunctionRegistryFeature|ITokenSpenderFeature|ITransformERC20Feature|IUniswapFeature|IUniswapV2Pair|IUniswapV3Feature|IUniswapV3Pool|IZeroEx|InitialMigration|LibBootstrap|LibCommonRichErrors|LibERC20Transformer|LibFeeCollector|LibLiquidityProviderRichErrors|LibMetaTransactionsRichErrors|LibMetaTransactionsStorage|LibMigrate|LibNativeOrder|LibNativeOrdersRichErrors|LibNativeOrdersStorage|LibOtcOrdersStorage|LibOwnableRichErrors|LibOwnableStorage|LibProxyRichErrors|LibProxyStorage|LibReentrancyGuardStorage|LibSignature|LibSignatureRichErrors|LibSimpleFunctionRegistryRichErrors|LibSimpleFunctionRegistryStorage|LibStorage|LibTransformERC20RichErrors|LibTransformERC20Storage|LibWalletRichErrors|LiquidityProviderFeature|LiquidityProviderSandbox|LogMetadataTransformer|MetaTransactionsFeature|MixinBalancer|MixinBalancerV2|MixinBancor|MixinClipper|MixinCoFiX|MixinCryptoCom|MixinCurve|MixinCurveV2|MixinDodo|MixinDodoV2|MixinKyber|MixinKyberDmm|MixinLido|MixinMStable|MixinMakerPSM|MixinMooniswap|MixinNerve|MixinOasis|MixinShell|MixinUniswap|MixinUniswapV2|MixinUniswapV3|MixinZeroExBridge|MooniswapLiquidityProvider|MultiplexFeature|NativeOrdersCancellation|NativeOrdersFeature|NativeOrdersInfo|NativeOrdersProtocolFees|NativeOrdersSettlement|OtcOrdersFeature|OwnableFeature|PancakeSwapFeature|PayTakerTransformer|PermissionlessTransformerDeployer|PositiveSlippageFeeTransformer|SimpleFunctionRegistryFeature|TestBridge|TestCallTarget|TestCurve|TestDelegateCaller|TestFeeCollectorController|TestFillQuoteTransformerBridge|TestFillQuoteTransformerExchange|TestFillQuoteTransformerHost|TestFixinProtocolFees|TestFixinTokenSpender|TestFullMigration|TestInitialMigration|TestLibNativeOrder|TestLibSignature|TestLiquidityProvider|TestMetaTransactionsNativeOrdersFeature|TestMetaTransactionsTransformERC20Feature|TestMigrator|TestMintTokenERC20Transformer|TestMintableERC20Token|TestMooniswap|TestNativeOrdersFeature|TestNoEthRecipient|TestOrderSignerRegistryWithContractWallet|TestPermissionlessTransformerDeployerSuicidal|TestPermissionlessTransformerDeployerTransformer|TestRfqOriginRegistration|TestSimpleFunctionRegistryFeatureImpl1|TestSimpleFunctionRegistryFeatureImpl2|TestStaking|TestTokenSpenderERC20Token|TestTransformERC20|TestTransformerBase|TestTransformerDeployerTransformer|TestTransformerHost|TestUniswapV3Factory|TestUniswapV3Feature|TestUniswapV3Pool|TestWeth|TestWethTransformerHost|TestZeroExFeature|TransformERC20Feature|Transformer|TransformerDeployer|UniswapFeature|UniswapV3Feature|WethTransformer|ZeroEx|ZeroExOptimized).json" | ||||
|     }, | ||||
|     "repository": { | ||||
|         "type": "git", | ||||
| @@ -56,12 +56,12 @@ | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/zero-ex", | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
| @@ -83,7 +83,7 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/protocol-utils": "^1.7.2", | ||||
|         "@0x/protocol-utils": "^1.8.0", | ||||
|         "@0x/subproviders": "^6.5.3", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|   | ||||
| @@ -82,6 +82,7 @@ import * as MetaTransactionsFeature from '../test/generated-artifacts/MetaTransa | ||||
| import * as MixinBalancer from '../test/generated-artifacts/MixinBalancer.json'; | ||||
| import * as MixinBalancerV2 from '../test/generated-artifacts/MixinBalancerV2.json'; | ||||
| import * as MixinBancor from '../test/generated-artifacts/MixinBancor.json'; | ||||
| import * as MixinClipper from '../test/generated-artifacts/MixinClipper.json'; | ||||
| import * as MixinCoFiX from '../test/generated-artifacts/MixinCoFiX.json'; | ||||
| import * as MixinCryptoCom from '../test/generated-artifacts/MixinCryptoCom.json'; | ||||
| import * as MixinCurve from '../test/generated-artifacts/MixinCurve.json'; | ||||
| @@ -257,6 +258,7 @@ export const artifacts = { | ||||
|     MixinBalancer: MixinBalancer as ContractArtifact, | ||||
|     MixinBalancerV2: MixinBalancerV2 as ContractArtifact, | ||||
|     MixinBancor: MixinBancor as ContractArtifact, | ||||
|     MixinClipper: MixinClipper as ContractArtifact, | ||||
|     MixinCoFiX: MixinCoFiX as ContractArtifact, | ||||
|     MixinCryptoCom: MixinCryptoCom as ContractArtifact, | ||||
|     MixinCurve: MixinCurve as ContractArtifact, | ||||
|   | ||||
| @@ -80,6 +80,7 @@ export * from '../test/generated-wrappers/meta_transactions_feature'; | ||||
| export * from '../test/generated-wrappers/mixin_balancer'; | ||||
| export * from '../test/generated-wrappers/mixin_balancer_v2'; | ||||
| export * from '../test/generated-wrappers/mixin_bancor'; | ||||
| export * from '../test/generated-wrappers/mixin_clipper'; | ||||
| export * from '../test/generated-wrappers/mixin_co_fi_x'; | ||||
| export * from '../test/generated-wrappers/mixin_crypto_com'; | ||||
| export * from '../test/generated-wrappers/mixin_curve'; | ||||
|   | ||||
| @@ -113,6 +113,7 @@ | ||||
|         "test/generated-artifacts/MixinBalancer.json", | ||||
|         "test/generated-artifacts/MixinBalancerV2.json", | ||||
|         "test/generated-artifacts/MixinBancor.json", | ||||
|         "test/generated-artifacts/MixinClipper.json", | ||||
|         "test/generated-artifacts/MixinCoFiX.json", | ||||
|         "test/generated-artifacts/MixinCryptoCom.json", | ||||
|         "test/generated-artifacts/MixinCurve.json", | ||||
|   | ||||
| @@ -1,4 +1,106 @@ | ||||
| [ | ||||
|     { | ||||
|         "version": "16.24.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add `Clipper` as a custom liquidity source", | ||||
|                 "pr": 299 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `Curve` `Tricrypto2` and `ESD` v2", | ||||
|                 "pr": 302 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1628225642 | ||||
|     }, | ||||
|     { | ||||
|         "version": "16.23.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix fill amount rounding error when covnerting fills to orders.", | ||||
|                 "pr": 296 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1627572227 | ||||
|     }, | ||||
|     { | ||||
|         "version": "16.23.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "ACryptoS", | ||||
|                 "pr": 284 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1626473497 | ||||
|     }, | ||||
|     { | ||||
|         "version": "16.22.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "IronSwap", | ||||
|                 "pr": 281 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1626214787 | ||||
|     }, | ||||
|     { | ||||
|         "version": "16.21.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "JetSwap", | ||||
|                 "pr": 280 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1625904026 | ||||
|     }, | ||||
|     { | ||||
|         "version": "16.20.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "ShibaSwap", | ||||
|                 "pr": 276 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1625607277 | ||||
|     }, | ||||
|     { | ||||
|         "version": "16.19.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix LiquidityProvider fallback", | ||||
|                 "pr": 272 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1625544188 | ||||
|     }, | ||||
|     { | ||||
|         "version": "16.19.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add LiquidityProvider to Polygon sources", | ||||
|                 "pr": 270 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1625190486 | ||||
|     }, | ||||
|     { | ||||
|         "version": "6.18.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Polygon Balance V2" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1624987208 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624562704, | ||||
|         "version": "6.18.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "6.18.1", | ||||
|         "changes": [ | ||||
|   | ||||
| @@ -5,6 +5,47 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v16.24.0 - _August 6, 2021_ | ||||
|  | ||||
|     * Add `Clipper` as a custom liquidity source (#299) | ||||
|     * Added `Curve` `Tricrypto2` and `ESD` v2 (#302) | ||||
|  | ||||
| ## v16.23.1 - _July 29, 2021_ | ||||
|  | ||||
|     * Fix fill amount rounding error when covnerting fills to orders. (#296) | ||||
|  | ||||
| ## v16.23.0 - _July 16, 2021_ | ||||
|  | ||||
|     * ACryptoS (#284) | ||||
|  | ||||
| ## v16.22.0 - _July 13, 2021_ | ||||
|  | ||||
|     * IronSwap (#281) | ||||
|  | ||||
| ## v16.21.0 - _July 10, 2021_ | ||||
|  | ||||
|     * JetSwap (#280) | ||||
|  | ||||
| ## v16.20.0 - _July 6, 2021_ | ||||
|  | ||||
|     * ShibaSwap (#276) | ||||
|  | ||||
| ## v16.19.1 - _July 6, 2021_ | ||||
|  | ||||
|     * Fix LiquidityProvider fallback (#272) | ||||
|  | ||||
| ## v16.19.0 - _July 2, 2021_ | ||||
|  | ||||
|     * Add LiquidityProvider to Polygon sources (#270) | ||||
|  | ||||
| ## v6.18.3 - _June 29, 2021_ | ||||
|  | ||||
|     * Polygon Balance V2 | ||||
|  | ||||
| ## v6.18.2 - _June 24, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v6.18.1 - _June 22, 2021_ | ||||
|  | ||||
|     * FirebirdOneSwap, ApeSwap. New hop tokens: DFYN, BANANA, WEXPOLY (#265) | ||||
|   | ||||
| @@ -20,12 +20,20 @@ | ||||
| pragma solidity ^0.6; | ||||
| pragma experimental ABIEncoderV2; | ||||
|  | ||||
| interface IKyberDmmFactory { | ||||
| interface IKyberDmmPool { | ||||
|  | ||||
|     function getPoolAtIndex(address token0, address token1, uint256 index) | ||||
|     function totalSupply() | ||||
|         external | ||||
|         view | ||||
|         returns (address); | ||||
|         returns (uint256); | ||||
| } | ||||
|  | ||||
| interface IKyberDmmFactory { | ||||
|  | ||||
|     function getPools(address token0, address token1) | ||||
|         external | ||||
|         view | ||||
|         returns (address[] memory _tokenPools); | ||||
| } | ||||
|  | ||||
| interface IKyberDmmRouter { | ||||
| @@ -140,17 +148,26 @@ contract KyberDmmSampler | ||||
|         view | ||||
|         returns (address[] memory pools) | ||||
|     { | ||||
|         pools = new address[](path.length - 1); | ||||
|         IKyberDmmFactory factory = IKyberDmmFactory(IKyberDmmRouter(router).factory()); | ||||
|         pools = new address[](path.length - 1); | ||||
|         for (uint256 i = 0; i < pools.length; i++) { | ||||
|             // Currently only supporting the first pool found at the index | ||||
|             // find the best pool | ||||
|             address[] memory allPools; | ||||
|             try | ||||
|                 factory.getPoolAtIndex | ||||
|                 factory.getPools | ||||
|                     {gas: KYBER_DMM_CALL_GAS} | ||||
|                     (path[i], path[i + 1], 0) | ||||
|                 returns (address pool) | ||||
|                     (path[i], path[i + 1]) | ||||
|                 returns (address[] memory allPools) | ||||
|             { | ||||
|                 pools[i] = pool; | ||||
|                 uint256 maxSupply = 0; | ||||
|                 require(allPools.length >= 1, "KyberDMMSampler/NO_POOLS_FOUND"); | ||||
|                 for (uint256 j = 0; j < allPools.length; j++) { | ||||
|                     uint256 totalSupply = IKyberDmmPool(allPools[j]).totalSupply(); | ||||
|                     if (totalSupply > maxSupply) { | ||||
|                         maxSupply = totalSupply; | ||||
|                         pools[i] = allPools[j]; | ||||
|                     } | ||||
|                 } | ||||
|             } catch (bytes memory) { | ||||
|                 return new address[](0); | ||||
|             } | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/asset-swapper", | ||||
|     "version": "6.18.1", | ||||
|     "version": "16.24.0", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -60,13 +60,13 @@ | ||||
|     "dependencies": { | ||||
|         "@0x/assert": "^3.0.27", | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contract-wrappers": "^13.17.2", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-zero-ex": "^0.26.0", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contract-wrappers": "^13.17.3", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-zero-ex": "^0.27.0", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/json-schemas": "^6.1.3", | ||||
|         "@0x/protocol-utils": "^1.7.2", | ||||
|         "@0x/protocol-utils": "^1.8.0", | ||||
|         "@0x/quote-server": "^6.0.2", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
| @@ -93,14 +93,14 @@ | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0x/abi-gen": "^5.6.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-exchange": "^3.2.35", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.34", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-exchange": "^3.2.36", | ||||
|         "@0x/contracts-exchange-libs": "^4.3.35", | ||||
|         "@0x/contracts-gen": "^2.0.38", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/mesh-rpc-client": "^9.4.2", | ||||
|         "@0x/migrations": "^8.0.11", | ||||
|         "@0x/migrations": "^8.0.12", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/subproviders": "^6.5.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|   | ||||
| @@ -2,6 +2,7 @@ import { ChainId } from '@0x/contract-addresses'; | ||||
| import { BigNumber, NULL_BYTES } from '@0x/utils'; | ||||
|  | ||||
| import { | ||||
|     ACRYPTOS_BSC_INFOS, | ||||
|     APESWAP_ROUTER_BY_CHAIN_ID, | ||||
|     BAKERYSWAP_ROUTER_BY_CHAIN_ID, | ||||
|     BELT_BSC_INFOS, | ||||
| @@ -18,6 +19,8 @@ import { | ||||
|     ELLIPSIS_BSC_INFOS, | ||||
|     FIREBIRDONESWAP_BSC_INFOS, | ||||
|     FIREBIRDONESWAP_POLYGON_INFOS, | ||||
|     IRONSWAP_POLYGON_INFOS, | ||||
|     JETSWAP_ROUTER_BY_CHAIN_ID, | ||||
|     JULSWAP_ROUTER_BY_CHAIN_ID, | ||||
|     KYBER_BANNED_RESERVES, | ||||
|     KYBER_BRIDGED_LIQUIDITY_PREFIX, | ||||
| @@ -32,6 +35,7 @@ import { | ||||
|     QUICKSWAP_ROUTER_BY_CHAIN_ID, | ||||
|     SADDLE_MAINNET_INFOS, | ||||
|     SHELL_POOLS_BY_CHAIN_ID, | ||||
|     SHIBASWAP_ROUTER_BY_CHAIN_ID, | ||||
|     SMOOTHY_BSC_INFOS, | ||||
|     SMOOTHY_MAINNET_INFOS, | ||||
|     SNOWSWAP_MAINNET_INFOS, | ||||
| @@ -284,6 +288,19 @@ export function getSaddleInfosForPair(chainId: ChainId, takerToken: string, make | ||||
|     ); | ||||
| } | ||||
|  | ||||
| export function getIronSwapInfosForPair(chainId: ChainId, takerToken: string, makerToken: string): CurveInfo[] { | ||||
|     if (chainId !== ChainId.Polygon) { | ||||
|         return []; | ||||
|     } | ||||
|     return Object.values(IRONSWAP_POLYGON_INFOS).filter(c => | ||||
|         [makerToken, takerToken].every( | ||||
|             t => | ||||
|                 (c.tokens.includes(t) && c.metaTokens === undefined) || | ||||
|                 (c.tokens.includes(t) && [makerToken, takerToken].filter(v => c.metaTokens?.includes(v)).length > 0), | ||||
|         ), | ||||
|     ); | ||||
| } | ||||
|  | ||||
| export function getXSigmaInfosForPair(chainId: ChainId, takerToken: string, makerToken: string): CurveInfo[] { | ||||
|     if (chainId !== ChainId.Mainnet) { | ||||
|         return []; | ||||
| @@ -297,6 +314,19 @@ export function getXSigmaInfosForPair(chainId: ChainId, takerToken: string, make | ||||
|     ); | ||||
| } | ||||
|  | ||||
| export function getAcryptosInfosForPair(chainId: ChainId, takerToken: string, makerToken: string): CurveInfo[] { | ||||
|     if (chainId !== ChainId.BSC) { | ||||
|         return []; | ||||
|     } | ||||
|     return Object.values(ACRYPTOS_BSC_INFOS).filter(c => | ||||
|         [makerToken, takerToken].every( | ||||
|             t => | ||||
|                 (c.tokens.includes(t) && c.metaTokens === undefined) || | ||||
|                 (c.tokens.includes(t) && [makerToken, takerToken].filter(v => c.metaTokens?.includes(v)).length > 0), | ||||
|         ), | ||||
|     ); | ||||
| } | ||||
|  | ||||
| export function getShellLikeInfosForPair( | ||||
|     chainId: ChainId, | ||||
|     takerToken: string, | ||||
| @@ -334,8 +364,10 @@ export function getCurveLikeInfosForPair( | ||||
|         | ERC20BridgeSource.Ellipsis | ||||
|         | ERC20BridgeSource.Smoothy | ||||
|         | ERC20BridgeSource.Saddle | ||||
|         | ERC20BridgeSource.IronSwap | ||||
|         | ERC20BridgeSource.XSigma | ||||
|         | ERC20BridgeSource.FirebirdOneSwap, | ||||
|         | ERC20BridgeSource.FirebirdOneSwap | ||||
|         | ERC20BridgeSource.ACryptos, | ||||
| ): CurveDetailedInfo[] { | ||||
|     let pools: CurveInfo[] = []; | ||||
|     switch (source) { | ||||
| @@ -372,6 +404,12 @@ export function getCurveLikeInfosForPair( | ||||
|         case ERC20BridgeSource.FirebirdOneSwap: | ||||
|             pools = getFirebirdOneSwapInfosForPair(chainId, takerToken, makerToken); | ||||
|             break; | ||||
|         case ERC20BridgeSource.IronSwap: | ||||
|             pools = getIronSwapInfosForPair(chainId, takerToken, makerToken); | ||||
|             break; | ||||
|         case ERC20BridgeSource.ACryptos: | ||||
|             pools = getAcryptosInfosForPair(chainId, takerToken, makerToken); | ||||
|             break; | ||||
|         default: | ||||
|             throw new Error(`Unknown Curve like source ${source}`); | ||||
|     } | ||||
| @@ -399,7 +437,9 @@ export function uniswapV2LikeRouterAddress( | ||||
|         | ERC20BridgeSource.ComethSwap | ||||
|         | ERC20BridgeSource.Dfyn | ||||
|         | ERC20BridgeSource.WaultSwap | ||||
|         | ERC20BridgeSource.Polydex, | ||||
|         | ERC20BridgeSource.Polydex | ||||
|         | ERC20BridgeSource.ShibaSwap | ||||
|         | ERC20BridgeSource.JetSwap, | ||||
| ): string { | ||||
|     switch (source) { | ||||
|         case ERC20BridgeSource.UniswapV2: | ||||
| @@ -432,6 +472,10 @@ export function uniswapV2LikeRouterAddress( | ||||
|             return WAULTSWAP_ROUTER_BY_CHAIN_ID[chainId]; | ||||
|         case ERC20BridgeSource.Polydex: | ||||
|             return POLYDEX_ROUTER_BY_CHAIN_ID[chainId]; | ||||
|         case ERC20BridgeSource.ShibaSwap: | ||||
|             return SHIBASWAP_ROUTER_BY_CHAIN_ID[chainId]; | ||||
|         case ERC20BridgeSource.JetSwap: | ||||
|             return JETSWAP_ROUTER_BY_CHAIN_ID[chainId]; | ||||
|         default: | ||||
|             throw new Error(`Unknown UniswapV2 like source ${source}`); | ||||
|     } | ||||
|   | ||||
| @@ -97,6 +97,8 @@ export const SELL_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | ||||
|             ERC20BridgeSource.XSigma, | ||||
|             ERC20BridgeSource.UniswapV3, | ||||
|             ERC20BridgeSource.CurveV2, | ||||
|             ERC20BridgeSource.ShibaSwap, | ||||
|             ERC20BridgeSource.Clipper, | ||||
|         ]), | ||||
|         [ChainId.Ropsten]: new SourceFilters([ | ||||
|             ERC20BridgeSource.Kyber, | ||||
| @@ -131,6 +133,8 @@ export const SELL_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | ||||
|             ERC20BridgeSource.LiquidityProvider, | ||||
|             ERC20BridgeSource.WaultSwap, | ||||
|             ERC20BridgeSource.FirebirdOneSwap, | ||||
|             ERC20BridgeSource.JetSwap, | ||||
|             ERC20BridgeSource.ACryptos, | ||||
|         ]), | ||||
|         [ChainId.Polygon]: new SourceFilters([ | ||||
|             ERC20BridgeSource.SushiSwap, | ||||
| @@ -146,6 +150,12 @@ export const SELL_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | ||||
|             ERC20BridgeSource.Polydex, | ||||
|             ERC20BridgeSource.ApeSwap, | ||||
|             ERC20BridgeSource.FirebirdOneSwap, | ||||
|             ERC20BridgeSource.BalancerV2, | ||||
|             ERC20BridgeSource.KyberDmm, | ||||
|             ERC20BridgeSource.LiquidityProvider, | ||||
|             ERC20BridgeSource.MultiHop, | ||||
|             ERC20BridgeSource.JetSwap, | ||||
|             ERC20BridgeSource.IronSwap, | ||||
|         ]), | ||||
|     }, | ||||
|     new SourceFilters([]), | ||||
| @@ -188,6 +198,8 @@ export const BUY_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | ||||
|             ERC20BridgeSource.XSigma, | ||||
|             ERC20BridgeSource.UniswapV3, | ||||
|             ERC20BridgeSource.CurveV2, | ||||
|             ERC20BridgeSource.ShibaSwap, | ||||
|             ERC20BridgeSource.Clipper, | ||||
|         ]), | ||||
|         [ChainId.Ropsten]: new SourceFilters([ | ||||
|             ERC20BridgeSource.Kyber, | ||||
| @@ -222,6 +234,8 @@ export const BUY_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | ||||
|             ERC20BridgeSource.LiquidityProvider, | ||||
|             ERC20BridgeSource.WaultSwap, | ||||
|             ERC20BridgeSource.FirebirdOneSwap, | ||||
|             ERC20BridgeSource.JetSwap, | ||||
|             ERC20BridgeSource.ACryptos, | ||||
|         ]), | ||||
|         [ChainId.Polygon]: new SourceFilters([ | ||||
|             ERC20BridgeSource.SushiSwap, | ||||
| @@ -237,6 +251,12 @@ export const BUY_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | ||||
|             ERC20BridgeSource.Polydex, | ||||
|             ERC20BridgeSource.ApeSwap, | ||||
|             ERC20BridgeSource.FirebirdOneSwap, | ||||
|             ERC20BridgeSource.BalancerV2, | ||||
|             ERC20BridgeSource.KyberDmm, | ||||
|             ERC20BridgeSource.LiquidityProvider, | ||||
|             ERC20BridgeSource.MultiHop, | ||||
|             ERC20BridgeSource.JetSwap, | ||||
|             ERC20BridgeSource.IronSwap, | ||||
|         ]), | ||||
|     }, | ||||
|     new SourceFilters([]), | ||||
| @@ -262,13 +282,13 @@ export const FEE_QUOTE_SOURCES_BY_CHAIN_ID = valueByChainId<ERC20BridgeSource[]> | ||||
|  | ||||
| // HACK(mzhu25): Limit and RFQ orders need to be treated as different sources | ||||
| //               when computing the exchange proxy gas overhead. | ||||
| export const SOURCE_FLAGS: { [key in ERC20BridgeSource]: number } & { | ||||
|     RfqOrder: number; | ||||
|     LimitOrder: number; | ||||
| export const SOURCE_FLAGS: { [key in ERC20BridgeSource]: bigint } & { | ||||
|     RfqOrder: bigint; | ||||
|     LimitOrder: bigint; | ||||
| } = Object.assign( | ||||
|     {}, | ||||
|     ...['RfqOrder', 'LimitOrder', ...Object.values(ERC20BridgeSource)].map((source, index) => ({ | ||||
|         [source]: source === ERC20BridgeSource.Native ? 0 : 1 << index, | ||||
|         [source]: source === ERC20BridgeSource.Native ? BigInt(0) : BigInt(1) << BigInt(index), | ||||
|     })), | ||||
| ); | ||||
|  | ||||
| @@ -343,6 +363,7 @@ export const MAINNET_TOKENS = { | ||||
|     crETH: '0xcbc1065255cbc3ab41a6868c22d1f1c573ab89fd', | ||||
|     ankrETH: '0xe95a203b1a91a908f9b9ce46459d101078c2c3cb', | ||||
|     vETH: '0x898bad2774eb97cf6b94605677f43b41871410b1', | ||||
|     alETH: '0x0100546f2cd4c9d97f798ffc9755e47865ff7ee6', | ||||
|     HT: '0x6f259637dcD74C767781E37Bc6133cd6A68aa161', | ||||
|     // Mirror Protocol | ||||
|     UST: '0xa47c8bf37f92abed4a126bda807a7b7498661acd', | ||||
| @@ -353,6 +374,9 @@ export const MAINNET_TOKENS = { | ||||
|     alUSD: '0xbc6da0fe9ad5f3b0d58160288917aa56653660e9', | ||||
|     FRAX: '0x853d955acef822db058eb8505911ed77f175b99e', | ||||
|     LUSD: '0x5f98805a4e8be255a32880fdec7f6728c6568ba0', | ||||
|     FEI: '0x956f47f50a910163d8bf957cf5846d573e7f87ca', | ||||
|     DSU: '0x605d26fbd5be761089281d5cec2ce86eea667109', | ||||
|     ESS: '0x24ae124c4cc33d6791f8e8b63520ed7107ac8b3e', | ||||
| }; | ||||
|  | ||||
| export const BSC_TOKENS = { | ||||
| @@ -363,8 +387,12 @@ export const BSC_TOKENS = { | ||||
|     DAI: '0x1af3f329e8be154074d8769d1ffa4ee058b1dbc3', | ||||
|     PAX: '0xb7f8cd00c5a06c0537e2abff0b58033d02e5e094', | ||||
|     UST: '0x23396cf899ca06c4472205fc903bdb4de249d6fc', | ||||
|     VAI: '0x4bd17003473389a42daf6a0a729f6fdb328bbbd7', | ||||
|     WEX: '0xa9c41a46a6b3531d28d5c32f6633dd2ff05dfb90', | ||||
|     WETH: '0x2170ed0880ac9a755fd29b2688956bd959f933f8', | ||||
|     BTCB: '0x7130d2a12b9bcbfae4f2634d864a1ee1ce3ead9c', | ||||
|     renBTC: '0xfce146bf3146100cfe5db4129cf6c82b0ef4ad8c', | ||||
|     pBTC: '0xed28a457a5a76596ac48d87c0f577020f6ea1c4c', | ||||
| }; | ||||
|  | ||||
| export const POLYGON_TOKENS = { | ||||
| @@ -424,10 +452,12 @@ export const CURVE_POOLS = { | ||||
|     FRAX: '0xd632f22692fac7611d2aa1c0d552930d43caed3b', | ||||
|     LUSD: '0xed279fdd11ca84beef15af5d39bb4d4bee23f0ca', | ||||
|     BUSD: '0x4807862aa8b2bf68830e4c8dc86d0e9a998e085a', | ||||
|     DSU3CRV: '0x6ec80df362d7042c50d4469bcfbc174c9dd9109a', | ||||
| }; | ||||
|  | ||||
| export const CURVE_V2_POOLS = { | ||||
|     tricrypto: '0x80466c64868e1ab14a1ddf27a676c3fcbe638fe5', | ||||
|     tricrypto2: '0xd51a44d3fae010294c616388b506acda1bfaae46', | ||||
| }; | ||||
|  | ||||
| export const CURVE_POLYGON_POOLS = { | ||||
| @@ -461,6 +491,12 @@ export const SMOOTHY_POOLS = { | ||||
| export const SADDLE_POOLS = { | ||||
|     stables: '0x3911f80530595fbd01ab1516ab61255d75aeb066', | ||||
|     bitcoins: '0x4f6a43ad7cba042606decaca730d4ce0a57ac62e', | ||||
|     alETH: '0xa6018520eaacc06c30ff2e1b3ee2c7c22e64196a', | ||||
|     d4: '0xc69ddcd4dfef25d8a793241834d4cc4b3668ead6', | ||||
| }; | ||||
|  | ||||
| export const IRONSWAP_POOLS = { | ||||
|     is3usd: '0x837503e8a8753ae17fb8c8151b8e6f586defcb57', | ||||
| }; | ||||
|  | ||||
| export const NERVE_POOLS = { | ||||
| @@ -487,6 +523,13 @@ export const FIREBIRDONESWAP_POLYGON_POOLS = { | ||||
|     oneswap: '0x01c9475dbd36e46d1961572c8de24b74616bae9e', | ||||
| }; | ||||
|  | ||||
| export const ACRYPTOS_POOLS = { | ||||
|     acs4usd: '0xb3f0c9ea1f05e312093fdb031e789a756659b0ac', | ||||
|     acs4vai: '0x191409d5a4effe25b0f4240557ba2192d18a191e', | ||||
|     acs4ust: '0x99c92765efc472a9709ced86310d64c4573c4b77', | ||||
|     acs3btc: '0xbe7caa236544d1b9a0e7f91e94b9f5bfd3b5ca81', | ||||
| }; | ||||
|  | ||||
| export const DEFAULT_INTERMEDIATE_TOKENS_BY_CHAIN_ID = valueByChainId<string[]>( | ||||
|     { | ||||
|         [ChainId.Mainnet]: [ | ||||
| @@ -517,10 +560,6 @@ export const DEFAULT_INTERMEDIATE_TOKENS_BY_CHAIN_ID = valueByChainId<string[]>( | ||||
|             POLYGON_TOKENS.DAI, | ||||
|             POLYGON_TOKENS.USDT, | ||||
|             POLYGON_TOKENS.WBTC, | ||||
|             POLYGON_TOKENS.QUICK, | ||||
|             POLYGON_TOKENS.DFYN, | ||||
|             POLYGON_TOKENS.BANANA, | ||||
|             POLYGON_TOKENS.WEXPOLY, | ||||
|         ], | ||||
|     }, | ||||
|     [], | ||||
| @@ -814,6 +853,11 @@ export const CURVE_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||
|         pool: CURVE_POOLS.ankreth, | ||||
|         gasSchedule: 125e3, | ||||
|     }), | ||||
|     [CURVE_POOLS.DSU3CRV]: createCurveMetaTriPool({ | ||||
|         tokens: [MAINNET_TOKENS.DSU], | ||||
|         pool: CURVE_POOLS.DSU3CRV, | ||||
|         gasSchedule: 387e3, | ||||
|     }), | ||||
| }; | ||||
|  | ||||
| export const CURVE_V2_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||
| @@ -822,6 +866,11 @@ export const CURVE_V2_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||
|         pool: CURVE_V2_POOLS.tricrypto, | ||||
|         gasSchedule: 300e3, | ||||
|     }), | ||||
|     [CURVE_V2_POOLS.tricrypto2]: createCurveExchangeV2Pool({ | ||||
|         tokens: [MAINNET_TOKENS.USDT, MAINNET_TOKENS.WBTC, MAINNET_TOKENS.WETH], | ||||
|         pool: CURVE_V2_POOLS.tricrypto2, | ||||
|         gasSchedule: 300e3, | ||||
|     }), | ||||
| }; | ||||
|  | ||||
| export const CURVE_POLYGON_INFOS: { [name: string]: CurveInfo } = { | ||||
| @@ -926,6 +975,36 @@ export const SADDLE_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||
|         metaTokens: undefined, | ||||
|         gasSchedule: 150e3, | ||||
|     }, | ||||
|     [SADDLE_POOLS.alETH]: { | ||||
|         exchangeFunctionSelector: CurveFunctionSelectors.swap, | ||||
|         sellQuoteFunctionSelector: CurveFunctionSelectors.calculateSwap, | ||||
|         buyQuoteFunctionSelector: CurveFunctionSelectors.None, | ||||
|         poolAddress: SADDLE_POOLS.alETH, | ||||
|         tokens: [MAINNET_TOKENS.WETH, MAINNET_TOKENS.alETH, MAINNET_TOKENS.sETH], | ||||
|         metaTokens: undefined, | ||||
|         gasSchedule: 200e3, | ||||
|     }, | ||||
|     [SADDLE_POOLS.d4]: { | ||||
|         exchangeFunctionSelector: CurveFunctionSelectors.swap, | ||||
|         sellQuoteFunctionSelector: CurveFunctionSelectors.calculateSwap, | ||||
|         buyQuoteFunctionSelector: CurveFunctionSelectors.None, | ||||
|         poolAddress: SADDLE_POOLS.d4, | ||||
|         tokens: [MAINNET_TOKENS.alUSD, MAINNET_TOKENS.FEI, MAINNET_TOKENS.FRAX, MAINNET_TOKENS.LUSD], | ||||
|         metaTokens: undefined, | ||||
|         gasSchedule: 150e3, | ||||
|     }, | ||||
| }; | ||||
|  | ||||
| export const IRONSWAP_POLYGON_INFOS: { [name: string]: CurveInfo } = { | ||||
|     [IRONSWAP_POOLS.is3usd]: { | ||||
|         exchangeFunctionSelector: CurveFunctionSelectors.swap, | ||||
|         sellQuoteFunctionSelector: CurveFunctionSelectors.calculateSwap, | ||||
|         buyQuoteFunctionSelector: CurveFunctionSelectors.None, | ||||
|         poolAddress: IRONSWAP_POOLS.is3usd, | ||||
|         tokens: [POLYGON_TOKENS.USDC, POLYGON_TOKENS.USDT, POLYGON_TOKENS.DAI], | ||||
|         metaTokens: undefined, | ||||
|         gasSchedule: 150e3, | ||||
|     }, | ||||
| }; | ||||
|  | ||||
| export const SMOOTHY_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||
| @@ -997,6 +1076,44 @@ export const FIREBIRDONESWAP_POLYGON_INFOS: { [name: string]: CurveInfo } = { | ||||
|     }, | ||||
| }; | ||||
|  | ||||
| const ACRYPTOS_ACS4USD_POOL_BSC_TOKENS = [BSC_TOKENS.BUSD, BSC_TOKENS.USDT, BSC_TOKENS.DAI, BSC_TOKENS.USDC]; | ||||
|  | ||||
| const createAcryptosMetaUsdPool = (info: { tokens: string[]; pool: string; gasSchedule: number }) => ({ | ||||
|     exchangeFunctionSelector: CurveFunctionSelectors.exchange_underlying, | ||||
|     sellQuoteFunctionSelector: CurveFunctionSelectors.get_dy_underlying, | ||||
|     buyQuoteFunctionSelector: CurveFunctionSelectors.None, | ||||
|     tokens: [...info.tokens, ...ACRYPTOS_ACS4USD_POOL_BSC_TOKENS], | ||||
|     metaTokens: info.tokens, | ||||
|     poolAddress: info.pool, | ||||
|     gasSchedule: info.gasSchedule, | ||||
| }); | ||||
|  | ||||
| export const ACRYPTOS_BSC_INFOS: { [name: string]: CurveInfo } = { | ||||
|     [ACRYPTOS_POOLS.acs4usd]: createCurveExchangePool({ | ||||
|         tokens: ACRYPTOS_ACS4USD_POOL_BSC_TOKENS, | ||||
|         pool: ACRYPTOS_POOLS.acs4usd, | ||||
|         gasSchedule: 145e3, | ||||
|     }), | ||||
|  | ||||
|     [ACRYPTOS_POOLS.acs4vai]: createAcryptosMetaUsdPool({ | ||||
|         tokens: [BSC_TOKENS.VAI], | ||||
|         pool: ACRYPTOS_POOLS.acs4vai, | ||||
|         gasSchedule: 300e3, | ||||
|     }), | ||||
|  | ||||
|     [ACRYPTOS_POOLS.acs4ust]: createAcryptosMetaUsdPool({ | ||||
|         tokens: [BSC_TOKENS.UST], | ||||
|         pool: ACRYPTOS_POOLS.acs4ust, | ||||
|         gasSchedule: 300e3, | ||||
|     }), | ||||
|  | ||||
|     [ACRYPTOS_POOLS.acs3btc]: createCurveExchangePool({ | ||||
|         tokens: [BSC_TOKENS.BTCB, BSC_TOKENS.renBTC, BSC_TOKENS.pBTC], | ||||
|         pool: ACRYPTOS_POOLS.acs3btc, | ||||
|         gasSchedule: 145e3, | ||||
|     }), | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Kyber reserve prefixes | ||||
|  * 0xff Fed price reserve | ||||
| @@ -1090,6 +1207,13 @@ export const LINKSWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||
|     NULL_ADDRESS, | ||||
| ); | ||||
|  | ||||
| export const SHIBASWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||
|     { | ||||
|         [ChainId.Mainnet]: '0x03f7724180aa6b939894b5ca4314783b0b36b329', | ||||
|     }, | ||||
|     NULL_ADDRESS, | ||||
| ); | ||||
|  | ||||
| export const MSTABLE_POOLS_BY_CHAIN_ID = valueByChainId( | ||||
|     { | ||||
|         [ChainId.Mainnet]: { | ||||
| @@ -1135,6 +1259,7 @@ export const OASIS_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||
| export const KYBER_DMM_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||
|     { | ||||
|         [ChainId.Mainnet]: '0x1c87257f5e8609940bc751a07bb085bb7f8cdbe6', | ||||
|         [ChainId.Polygon]: '0x546c79662e028b661dfb4767664d0273184e4dd1', | ||||
|     }, | ||||
|     NULL_ADDRESS, | ||||
| ); | ||||
| @@ -1283,6 +1408,7 @@ export const COMPONENT_POOLS_BY_CHAIN_ID = valueByChainId( | ||||
| export const BALANCER_V2_VAULT_ADDRESS_BY_CHAIN = valueByChainId<string>( | ||||
|     { | ||||
|         [ChainId.Mainnet]: '0xba12222222228d8ba445958a75a0704d566bf2c8', | ||||
|         [ChainId.Polygon]: '0xba12222222228d8ba445958a75a0704d566bf2c8', | ||||
|     }, | ||||
|     NULL_ADDRESS, | ||||
| ); | ||||
| @@ -1300,10 +1426,32 @@ export const LIDO_INFO_BY_CHAIN = valueByChainId<LidoInfo>( | ||||
|     }, | ||||
| ); | ||||
|  | ||||
| export const CLIPPER_INFO_BY_CHAIN = valueByChainId( | ||||
|     { | ||||
|         [ChainId.Mainnet]: { | ||||
|             poolAddress: '0xe82906b6b1b04f631d126c974af57a3a7b6a99d9', | ||||
|             tokens: [ | ||||
|                 MAINNET_TOKENS.WETH, // technically ETH but our sampler and mixin handle this | ||||
|                 MAINNET_TOKENS.WBTC, | ||||
|                 MAINNET_TOKENS.USDC, | ||||
|                 MAINNET_TOKENS.USDT, | ||||
|                 MAINNET_TOKENS.DAI, | ||||
|             ], | ||||
|         }, | ||||
|     }, | ||||
|     { poolAddress: NULL_ADDRESS, tokens: [] }, | ||||
| ); | ||||
|  | ||||
| export const BALANCER_SUBGRAPH_URL = 'https://api.thegraph.com/subgraphs/name/balancer-labs/balancer'; | ||||
| export const BALANCER_TOP_POOLS_FETCHED = 250; | ||||
| export const BALANCER_MAX_POOLS_FETCHED = 3; | ||||
| export const BALANCER_V2_SUBGRAPH_URL = 'https://api.thegraph.com/subgraphs/name/balancer-labs/balancer-v2'; | ||||
|  | ||||
| export const BALANCER_V2_SUBGRAPH_URL_BY_CHAIN = valueByChainId<string>( | ||||
|     { | ||||
|         [ChainId.Polygon]: 'https://api.thegraph.com/subgraphs/name/balancer-labs/balancer-polygon-v2', | ||||
|     }, | ||||
|     'https://api.thegraph.com/subgraphs/name/balancer-labs/balancer-v2', | ||||
| ); | ||||
|  | ||||
| export const UNISWAPV3_CONFIG_BY_CHAIN_ID = valueByChainId( | ||||
|     { | ||||
| @@ -1411,6 +1559,14 @@ export const POLYDEX_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||
|     NULL_ADDRESS, | ||||
| ); | ||||
|  | ||||
| export const JETSWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||
|     { | ||||
|         [ChainId.BSC]: '0xbe65b8f75b9f20f4c522e0067a3887fada714800', | ||||
|         [ChainId.Polygon]: '0x5c6ec38fb0e2609672bdf628b1fd605a523e5923', | ||||
|     }, | ||||
|     NULL_ADDRESS, | ||||
| ); | ||||
|  | ||||
| const uniswapV2CloneGasSchedule = (fillData?: FillData) => { | ||||
|     // TODO: Different base cost if to/from ETH. | ||||
|     let gas = 90e3; | ||||
| @@ -1453,6 +1609,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | ||||
|     [ERC20BridgeSource.Ellipsis]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||
|     [ERC20BridgeSource.Smoothy]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||
|     [ERC20BridgeSource.Saddle]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||
|     [ERC20BridgeSource.IronSwap]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||
|     [ERC20BridgeSource.XSigma]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||
|     [ERC20BridgeSource.FirebirdOneSwap]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||
|     [ERC20BridgeSource.MultiBridge]: () => 350e3, | ||||
| @@ -1460,6 +1617,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | ||||
|     [ERC20BridgeSource.SushiSwap]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.CryptoCom]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.Linkswap]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.ShibaSwap]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.Balancer]: () => 120e3, | ||||
|     [ERC20BridgeSource.BalancerV2]: () => 100e3, | ||||
|     [ERC20BridgeSource.Cream]: () => 120e3, | ||||
| @@ -1514,6 +1672,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | ||||
|         return gas; | ||||
|     }, | ||||
|     [ERC20BridgeSource.Lido]: () => 226e3, | ||||
|     [ERC20BridgeSource.Clipper]: () => 170e3, | ||||
|  | ||||
|     // | ||||
|     // BSC | ||||
| @@ -1526,6 +1685,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | ||||
|     [ERC20BridgeSource.CheeseSwap]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.JulSwap]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.WaultSwap]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.ACryptos]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||
|  | ||||
|     // | ||||
|     // Polygon | ||||
| @@ -1534,6 +1694,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | ||||
|     [ERC20BridgeSource.ComethSwap]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.Dfyn]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.Polydex]: uniswapV2CloneGasSchedule, | ||||
|     [ERC20BridgeSource.JetSwap]: uniswapV2CloneGasSchedule, | ||||
| }; | ||||
|  | ||||
| export const DEFAULT_FEE_SCHEDULE: Required<FeeSchedule> = { ...DEFAULT_GAS_SCHEDULE }; | ||||
|   | ||||
| @@ -523,7 +523,7 @@ export class MarketOperationUtils { | ||||
|             const sturdyFills = fills.filter(p => p.length > 0 && !fragileSources.includes(p[0].source)); | ||||
|             const sturdyOptimalPath = await findOptimalPathAsync(side, sturdyFills, inputAmount, opts.runLimit, { | ||||
|                 ...penaltyOpts, | ||||
|                 exchangeProxyOverhead: (sourceFlags: number) => | ||||
|                 exchangeProxyOverhead: (sourceFlags: bigint) => | ||||
|                     // tslint:disable-next-line: no-bitwise | ||||
|                     penaltyOpts.exchangeProxyOverhead(sourceFlags | optimalPath.sourceFlags), | ||||
|             }); | ||||
|   | ||||
| @@ -3,7 +3,7 @@ import { AbiEncoder, BigNumber } from '@0x/utils'; | ||||
|  | ||||
| import { AssetSwapperContractAddresses, MarketOperation } from '../../types'; | ||||
|  | ||||
| import { MAX_UINT256, ZERO_AMOUNT } from './constants'; | ||||
| import { MAX_UINT256, NULL_BYTES, ZERO_AMOUNT } from './constants'; | ||||
| import { | ||||
|     AggregationError, | ||||
|     BalancerFillData, | ||||
| @@ -172,6 +172,16 @@ export function getErc20BridgeSourceToBridgeSource(source: ERC20BridgeSource): s | ||||
|             return encodeBridgeSourceId(BridgeProtocol.Nerve, 'FirebirdOneSwap'); | ||||
|         case ERC20BridgeSource.Lido: | ||||
|             return encodeBridgeSourceId(BridgeProtocol.Lido, 'Lido'); | ||||
|         case ERC20BridgeSource.ShibaSwap: | ||||
|             return encodeBridgeSourceId(BridgeProtocol.UniswapV2, 'ShibaSwap'); | ||||
|         case ERC20BridgeSource.JetSwap: | ||||
|             return encodeBridgeSourceId(BridgeProtocol.UniswapV2, 'JetSwap'); | ||||
|         case ERC20BridgeSource.IronSwap: | ||||
|             return encodeBridgeSourceId(BridgeProtocol.Nerve, 'IronSwap'); | ||||
|         case ERC20BridgeSource.ACryptos: | ||||
|             return encodeBridgeSourceId(BridgeProtocol.Curve, 'ACryptoS'); | ||||
|         case ERC20BridgeSource.Clipper: | ||||
|             return encodeBridgeSourceId(BridgeProtocol.Clipper, 'Clipper'); | ||||
|         default: | ||||
|             throw new Error(AggregationError.NoBridgeForSource); | ||||
|     } | ||||
| @@ -204,6 +214,8 @@ export function createBridgeDataForBridgeOrder(order: OptimizedMarketBridgeOrder | ||||
|         case ERC20BridgeSource.Saddle: | ||||
|         case ERC20BridgeSource.XSigma: | ||||
|         case ERC20BridgeSource.FirebirdOneSwap: | ||||
|         case ERC20BridgeSource.IronSwap: | ||||
|         case ERC20BridgeSource.ACryptos: | ||||
|             const curveFillData = (order as OptimizedMarketBridgeOrder<CurveFillData>).fillData; | ||||
|             bridgeData = encoder.encode([ | ||||
|                 curveFillData.pool.poolAddress, | ||||
| @@ -242,6 +254,8 @@ export function createBridgeDataForBridgeOrder(order: OptimizedMarketBridgeOrder | ||||
|         case ERC20BridgeSource.Dfyn: | ||||
|         case ERC20BridgeSource.WaultSwap: | ||||
|         case ERC20BridgeSource.Polydex: | ||||
|         case ERC20BridgeSource.ShibaSwap: | ||||
|         case ERC20BridgeSource.JetSwap: | ||||
|             const uniswapV2FillData = (order as OptimizedMarketBridgeOrder<UniswapV2FillData>).fillData; | ||||
|             bridgeData = encoder.encode([uniswapV2FillData.router, uniswapV2FillData.tokenAddressPath]); | ||||
|             break; | ||||
| @@ -306,6 +320,10 @@ export function createBridgeDataForBridgeOrder(order: OptimizedMarketBridgeOrder | ||||
|             const lidoFillData = (order as OptimizedMarketBridgeOrder<LidoFillData>).fillData; | ||||
|             bridgeData = encoder.encode([lidoFillData.stEthTokenAddress]); | ||||
|             break; | ||||
|         case ERC20BridgeSource.Clipper: | ||||
|             const clipperFillData = (order as OptimizedMarketBridgeOrder<LiquidityProviderFillData>).fillData; | ||||
|             bridgeData = encoder.encode([clipperFillData.poolAddress, NULL_BYTES]); | ||||
|             break; | ||||
|         default: | ||||
|             throw new Error(AggregationError.NoBridgeForSource); | ||||
|     } | ||||
| @@ -421,12 +439,15 @@ export const BRIDGE_ENCODERS: { | ||||
|     [ERC20BridgeSource.Saddle]: curveEncoder, | ||||
|     [ERC20BridgeSource.XSigma]: curveEncoder, | ||||
|     [ERC20BridgeSource.FirebirdOneSwap]: curveEncoder, | ||||
|     [ERC20BridgeSource.IronSwap]: curveEncoder, | ||||
|     [ERC20BridgeSource.ACryptos]: curveEncoder, | ||||
|     // UniswapV2 like, (router, address[]) | ||||
|     [ERC20BridgeSource.Bancor]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.UniswapV2]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.SushiSwap]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.CryptoCom]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.Linkswap]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.ShibaSwap]: routerAddressPathEncoder, | ||||
|     // BSC | ||||
|     [ERC20BridgeSource.PancakeSwap]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.PancakeSwapV2]: routerAddressPathEncoder, | ||||
| @@ -441,6 +462,7 @@ export const BRIDGE_ENCODERS: { | ||||
|     [ERC20BridgeSource.ComethSwap]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.Dfyn]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.Polydex]: routerAddressPathEncoder, | ||||
|     [ERC20BridgeSource.JetSwap]: routerAddressPathEncoder, | ||||
|     // Generic pools | ||||
|     [ERC20BridgeSource.Shell]: poolEncoder, | ||||
|     [ERC20BridgeSource.Component]: poolEncoder, | ||||
| @@ -459,14 +481,18 @@ export const BRIDGE_ENCODERS: { | ||||
|     ]), | ||||
|     [ERC20BridgeSource.KyberDmm]: AbiEncoder.create('(address,address[],address[])'), | ||||
|     [ERC20BridgeSource.Lido]: AbiEncoder.create('(address)'), | ||||
|     [ERC20BridgeSource.Clipper]: AbiEncoder.create([ | ||||
|         { name: 'provider', type: 'address' }, | ||||
|         { name: 'data', type: 'bytes' }, | ||||
|     ]), | ||||
| }; | ||||
|  | ||||
| function getFillTokenAmounts(fill: CollapsedFill, side: MarketOperation): [BigNumber, BigNumber] { | ||||
|     return [ | ||||
|         // Maker asset amount. | ||||
|         side === MarketOperation.Sell ? fill.output : fill.input, | ||||
|         side === MarketOperation.Sell ? fill.output.integerValue(BigNumber.ROUND_DOWN) : fill.input, | ||||
|         // Taker asset amount. | ||||
|         side === MarketOperation.Sell ? fill.input : fill.output, | ||||
|         side === MarketOperation.Sell ? fill.input : fill.output.integerValue(BigNumber.ROUND_UP), | ||||
|     ]; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -36,7 +36,7 @@ export const DEFAULT_PATH_PENALTY_OPTS: PathPenaltyOpts = { | ||||
| export class Path { | ||||
|     public collapsedFills?: ReadonlyArray<CollapsedFill>; | ||||
|     public orders?: OptimizedMarketOrder[]; | ||||
|     public sourceFlags: number = 0; | ||||
|     public sourceFlags: bigint = BigInt(0); | ||||
|     protected _size: PathSize = { input: ZERO_AMOUNT, output: ZERO_AMOUNT }; | ||||
|     protected _adjustedSize: PathSize = { input: ZERO_AMOUNT, output: ZERO_AMOUNT }; | ||||
|  | ||||
| @@ -78,6 +78,11 @@ export class Path { | ||||
|         return this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add a fallback path to the current path | ||||
|      * Fallback must contain exclusive fills that are | ||||
|      * not present in this path | ||||
|      */ | ||||
|     public addFallback(fallback: Path): this { | ||||
|         // If the last fill is Native and penultimate is not, then the intention was to partial fill | ||||
|         // In this case we drop it entirely as we can't handle a failure at the end and we don't | ||||
| @@ -93,9 +98,18 @@ export class Path { | ||||
|         // an additional protocol fee. I.e [Uniswap,Native,Kyber] becomes [Native,Uniswap,Kyber] | ||||
|         // In the previous step we dropped any hanging Native partial fills, as to not fully fill | ||||
|         const nativeFills = this.fills.filter(f => f.source === ERC20BridgeSource.Native); | ||||
|         this.fills = [...nativeFills.filter(f => f !== lastNativeFillIfExists), ...fallback.fills]; | ||||
|         const otherFills = this.fills.filter(f => f.source !== ERC20BridgeSource.Native); | ||||
|         const otherSourcePathIds = otherFills.map(f => f.sourcePathId); | ||||
|         this.fills = [ | ||||
|             // Append all of the native fills first | ||||
|             ...nativeFills.filter(f => f !== lastNativeFillIfExists), | ||||
|             // Add the other fills that are not native in the optimal path | ||||
|             ...otherFills, | ||||
|             // Add the fallbacks to the end that aren't already included | ||||
|             ...fallback.fills.filter(f => !otherSourcePathIds.includes(f.sourcePathId)), | ||||
|         ]; | ||||
|         // Recompute the source flags | ||||
|         this.sourceFlags = this.fills.reduce((flags, fill) => flags | fill.flags, 0); | ||||
|         this.sourceFlags = this.fills.reduce((flags, fill) => flags | fill.flags, BigInt(0)); | ||||
|         return this; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,3 +1,4 @@ | ||||
| import { ChainId } from '@0x/contract-addresses'; | ||||
| import { BigNumber } from '@0x/utils'; | ||||
| // import { parsePoolData } from '@balancer-labs'; // TODO - upgrade to v2 | ||||
| import { Pool } from '@balancer-labs/sor/dist/types'; | ||||
| @@ -5,7 +6,11 @@ import { gql, request } from 'graphql-request'; | ||||
|  | ||||
| import { DEFAULT_WARNING_LOGGER } from '../../../constants'; | ||||
| import { LogFunction } from '../../../types'; | ||||
| import { BALANCER_MAX_POOLS_FETCHED, BALANCER_TOP_POOLS_FETCHED, BALANCER_V2_SUBGRAPH_URL } from '../constants'; | ||||
| import { | ||||
|     BALANCER_MAX_POOLS_FETCHED, | ||||
|     BALANCER_TOP_POOLS_FETCHED, | ||||
|     BALANCER_V2_SUBGRAPH_URL_BY_CHAIN, | ||||
| } from '../constants'; | ||||
|  | ||||
| import { parsePoolData } from './balancer_sor_v2'; | ||||
| import { CacheValue, PoolsCache } from './pools_cache'; | ||||
| @@ -45,7 +50,8 @@ export class BalancerV2PoolsCache extends PoolsCache { | ||||
|     } | ||||
|  | ||||
|     constructor( | ||||
|         private readonly subgraphUrl: string = BALANCER_V2_SUBGRAPH_URL, | ||||
|         chainId: ChainId, | ||||
|         private readonly subgraphUrl: string = BALANCER_V2_SUBGRAPH_URL_BY_CHAIN[chainId], | ||||
|         private readonly maxPoolsFetched: number = BALANCER_MAX_POOLS_FETCHED, | ||||
|         private readonly _topPoolsFetched: number = BALANCER_TOP_POOLS_FETCHED, | ||||
|         private readonly _warningLogger: LogFunction = DEFAULT_WARNING_LOGGER, | ||||
|   | ||||
| @@ -20,6 +20,7 @@ import { | ||||
| import { | ||||
|     BALANCER_V2_VAULT_ADDRESS_BY_CHAIN, | ||||
|     BANCOR_REGISTRY_BY_CHAIN_ID, | ||||
|     CLIPPER_INFO_BY_CHAIN, | ||||
|     DODOV1_CONFIG_BY_CHAIN_ID, | ||||
|     DODOV2_FACTORIES_BY_CHAIN_ID, | ||||
|     KYBER_CONFIG_BY_CHAIN_ID, | ||||
| @@ -122,7 +123,7 @@ export class SamplerOperations { | ||||
|         this.poolsCaches = poolsCaches | ||||
|             ? poolsCaches | ||||
|             : { | ||||
|                   [ERC20BridgeSource.BalancerV2]: new BalancerV2PoolsCache(), | ||||
|                   [ERC20BridgeSource.BalancerV2]: new BalancerV2PoolsCache(chainId), | ||||
|                   [ERC20BridgeSource.Balancer]: new BalancerPoolsCache(), | ||||
|                   [ERC20BridgeSource.Cream]: new CreamPoolsCache(), | ||||
|               }; | ||||
| @@ -359,9 +360,10 @@ export class SamplerOperations { | ||||
|         takerToken: string, | ||||
|         takerFillAmounts: BigNumber[], | ||||
|         gasCost: number, | ||||
|         source: ERC20BridgeSource = ERC20BridgeSource.LiquidityProvider, | ||||
|     ): SourceQuoteOperation<LiquidityProviderFillData> { | ||||
|         return new SamplerContractOperation({ | ||||
|             source: ERC20BridgeSource.LiquidityProvider, | ||||
|             source, | ||||
|             fillData: { | ||||
|                 poolAddress: providerAddress, | ||||
|                 gasCost, | ||||
| @@ -378,9 +380,10 @@ export class SamplerOperations { | ||||
|         takerToken: string, | ||||
|         makerFillAmounts: BigNumber[], | ||||
|         gasCost: number, | ||||
|         source: ERC20BridgeSource = ERC20BridgeSource.LiquidityProvider, | ||||
|     ): SourceQuoteOperation<LiquidityProviderFillData> { | ||||
|         return new SamplerContractOperation({ | ||||
|             source: ERC20BridgeSource.LiquidityProvider, | ||||
|             source, | ||||
|             fillData: { | ||||
|                 poolAddress: providerAddress, | ||||
|                 gasCost, | ||||
| @@ -1229,6 +1232,8 @@ export class SamplerOperations { | ||||
|                     case ERC20BridgeSource.Dfyn: | ||||
|                     case ERC20BridgeSource.WaultSwap: | ||||
|                     case ERC20BridgeSource.Polydex: | ||||
|                     case ERC20BridgeSource.ShibaSwap: | ||||
|                     case ERC20BridgeSource.JetSwap: | ||||
|                         const uniLikeRouter = uniswapV2LikeRouterAddress(this.chainId, source); | ||||
|                         if (!isValidAddress(uniLikeRouter)) { | ||||
|                             return []; | ||||
| @@ -1263,6 +1268,8 @@ export class SamplerOperations { | ||||
|                     case ERC20BridgeSource.Saddle: | ||||
|                     case ERC20BridgeSource.XSigma: | ||||
|                     case ERC20BridgeSource.FirebirdOneSwap: | ||||
|                     case ERC20BridgeSource.IronSwap: | ||||
|                     case ERC20BridgeSource.ACryptos: | ||||
|                         return getCurveLikeInfosForPair(this.chainId, takerToken, makerToken, source).map(pool => | ||||
|                             this.getCurveSellQuotes( | ||||
|                                 pool, | ||||
| @@ -1318,9 +1325,9 @@ export class SamplerOperations { | ||||
|                                 takerToken, | ||||
|                                 makerToken, | ||||
|                             ) || [] | ||||
|                         ).map(poolAddress => | ||||
|                         ).map(balancerPool => | ||||
|                             this.getBalancerSellQuotes( | ||||
|                                 poolAddress, | ||||
|                                 balancerPool, | ||||
|                                 makerToken, | ||||
|                                 takerToken, | ||||
|                                 takerFillAmounts, | ||||
| @@ -1354,9 +1361,9 @@ export class SamplerOperations { | ||||
|                                 takerToken, | ||||
|                                 makerToken, | ||||
|                             ) || [] | ||||
|                         ).map(poolAddress => | ||||
|                         ).map(creamPool => | ||||
|                             this.getBalancerSellQuotes( | ||||
|                                 poolAddress, | ||||
|                                 creamPool, | ||||
|                                 makerToken, | ||||
|                                 takerToken, | ||||
|                                 takerFillAmounts, | ||||
| @@ -1445,6 +1452,32 @@ export class SamplerOperations { | ||||
|  | ||||
|                         return this.getLidoSellQuotes(lidoInfo, makerToken, takerToken, takerFillAmounts); | ||||
|                     } | ||||
|                     case ERC20BridgeSource.Clipper: | ||||
|                         const { poolAddress: clipperPoolAddress, tokens: clipperTokens } = CLIPPER_INFO_BY_CHAIN[ | ||||
|                             this.chainId | ||||
|                         ]; | ||||
|                         if ( | ||||
|                             clipperPoolAddress === NULL_ADDRESS || | ||||
|                             !clipperTokens.includes(makerToken) || | ||||
|                             !clipperTokens.includes(takerToken) | ||||
|                         ) { | ||||
|                             return []; | ||||
|                         } | ||||
|                         // Clipper requires WETH to be represented as address(0) | ||||
|                         const adjustedMakerToken = | ||||
|                             makerToken === NATIVE_FEE_TOKEN_BY_CHAIN_ID[this.chainId] ? NULL_ADDRESS : makerToken; | ||||
|                         const adjustedTakerToken = | ||||
|                             takerToken === NATIVE_FEE_TOKEN_BY_CHAIN_ID[this.chainId] ? NULL_ADDRESS : takerToken; | ||||
|                         // Supports the PLP interface | ||||
|                         return this.getLiquidityProviderSellQuotes( | ||||
|                             clipperPoolAddress, | ||||
|                             adjustedMakerToken, | ||||
|                             adjustedTakerToken, | ||||
|                             takerFillAmounts, | ||||
|                             // tslint:disable-next-line: custom-no-magic-numbers | ||||
|                             0, // Not used for Clipper | ||||
|                             ERC20BridgeSource.Clipper, | ||||
|                         ); | ||||
|                     default: | ||||
|                         throw new Error(`Unsupported sell sample source: ${source}`); | ||||
|                 } | ||||
| @@ -1499,6 +1532,8 @@ export class SamplerOperations { | ||||
|                     case ERC20BridgeSource.Dfyn: | ||||
|                     case ERC20BridgeSource.WaultSwap: | ||||
|                     case ERC20BridgeSource.Polydex: | ||||
|                     case ERC20BridgeSource.ShibaSwap: | ||||
|                     case ERC20BridgeSource.JetSwap: | ||||
|                         const uniLikeRouter = uniswapV2LikeRouterAddress(this.chainId, source); | ||||
|                         if (!isValidAddress(uniLikeRouter)) { | ||||
|                             return []; | ||||
| @@ -1533,6 +1568,8 @@ export class SamplerOperations { | ||||
|                     case ERC20BridgeSource.Saddle: | ||||
|                     case ERC20BridgeSource.XSigma: | ||||
|                     case ERC20BridgeSource.FirebirdOneSwap: | ||||
|                     case ERC20BridgeSource.IronSwap: | ||||
|                     case ERC20BridgeSource.ACryptos: | ||||
|                         return getCurveLikeInfosForPair(this.chainId, takerToken, makerToken, source).map(pool => | ||||
|                             this.getCurveBuyQuotes( | ||||
|                                 pool, | ||||
| @@ -1710,6 +1747,32 @@ export class SamplerOperations { | ||||
|  | ||||
|                         return this.getLidoBuyQuotes(lidoInfo, makerToken, takerToken, makerFillAmounts); | ||||
|                     } | ||||
|                     case ERC20BridgeSource.Clipper: | ||||
|                         const { poolAddress: clipperPoolAddress, tokens: clipperTokens } = CLIPPER_INFO_BY_CHAIN[ | ||||
|                             this.chainId | ||||
|                         ]; | ||||
|                         if ( | ||||
|                             clipperPoolAddress === NULL_ADDRESS || | ||||
|                             !clipperTokens.includes(makerToken) || | ||||
|                             !clipperTokens.includes(takerToken) | ||||
|                         ) { | ||||
|                             return []; | ||||
|                         } | ||||
|                         // Clipper requires WETH to be represented as address(0) | ||||
|                         const adjustedMakerToken = | ||||
|                             makerToken === NATIVE_FEE_TOKEN_BY_CHAIN_ID[this.chainId] ? NULL_ADDRESS : makerToken; | ||||
|                         const adjustedTakerToken = | ||||
|                             takerToken === NATIVE_FEE_TOKEN_BY_CHAIN_ID[this.chainId] ? NULL_ADDRESS : takerToken; | ||||
|                         // Supports the PLP interface | ||||
|                         return this.getLiquidityProviderBuyQuotes( | ||||
|                             clipperPoolAddress, | ||||
|                             adjustedMakerToken, | ||||
|                             adjustedTakerToken, | ||||
|                             makerFillAmounts, | ||||
|                             // tslint:disable-next-line: custom-no-magic-numbers | ||||
|                             0, // Not used for Clipper | ||||
|                             ERC20BridgeSource.Clipper, | ||||
|                         ); | ||||
|                     default: | ||||
|                         throw new Error(`Unsupported buy sample source: ${source}`); | ||||
|                 } | ||||
|   | ||||
| @@ -68,6 +68,8 @@ export enum ERC20BridgeSource { | ||||
|     UniswapV3 = 'Uniswap_V3', | ||||
|     CurveV2 = 'Curve_V2', | ||||
|     Lido = 'Lido', | ||||
|     ShibaSwap = 'ShibaSwap', | ||||
|     Clipper = 'Clipper', | ||||
|     // BSC only | ||||
|     PancakeSwap = 'PancakeSwap', | ||||
|     PancakeSwapV2 = 'PancakeSwap_V2', | ||||
| @@ -79,6 +81,7 @@ export enum ERC20BridgeSource { | ||||
|     CafeSwap = 'CafeSwap', | ||||
|     CheeseSwap = 'CheeseSwap', | ||||
|     JulSwap = 'JulSwap', | ||||
|     ACryptos = 'ACryptoS', | ||||
|     // Polygon only | ||||
|     QuickSwap = 'QuickSwap', | ||||
|     ComethSwap = 'ComethSwap', | ||||
| @@ -86,6 +89,8 @@ export enum ERC20BridgeSource { | ||||
|     WaultSwap = 'WaultSwap', | ||||
|     Polydex = 'Polydex', | ||||
|     FirebirdOneSwap = 'FirebirdOneSwap', | ||||
|     JetSwap = 'JetSwap', | ||||
|     IronSwap = 'IronSwap', | ||||
| } | ||||
| export type SourcesWithPoolsCache = ERC20BridgeSource.Balancer | ERC20BridgeSource.BalancerV2 | ERC20BridgeSource.Cream; | ||||
|  | ||||
| @@ -274,7 +279,7 @@ export interface Fill<TFillData extends FillData = FillData> { | ||||
|     // paths that have the same `source` IDs but are distinct (e.g., Curves). | ||||
|     sourcePathId: string; | ||||
|     // See `SOURCE_FLAGS`. | ||||
|     flags: number; | ||||
|     flags: bigint; | ||||
|     // Input fill amount (taker asset amount in a sell, maker asset amount in a buy). | ||||
|     input: BigNumber; | ||||
|     // Output fill amount (maker asset amount in a sell, taker asset amount in a buy). | ||||
| @@ -363,7 +368,7 @@ export interface GetMarketOrdersRfqOpts extends RfqRequestOpts { | ||||
|  | ||||
| export type FeeEstimate = (fillData: FillData) => number | BigNumber; | ||||
| export type FeeSchedule = Partial<{ [key in ERC20BridgeSource]: FeeEstimate }>; | ||||
| export type ExchangeProxyOverhead = (sourceFlags: number) => BigNumber; | ||||
| export type ExchangeProxyOverhead = (sourceFlags: bigint) => BigNumber; | ||||
|  | ||||
| /** | ||||
|  * Options for `getMarketSellOrdersAsync()` and `getMarketBuyOrdersAsync()`. | ||||
| @@ -465,7 +470,7 @@ export interface SourceQuoteOperation<TFillData extends FillData = FillData> ext | ||||
|  | ||||
| export interface OptimizerResult { | ||||
|     optimizedOrders: OptimizedMarketOrder[]; | ||||
|     sourceFlags: number; | ||||
|     sourceFlags: bigint; | ||||
|     liquidityDelivered: CollapsedFill[] | DexSample<MultiHopFillData>; | ||||
|     marketSideLiquidity: MarketSideLiquidity; | ||||
|     adjustedRate: BigNumber; | ||||
|   | ||||
| @@ -29,6 +29,7 @@ import { RfqMakerBlacklist } from './rfq_maker_blacklist'; | ||||
|  | ||||
| const MAKER_TIMEOUT_STREAK_LENGTH = 10; | ||||
| const MAKER_TIMEOUT_BLACKLIST_DURATION_MINUTES = 10; | ||||
| const FILL_RATIO_WARNING_LEVEL = 0.99; | ||||
| const rfqMakerBlacklist = new RfqMakerBlacklist(MAKER_TIMEOUT_STREAK_LENGTH, MAKER_TIMEOUT_BLACKLIST_DURATION_MINUTES); | ||||
|  | ||||
| interface RfqQuote<T> { | ||||
| @@ -563,6 +564,22 @@ export class QuoteRequestor { | ||||
|                 this._warningLogger(order, 'Expiry too soon in RFQ-T firm quote, filtering out'); | ||||
|                 return false; | ||||
|             } else { | ||||
|                 const takerAmount = new BigNumber(order.takerAmount); | ||||
|                 const fillRatio = takerAmount.div(assetFillAmount); | ||||
|                 if (fillRatio.lt(1) && fillRatio.gte(FILL_RATIO_WARNING_LEVEL)) { | ||||
|                     this._warningLogger( | ||||
|                         { | ||||
|                             makerUri: result.makerUri, | ||||
|                             fillRatio, | ||||
|                             assetFillAmount, | ||||
|                             takerToken, | ||||
|                             makerToken, | ||||
|                             takerAmount: order.takerAmount, | ||||
|                             makerAmount: order.makerAmount, | ||||
|                         }, | ||||
|                         'Fill ratio in warning range', | ||||
|                     ); | ||||
|                 } | ||||
|                 return true; | ||||
|             } | ||||
|         }); | ||||
|   | ||||
| @@ -39,7 +39,7 @@ const feeSchedule = { | ||||
|     [ERC20BridgeSource.Native]: _.constant(GAS_PRICE.times(NATIVE_ORDER_FEE)), | ||||
| }; | ||||
|  | ||||
| const exchangeProxyOverhead = (sourceFlags: number) => { | ||||
| const exchangeProxyOverhead = (sourceFlags: bigint) => { | ||||
|     if ([SOURCE_FLAGS.RfqOrder].includes(sourceFlags)) { | ||||
|         return new BigNumber(20e3).times(GAS_PRICE); | ||||
|     } else { | ||||
|   | ||||
| @@ -1280,7 +1280,7 @@ describe('MarketOperationUtils tests', () => { | ||||
|                 }); | ||||
|                 const optimizer = new MarketOperationUtils(MOCK_SAMPLER, contractAddresses, ORDER_DOMAIN); | ||||
|                 const gasPrice = 100e9; // 100 gwei | ||||
|                 const exchangeProxyOverhead = (sourceFlags: number) => | ||||
|                 const exchangeProxyOverhead = (sourceFlags: bigint) => | ||||
|                     sourceFlags === SOURCE_FLAGS.LiquidityProvider | ||||
|                         ? constants.ZERO_AMOUNT | ||||
|                         : new BigNumber(1.3e5).times(gasPrice); | ||||
| @@ -1663,7 +1663,7 @@ describe('MarketOperationUtils tests', () => { | ||||
|                 }); | ||||
|                 const optimizer = new MarketOperationUtils(MOCK_SAMPLER, contractAddresses, ORDER_DOMAIN); | ||||
|                 const gasPrice = 100e9; // 100 gwei | ||||
|                 const exchangeProxyOverhead = (sourceFlags: number) => | ||||
|                 const exchangeProxyOverhead = (sourceFlags: bigint) => | ||||
|                     sourceFlags === SOURCE_FLAGS.LiquidityProvider | ||||
|                         ? constants.ZERO_AMOUNT | ||||
|                         : new BigNumber(1.3e5).times(gasPrice); | ||||
|   | ||||
							
								
								
									
										86
									
								
								packages/asset-swapper/test/path_test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								packages/asset-swapper/test/path_test.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | ||||
| import { expect } from '@0x/contracts-test-utils'; | ||||
| import { BigNumber } from '@0x/utils'; | ||||
|  | ||||
| import { MarketOperation } from '../src/types'; | ||||
| import { Path } from '../src/utils/market_operation_utils/path'; | ||||
| import { ERC20BridgeSource, Fill } from '../src/utils/market_operation_utils/types'; | ||||
|  | ||||
| const createFill = ( | ||||
|     source: ERC20BridgeSource, | ||||
|     input: BigNumber = new BigNumber(100), | ||||
|     output: BigNumber = new BigNumber(100), | ||||
| ): Fill => | ||||
|     // tslint:disable-next-line: no-object-literal-type-assertion | ||||
|     ({ | ||||
|         source, | ||||
|         input, | ||||
|         output, | ||||
|         adjustedOutput: output, | ||||
|         flags: BigInt(0), | ||||
|         sourcePathId: source, | ||||
|     } as Fill); | ||||
|  | ||||
| describe('Path', () => { | ||||
|     it('Adds a fallback', () => { | ||||
|         const targetInput = new BigNumber(100); | ||||
|         const path = Path.create( | ||||
|             MarketOperation.Sell, | ||||
|             [createFill(ERC20BridgeSource.Native), createFill(ERC20BridgeSource.Native)], | ||||
|             targetInput, | ||||
|         ); | ||||
|         const fallback = Path.create(MarketOperation.Sell, [createFill(ERC20BridgeSource.Uniswap)], targetInput); | ||||
|         path.addFallback(fallback); | ||||
|         const sources = path.fills.map(f => f.source); | ||||
|         expect(sources).to.deep.eq([ERC20BridgeSource.Native, ERC20BridgeSource.Native, ERC20BridgeSource.Uniswap]); | ||||
|     }); | ||||
|  | ||||
|     it('Adds a fallback with LiquidityProvider', () => { | ||||
|         const targetInput = new BigNumber(100); | ||||
|         const path = Path.create( | ||||
|             MarketOperation.Sell, | ||||
|             [createFill(ERC20BridgeSource.Native), createFill(ERC20BridgeSource.LiquidityProvider)], | ||||
|             targetInput, | ||||
|         ); | ||||
|         const fallback = Path.create(MarketOperation.Sell, [createFill(ERC20BridgeSource.Uniswap)], targetInput); | ||||
|         path.addFallback(fallback); | ||||
|         const sources = path.fills.map(f => f.source); | ||||
|         expect(sources).to.deep.eq([ | ||||
|             ERC20BridgeSource.Native, | ||||
|             ERC20BridgeSource.LiquidityProvider, | ||||
|             ERC20BridgeSource.Uniswap, | ||||
|         ]); | ||||
|     }); | ||||
|  | ||||
|     it('Removes partial Native orders', () => { | ||||
|         const targetInput = new BigNumber(100); | ||||
|         const path = Path.create( | ||||
|             MarketOperation.Sell, | ||||
|             [ | ||||
|                 createFill(ERC20BridgeSource.Uniswap), | ||||
|                 createFill(ERC20BridgeSource.LiquidityProvider), | ||||
|                 createFill(ERC20BridgeSource.Native), | ||||
|             ], | ||||
|             targetInput, | ||||
|         ); | ||||
|         const fallback = Path.create(MarketOperation.Sell, [createFill(ERC20BridgeSource.Kyber)], targetInput); | ||||
|         path.addFallback(fallback); | ||||
|         const sources = path.fills.map(f => f.source); | ||||
|         expect(sources).to.deep.eq([ | ||||
|             ERC20BridgeSource.Uniswap, | ||||
|             ERC20BridgeSource.LiquidityProvider, | ||||
|             ERC20BridgeSource.Kyber, | ||||
|         ]); | ||||
|     }); | ||||
|     it('Handles duplicates', () => { | ||||
|         const targetInput = new BigNumber(100); | ||||
|         const path = Path.create( | ||||
|             MarketOperation.Sell, | ||||
|             [createFill(ERC20BridgeSource.Uniswap), createFill(ERC20BridgeSource.LiquidityProvider)], | ||||
|             targetInput, | ||||
|         ); | ||||
|         const fallback = Path.create(MarketOperation.Sell, [createFill(ERC20BridgeSource.Uniswap)], targetInput); | ||||
|         path.addFallback(fallback); | ||||
|         const sources = path.fills.map(f => f.source); | ||||
|         expect(sources).to.deep.eq([ERC20BridgeSource.Uniswap, ERC20BridgeSource.LiquidityProvider]); | ||||
|     }); | ||||
| }); | ||||
| @@ -1,3 +1,4 @@ | ||||
| import { ChainId } from '@0x/contract-addresses'; | ||||
| import * as chai from 'chai'; | ||||
| import 'mocha'; | ||||
|  | ||||
| @@ -49,7 +50,7 @@ describe('Pools Caches for Balancer-based sampling', () => { | ||||
|     }); | ||||
|  | ||||
|     describe('BalancerV2PoolsCache', () => { | ||||
|         const cache = new BalancerV2PoolsCache(); | ||||
|         const cache = new BalancerV2PoolsCache(ChainId.Mainnet); | ||||
|         it('fetches pools', async () => { | ||||
|             const pairs = [ | ||||
|                 [wethAddress, wbtcAddress], | ||||
|   | ||||
| @@ -1,4 +1,14 @@ | ||||
| [ | ||||
|     { | ||||
|         "version": "6.5.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Deployed `Clipper`", | ||||
|                 "pr": 299 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1628225642 | ||||
|     }, | ||||
|     { | ||||
|         "version": "6.4.0", | ||||
|         "changes": [ | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v6.5.0 - _August 6, 2021_ | ||||
|  | ||||
|     * Deployed `Clipper` (#299) | ||||
|  | ||||
| ## v6.4.0 - _June 22, 2021_ | ||||
|  | ||||
|     * Deployed Lido FQT | ||||
|   | ||||
| @@ -36,7 +36,7 @@ | ||||
|             "wethTransformer": "0xb2bc06a4efb20fc6553a69dbfa49b7be938034a7", | ||||
|             "payTakerTransformer": "0x4638a7ebe75b911b995d0ec73a81e4f85f41f24e", | ||||
|             "affiliateFeeTransformer": "0xda6d9fc5998f550a094585cf9171f0e8ee3ac59f", | ||||
|             "fillQuoteTransformer": "0x6dfdb2537683ce6101f9090a78197dd58c30bfac", | ||||
|             "fillQuoteTransformer": "0xb4fa284689c9784a60d840eb136bb16c5246191f", | ||||
|             "positiveSlippageFeeTransformer": "0xa9416ce1dbde8d331210c07b5c253d94ee4cc3fd" | ||||
|         } | ||||
|     }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contract-addresses", | ||||
|     "version": "6.4.0", | ||||
|     "version": "6.5.0", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contract-wrappers-test", | ||||
|     "version": "12.2.50", | ||||
|     "version": "12.2.51", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -31,11 +31,11 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/packages/contract-wrappers-test", | ||||
|     "devDependencies": { | ||||
|         "@0x/contract-wrappers": "^13.17.2", | ||||
|         "@0x/contracts-test-utils": "^5.4.5", | ||||
|         "@0x/contract-wrappers": "^13.17.3", | ||||
|         "@0x/contracts-test-utils": "^5.4.6", | ||||
|         "@0x/dev-utils": "^4.2.7", | ||||
|         "@0x/migrations": "^8.0.11", | ||||
|         "@0x/order-utils": "^10.4.26", | ||||
|         "@0x/migrations": "^8.0.12", | ||||
|         "@0x/order-utils": "^10.4.27", | ||||
|         "@0x/subproviders": "^6.5.3", | ||||
|         "@0x/ts-doc-gen": "^0.0.28", | ||||
|         "@0x/tslint-config": "^4.1.4", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "13.17.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "13.17.2", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v13.17.3 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v13.17.2 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/contract-wrappers", | ||||
|     "version": "13.17.2", | ||||
|     "version": "13.17.3", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -57,7 +57,7 @@ | ||||
|     "dependencies": { | ||||
|         "@0x/assert": "^3.0.27", | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/json-schemas": "^6.1.3", | ||||
|         "@0x/types": "^3.3.3", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "8.0.12", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "8.0.11", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v8.0.12 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v8.0.11 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/migrations", | ||||
|     "version": "8.0.11", | ||||
|     "version": "8.0.12", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -68,20 +68,20 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/base-contract": "^6.4.0", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.16", | ||||
|         "@0x/contracts-coordinator": "^3.1.35", | ||||
|         "@0x/contracts-dev-utils": "^1.3.33", | ||||
|         "@0x/contracts-erc1155": "^2.1.34", | ||||
|         "@0x/contracts-erc20": "^3.3.13", | ||||
|         "@0x/contracts-erc721": "^3.1.34", | ||||
|         "@0x/contracts-exchange": "^3.2.35", | ||||
|         "@0x/contracts-exchange-forwarder": "^4.2.35", | ||||
|         "@0x/contracts-extensions": "^6.2.29", | ||||
|         "@0x/contracts-multisig": "^4.1.35", | ||||
|         "@0x/contracts-staking": "^2.0.42", | ||||
|         "@0x/contracts-utils": "^4.7.13", | ||||
|         "@0x/contracts-zero-ex": "^0.26.0", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contracts-asset-proxy": "^3.7.17", | ||||
|         "@0x/contracts-coordinator": "^3.1.36", | ||||
|         "@0x/contracts-dev-utils": "^1.3.34", | ||||
|         "@0x/contracts-erc1155": "^2.1.35", | ||||
|         "@0x/contracts-erc20": "^3.3.14", | ||||
|         "@0x/contracts-erc721": "^3.1.35", | ||||
|         "@0x/contracts-exchange": "^3.2.36", | ||||
|         "@0x/contracts-exchange-forwarder": "^4.2.36", | ||||
|         "@0x/contracts-extensions": "^6.2.30", | ||||
|         "@0x/contracts-multisig": "^4.1.36", | ||||
|         "@0x/contracts-staking": "^2.0.43", | ||||
|         "@0x/contracts-utils": "^4.7.14", | ||||
|         "@0x/contracts-zero-ex": "^0.27.0", | ||||
|         "@0x/sol-compiler": "^4.7.3", | ||||
|         "@0x/subproviders": "^6.5.3", | ||||
|         "@0x/typescript-typings": "^5.2.0", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1628225642, | ||||
|         "version": "10.4.27", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "10.4.26", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v10.4.27 - _August 6, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v10.4.26 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/order-utils", | ||||
|     "version": "10.4.26", | ||||
|     "version": "10.4.27", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -69,8 +69,8 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/assert": "^3.0.27", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contract-wrappers": "^13.17.2", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contract-wrappers": "^13.17.3", | ||||
|         "@0x/json-schemas": "^6.1.3", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|         "@0x/web3-wrapper": "^7.5.3", | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| [ | ||||
|     { | ||||
|         "version": "1.8.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add `Clipper`" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1628225642 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1624356181, | ||||
|         "version": "1.7.2", | ||||
|   | ||||
| @@ -5,6 +5,10 @@ Edit the package's CHANGELOG.json file only. | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v1.8.0 - _August 6, 2021_ | ||||
|  | ||||
|     * Add `Clipper` | ||||
|  | ||||
| ## v1.7.2 - _June 22, 2021_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0x/protocol-utils", | ||||
|     "version": "1.7.2", | ||||
|     "version": "1.8.0", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -63,8 +63,8 @@ | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0x/assert": "^3.0.27", | ||||
|         "@0x/contract-addresses": "^6.4.0", | ||||
|         "@0x/contract-wrappers": "^13.17.2", | ||||
|         "@0x/contract-addresses": "^6.5.0", | ||||
|         "@0x/contract-wrappers": "^13.17.3", | ||||
|         "@0x/json-schemas": "^6.1.3", | ||||
|         "@0x/subproviders": "^6.5.3", | ||||
|         "@0x/utils": "^6.4.3", | ||||
|   | ||||
| @@ -131,6 +131,7 @@ export enum BridgeProtocol { | ||||
|     KyberDmm, | ||||
|     CurveV2, | ||||
|     Lido, | ||||
|     Clipper, | ||||
| } | ||||
| // tslint:enable: enum-naming | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user