Compare commits
	
		
			44 Commits
		
	
	
		
			@0x/contra
			...
			protocol@6
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 692231c2ea | ||
|  | 3a1becc3e4 | ||
|  | 3653e2d7f9 | ||
|  | 65def38d98 | ||
|  | 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 | ||
|  | efd83be779 | ||
|  | 603bc1d51c | ||
|  | 32a930a7fc | 
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "3.7.18", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "3.7.17", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "3.7.16", |         "version": "3.7.16", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v3.7.18 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v3.7.17 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v3.7.16 - _June 22, 2021_ | ## v3.7.16 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-asset-proxy", |     "name": "@0x/contracts-asset-proxy", | ||||||
|     "version": "3.7.16", |     "version": "3.7.18", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -52,10 +52,10 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/protocol", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/protocol", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contract-wrappers": "^13.17.2", |         "@0x/contract-wrappers": "^13.17.4", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
| @@ -80,11 +80,11 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contracts-erc1155": "^2.1.34", |         "@0x/contracts-erc1155": "^2.1.36", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-erc721": "^3.1.34", |         "@0x/contracts-erc721": "^3.1.36", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "1.1.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "1.1.35", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "1.1.34", |         "version": "1.1.34", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v1.1.36 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v1.1.35 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v1.1.34 - _June 22, 2021_ | ## v1.1.34 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-broker", |     "name": "@0x/contracts-broker", | ||||||
|     "version": "1.1.34", |     "version": "1.1.36", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -52,14 +52,14 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-erc721": "^3.1.34", |         "@0x/contracts-erc721": "^3.1.36", | ||||||
|         "@0x/contracts-exchange": "^3.2.35", |         "@0x/contracts-exchange": "^3.2.37", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
| @@ -85,7 +85,7 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|         "ethereum-types": "^3.5.0" |         "ethereum-types": "^3.5.0" | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "3.1.37", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "3.1.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "3.1.35", |         "version": "3.1.35", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v3.1.37 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v3.1.36 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v3.1.35 - _June 22, 2021_ | ## v3.1.35 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-coordinator", |     "name": "@0x/contracts-coordinator", | ||||||
|     "version": "3.1.35", |     "version": "3.1.37", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -53,12 +53,12 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-dev-utils": "^1.3.33", |         "@0x/contracts-dev-utils": "^1.3.35", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
| @@ -84,10 +84,10 @@ | |||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/assert": "^3.0.27", |         "@0x/assert": "^3.0.27", | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contracts-exchange": "^3.2.35", |         "@0x/contracts-exchange": "^3.2.37", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/json-schemas": "^6.1.3", |         "@0x/json-schemas": "^6.1.3", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "1.3.35", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "1.3.34", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "1.3.33", |         "version": "1.3.33", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v1.3.35 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v1.3.34 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v1.3.33 - _June 22, 2021_ | ## v1.3.33 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-dev-utils", |     "name": "@0x/contracts-dev-utils", | ||||||
|     "version": "1.3.33", |     "version": "1.3.35", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -43,10 +43,10 @@ | |||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/assert": "^3.0.27", |         "@0x/assert": "^3.0.27", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "2.1.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "2.1.35", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "2.1.34", |         "version": "2.1.34", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v2.1.36 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v2.1.35 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v2.1.34 - _June 22, 2021_ | ## v2.1.34 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-erc1155", |     "name": "@0x/contracts-erc1155", | ||||||
|     "version": "2.1.34", |     "version": "2.1.36", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -54,7 +54,7 @@ | |||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
| @@ -81,7 +81,7 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|         "@0x/web3-wrapper": "^7.5.3", |         "@0x/web3-wrapper": "^7.5.3", | ||||||
|         "lodash": "^4.17.11" |         "lodash": "^4.17.11" | ||||||
|   | |||||||
| @@ -1,4 +1,23 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "version": "3.3.15", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Add ethers as a dependency", | ||||||
|  |                 "pr": 305 | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1628665757 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "3.3.14", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "3.3.13", |         "version": "3.3.13", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v3.3.15 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Add ethers as a dependency (#305) | ||||||
|  |  | ||||||
|  | ## v3.3.14 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v3.3.13 - _June 22, 2021_ | ## v3.3.13 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-erc20", |     "name": "@0x/contracts-erc20", | ||||||
|     "version": "3.3.13", |     "version": "3.3.15", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -53,8 +53,8 @@ | |||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
| @@ -82,7 +82,8 @@ | |||||||
|         "typescript": "4.2.2" |         "typescript": "4.2.2" | ||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0" |         "@0x/base-contract": "^6.4.0", | ||||||
|  |         "ethers": "~4.0.4" | ||||||
|     }, |     }, | ||||||
|     "publishConfig": { |     "publishConfig": { | ||||||
|         "access": "public" |         "access": "public" | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "3.1.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "3.1.35", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "3.1.34", |         "version": "3.1.34", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v3.1.36 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v3.1.35 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v3.1.34 - _June 22, 2021_ | ## v3.1.34 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-erc721", |     "name": "@0x/contracts-erc721", | ||||||
|     "version": "3.1.34", |     "version": "3.1.36", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -54,8 +54,8 @@ | |||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "4.2.37", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "4.2.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "4.2.35", |         "version": "4.2.35", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v4.2.37 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v4.2.36 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v4.2.35 - _June 22, 2021_ | ## v4.2.35 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-exchange-forwarder", |     "name": "@0x/contracts-exchange-forwarder", | ||||||
|     "version": "4.2.35", |     "version": "4.2.37", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -53,18 +53,18 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-dev-utils": "^1.3.33", |         "@0x/contracts-dev-utils": "^1.3.35", | ||||||
|         "@0x/contracts-erc1155": "^2.1.34", |         "@0x/contracts-erc1155": "^2.1.36", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-erc721": "^3.1.34", |         "@0x/contracts-erc721": "^3.1.36", | ||||||
|         "@0x/contracts-exchange": "^3.2.35", |         "@0x/contracts-exchange": "^3.2.37", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "4.3.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "4.3.35", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "4.3.34", |         "version": "4.3.34", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v4.3.36 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v4.3.35 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v4.3.34 - _June 22, 2021_ | ## v4.3.34 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-exchange-libs", |     "name": "@0x/contracts-exchange-libs", | ||||||
|     "version": "4.3.34", |     "version": "4.3.36", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -81,9 +81,9 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "3.2.37", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "3.2.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "3.2.35", |         "version": "3.2.35", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v3.2.37 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v3.2.36 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v3.2.35 - _June 22, 2021_ | ## v3.2.35 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-exchange", |     "name": "@0x/contracts-exchange", | ||||||
|     "version": "3.2.35", |     "version": "3.2.37", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -53,13 +53,13 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/protocol", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/protocol", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-multisig": "^4.1.35", |         "@0x/contracts-multisig": "^4.1.37", | ||||||
|         "@0x/contracts-staking": "^2.0.42", |         "@0x/contracts-staking": "^2.0.44", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
| @@ -89,11 +89,11 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contracts-dev-utils": "^1.3.33", |         "@0x/contracts-dev-utils": "^1.3.35", | ||||||
|         "@0x/contracts-erc1155": "^2.1.34", |         "@0x/contracts-erc1155": "^2.1.36", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-erc721": "^3.1.34", |         "@0x/contracts-erc721": "^3.1.36", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|         "lodash": "^4.17.11" |         "lodash": "^4.17.11" | ||||||
|     }, |     }, | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "6.2.31", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "6.2.30", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "6.2.29", |         "version": "6.2.29", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v6.2.31 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v6.2.30 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v6.2.29 - _June 22, 2021_ | ## v6.2.29 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-extensions", |     "name": "@0x/contracts-extensions", | ||||||
|     "version": "6.2.29", |     "version": "6.2.31", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -53,16 +53,16 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-dev-utils": "^1.3.33", |         "@0x/contracts-dev-utils": "^1.3.35", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-erc721": "^3.1.34", |         "@0x/contracts-erc721": "^3.1.36", | ||||||
|         "@0x/contracts-exchange": "^3.2.35", |         "@0x/contracts-exchange": "^3.2.37", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
| @@ -91,7 +91,7 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|         "ethereum-types": "^3.5.0" |         "ethereum-types": "^3.5.0" | ||||||
|     }, |     }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-integrations", |     "name": "@0x/contracts-integrations", | ||||||
|     "version": "2.7.51", |     "version": "2.7.63", | ||||||
|     "private": true, |     "private": true, | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
| @@ -53,21 +53,21 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/extensions", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contract-wrappers": "^13.17.2", |         "@0x/contract-wrappers": "^13.17.4", | ||||||
|         "@0x/contracts-broker": "^1.1.34", |         "@0x/contracts-broker": "^1.1.36", | ||||||
|         "@0x/contracts-coordinator": "^3.1.35", |         "@0x/contracts-coordinator": "^3.1.37", | ||||||
|         "@0x/contracts-dev-utils": "^1.3.33", |         "@0x/contracts-dev-utils": "^1.3.35", | ||||||
|         "@0x/contracts-exchange-forwarder": "^4.2.35", |         "@0x/contracts-exchange-forwarder": "^4.2.37", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/contracts-extensions": "^6.2.29", |         "@0x/contracts-extensions": "^6.2.31", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/coordinator-server": "^1.0.5", |         "@0x/coordinator-server": "^1.0.5", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/migrations": "^8.0.11", |         "@0x/migrations": "^8.1.0", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/protocol-utils": "^1.7.2", |         "@0x/protocol-utils": "^1.8.1", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
|         "@0x/web3-wrapper": "^7.5.3", |         "@0x/web3-wrapper": "^7.5.3", | ||||||
| @@ -93,17 +93,17 @@ | |||||||
|         "typescript": "4.2.2" |         "typescript": "4.2.2" | ||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/asset-swapper": "^6.18.0", |         "@0x/asset-swapper": "^16.24.1", | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-erc1155": "^2.1.34", |         "@0x/contracts-erc1155": "^2.1.36", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-erc721": "^3.1.34", |         "@0x/contracts-erc721": "^3.1.36", | ||||||
|         "@0x/contracts-exchange": "^3.2.35", |         "@0x/contracts-exchange": "^3.2.37", | ||||||
|         "@0x/contracts-multisig": "^4.1.35", |         "@0x/contracts-multisig": "^4.1.37", | ||||||
|         "@0x/contracts-staking": "^2.0.42", |         "@0x/contracts-staking": "^2.0.44", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-zero-ex": "^0.26.0", |         "@0x/contracts-zero-ex": "^0.27.1", | ||||||
|         "@0x/subproviders": "^6.5.3", |         "@0x/subproviders": "^6.5.3", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "4.1.37", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "4.1.36", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "4.1.35", |         "version": "4.1.35", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v4.1.37 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v4.1.36 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v4.1.35 - _June 22, 2021_ | ## v4.1.35 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-multisig", |     "name": "@0x/contracts-multisig", | ||||||
|     "version": "4.1.35", |     "version": "4.1.37", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -50,11 +50,11 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/multisig", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/multisig", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "2.0.44", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "2.0.43", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "2.0.42", |         "version": "2.0.42", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v2.0.44 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v2.0.43 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v2.0.42 - _June 22, 2021_ | ## v2.0.42 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-staking", |     "name": "@0x/contracts-staking", | ||||||
|     "version": "2.0.42", |     "version": "2.0.44", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -54,14 +54,14 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/tokens", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/tokens", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-dev-utils": "^1.3.33", |         "@0x/contracts-dev-utils": "^1.3.35", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
| @@ -88,7 +88,7 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|         "ethereum-types": "^3.5.0", |         "ethereum-types": "^3.5.0", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "5.4.7", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "5.4.6", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "5.4.5", |         "version": "5.4.5", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v5.4.7 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v5.4.6 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v5.4.5 - _June 22, 2021_ | ## v5.4.5 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-test-utils", |     "name": "@0x/contracts-test-utils", | ||||||
|     "version": "5.4.5", |     "version": "5.4.7", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -44,10 +44,10 @@ | |||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/assert": "^3.0.27", |         "@0x/assert": "^3.0.27", | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/json-schemas": "^6.1.3", |         "@0x/json-schemas": "^6.1.3", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/sol-coverage": "^4.0.37", |         "@0x/sol-coverage": "^4.0.37", | ||||||
|         "@0x/sol-profiler": "^4.1.27", |         "@0x/sol-profiler": "^4.1.27", | ||||||
|         "@0x/sol-trace": "^3.0.37", |         "@0x/sol-trace": "^3.0.37", | ||||||
|   | |||||||
| @@ -1,4 +1,23 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "1.3.1", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "version": "1.3.0", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Added proposal 1 params and test", | ||||||
|  |                 "pr": 298 | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1628225642 | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "1.2.3", |         "version": "1.2.3", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v1.3.1 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v1.3.0 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Added proposal 1 params and test (#298) | ||||||
|  |  | ||||||
| ## v1.2.3 - _June 22, 2021_ | ## v1.2.3 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-treasury", |     "name": "@0x/contracts-treasury", | ||||||
|     "version": "1.2.3", |     "version": "1.3.1", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -47,12 +47,12 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/treasury", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/treasury", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-staking": "^2.0.42", |         "@0x/contracts-staking": "^2.0.44", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
| @@ -73,7 +73,7 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/protocol-utils": "^1.7.2", |         "@0x/protocol-utils": "^1.8.1", | ||||||
|         "@0x/subproviders": "^6.5.3", |         "@0x/subproviders": "^6.5.3", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@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,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "4.7.15", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "4.7.14", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "4.7.13", |         "version": "4.7.13", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v4.7.15 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v4.7.14 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v4.7.13 - _June 22, 2021_ | ## v4.7.13 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contracts-utils", |     "name": "@0x/contracts-utils", | ||||||
|     "version": "4.7.13", |     "version": "4.7.15", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -52,9 +52,9 @@ | |||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "0.27.1", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "version": "0.27.0", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Add `Clipper` as a custom liquidity source" | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1628225642 | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "version": "0.26.0", |         "version": "0.26.0", | ||||||
|         "changes": [ |         "changes": [ | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v0.27.1 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v0.27.0 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Add `Clipper` as a custom liquidity source | ||||||
|  |  | ||||||
| ## v0.26.0 - _June 22, 2021_ | ## v0.26.0 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Add Lido stETH deposit integration (#260) |     * Add Lido stETH deposit integration (#260) | ||||||
|   | |||||||
| @@ -25,6 +25,7 @@ import "./BridgeProtocols.sol"; | |||||||
| import "./mixins/MixinBalancer.sol"; | import "./mixins/MixinBalancer.sol"; | ||||||
| import "./mixins/MixinBalancerV2.sol"; | import "./mixins/MixinBalancerV2.sol"; | ||||||
| import "./mixins/MixinBancor.sol"; | import "./mixins/MixinBancor.sol"; | ||||||
|  | import "./mixins/MixinClipper.sol"; | ||||||
| import "./mixins/MixinCoFiX.sol"; | import "./mixins/MixinCoFiX.sol"; | ||||||
| import "./mixins/MixinCurve.sol"; | import "./mixins/MixinCurve.sol"; | ||||||
| import "./mixins/MixinCurveV2.sol"; | import "./mixins/MixinCurveV2.sol"; | ||||||
| @@ -50,6 +51,7 @@ contract BridgeAdapter is | |||||||
|     MixinBalancer, |     MixinBalancer, | ||||||
|     MixinBalancerV2, |     MixinBalancerV2, | ||||||
|     MixinBancor, |     MixinBancor, | ||||||
|  |     MixinClipper, | ||||||
|     MixinCoFiX, |     MixinCoFiX, | ||||||
|     MixinCurve, |     MixinCurve, | ||||||
|     MixinCurveV2, |     MixinCurveV2, | ||||||
| @@ -75,6 +77,7 @@ contract BridgeAdapter is | |||||||
|         MixinBalancer() |         MixinBalancer() | ||||||
|         MixinBalancerV2() |         MixinBalancerV2() | ||||||
|         MixinBancor(weth) |         MixinBancor(weth) | ||||||
|  |         MixinClipper(weth) | ||||||
|         MixinCoFiX() |         MixinCoFiX() | ||||||
|         MixinCurve(weth) |         MixinCurve(weth) | ||||||
|         MixinCurveV2() |         MixinCurveV2() | ||||||
| @@ -245,6 +248,13 @@ contract BridgeAdapter is | |||||||
|                 sellAmount, |                 sellAmount, | ||||||
|                 order.bridgeData |                 order.bridgeData | ||||||
|             ); |             ); | ||||||
|  |         } else if (protocolId == BridgeProtocols.CLIPPER) { | ||||||
|  |             boughtAmount = _tradeClipper( | ||||||
|  |                 sellToken, | ||||||
|  |                 buyToken, | ||||||
|  |                 sellAmount, | ||||||
|  |                 order.bridgeData | ||||||
|  |             ); | ||||||
|         } else { |         } else { | ||||||
|             boughtAmount = _tradeZeroExBridge( |             boughtAmount = _tradeZeroExBridge( | ||||||
|                 sellToken, |                 sellToken, | ||||||
|   | |||||||
| @@ -49,4 +49,5 @@ library BridgeProtocols { | |||||||
|     uint128 internal constant KYBERDMM    = 19; |     uint128 internal constant KYBERDMM    = 19; | ||||||
|     uint128 internal constant CURVEV2     = 20; |     uint128 internal constant CURVEV2     = 20; | ||||||
|     uint128 internal constant LIDO        = 21; |     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", |     "name": "@0x/contracts-zero-ex", | ||||||
|     "version": "0.26.0", |     "version": "0.27.1", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -43,7 +43,7 @@ | |||||||
|     "config": { |     "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", |         "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: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": { |     "repository": { | ||||||
|         "type": "git", |         "type": "git", | ||||||
| @@ -56,12 +56,12 @@ | |||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/zero-ex", |     "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/zero-ex", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
| @@ -83,7 +83,7 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/protocol-utils": "^1.7.2", |         "@0x/protocol-utils": "^1.8.1", | ||||||
|         "@0x/subproviders": "^6.5.3", |         "@0x/subproviders": "^6.5.3", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@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 MixinBalancer from '../test/generated-artifacts/MixinBalancer.json'; | ||||||
| import * as MixinBalancerV2 from '../test/generated-artifacts/MixinBalancerV2.json'; | import * as MixinBalancerV2 from '../test/generated-artifacts/MixinBalancerV2.json'; | ||||||
| import * as MixinBancor from '../test/generated-artifacts/MixinBancor.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 MixinCoFiX from '../test/generated-artifacts/MixinCoFiX.json'; | ||||||
| import * as MixinCryptoCom from '../test/generated-artifacts/MixinCryptoCom.json'; | import * as MixinCryptoCom from '../test/generated-artifacts/MixinCryptoCom.json'; | ||||||
| import * as MixinCurve from '../test/generated-artifacts/MixinCurve.json'; | import * as MixinCurve from '../test/generated-artifacts/MixinCurve.json'; | ||||||
| @@ -257,6 +258,7 @@ export const artifacts = { | |||||||
|     MixinBalancer: MixinBalancer as ContractArtifact, |     MixinBalancer: MixinBalancer as ContractArtifact, | ||||||
|     MixinBalancerV2: MixinBalancerV2 as ContractArtifact, |     MixinBalancerV2: MixinBalancerV2 as ContractArtifact, | ||||||
|     MixinBancor: MixinBancor as ContractArtifact, |     MixinBancor: MixinBancor as ContractArtifact, | ||||||
|  |     MixinClipper: MixinClipper as ContractArtifact, | ||||||
|     MixinCoFiX: MixinCoFiX as ContractArtifact, |     MixinCoFiX: MixinCoFiX as ContractArtifact, | ||||||
|     MixinCryptoCom: MixinCryptoCom as ContractArtifact, |     MixinCryptoCom: MixinCryptoCom as ContractArtifact, | ||||||
|     MixinCurve: MixinCurve 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'; | ||||||
| export * from '../test/generated-wrappers/mixin_balancer_v2'; | export * from '../test/generated-wrappers/mixin_balancer_v2'; | ||||||
| export * from '../test/generated-wrappers/mixin_bancor'; | 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_co_fi_x'; | ||||||
| export * from '../test/generated-wrappers/mixin_crypto_com'; | export * from '../test/generated-wrappers/mixin_crypto_com'; | ||||||
| export * from '../test/generated-wrappers/mixin_curve'; | export * from '../test/generated-wrappers/mixin_curve'; | ||||||
|   | |||||||
| @@ -113,6 +113,7 @@ | |||||||
|         "test/generated-artifacts/MixinBalancer.json", |         "test/generated-artifacts/MixinBalancer.json", | ||||||
|         "test/generated-artifacts/MixinBalancerV2.json", |         "test/generated-artifacts/MixinBalancerV2.json", | ||||||
|         "test/generated-artifacts/MixinBancor.json", |         "test/generated-artifacts/MixinBancor.json", | ||||||
|  |         "test/generated-artifacts/MixinClipper.json", | ||||||
|         "test/generated-artifacts/MixinCoFiX.json", |         "test/generated-artifacts/MixinCoFiX.json", | ||||||
|         "test/generated-artifacts/MixinCryptoCom.json", |         "test/generated-artifacts/MixinCryptoCom.json", | ||||||
|         "test/generated-artifacts/MixinCurve.json", |         "test/generated-artifacts/MixinCurve.json", | ||||||
|   | |||||||
| @@ -1,4 +1,125 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "16.24.1", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "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": [ | ||||||
|  |             { | ||||||
|  |                 "note": "FirebirdOneSwap, ApeSwap. New hop tokens: DFYN, BANANA, WEXPOLY", | ||||||
|  |                 "pr": 265 | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1624405040 | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "version": "6.18.0", |         "version": "6.18.0", | ||||||
|         "changes": [ |         "changes": [ | ||||||
|   | |||||||
| @@ -5,6 +5,55 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v16.24.1 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## 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) | ||||||
|  |  | ||||||
| ## v6.18.0 - _June 22, 2021_ | ## v6.18.0 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Add Lido stETH deposit integration (#260) |     * Add Lido stETH deposit integration (#260) | ||||||
|   | |||||||
| @@ -20,12 +20,20 @@ | |||||||
| pragma solidity ^0.6; | pragma solidity ^0.6; | ||||||
| pragma experimental ABIEncoderV2; | pragma experimental ABIEncoderV2; | ||||||
|  |  | ||||||
| interface IKyberDmmFactory { | interface IKyberDmmPool { | ||||||
|  |  | ||||||
|     function getPoolAtIndex(address token0, address token1, uint256 index) |     function totalSupply() | ||||||
|         external |         external | ||||||
|         view |         view | ||||||
|         returns (address); |         returns (uint256); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | interface IKyberDmmFactory { | ||||||
|  |  | ||||||
|  |     function getPools(address token0, address token1) | ||||||
|  |         external | ||||||
|  |         view | ||||||
|  |         returns (address[] memory _tokenPools); | ||||||
| } | } | ||||||
|  |  | ||||||
| interface IKyberDmmRouter { | interface IKyberDmmRouter { | ||||||
| @@ -140,17 +148,26 @@ contract KyberDmmSampler | |||||||
|         view |         view | ||||||
|         returns (address[] memory pools) |         returns (address[] memory pools) | ||||||
|     { |     { | ||||||
|         pools = new address[](path.length - 1); |  | ||||||
|         IKyberDmmFactory factory = IKyberDmmFactory(IKyberDmmRouter(router).factory()); |         IKyberDmmFactory factory = IKyberDmmFactory(IKyberDmmRouter(router).factory()); | ||||||
|  |         pools = new address[](path.length - 1); | ||||||
|         for (uint256 i = 0; i < pools.length; i++) { |         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 |             try | ||||||
|                 factory.getPoolAtIndex |                 factory.getPools | ||||||
|                     {gas: KYBER_DMM_CALL_GAS} |                     {gas: KYBER_DMM_CALL_GAS} | ||||||
|                     (path[i], path[i + 1], 0) |                     (path[i], path[i + 1]) | ||||||
|                 returns (address pool) |                 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) { |             } catch (bytes memory) { | ||||||
|                 return new address[](0); |                 return new address[](0); | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/asset-swapper", |     "name": "@0x/asset-swapper", | ||||||
|     "version": "6.18.0", |     "version": "16.24.1", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -60,13 +60,13 @@ | |||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/assert": "^3.0.27", |         "@0x/assert": "^3.0.27", | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contract-wrappers": "^13.17.2", |         "@0x/contract-wrappers": "^13.17.4", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-zero-ex": "^0.26.0", |         "@0x/contracts-zero-ex": "^0.27.1", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/json-schemas": "^6.1.3", |         "@0x/json-schemas": "^6.1.3", | ||||||
|         "@0x/protocol-utils": "^1.7.2", |         "@0x/protocol-utils": "^1.8.1", | ||||||
|         "@0x/quote-server": "^6.0.2", |         "@0x/quote-server": "^6.0.2", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
| @@ -93,14 +93,14 @@ | |||||||
|     }, |     }, | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/abi-gen": "^5.6.0", |         "@0x/abi-gen": "^5.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-exchange": "^3.2.35", |         "@0x/contracts-exchange": "^3.2.37", | ||||||
|         "@0x/contracts-exchange-libs": "^4.3.34", |         "@0x/contracts-exchange-libs": "^4.3.36", | ||||||
|         "@0x/contracts-gen": "^2.0.38", |         "@0x/contracts-gen": "^2.0.38", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/mesh-rpc-client": "^9.4.2", |         "@0x/mesh-rpc-client": "^9.4.2", | ||||||
|         "@0x/migrations": "^8.0.11", |         "@0x/migrations": "^8.1.0", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/subproviders": "^6.5.3", |         "@0x/subproviders": "^6.5.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@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 { BigNumber, NULL_BYTES } from '@0x/utils'; | ||||||
|  |  | ||||||
| import { | import { | ||||||
|  |     ACRYPTOS_BSC_INFOS, | ||||||
|     APESWAP_ROUTER_BY_CHAIN_ID, |     APESWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     BAKERYSWAP_ROUTER_BY_CHAIN_ID, |     BAKERYSWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     BELT_BSC_INFOS, |     BELT_BSC_INFOS, | ||||||
| @@ -16,6 +17,10 @@ import { | |||||||
|     CURVE_V2_POLYGON_INFOS, |     CURVE_V2_POLYGON_INFOS, | ||||||
|     DFYN_ROUTER_BY_CHAIN_ID, |     DFYN_ROUTER_BY_CHAIN_ID, | ||||||
|     ELLIPSIS_BSC_INFOS, |     ELLIPSIS_BSC_INFOS, | ||||||
|  |     FIREBIRDONESWAP_BSC_INFOS, | ||||||
|  |     FIREBIRDONESWAP_POLYGON_INFOS, | ||||||
|  |     IRONSWAP_POLYGON_INFOS, | ||||||
|  |     JETSWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     JULSWAP_ROUTER_BY_CHAIN_ID, |     JULSWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     KYBER_BANNED_RESERVES, |     KYBER_BANNED_RESERVES, | ||||||
|     KYBER_BRIDGED_LIQUIDITY_PREFIX, |     KYBER_BRIDGED_LIQUIDITY_PREFIX, | ||||||
| @@ -30,13 +35,14 @@ import { | |||||||
|     QUICKSWAP_ROUTER_BY_CHAIN_ID, |     QUICKSWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     SADDLE_MAINNET_INFOS, |     SADDLE_MAINNET_INFOS, | ||||||
|     SHELL_POOLS_BY_CHAIN_ID, |     SHELL_POOLS_BY_CHAIN_ID, | ||||||
|  |     SHIBASWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     SMOOTHY_BSC_INFOS, |     SMOOTHY_BSC_INFOS, | ||||||
|     SMOOTHY_MAINNET_INFOS, |     SMOOTHY_MAINNET_INFOS, | ||||||
|     SNOWSWAP_MAINNET_INFOS, |     SNOWSWAP_MAINNET_INFOS, | ||||||
|     SUSHISWAP_ROUTER_BY_CHAIN_ID, |     SUSHISWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     SWERVE_MAINNET_INFOS, |     SWERVE_MAINNET_INFOS, | ||||||
|     UNISWAPV2_ROUTER_BY_CHAIN_ID, |     UNISWAPV2_ROUTER_BY_CHAIN_ID, | ||||||
|     WAULT_ROUTER_BY_CHAIN_ID, |     WAULTSWAP_ROUTER_BY_CHAIN_ID, | ||||||
|     XSIGMA_MAINNET_INFOS, |     XSIGMA_MAINNET_INFOS, | ||||||
| } from './constants'; | } from './constants'; | ||||||
| import { CurveInfo, ERC20BridgeSource } from './types'; | import { CurveInfo, ERC20BridgeSource } from './types'; | ||||||
| @@ -195,6 +201,30 @@ export function getNerveInfosForPair(chainId: ChainId, takerToken: string, maker | |||||||
|     ); |     ); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export function getFirebirdOneSwapInfosForPair(chainId: ChainId, takerToken: string, makerToken: string): CurveInfo[] { | ||||||
|  |     if (chainId === ChainId.BSC) { | ||||||
|  |         return Object.values(FIREBIRDONESWAP_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), | ||||||
|  |             ), | ||||||
|  |         ); | ||||||
|  |     } else if (chainId === ChainId.Polygon) { | ||||||
|  |         return Object.values(FIREBIRDONESWAP_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), | ||||||
|  |             ), | ||||||
|  |         ); | ||||||
|  |     } else { | ||||||
|  |         return []; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| export function getBeltInfosForPair(chainId: ChainId, takerToken: string, makerToken: string): CurveInfo[] { | export function getBeltInfosForPair(chainId: ChainId, takerToken: string, makerToken: string): CurveInfo[] { | ||||||
|     if (chainId !== ChainId.BSC) { |     if (chainId !== ChainId.BSC) { | ||||||
|         return []; |         return []; | ||||||
| @@ -258,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[] { | export function getXSigmaInfosForPair(chainId: ChainId, takerToken: string, makerToken: string): CurveInfo[] { | ||||||
|     if (chainId !== ChainId.Mainnet) { |     if (chainId !== ChainId.Mainnet) { | ||||||
|         return []; |         return []; | ||||||
| @@ -271,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( | export function getShellLikeInfosForPair( | ||||||
|     chainId: ChainId, |     chainId: ChainId, | ||||||
|     takerToken: string, |     takerToken: string, | ||||||
| @@ -308,7 +364,10 @@ export function getCurveLikeInfosForPair( | |||||||
|         | ERC20BridgeSource.Ellipsis |         | ERC20BridgeSource.Ellipsis | ||||||
|         | ERC20BridgeSource.Smoothy |         | ERC20BridgeSource.Smoothy | ||||||
|         | ERC20BridgeSource.Saddle |         | ERC20BridgeSource.Saddle | ||||||
|         | ERC20BridgeSource.XSigma, |         | ERC20BridgeSource.IronSwap | ||||||
|  |         | ERC20BridgeSource.XSigma | ||||||
|  |         | ERC20BridgeSource.FirebirdOneSwap | ||||||
|  |         | ERC20BridgeSource.ACryptos, | ||||||
| ): CurveDetailedInfo[] { | ): CurveDetailedInfo[] { | ||||||
|     let pools: CurveInfo[] = []; |     let pools: CurveInfo[] = []; | ||||||
|     switch (source) { |     switch (source) { | ||||||
| @@ -342,6 +401,15 @@ export function getCurveLikeInfosForPair( | |||||||
|         case ERC20BridgeSource.XSigma: |         case ERC20BridgeSource.XSigma: | ||||||
|             pools = getXSigmaInfosForPair(chainId, takerToken, makerToken); |             pools = getXSigmaInfosForPair(chainId, takerToken, makerToken); | ||||||
|             break; |             break; | ||||||
|  |         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: |         default: | ||||||
|             throw new Error(`Unknown Curve like source ${source}`); |             throw new Error(`Unknown Curve like source ${source}`); | ||||||
|     } |     } | ||||||
| @@ -369,7 +437,9 @@ export function uniswapV2LikeRouterAddress( | |||||||
|         | ERC20BridgeSource.ComethSwap |         | ERC20BridgeSource.ComethSwap | ||||||
|         | ERC20BridgeSource.Dfyn |         | ERC20BridgeSource.Dfyn | ||||||
|         | ERC20BridgeSource.WaultSwap |         | ERC20BridgeSource.WaultSwap | ||||||
|         | ERC20BridgeSource.Polydex, |         | ERC20BridgeSource.Polydex | ||||||
|  |         | ERC20BridgeSource.ShibaSwap | ||||||
|  |         | ERC20BridgeSource.JetSwap, | ||||||
| ): string { | ): string { | ||||||
|     switch (source) { |     switch (source) { | ||||||
|         case ERC20BridgeSource.UniswapV2: |         case ERC20BridgeSource.UniswapV2: | ||||||
| @@ -399,9 +469,13 @@ export function uniswapV2LikeRouterAddress( | |||||||
|         case ERC20BridgeSource.Dfyn: |         case ERC20BridgeSource.Dfyn: | ||||||
|             return DFYN_ROUTER_BY_CHAIN_ID[chainId]; |             return DFYN_ROUTER_BY_CHAIN_ID[chainId]; | ||||||
|         case ERC20BridgeSource.WaultSwap: |         case ERC20BridgeSource.WaultSwap: | ||||||
|             return WAULT_ROUTER_BY_CHAIN_ID[chainId]; |             return WAULTSWAP_ROUTER_BY_CHAIN_ID[chainId]; | ||||||
|         case ERC20BridgeSource.Polydex: |         case ERC20BridgeSource.Polydex: | ||||||
|             return POLYDEX_ROUTER_BY_CHAIN_ID[chainId]; |             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: |         default: | ||||||
|             throw new Error(`Unknown UniswapV2 like source ${source}`); |             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.XSigma, | ||||||
|             ERC20BridgeSource.UniswapV3, |             ERC20BridgeSource.UniswapV3, | ||||||
|             ERC20BridgeSource.CurveV2, |             ERC20BridgeSource.CurveV2, | ||||||
|  |             ERC20BridgeSource.ShibaSwap, | ||||||
|  |             ERC20BridgeSource.Clipper, | ||||||
|         ]), |         ]), | ||||||
|         [ChainId.Ropsten]: new SourceFilters([ |         [ChainId.Ropsten]: new SourceFilters([ | ||||||
|             ERC20BridgeSource.Kyber, |             ERC20BridgeSource.Kyber, | ||||||
| @@ -130,6 +132,9 @@ export const SELL_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | |||||||
|             ERC20BridgeSource.JulSwap, |             ERC20BridgeSource.JulSwap, | ||||||
|             ERC20BridgeSource.LiquidityProvider, |             ERC20BridgeSource.LiquidityProvider, | ||||||
|             ERC20BridgeSource.WaultSwap, |             ERC20BridgeSource.WaultSwap, | ||||||
|  |             ERC20BridgeSource.FirebirdOneSwap, | ||||||
|  |             ERC20BridgeSource.JetSwap, | ||||||
|  |             ERC20BridgeSource.ACryptos, | ||||||
|         ]), |         ]), | ||||||
|         [ChainId.Polygon]: new SourceFilters([ |         [ChainId.Polygon]: new SourceFilters([ | ||||||
|             ERC20BridgeSource.SushiSwap, |             ERC20BridgeSource.SushiSwap, | ||||||
| @@ -143,6 +148,14 @@ export const SELL_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | |||||||
|             ERC20BridgeSource.CurveV2, |             ERC20BridgeSource.CurveV2, | ||||||
|             ERC20BridgeSource.WaultSwap, |             ERC20BridgeSource.WaultSwap, | ||||||
|             ERC20BridgeSource.Polydex, |             ERC20BridgeSource.Polydex, | ||||||
|  |             ERC20BridgeSource.ApeSwap, | ||||||
|  |             ERC20BridgeSource.FirebirdOneSwap, | ||||||
|  |             ERC20BridgeSource.BalancerV2, | ||||||
|  |             ERC20BridgeSource.KyberDmm, | ||||||
|  |             ERC20BridgeSource.LiquidityProvider, | ||||||
|  |             ERC20BridgeSource.MultiHop, | ||||||
|  |             ERC20BridgeSource.JetSwap, | ||||||
|  |             ERC20BridgeSource.IronSwap, | ||||||
|         ]), |         ]), | ||||||
|     }, |     }, | ||||||
|     new SourceFilters([]), |     new SourceFilters([]), | ||||||
| @@ -185,6 +198,8 @@ export const BUY_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | |||||||
|             ERC20BridgeSource.XSigma, |             ERC20BridgeSource.XSigma, | ||||||
|             ERC20BridgeSource.UniswapV3, |             ERC20BridgeSource.UniswapV3, | ||||||
|             ERC20BridgeSource.CurveV2, |             ERC20BridgeSource.CurveV2, | ||||||
|  |             ERC20BridgeSource.ShibaSwap, | ||||||
|  |             ERC20BridgeSource.Clipper, | ||||||
|         ]), |         ]), | ||||||
|         [ChainId.Ropsten]: new SourceFilters([ |         [ChainId.Ropsten]: new SourceFilters([ | ||||||
|             ERC20BridgeSource.Kyber, |             ERC20BridgeSource.Kyber, | ||||||
| @@ -218,6 +233,9 @@ export const BUY_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | |||||||
|             ERC20BridgeSource.JulSwap, |             ERC20BridgeSource.JulSwap, | ||||||
|             ERC20BridgeSource.LiquidityProvider, |             ERC20BridgeSource.LiquidityProvider, | ||||||
|             ERC20BridgeSource.WaultSwap, |             ERC20BridgeSource.WaultSwap, | ||||||
|  |             ERC20BridgeSource.FirebirdOneSwap, | ||||||
|  |             ERC20BridgeSource.JetSwap, | ||||||
|  |             ERC20BridgeSource.ACryptos, | ||||||
|         ]), |         ]), | ||||||
|         [ChainId.Polygon]: new SourceFilters([ |         [ChainId.Polygon]: new SourceFilters([ | ||||||
|             ERC20BridgeSource.SushiSwap, |             ERC20BridgeSource.SushiSwap, | ||||||
| @@ -231,6 +249,14 @@ export const BUY_SOURCE_FILTER_BY_CHAIN_ID = valueByChainId<SourceFilters>( | |||||||
|             ERC20BridgeSource.CurveV2, |             ERC20BridgeSource.CurveV2, | ||||||
|             ERC20BridgeSource.WaultSwap, |             ERC20BridgeSource.WaultSwap, | ||||||
|             ERC20BridgeSource.Polydex, |             ERC20BridgeSource.Polydex, | ||||||
|  |             ERC20BridgeSource.ApeSwap, | ||||||
|  |             ERC20BridgeSource.FirebirdOneSwap, | ||||||
|  |             ERC20BridgeSource.BalancerV2, | ||||||
|  |             ERC20BridgeSource.KyberDmm, | ||||||
|  |             ERC20BridgeSource.LiquidityProvider, | ||||||
|  |             ERC20BridgeSource.MultiHop, | ||||||
|  |             ERC20BridgeSource.JetSwap, | ||||||
|  |             ERC20BridgeSource.IronSwap, | ||||||
|         ]), |         ]), | ||||||
|     }, |     }, | ||||||
|     new SourceFilters([]), |     new SourceFilters([]), | ||||||
| @@ -256,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 | // HACK(mzhu25): Limit and RFQ orders need to be treated as different sources | ||||||
| //               when computing the exchange proxy gas overhead. | //               when computing the exchange proxy gas overhead. | ||||||
| export const SOURCE_FLAGS: { [key in ERC20BridgeSource]: number } & { | export const SOURCE_FLAGS: { [key in ERC20BridgeSource]: bigint } & { | ||||||
|     RfqOrder: number; |     RfqOrder: bigint; | ||||||
|     LimitOrder: number; |     LimitOrder: bigint; | ||||||
| } = Object.assign( | } = Object.assign( | ||||||
|     {}, |     {}, | ||||||
|     ...['RfqOrder', 'LimitOrder', ...Object.values(ERC20BridgeSource)].map((source, index) => ({ |     ...['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), | ||||||
|     })), |     })), | ||||||
| ); | ); | ||||||
|  |  | ||||||
| @@ -337,6 +363,7 @@ export const MAINNET_TOKENS = { | |||||||
|     crETH: '0xcbc1065255cbc3ab41a6868c22d1f1c573ab89fd', |     crETH: '0xcbc1065255cbc3ab41a6868c22d1f1c573ab89fd', | ||||||
|     ankrETH: '0xe95a203b1a91a908f9b9ce46459d101078c2c3cb', |     ankrETH: '0xe95a203b1a91a908f9b9ce46459d101078c2c3cb', | ||||||
|     vETH: '0x898bad2774eb97cf6b94605677f43b41871410b1', |     vETH: '0x898bad2774eb97cf6b94605677f43b41871410b1', | ||||||
|  |     alETH: '0x0100546f2cd4c9d97f798ffc9755e47865ff7ee6', | ||||||
|     HT: '0x6f259637dcD74C767781E37Bc6133cd6A68aa161', |     HT: '0x6f259637dcD74C767781E37Bc6133cd6A68aa161', | ||||||
|     // Mirror Protocol |     // Mirror Protocol | ||||||
|     UST: '0xa47c8bf37f92abed4a126bda807a7b7498661acd', |     UST: '0xa47c8bf37f92abed4a126bda807a7b7498661acd', | ||||||
| @@ -347,15 +374,25 @@ export const MAINNET_TOKENS = { | |||||||
|     alUSD: '0xbc6da0fe9ad5f3b0d58160288917aa56653660e9', |     alUSD: '0xbc6da0fe9ad5f3b0d58160288917aa56653660e9', | ||||||
|     FRAX: '0x853d955acef822db058eb8505911ed77f175b99e', |     FRAX: '0x853d955acef822db058eb8505911ed77f175b99e', | ||||||
|     LUSD: '0x5f98805a4e8be255a32880fdec7f6728c6568ba0', |     LUSD: '0x5f98805a4e8be255a32880fdec7f6728c6568ba0', | ||||||
|  |     FEI: '0x956f47f50a910163d8bf957cf5846d573e7f87ca', | ||||||
|  |     DSU: '0x605d26fbd5be761089281d5cec2ce86eea667109', | ||||||
|  |     ESS: '0x24ae124c4cc33d6791f8e8b63520ed7107ac8b3e', | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export const BSC_TOKENS = { | export const BSC_TOKENS = { | ||||||
|  |     WBNB: '0xbb4cdb9cbd36b01bd1cbaebf2de08d9173bc095c', | ||||||
|     BUSD: '0xe9e7cea3dedca5984780bafc599bd69add087d56', |     BUSD: '0xe9e7cea3dedca5984780bafc599bd69add087d56', | ||||||
|     USDT: '0x55d398326f99059ff775485246999027b3197955', |     USDT: '0x55d398326f99059ff775485246999027b3197955', | ||||||
|     USDC: '0x8ac76a51cc950d9822d68b83fe1ad97b32cd580d', |     USDC: '0x8ac76a51cc950d9822d68b83fe1ad97b32cd580d', | ||||||
|     DAI: '0x1af3f329e8be154074d8769d1ffa4ee058b1dbc3', |     DAI: '0x1af3f329e8be154074d8769d1ffa4ee058b1dbc3', | ||||||
|     PAX: '0xb7f8cd00c5a06c0537e2abff0b58033d02e5e094', |     PAX: '0xb7f8cd00c5a06c0537e2abff0b58033d02e5e094', | ||||||
|     UST: '0x23396cf899ca06c4472205fc903bdb4de249d6fc', |     UST: '0x23396cf899ca06c4472205fc903bdb4de249d6fc', | ||||||
|  |     VAI: '0x4bd17003473389a42daf6a0a729f6fdb328bbbd7', | ||||||
|  |     WEX: '0xa9c41a46a6b3531d28d5c32f6633dd2ff05dfb90', | ||||||
|  |     WETH: '0x2170ed0880ac9a755fd29b2688956bd959f933f8', | ||||||
|  |     BTCB: '0x7130d2a12b9bcbfae4f2634d864a1ee1ce3ead9c', | ||||||
|  |     renBTC: '0xfce146bf3146100cfe5db4129cf6c82b0ef4ad8c', | ||||||
|  |     pBTC: '0xed28a457a5a76596ac48d87c0f577020f6ea1c4c', | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export const POLYGON_TOKENS = { | export const POLYGON_TOKENS = { | ||||||
| @@ -370,8 +407,9 @@ export const POLYGON_TOKENS = { | |||||||
|     WETH: '0x7ceb23fd6bc0add59e62ac25578270cff1b9f619', |     WETH: '0x7ceb23fd6bc0add59e62ac25578270cff1b9f619', | ||||||
|     renBTC: '0xdbf31df14b66535af65aac99c32e9ea844e14501', |     renBTC: '0xdbf31df14b66535af65aac99c32e9ea844e14501', | ||||||
|     QUICK: '0x831753dd7087cac61ab5644b308642cc1c33dc13', |     QUICK: '0x831753dd7087cac61ab5644b308642cc1c33dc13', | ||||||
|     TITAN: '0xaaa5b9e6c589642f98a1cda99b9d024b8407285a', |     DFYN: '0xc168e40227e4ebd8c1cae80f7a55a4f0e6d66c97', | ||||||
|     IRON: '0xd86b5923f3ad7b585ed81b448170ae026c65ae9a', |     BANANA: '0x5d47baba0d66083c52009271faf3f50dcc01023c', | ||||||
|  |     WEXPOLY: '0x4c4bf319237d98a30a929a96112effa8da3510eb', | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export const CURVE_POOLS = { | export const CURVE_POOLS = { | ||||||
| @@ -414,10 +452,12 @@ export const CURVE_POOLS = { | |||||||
|     FRAX: '0xd632f22692fac7611d2aa1c0d552930d43caed3b', |     FRAX: '0xd632f22692fac7611d2aa1c0d552930d43caed3b', | ||||||
|     LUSD: '0xed279fdd11ca84beef15af5d39bb4d4bee23f0ca', |     LUSD: '0xed279fdd11ca84beef15af5d39bb4d4bee23f0ca', | ||||||
|     BUSD: '0x4807862aa8b2bf68830e4c8dc86d0e9a998e085a', |     BUSD: '0x4807862aa8b2bf68830e4c8dc86d0e9a998e085a', | ||||||
|  |     DSU3CRV: '0x6ec80df362d7042c50d4469bcfbc174c9dd9109a', | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export const CURVE_V2_POOLS = { | export const CURVE_V2_POOLS = { | ||||||
|     tricrypto: '0x80466c64868e1ab14a1ddf27a676c3fcbe638fe5', |     tricrypto: '0x80466c64868e1ab14a1ddf27a676c3fcbe638fe5', | ||||||
|  |     tricrypto2: '0xd51a44d3fae010294c616388b506acda1bfaae46', | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export const CURVE_POLYGON_POOLS = { | export const CURVE_POLYGON_POOLS = { | ||||||
| @@ -451,6 +491,12 @@ export const SMOOTHY_POOLS = { | |||||||
| export const SADDLE_POOLS = { | export const SADDLE_POOLS = { | ||||||
|     stables: '0x3911f80530595fbd01ab1516ab61255d75aeb066', |     stables: '0x3911f80530595fbd01ab1516ab61255d75aeb066', | ||||||
|     bitcoins: '0x4f6a43ad7cba042606decaca730d4ce0a57ac62e', |     bitcoins: '0x4f6a43ad7cba042606decaca730d4ce0a57ac62e', | ||||||
|  |     alETH: '0xa6018520eaacc06c30ff2e1b3ee2c7c22e64196a', | ||||||
|  |     d4: '0xc69ddcd4dfef25d8a793241834d4cc4b3668ead6', | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const IRONSWAP_POOLS = { | ||||||
|  |     is3usd: '0x837503e8a8753ae17fb8c8151b8e6f586defcb57', | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export const NERVE_POOLS = { | export const NERVE_POOLS = { | ||||||
| @@ -469,6 +515,21 @@ export const XSIGMA_POOLS = { | |||||||
|     stable: '0x3333333ACdEdBbC9Ad7bda0876e60714195681c5', |     stable: '0x3333333ACdEdBbC9Ad7bda0876e60714195681c5', | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export const FIREBIRDONESWAP_BSC_POOLS = { | ||||||
|  |     oneswap: '0x01c9475dbd36e46d1961572c8de24b74616bae9e', | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | 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[]>( | export const DEFAULT_INTERMEDIATE_TOKENS_BY_CHAIN_ID = valueByChainId<string[]>( | ||||||
|     { |     { | ||||||
|         [ChainId.Mainnet]: [ |         [ChainId.Mainnet]: [ | ||||||
| @@ -479,12 +540,13 @@ export const DEFAULT_INTERMEDIATE_TOKENS_BY_CHAIN_ID = valueByChainId<string[]>( | |||||||
|             MAINNET_TOKENS.WBTC, |             MAINNET_TOKENS.WBTC, | ||||||
|         ], |         ], | ||||||
|         [ChainId.BSC]: [ |         [ChainId.BSC]: [ | ||||||
|             '0xbb4cdb9cbd36b01bd1cbaebf2de08d9173bc095c', // WBNB |             BSC_TOKENS.WBNB, | ||||||
|             '0xe9e7cea3dedca5984780bafc599bd69add087d56', // BUSD |             BSC_TOKENS.BUSD, | ||||||
|             '0x1af3f329e8be154074d8769d1ffa4ee058b1dbc3', // DAI |             BSC_TOKENS.DAI, | ||||||
|             '0x8ac76a51cc950d9822d68b83fe1ad97b32cd580d', // USDC |             BSC_TOKENS.USDC, | ||||||
|             '0x2170ed0880ac9a755fd29b2688956bd959f933f8', // ETH |             BSC_TOKENS.WETH, | ||||||
|             '0x55d398326f99059ff775485246999027b3197955', // BUSD-T |             BSC_TOKENS.USDT, | ||||||
|  |             BSC_TOKENS.WEX, | ||||||
|         ], |         ], | ||||||
|         [ChainId.Ropsten]: [ |         [ChainId.Ropsten]: [ | ||||||
|             getContractAddressesForChainOrThrow(ChainId.Ropsten).etherToken, |             getContractAddressesForChainOrThrow(ChainId.Ropsten).etherToken, | ||||||
| @@ -498,9 +560,6 @@ export const DEFAULT_INTERMEDIATE_TOKENS_BY_CHAIN_ID = valueByChainId<string[]>( | |||||||
|             POLYGON_TOKENS.DAI, |             POLYGON_TOKENS.DAI, | ||||||
|             POLYGON_TOKENS.USDT, |             POLYGON_TOKENS.USDT, | ||||||
|             POLYGON_TOKENS.WBTC, |             POLYGON_TOKENS.WBTC, | ||||||
|             POLYGON_TOKENS.QUICK, |  | ||||||
|             POLYGON_TOKENS.TITAN, |  | ||||||
|             POLYGON_TOKENS.IRON, |  | ||||||
|         ], |         ], | ||||||
|     }, |     }, | ||||||
|     [], |     [], | ||||||
| @@ -794,6 +853,11 @@ export const CURVE_MAINNET_INFOS: { [name: string]: CurveInfo } = { | |||||||
|         pool: CURVE_POOLS.ankreth, |         pool: CURVE_POOLS.ankreth, | ||||||
|         gasSchedule: 125e3, |         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 } = { | export const CURVE_V2_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||||
| @@ -802,6 +866,11 @@ export const CURVE_V2_MAINNET_INFOS: { [name: string]: CurveInfo } = { | |||||||
|         pool: CURVE_V2_POOLS.tricrypto, |         pool: CURVE_V2_POOLS.tricrypto, | ||||||
|         gasSchedule: 300e3, |         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 } = { | export const CURVE_POLYGON_INFOS: { [name: string]: CurveInfo } = { | ||||||
| @@ -886,7 +955,7 @@ export const XSIGMA_MAINNET_INFOS: { [name: string]: CurveInfo } = { | |||||||
|     }), |     }), | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Curve pools like using custom selectors | // Curve-like sources using custom selectors | ||||||
| export const SADDLE_MAINNET_INFOS: { [name: string]: CurveInfo } = { | export const SADDLE_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||||
|     [SADDLE_POOLS.stables]: { |     [SADDLE_POOLS.stables]: { | ||||||
|         exchangeFunctionSelector: CurveFunctionSelectors.swap, |         exchangeFunctionSelector: CurveFunctionSelectors.swap, | ||||||
| @@ -906,6 +975,36 @@ export const SADDLE_MAINNET_INFOS: { [name: string]: CurveInfo } = { | |||||||
|         metaTokens: undefined, |         metaTokens: undefined, | ||||||
|         gasSchedule: 150e3, |         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 } = { | export const SMOOTHY_MAINNET_INFOS: { [name: string]: CurveInfo } = { | ||||||
| @@ -953,6 +1052,68 @@ export const NERVE_BSC_INFOS: { [name: string]: CurveInfo } = { | |||||||
|     }, |     }, | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export const FIREBIRDONESWAP_BSC_INFOS: { [name: string]: CurveInfo } = { | ||||||
|  |     [FIREBIRDONESWAP_BSC_POOLS.oneswap]: { | ||||||
|  |         exchangeFunctionSelector: CurveFunctionSelectors.swap, | ||||||
|  |         sellQuoteFunctionSelector: CurveFunctionSelectors.calculateSwap, | ||||||
|  |         buyQuoteFunctionSelector: CurveFunctionSelectors.None, | ||||||
|  |         poolAddress: FIREBIRDONESWAP_BSC_POOLS.oneswap, | ||||||
|  |         tokens: [BSC_TOKENS.BUSD, BSC_TOKENS.USDT, BSC_TOKENS.DAI, BSC_TOKENS.USDC], | ||||||
|  |         metaTokens: undefined, | ||||||
|  |         gasSchedule: 100e3, | ||||||
|  |     }, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const FIREBIRDONESWAP_POLYGON_INFOS: { [name: string]: CurveInfo } = { | ||||||
|  |     [FIREBIRDONESWAP_POLYGON_POOLS.oneswap]: { | ||||||
|  |         exchangeFunctionSelector: CurveFunctionSelectors.swap, | ||||||
|  |         sellQuoteFunctionSelector: CurveFunctionSelectors.calculateSwap, | ||||||
|  |         buyQuoteFunctionSelector: CurveFunctionSelectors.None, | ||||||
|  |         poolAddress: FIREBIRDONESWAP_POLYGON_POOLS.oneswap, | ||||||
|  |         tokens: [POLYGON_TOKENS.DAI, POLYGON_TOKENS.USDC, POLYGON_TOKENS.USDT], | ||||||
|  |         metaTokens: undefined, | ||||||
|  |         gasSchedule: 100e3, | ||||||
|  |     }, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | 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 |  * Kyber reserve prefixes | ||||||
|  * 0xff Fed price reserve |  * 0xff Fed price reserve | ||||||
| @@ -1046,6 +1207,13 @@ export const LINKSWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | |||||||
|     NULL_ADDRESS, |     NULL_ADDRESS, | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  | export const SHIBASWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||||
|  |     { | ||||||
|  |         [ChainId.Mainnet]: '0x03f7724180aa6b939894b5ca4314783b0b36b329', | ||||||
|  |     }, | ||||||
|  |     NULL_ADDRESS, | ||||||
|  | ); | ||||||
|  |  | ||||||
| export const MSTABLE_POOLS_BY_CHAIN_ID = valueByChainId( | export const MSTABLE_POOLS_BY_CHAIN_ID = valueByChainId( | ||||||
|     { |     { | ||||||
|         [ChainId.Mainnet]: { |         [ChainId.Mainnet]: { | ||||||
| @@ -1091,6 +1259,7 @@ export const OASIS_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | |||||||
| export const KYBER_DMM_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | export const KYBER_DMM_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||||
|     { |     { | ||||||
|         [ChainId.Mainnet]: '0x1c87257f5e8609940bc751a07bb085bb7f8cdbe6', |         [ChainId.Mainnet]: '0x1c87257f5e8609940bc751a07bb085bb7f8cdbe6', | ||||||
|  |         [ChainId.Polygon]: '0x546c79662e028b661dfb4767664d0273184e4dd1', | ||||||
|     }, |     }, | ||||||
|     NULL_ADDRESS, |     NULL_ADDRESS, | ||||||
| ); | ); | ||||||
| @@ -1239,6 +1408,7 @@ export const COMPONENT_POOLS_BY_CHAIN_ID = valueByChainId( | |||||||
| export const BALANCER_V2_VAULT_ADDRESS_BY_CHAIN = valueByChainId<string>( | export const BALANCER_V2_VAULT_ADDRESS_BY_CHAIN = valueByChainId<string>( | ||||||
|     { |     { | ||||||
|         [ChainId.Mainnet]: '0xba12222222228d8ba445958a75a0704d566bf2c8', |         [ChainId.Mainnet]: '0xba12222222228d8ba445958a75a0704d566bf2c8', | ||||||
|  |         [ChainId.Polygon]: '0xba12222222228d8ba445958a75a0704d566bf2c8', | ||||||
|     }, |     }, | ||||||
|     NULL_ADDRESS, |     NULL_ADDRESS, | ||||||
| ); | ); | ||||||
| @@ -1256,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_SUBGRAPH_URL = 'https://api.thegraph.com/subgraphs/name/balancer-labs/balancer'; | ||||||
| export const BALANCER_TOP_POOLS_FETCHED = 250; | export const BALANCER_TOP_POOLS_FETCHED = 250; | ||||||
| export const BALANCER_MAX_POOLS_FETCHED = 3; | 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( | export const UNISWAPV3_CONFIG_BY_CHAIN_ID = valueByChainId( | ||||||
|     { |     { | ||||||
| @@ -1302,6 +1494,7 @@ export const BAKERYSWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | |||||||
| export const APESWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | export const APESWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||||
|     { |     { | ||||||
|         [ChainId.BSC]: '0xc0788a3ad43d79aa53b09c2eacc313a787d1d607', |         [ChainId.BSC]: '0xc0788a3ad43d79aa53b09c2eacc313a787d1d607', | ||||||
|  |         [ChainId.Polygon]: '0xc0788a3ad43d79aa53b09c2eacc313a787d1d607', | ||||||
|     }, |     }, | ||||||
|     NULL_ADDRESS, |     NULL_ADDRESS, | ||||||
| ); | ); | ||||||
| @@ -1351,7 +1544,7 @@ export const DFYN_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | |||||||
|     NULL_ADDRESS, |     NULL_ADDRESS, | ||||||
| ); | ); | ||||||
|  |  | ||||||
| export const WAULT_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | export const WAULTSWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||||
|     { |     { | ||||||
|         [ChainId.BSC]: '0xd48745e39bbed146eec15b79cbf964884f9877c2', |         [ChainId.BSC]: '0xd48745e39bbed146eec15b79cbf964884f9877c2', | ||||||
|         [ChainId.Polygon]: '0x3a1d87f206d12415f5b0a33e786967680aab4f6d', |         [ChainId.Polygon]: '0x3a1d87f206d12415f5b0a33e786967680aab4f6d', | ||||||
| @@ -1366,6 +1559,14 @@ export const POLYDEX_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | |||||||
|     NULL_ADDRESS, |     NULL_ADDRESS, | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  | export const JETSWAP_ROUTER_BY_CHAIN_ID = valueByChainId<string>( | ||||||
|  |     { | ||||||
|  |         [ChainId.BSC]: '0xbe65b8f75b9f20f4c522e0067a3887fada714800', | ||||||
|  |         [ChainId.Polygon]: '0x5c6ec38fb0e2609672bdf628b1fd605a523e5923', | ||||||
|  |     }, | ||||||
|  |     NULL_ADDRESS, | ||||||
|  | ); | ||||||
|  |  | ||||||
| const uniswapV2CloneGasSchedule = (fillData?: FillData) => { | const uniswapV2CloneGasSchedule = (fillData?: FillData) => { | ||||||
|     // TODO: Different base cost if to/from ETH. |     // TODO: Different base cost if to/from ETH. | ||||||
|     let gas = 90e3; |     let gas = 90e3; | ||||||
| @@ -1408,12 +1609,15 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | |||||||
|     [ERC20BridgeSource.Ellipsis]: fillData => (fillData as CurveFillData).pool.gasSchedule, |     [ERC20BridgeSource.Ellipsis]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||||
|     [ERC20BridgeSource.Smoothy]: fillData => (fillData as CurveFillData).pool.gasSchedule, |     [ERC20BridgeSource.Smoothy]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||||
|     [ERC20BridgeSource.Saddle]: 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.XSigma]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||||
|  |     [ERC20BridgeSource.FirebirdOneSwap]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||||
|     [ERC20BridgeSource.MultiBridge]: () => 350e3, |     [ERC20BridgeSource.MultiBridge]: () => 350e3, | ||||||
|     [ERC20BridgeSource.UniswapV2]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.UniswapV2]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.SushiSwap]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.SushiSwap]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.CryptoCom]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.CryptoCom]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.Linkswap]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.Linkswap]: uniswapV2CloneGasSchedule, | ||||||
|  |     [ERC20BridgeSource.ShibaSwap]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.Balancer]: () => 120e3, |     [ERC20BridgeSource.Balancer]: () => 120e3, | ||||||
|     [ERC20BridgeSource.BalancerV2]: () => 100e3, |     [ERC20BridgeSource.BalancerV2]: () => 100e3, | ||||||
|     [ERC20BridgeSource.Cream]: () => 120e3, |     [ERC20BridgeSource.Cream]: () => 120e3, | ||||||
| @@ -1468,6 +1672,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | |||||||
|         return gas; |         return gas; | ||||||
|     }, |     }, | ||||||
|     [ERC20BridgeSource.Lido]: () => 226e3, |     [ERC20BridgeSource.Lido]: () => 226e3, | ||||||
|  |     [ERC20BridgeSource.Clipper]: () => 170e3, | ||||||
|  |  | ||||||
|     // |     // | ||||||
|     // BSC |     // BSC | ||||||
| @@ -1480,6 +1685,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | |||||||
|     [ERC20BridgeSource.CheeseSwap]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.CheeseSwap]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.JulSwap]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.JulSwap]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.WaultSwap]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.WaultSwap]: uniswapV2CloneGasSchedule, | ||||||
|  |     [ERC20BridgeSource.ACryptos]: fillData => (fillData as CurveFillData).pool.gasSchedule, | ||||||
|  |  | ||||||
|     // |     // | ||||||
|     // Polygon |     // Polygon | ||||||
| @@ -1488,6 +1694,7 @@ export const DEFAULT_GAS_SCHEDULE: Required<FeeSchedule> = { | |||||||
|     [ERC20BridgeSource.ComethSwap]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.ComethSwap]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.Dfyn]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.Dfyn]: uniswapV2CloneGasSchedule, | ||||||
|     [ERC20BridgeSource.Polydex]: uniswapV2CloneGasSchedule, |     [ERC20BridgeSource.Polydex]: uniswapV2CloneGasSchedule, | ||||||
|  |     [ERC20BridgeSource.JetSwap]: uniswapV2CloneGasSchedule, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export const DEFAULT_FEE_SCHEDULE: Required<FeeSchedule> = { ...DEFAULT_GAS_SCHEDULE }; | 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 sturdyFills = fills.filter(p => p.length > 0 && !fragileSources.includes(p[0].source)); | ||||||
|             const sturdyOptimalPath = await findOptimalPathAsync(side, sturdyFills, inputAmount, opts.runLimit, { |             const sturdyOptimalPath = await findOptimalPathAsync(side, sturdyFills, inputAmount, opts.runLimit, { | ||||||
|                 ...penaltyOpts, |                 ...penaltyOpts, | ||||||
|                 exchangeProxyOverhead: (sourceFlags: number) => |                 exchangeProxyOverhead: (sourceFlags: bigint) => | ||||||
|                     // tslint:disable-next-line: no-bitwise |                     // tslint:disable-next-line: no-bitwise | ||||||
|                     penaltyOpts.exchangeProxyOverhead(sourceFlags | optimalPath.sourceFlags), |                     penaltyOpts.exchangeProxyOverhead(sourceFlags | optimalPath.sourceFlags), | ||||||
|             }); |             }); | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ import { AbiEncoder, BigNumber } from '@0x/utils'; | |||||||
|  |  | ||||||
| import { AssetSwapperContractAddresses, MarketOperation } from '../../types'; | import { AssetSwapperContractAddresses, MarketOperation } from '../../types'; | ||||||
|  |  | ||||||
| import { MAX_UINT256, ZERO_AMOUNT } from './constants'; | import { MAX_UINT256, NULL_BYTES, ZERO_AMOUNT } from './constants'; | ||||||
| import { | import { | ||||||
|     AggregationError, |     AggregationError, | ||||||
|     BalancerFillData, |     BalancerFillData, | ||||||
| @@ -168,8 +168,20 @@ export function getErc20BridgeSourceToBridgeSource(source: ERC20BridgeSource): s | |||||||
|             return encodeBridgeSourceId(BridgeProtocol.UniswapV2, 'WaultSwap'); |             return encodeBridgeSourceId(BridgeProtocol.UniswapV2, 'WaultSwap'); | ||||||
|         case ERC20BridgeSource.Polydex: |         case ERC20BridgeSource.Polydex: | ||||||
|             return encodeBridgeSourceId(BridgeProtocol.UniswapV2, 'Polydex'); |             return encodeBridgeSourceId(BridgeProtocol.UniswapV2, 'Polydex'); | ||||||
|  |         case ERC20BridgeSource.FirebirdOneSwap: | ||||||
|  |             return encodeBridgeSourceId(BridgeProtocol.Nerve, 'FirebirdOneSwap'); | ||||||
|         case ERC20BridgeSource.Lido: |         case ERC20BridgeSource.Lido: | ||||||
|             return encodeBridgeSourceId(BridgeProtocol.Lido, '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: |         default: | ||||||
|             throw new Error(AggregationError.NoBridgeForSource); |             throw new Error(AggregationError.NoBridgeForSource); | ||||||
|     } |     } | ||||||
| @@ -201,6 +213,9 @@ export function createBridgeDataForBridgeOrder(order: OptimizedMarketBridgeOrder | |||||||
|         case ERC20BridgeSource.Smoothy: |         case ERC20BridgeSource.Smoothy: | ||||||
|         case ERC20BridgeSource.Saddle: |         case ERC20BridgeSource.Saddle: | ||||||
|         case ERC20BridgeSource.XSigma: |         case ERC20BridgeSource.XSigma: | ||||||
|  |         case ERC20BridgeSource.FirebirdOneSwap: | ||||||
|  |         case ERC20BridgeSource.IronSwap: | ||||||
|  |         case ERC20BridgeSource.ACryptos: | ||||||
|             const curveFillData = (order as OptimizedMarketBridgeOrder<CurveFillData>).fillData; |             const curveFillData = (order as OptimizedMarketBridgeOrder<CurveFillData>).fillData; | ||||||
|             bridgeData = encoder.encode([ |             bridgeData = encoder.encode([ | ||||||
|                 curveFillData.pool.poolAddress, |                 curveFillData.pool.poolAddress, | ||||||
| @@ -239,6 +254,8 @@ export function createBridgeDataForBridgeOrder(order: OptimizedMarketBridgeOrder | |||||||
|         case ERC20BridgeSource.Dfyn: |         case ERC20BridgeSource.Dfyn: | ||||||
|         case ERC20BridgeSource.WaultSwap: |         case ERC20BridgeSource.WaultSwap: | ||||||
|         case ERC20BridgeSource.Polydex: |         case ERC20BridgeSource.Polydex: | ||||||
|  |         case ERC20BridgeSource.ShibaSwap: | ||||||
|  |         case ERC20BridgeSource.JetSwap: | ||||||
|             const uniswapV2FillData = (order as OptimizedMarketBridgeOrder<UniswapV2FillData>).fillData; |             const uniswapV2FillData = (order as OptimizedMarketBridgeOrder<UniswapV2FillData>).fillData; | ||||||
|             bridgeData = encoder.encode([uniswapV2FillData.router, uniswapV2FillData.tokenAddressPath]); |             bridgeData = encoder.encode([uniswapV2FillData.router, uniswapV2FillData.tokenAddressPath]); | ||||||
|             break; |             break; | ||||||
| @@ -303,6 +320,10 @@ export function createBridgeDataForBridgeOrder(order: OptimizedMarketBridgeOrder | |||||||
|             const lidoFillData = (order as OptimizedMarketBridgeOrder<LidoFillData>).fillData; |             const lidoFillData = (order as OptimizedMarketBridgeOrder<LidoFillData>).fillData; | ||||||
|             bridgeData = encoder.encode([lidoFillData.stEthTokenAddress]); |             bridgeData = encoder.encode([lidoFillData.stEthTokenAddress]); | ||||||
|             break; |             break; | ||||||
|  |         case ERC20BridgeSource.Clipper: | ||||||
|  |             const clipperFillData = (order as OptimizedMarketBridgeOrder<LiquidityProviderFillData>).fillData; | ||||||
|  |             bridgeData = encoder.encode([clipperFillData.poolAddress, NULL_BYTES]); | ||||||
|  |             break; | ||||||
|         default: |         default: | ||||||
|             throw new Error(AggregationError.NoBridgeForSource); |             throw new Error(AggregationError.NoBridgeForSource); | ||||||
|     } |     } | ||||||
| @@ -417,12 +438,16 @@ export const BRIDGE_ENCODERS: { | |||||||
|     [ERC20BridgeSource.Smoothy]: curveEncoder, |     [ERC20BridgeSource.Smoothy]: curveEncoder, | ||||||
|     [ERC20BridgeSource.Saddle]: curveEncoder, |     [ERC20BridgeSource.Saddle]: curveEncoder, | ||||||
|     [ERC20BridgeSource.XSigma]: curveEncoder, |     [ERC20BridgeSource.XSigma]: curveEncoder, | ||||||
|  |     [ERC20BridgeSource.FirebirdOneSwap]: curveEncoder, | ||||||
|  |     [ERC20BridgeSource.IronSwap]: curveEncoder, | ||||||
|  |     [ERC20BridgeSource.ACryptos]: curveEncoder, | ||||||
|     // UniswapV2 like, (router, address[]) |     // UniswapV2 like, (router, address[]) | ||||||
|     [ERC20BridgeSource.Bancor]: routerAddressPathEncoder, |     [ERC20BridgeSource.Bancor]: routerAddressPathEncoder, | ||||||
|     [ERC20BridgeSource.UniswapV2]: routerAddressPathEncoder, |     [ERC20BridgeSource.UniswapV2]: routerAddressPathEncoder, | ||||||
|     [ERC20BridgeSource.SushiSwap]: routerAddressPathEncoder, |     [ERC20BridgeSource.SushiSwap]: routerAddressPathEncoder, | ||||||
|     [ERC20BridgeSource.CryptoCom]: routerAddressPathEncoder, |     [ERC20BridgeSource.CryptoCom]: routerAddressPathEncoder, | ||||||
|     [ERC20BridgeSource.Linkswap]: routerAddressPathEncoder, |     [ERC20BridgeSource.Linkswap]: routerAddressPathEncoder, | ||||||
|  |     [ERC20BridgeSource.ShibaSwap]: routerAddressPathEncoder, | ||||||
|     // BSC |     // BSC | ||||||
|     [ERC20BridgeSource.PancakeSwap]: routerAddressPathEncoder, |     [ERC20BridgeSource.PancakeSwap]: routerAddressPathEncoder, | ||||||
|     [ERC20BridgeSource.PancakeSwapV2]: routerAddressPathEncoder, |     [ERC20BridgeSource.PancakeSwapV2]: routerAddressPathEncoder, | ||||||
| @@ -437,6 +462,7 @@ export const BRIDGE_ENCODERS: { | |||||||
|     [ERC20BridgeSource.ComethSwap]: routerAddressPathEncoder, |     [ERC20BridgeSource.ComethSwap]: routerAddressPathEncoder, | ||||||
|     [ERC20BridgeSource.Dfyn]: routerAddressPathEncoder, |     [ERC20BridgeSource.Dfyn]: routerAddressPathEncoder, | ||||||
|     [ERC20BridgeSource.Polydex]: routerAddressPathEncoder, |     [ERC20BridgeSource.Polydex]: routerAddressPathEncoder, | ||||||
|  |     [ERC20BridgeSource.JetSwap]: routerAddressPathEncoder, | ||||||
|     // Generic pools |     // Generic pools | ||||||
|     [ERC20BridgeSource.Shell]: poolEncoder, |     [ERC20BridgeSource.Shell]: poolEncoder, | ||||||
|     [ERC20BridgeSource.Component]: poolEncoder, |     [ERC20BridgeSource.Component]: poolEncoder, | ||||||
| @@ -455,14 +481,18 @@ export const BRIDGE_ENCODERS: { | |||||||
|     ]), |     ]), | ||||||
|     [ERC20BridgeSource.KyberDmm]: AbiEncoder.create('(address,address[],address[])'), |     [ERC20BridgeSource.KyberDmm]: AbiEncoder.create('(address,address[],address[])'), | ||||||
|     [ERC20BridgeSource.Lido]: AbiEncoder.create('(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] { | function getFillTokenAmounts(fill: CollapsedFill, side: MarketOperation): [BigNumber, BigNumber] { | ||||||
|     return [ |     return [ | ||||||
|         // Maker asset amount. |         // Maker asset amount. | ||||||
|         side === MarketOperation.Sell ? fill.output : fill.input, |         side === MarketOperation.Sell ? fill.output.integerValue(BigNumber.ROUND_DOWN) : fill.input, | ||||||
|         // Taker asset amount. |         // 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 { | export class Path { | ||||||
|     public collapsedFills?: ReadonlyArray<CollapsedFill>; |     public collapsedFills?: ReadonlyArray<CollapsedFill>; | ||||||
|     public orders?: OptimizedMarketOrder[]; |     public orders?: OptimizedMarketOrder[]; | ||||||
|     public sourceFlags: number = 0; |     public sourceFlags: bigint = BigInt(0); | ||||||
|     protected _size: PathSize = { input: ZERO_AMOUNT, output: ZERO_AMOUNT }; |     protected _size: PathSize = { input: ZERO_AMOUNT, output: ZERO_AMOUNT }; | ||||||
|     protected _adjustedSize: 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; |         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 { |     public addFallback(fallback: Path): this { | ||||||
|         // If the last fill is Native and penultimate is not, then the intention was to partial fill |         // 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 |         // 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] |         // 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 |         // 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); |         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 |         // 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; |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,3 +1,4 @@ | |||||||
|  | import { ChainId } from '@0x/contract-addresses'; | ||||||
| import { BigNumber } from '@0x/utils'; | import { BigNumber } from '@0x/utils'; | ||||||
| // import { parsePoolData } from '@balancer-labs'; // TODO - upgrade to v2 | // import { parsePoolData } from '@balancer-labs'; // TODO - upgrade to v2 | ||||||
| import { Pool } from '@balancer-labs/sor/dist/types'; | 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 { DEFAULT_WARNING_LOGGER } from '../../../constants'; | ||||||
| import { LogFunction } from '../../../types'; | 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 { parsePoolData } from './balancer_sor_v2'; | ||||||
| import { CacheValue, PoolsCache } from './pools_cache'; | import { CacheValue, PoolsCache } from './pools_cache'; | ||||||
| @@ -45,7 +50,8 @@ export class BalancerV2PoolsCache extends PoolsCache { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     constructor( |     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 maxPoolsFetched: number = BALANCER_MAX_POOLS_FETCHED, | ||||||
|         private readonly _topPoolsFetched: number = BALANCER_TOP_POOLS_FETCHED, |         private readonly _topPoolsFetched: number = BALANCER_TOP_POOLS_FETCHED, | ||||||
|         private readonly _warningLogger: LogFunction = DEFAULT_WARNING_LOGGER, |         private readonly _warningLogger: LogFunction = DEFAULT_WARNING_LOGGER, | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ import { | |||||||
| import { | import { | ||||||
|     BALANCER_V2_VAULT_ADDRESS_BY_CHAIN, |     BALANCER_V2_VAULT_ADDRESS_BY_CHAIN, | ||||||
|     BANCOR_REGISTRY_BY_CHAIN_ID, |     BANCOR_REGISTRY_BY_CHAIN_ID, | ||||||
|  |     CLIPPER_INFO_BY_CHAIN, | ||||||
|     DODOV1_CONFIG_BY_CHAIN_ID, |     DODOV1_CONFIG_BY_CHAIN_ID, | ||||||
|     DODOV2_FACTORIES_BY_CHAIN_ID, |     DODOV2_FACTORIES_BY_CHAIN_ID, | ||||||
|     KYBER_CONFIG_BY_CHAIN_ID, |     KYBER_CONFIG_BY_CHAIN_ID, | ||||||
| @@ -122,7 +123,7 @@ export class SamplerOperations { | |||||||
|         this.poolsCaches = poolsCaches |         this.poolsCaches = poolsCaches | ||||||
|             ? poolsCaches |             ? poolsCaches | ||||||
|             : { |             : { | ||||||
|                   [ERC20BridgeSource.BalancerV2]: new BalancerV2PoolsCache(), |                   [ERC20BridgeSource.BalancerV2]: new BalancerV2PoolsCache(chainId), | ||||||
|                   [ERC20BridgeSource.Balancer]: new BalancerPoolsCache(), |                   [ERC20BridgeSource.Balancer]: new BalancerPoolsCache(), | ||||||
|                   [ERC20BridgeSource.Cream]: new CreamPoolsCache(), |                   [ERC20BridgeSource.Cream]: new CreamPoolsCache(), | ||||||
|               }; |               }; | ||||||
| @@ -359,9 +360,10 @@ export class SamplerOperations { | |||||||
|         takerToken: string, |         takerToken: string, | ||||||
|         takerFillAmounts: BigNumber[], |         takerFillAmounts: BigNumber[], | ||||||
|         gasCost: number, |         gasCost: number, | ||||||
|  |         source: ERC20BridgeSource = ERC20BridgeSource.LiquidityProvider, | ||||||
|     ): SourceQuoteOperation<LiquidityProviderFillData> { |     ): SourceQuoteOperation<LiquidityProviderFillData> { | ||||||
|         return new SamplerContractOperation({ |         return new SamplerContractOperation({ | ||||||
|             source: ERC20BridgeSource.LiquidityProvider, |             source, | ||||||
|             fillData: { |             fillData: { | ||||||
|                 poolAddress: providerAddress, |                 poolAddress: providerAddress, | ||||||
|                 gasCost, |                 gasCost, | ||||||
| @@ -378,9 +380,10 @@ export class SamplerOperations { | |||||||
|         takerToken: string, |         takerToken: string, | ||||||
|         makerFillAmounts: BigNumber[], |         makerFillAmounts: BigNumber[], | ||||||
|         gasCost: number, |         gasCost: number, | ||||||
|  |         source: ERC20BridgeSource = ERC20BridgeSource.LiquidityProvider, | ||||||
|     ): SourceQuoteOperation<LiquidityProviderFillData> { |     ): SourceQuoteOperation<LiquidityProviderFillData> { | ||||||
|         return new SamplerContractOperation({ |         return new SamplerContractOperation({ | ||||||
|             source: ERC20BridgeSource.LiquidityProvider, |             source, | ||||||
|             fillData: { |             fillData: { | ||||||
|                 poolAddress: providerAddress, |                 poolAddress: providerAddress, | ||||||
|                 gasCost, |                 gasCost, | ||||||
| @@ -1229,6 +1232,8 @@ export class SamplerOperations { | |||||||
|                     case ERC20BridgeSource.Dfyn: |                     case ERC20BridgeSource.Dfyn: | ||||||
|                     case ERC20BridgeSource.WaultSwap: |                     case ERC20BridgeSource.WaultSwap: | ||||||
|                     case ERC20BridgeSource.Polydex: |                     case ERC20BridgeSource.Polydex: | ||||||
|  |                     case ERC20BridgeSource.ShibaSwap: | ||||||
|  |                     case ERC20BridgeSource.JetSwap: | ||||||
|                         const uniLikeRouter = uniswapV2LikeRouterAddress(this.chainId, source); |                         const uniLikeRouter = uniswapV2LikeRouterAddress(this.chainId, source); | ||||||
|                         if (!isValidAddress(uniLikeRouter)) { |                         if (!isValidAddress(uniLikeRouter)) { | ||||||
|                             return []; |                             return []; | ||||||
| @@ -1262,6 +1267,9 @@ export class SamplerOperations { | |||||||
|                     case ERC20BridgeSource.Ellipsis: |                     case ERC20BridgeSource.Ellipsis: | ||||||
|                     case ERC20BridgeSource.Saddle: |                     case ERC20BridgeSource.Saddle: | ||||||
|                     case ERC20BridgeSource.XSigma: |                     case ERC20BridgeSource.XSigma: | ||||||
|  |                     case ERC20BridgeSource.FirebirdOneSwap: | ||||||
|  |                     case ERC20BridgeSource.IronSwap: | ||||||
|  |                     case ERC20BridgeSource.ACryptos: | ||||||
|                         return getCurveLikeInfosForPair(this.chainId, takerToken, makerToken, source).map(pool => |                         return getCurveLikeInfosForPair(this.chainId, takerToken, makerToken, source).map(pool => | ||||||
|                             this.getCurveSellQuotes( |                             this.getCurveSellQuotes( | ||||||
|                                 pool, |                                 pool, | ||||||
| @@ -1317,9 +1325,9 @@ export class SamplerOperations { | |||||||
|                                 takerToken, |                                 takerToken, | ||||||
|                                 makerToken, |                                 makerToken, | ||||||
|                             ) || [] |                             ) || [] | ||||||
|                         ).map(poolAddress => |                         ).map(balancerPool => | ||||||
|                             this.getBalancerSellQuotes( |                             this.getBalancerSellQuotes( | ||||||
|                                 poolAddress, |                                 balancerPool, | ||||||
|                                 makerToken, |                                 makerToken, | ||||||
|                                 takerToken, |                                 takerToken, | ||||||
|                                 takerFillAmounts, |                                 takerFillAmounts, | ||||||
| @@ -1353,9 +1361,9 @@ export class SamplerOperations { | |||||||
|                                 takerToken, |                                 takerToken, | ||||||
|                                 makerToken, |                                 makerToken, | ||||||
|                             ) || [] |                             ) || [] | ||||||
|                         ).map(poolAddress => |                         ).map(creamPool => | ||||||
|                             this.getBalancerSellQuotes( |                             this.getBalancerSellQuotes( | ||||||
|                                 poolAddress, |                                 creamPool, | ||||||
|                                 makerToken, |                                 makerToken, | ||||||
|                                 takerToken, |                                 takerToken, | ||||||
|                                 takerFillAmounts, |                                 takerFillAmounts, | ||||||
| @@ -1444,6 +1452,32 @@ export class SamplerOperations { | |||||||
|  |  | ||||||
|                         return this.getLidoSellQuotes(lidoInfo, makerToken, takerToken, takerFillAmounts); |                         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: |                     default: | ||||||
|                         throw new Error(`Unsupported sell sample source: ${source}`); |                         throw new Error(`Unsupported sell sample source: ${source}`); | ||||||
|                 } |                 } | ||||||
| @@ -1498,6 +1532,8 @@ export class SamplerOperations { | |||||||
|                     case ERC20BridgeSource.Dfyn: |                     case ERC20BridgeSource.Dfyn: | ||||||
|                     case ERC20BridgeSource.WaultSwap: |                     case ERC20BridgeSource.WaultSwap: | ||||||
|                     case ERC20BridgeSource.Polydex: |                     case ERC20BridgeSource.Polydex: | ||||||
|  |                     case ERC20BridgeSource.ShibaSwap: | ||||||
|  |                     case ERC20BridgeSource.JetSwap: | ||||||
|                         const uniLikeRouter = uniswapV2LikeRouterAddress(this.chainId, source); |                         const uniLikeRouter = uniswapV2LikeRouterAddress(this.chainId, source); | ||||||
|                         if (!isValidAddress(uniLikeRouter)) { |                         if (!isValidAddress(uniLikeRouter)) { | ||||||
|                             return []; |                             return []; | ||||||
| @@ -1531,6 +1567,9 @@ export class SamplerOperations { | |||||||
|                     case ERC20BridgeSource.Ellipsis: |                     case ERC20BridgeSource.Ellipsis: | ||||||
|                     case ERC20BridgeSource.Saddle: |                     case ERC20BridgeSource.Saddle: | ||||||
|                     case ERC20BridgeSource.XSigma: |                     case ERC20BridgeSource.XSigma: | ||||||
|  |                     case ERC20BridgeSource.FirebirdOneSwap: | ||||||
|  |                     case ERC20BridgeSource.IronSwap: | ||||||
|  |                     case ERC20BridgeSource.ACryptos: | ||||||
|                         return getCurveLikeInfosForPair(this.chainId, takerToken, makerToken, source).map(pool => |                         return getCurveLikeInfosForPair(this.chainId, takerToken, makerToken, source).map(pool => | ||||||
|                             this.getCurveBuyQuotes( |                             this.getCurveBuyQuotes( | ||||||
|                                 pool, |                                 pool, | ||||||
| @@ -1708,6 +1747,32 @@ export class SamplerOperations { | |||||||
|  |  | ||||||
|                         return this.getLidoBuyQuotes(lidoInfo, makerToken, takerToken, makerFillAmounts); |                         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: |                     default: | ||||||
|                         throw new Error(`Unsupported buy sample source: ${source}`); |                         throw new Error(`Unsupported buy sample source: ${source}`); | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -68,6 +68,8 @@ export enum ERC20BridgeSource { | |||||||
|     UniswapV3 = 'Uniswap_V3', |     UniswapV3 = 'Uniswap_V3', | ||||||
|     CurveV2 = 'Curve_V2', |     CurveV2 = 'Curve_V2', | ||||||
|     Lido = 'Lido', |     Lido = 'Lido', | ||||||
|  |     ShibaSwap = 'ShibaSwap', | ||||||
|  |     Clipper = 'Clipper', | ||||||
|     // BSC only |     // BSC only | ||||||
|     PancakeSwap = 'PancakeSwap', |     PancakeSwap = 'PancakeSwap', | ||||||
|     PancakeSwapV2 = 'PancakeSwap_V2', |     PancakeSwapV2 = 'PancakeSwap_V2', | ||||||
| @@ -79,12 +81,16 @@ export enum ERC20BridgeSource { | |||||||
|     CafeSwap = 'CafeSwap', |     CafeSwap = 'CafeSwap', | ||||||
|     CheeseSwap = 'CheeseSwap', |     CheeseSwap = 'CheeseSwap', | ||||||
|     JulSwap = 'JulSwap', |     JulSwap = 'JulSwap', | ||||||
|  |     ACryptos = 'ACryptoS', | ||||||
|     // Polygon only |     // Polygon only | ||||||
|     QuickSwap = 'QuickSwap', |     QuickSwap = 'QuickSwap', | ||||||
|     ComethSwap = 'ComethSwap', |     ComethSwap = 'ComethSwap', | ||||||
|     Dfyn = 'Dfyn', |     Dfyn = 'Dfyn', | ||||||
|     WaultSwap = 'WaultSwap', |     WaultSwap = 'WaultSwap', | ||||||
|     Polydex = 'Polydex', |     Polydex = 'Polydex', | ||||||
|  |     FirebirdOneSwap = 'FirebirdOneSwap', | ||||||
|  |     JetSwap = 'JetSwap', | ||||||
|  |     IronSwap = 'IronSwap', | ||||||
| } | } | ||||||
| export type SourcesWithPoolsCache = ERC20BridgeSource.Balancer | ERC20BridgeSource.BalancerV2 | ERC20BridgeSource.Cream; | export type SourcesWithPoolsCache = ERC20BridgeSource.Balancer | ERC20BridgeSource.BalancerV2 | ERC20BridgeSource.Cream; | ||||||
|  |  | ||||||
| @@ -273,7 +279,7 @@ export interface Fill<TFillData extends FillData = FillData> { | |||||||
|     // paths that have the same `source` IDs but are distinct (e.g., Curves). |     // paths that have the same `source` IDs but are distinct (e.g., Curves). | ||||||
|     sourcePathId: string; |     sourcePathId: string; | ||||||
|     // See `SOURCE_FLAGS`. |     // See `SOURCE_FLAGS`. | ||||||
|     flags: number; |     flags: bigint; | ||||||
|     // Input fill amount (taker asset amount in a sell, maker asset amount in a buy). |     // Input fill amount (taker asset amount in a sell, maker asset amount in a buy). | ||||||
|     input: BigNumber; |     input: BigNumber; | ||||||
|     // Output fill amount (maker asset amount in a sell, taker asset amount in a buy). |     // Output fill amount (maker asset amount in a sell, taker asset amount in a buy). | ||||||
| @@ -362,7 +368,7 @@ export interface GetMarketOrdersRfqOpts extends RfqRequestOpts { | |||||||
|  |  | ||||||
| export type FeeEstimate = (fillData: FillData) => number | BigNumber; | export type FeeEstimate = (fillData: FillData) => number | BigNumber; | ||||||
| export type FeeSchedule = Partial<{ [key in ERC20BridgeSource]: FeeEstimate }>; | 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()`. |  * Options for `getMarketSellOrdersAsync()` and `getMarketBuyOrdersAsync()`. | ||||||
| @@ -464,7 +470,7 @@ export interface SourceQuoteOperation<TFillData extends FillData = FillData> ext | |||||||
|  |  | ||||||
| export interface OptimizerResult { | export interface OptimizerResult { | ||||||
|     optimizedOrders: OptimizedMarketOrder[]; |     optimizedOrders: OptimizedMarketOrder[]; | ||||||
|     sourceFlags: number; |     sourceFlags: bigint; | ||||||
|     liquidityDelivered: CollapsedFill[] | DexSample<MultiHopFillData>; |     liquidityDelivered: CollapsedFill[] | DexSample<MultiHopFillData>; | ||||||
|     marketSideLiquidity: MarketSideLiquidity; |     marketSideLiquidity: MarketSideLiquidity; | ||||||
|     adjustedRate: BigNumber; |     adjustedRate: BigNumber; | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ import { RfqMakerBlacklist } from './rfq_maker_blacklist'; | |||||||
|  |  | ||||||
| const MAKER_TIMEOUT_STREAK_LENGTH = 10; | const MAKER_TIMEOUT_STREAK_LENGTH = 10; | ||||||
| const MAKER_TIMEOUT_BLACKLIST_DURATION_MINUTES = 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); | const rfqMakerBlacklist = new RfqMakerBlacklist(MAKER_TIMEOUT_STREAK_LENGTH, MAKER_TIMEOUT_BLACKLIST_DURATION_MINUTES); | ||||||
|  |  | ||||||
| interface RfqQuote<T> { | interface RfqQuote<T> { | ||||||
| @@ -563,6 +564,22 @@ export class QuoteRequestor { | |||||||
|                 this._warningLogger(order, 'Expiry too soon in RFQ-T firm quote, filtering out'); |                 this._warningLogger(order, 'Expiry too soon in RFQ-T firm quote, filtering out'); | ||||||
|                 return false; |                 return false; | ||||||
|             } else { |             } 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; |                 return true; | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ const feeSchedule = { | |||||||
|     [ERC20BridgeSource.Native]: _.constant(GAS_PRICE.times(NATIVE_ORDER_FEE)), |     [ERC20BridgeSource.Native]: _.constant(GAS_PRICE.times(NATIVE_ORDER_FEE)), | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const exchangeProxyOverhead = (sourceFlags: number) => { | const exchangeProxyOverhead = (sourceFlags: bigint) => { | ||||||
|     if ([SOURCE_FLAGS.RfqOrder].includes(sourceFlags)) { |     if ([SOURCE_FLAGS.RfqOrder].includes(sourceFlags)) { | ||||||
|         return new BigNumber(20e3).times(GAS_PRICE); |         return new BigNumber(20e3).times(GAS_PRICE); | ||||||
|     } else { |     } else { | ||||||
|   | |||||||
| @@ -1280,7 +1280,7 @@ describe('MarketOperationUtils tests', () => { | |||||||
|                 }); |                 }); | ||||||
|                 const optimizer = new MarketOperationUtils(MOCK_SAMPLER, contractAddresses, ORDER_DOMAIN); |                 const optimizer = new MarketOperationUtils(MOCK_SAMPLER, contractAddresses, ORDER_DOMAIN); | ||||||
|                 const gasPrice = 100e9; // 100 gwei |                 const gasPrice = 100e9; // 100 gwei | ||||||
|                 const exchangeProxyOverhead = (sourceFlags: number) => |                 const exchangeProxyOverhead = (sourceFlags: bigint) => | ||||||
|                     sourceFlags === SOURCE_FLAGS.LiquidityProvider |                     sourceFlags === SOURCE_FLAGS.LiquidityProvider | ||||||
|                         ? constants.ZERO_AMOUNT |                         ? constants.ZERO_AMOUNT | ||||||
|                         : new BigNumber(1.3e5).times(gasPrice); |                         : new BigNumber(1.3e5).times(gasPrice); | ||||||
| @@ -1663,7 +1663,7 @@ describe('MarketOperationUtils tests', () => { | |||||||
|                 }); |                 }); | ||||||
|                 const optimizer = new MarketOperationUtils(MOCK_SAMPLER, contractAddresses, ORDER_DOMAIN); |                 const optimizer = new MarketOperationUtils(MOCK_SAMPLER, contractAddresses, ORDER_DOMAIN); | ||||||
|                 const gasPrice = 100e9; // 100 gwei |                 const gasPrice = 100e9; // 100 gwei | ||||||
|                 const exchangeProxyOverhead = (sourceFlags: number) => |                 const exchangeProxyOverhead = (sourceFlags: bigint) => | ||||||
|                     sourceFlags === SOURCE_FLAGS.LiquidityProvider |                     sourceFlags === SOURCE_FLAGS.LiquidityProvider | ||||||
|                         ? constants.ZERO_AMOUNT |                         ? constants.ZERO_AMOUNT | ||||||
|                         : new BigNumber(1.3e5).times(gasPrice); |                         : 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 * as chai from 'chai'; | ||||||
| import 'mocha'; | import 'mocha'; | ||||||
|  |  | ||||||
| @@ -49,7 +50,7 @@ describe('Pools Caches for Balancer-based sampling', () => { | |||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     describe('BalancerV2PoolsCache', () => { |     describe('BalancerV2PoolsCache', () => { | ||||||
|         const cache = new BalancerV2PoolsCache(); |         const cache = new BalancerV2PoolsCache(ChainId.Mainnet); | ||||||
|         it('fetches pools', async () => { |         it('fetches pools', async () => { | ||||||
|             const pairs = [ |             const pairs = [ | ||||||
|                 [wethAddress, wbtcAddress], |                 [wethAddress, wbtcAddress], | ||||||
|   | |||||||
| @@ -1,4 +1,24 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "version": "6.6.0", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Add zrxTreasury address", | ||||||
|  |                 "pr": 301 | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1628665757 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "version": "6.5.0", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Deployed `Clipper`", | ||||||
|  |                 "pr": 299 | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1628225642 | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "version": "6.4.0", |         "version": "6.4.0", | ||||||
|         "changes": [ |         "changes": [ | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v6.6.0 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Add zrxTreasury address (#301) | ||||||
|  |  | ||||||
|  | ## v6.5.0 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Deployed `Clipper` (#299) | ||||||
|  |  | ||||||
| ## v6.4.0 - _June 22, 2021_ | ## v6.4.0 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Deployed Lido FQT |     * Deployed Lido FQT | ||||||
|   | |||||||
| @@ -32,11 +32,12 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0x39dce47a67ad34344eab877eae3ef1fa2a1d50bb", |         "exchangeProxyTransformerDeployer": "0x39dce47a67ad34344eab877eae3ef1fa2a1d50bb", | ||||||
|         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", |         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0x407b4128e9ecad8769b2332312a9f655cb9f5f3a", |         "exchangeProxyLiquidityProviderSandbox": "0x407b4128e9ecad8769b2332312a9f655cb9f5f3a", | ||||||
|  |         "zrxTreasury": "0x0bb1810061c2f5b2088054ee184e6c79e1591101", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0xb2bc06a4efb20fc6553a69dbfa49b7be938034a7", |             "wethTransformer": "0xb2bc06a4efb20fc6553a69dbfa49b7be938034a7", | ||||||
|             "payTakerTransformer": "0x4638a7ebe75b911b995d0ec73a81e4f85f41f24e", |             "payTakerTransformer": "0x4638a7ebe75b911b995d0ec73a81e4f85f41f24e", | ||||||
|             "affiliateFeeTransformer": "0xda6d9fc5998f550a094585cf9171f0e8ee3ac59f", |             "affiliateFeeTransformer": "0xda6d9fc5998f550a094585cf9171f0e8ee3ac59f", | ||||||
|             "fillQuoteTransformer": "0x6dfdb2537683ce6101f9090a78197dd58c30bfac", |             "fillQuoteTransformer": "0xb4fa284689c9784a60d840eb136bb16c5246191f", | ||||||
|             "positiveSlippageFeeTransformer": "0xa9416ce1dbde8d331210c07b5c253d94ee4cc3fd" |             "positiveSlippageFeeTransformer": "0xa9416ce1dbde8d331210c07b5c253d94ee4cc3fd" | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
| @@ -73,6 +74,7 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0x1c9a27658dd303a31205a3b245e8993b92d4d502", |         "exchangeProxyTransformerDeployer": "0x1c9a27658dd303a31205a3b245e8993b92d4d502", | ||||||
|         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", |         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0x53a3a41047ae6f6a593df847e3bb287ecd3ac825", |         "exchangeProxyLiquidityProviderSandbox": "0x53a3a41047ae6f6a593df847e3bb287ecd3ac825", | ||||||
|  |         "zrxTreasury": "0x0000000000000000000000000000000000000000", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0x05ad19aa3826e0609a19568ffbd1dfe86c6c7184", |             "wethTransformer": "0x05ad19aa3826e0609a19568ffbd1dfe86c6c7184", | ||||||
|             "payTakerTransformer": "0x6d0ebf2bcd9cc93ec553b60ad201943dcca4e291", |             "payTakerTransformer": "0x6d0ebf2bcd9cc93ec553b60ad201943dcca4e291", | ||||||
| @@ -114,6 +116,7 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0x1c9a27658dd303a31205a3b245e8993b92d4d502", |         "exchangeProxyTransformerDeployer": "0x1c9a27658dd303a31205a3b245e8993b92d4d502", | ||||||
|         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", |         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0x2e2090562076197f94f8d1beac0963b6d4c118b6", |         "exchangeProxyLiquidityProviderSandbox": "0x2e2090562076197f94f8d1beac0963b6d4c118b6", | ||||||
|  |         "zrxTreasury": "0x0000000000000000000000000000000000000000", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0x8d822fe2b42f60531203e288f5f357fa79474437", |             "wethTransformer": "0x8d822fe2b42f60531203e288f5f357fa79474437", | ||||||
|             "payTakerTransformer": "0x150652244723102faeaefa4c79597d097ffa26c6", |             "payTakerTransformer": "0x150652244723102faeaefa4c79597d097ffa26c6", | ||||||
| @@ -155,6 +158,7 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0x1b62de2dbb5e7aa519e9c442721ecef75702807f", |         "exchangeProxyTransformerDeployer": "0x1b62de2dbb5e7aa519e9c442721ecef75702807f", | ||||||
|         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", |         "exchangeProxyFlashWallet": "0x22f9dcf4647084d6c31b2765f6910cd85c178c18", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0x4022e3982f326455f0905de3dbc4449999baf2dc", |         "exchangeProxyLiquidityProviderSandbox": "0x4022e3982f326455f0905de3dbc4449999baf2dc", | ||||||
|  |         "zrxTreasury": "0x0000000000000000000000000000000000000000", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0x9ce35b5ee9e710535e3988e3f8731d9ca9dba17d", |             "wethTransformer": "0x9ce35b5ee9e710535e3988e3f8731d9ca9dba17d", | ||||||
|             "payTakerTransformer": "0x5a53e7b02a83aa9f60ccf4e424f0442c255bc977", |             "payTakerTransformer": "0x5a53e7b02a83aa9f60ccf4e424f0442c255bc977", | ||||||
| @@ -196,6 +200,7 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0x8224aa8fe5c9f07d5a59c735386ff6cc6aaeb568", |         "exchangeProxyTransformerDeployer": "0x8224aa8fe5c9f07d5a59c735386ff6cc6aaeb568", | ||||||
|         "exchangeProxyFlashWallet": "0xdb6f1920a889355780af7570773609bd8cb1f498", |         "exchangeProxyFlashWallet": "0xdb6f1920a889355780af7570773609bd8cb1f498", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0xde7b2747624a647600fdb349184d0448ab954929", |         "exchangeProxyLiquidityProviderSandbox": "0xde7b2747624a647600fdb349184d0448ab954929", | ||||||
|  |         "zrxTreasury": "0x0000000000000000000000000000000000000000", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0xac3d95668c092e895cd83a9cbafe9c7d9906471f", |             "wethTransformer": "0xac3d95668c092e895cd83a9cbafe9c7d9906471f", | ||||||
|             "payTakerTransformer": "0x4f5e8ca2cadecd4a467ae441e4b03de4278a4574", |             "payTakerTransformer": "0x4f5e8ca2cadecd4a467ae441e4b03de4278a4574", | ||||||
| @@ -237,6 +242,7 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0x5409ed021d9299bf6814279a6a1411a7e866a631", |         "exchangeProxyTransformerDeployer": "0x5409ed021d9299bf6814279a6a1411a7e866a631", | ||||||
|         "exchangeProxyFlashWallet": "0xb9682a8e7920b431f1d412b8510f0077410c8faa", |         "exchangeProxyFlashWallet": "0xb9682a8e7920b431f1d412b8510f0077410c8faa", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0x0000000000000000000000000000000000000000", |         "exchangeProxyLiquidityProviderSandbox": "0x0000000000000000000000000000000000000000", | ||||||
|  |         "zrxTreasury": "0x0000000000000000000000000000000000000000", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0xc6b0d3c45a6b5092808196cb00df5c357d55e1d5", |             "wethTransformer": "0xc6b0d3c45a6b5092808196cb00df5c357d55e1d5", | ||||||
|             "payTakerTransformer": "0x7209185959d7227fb77274e1e88151d7c4c368d3", |             "payTakerTransformer": "0x7209185959d7227fb77274e1e88151d7c4c368d3", | ||||||
| @@ -278,6 +284,7 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0xe6d9207df11c55bce2f7a189ae95e3222d5484d3", |         "exchangeProxyTransformerDeployer": "0xe6d9207df11c55bce2f7a189ae95e3222d5484d3", | ||||||
|         "exchangeProxyFlashWallet": "0xdb6f1920a889355780af7570773609bd8cb1f498", |         "exchangeProxyFlashWallet": "0xdb6f1920a889355780af7570773609bd8cb1f498", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0x4dd97080adf36103bd3db822f9d3c0e44890fd69", |         "exchangeProxyLiquidityProviderSandbox": "0x4dd97080adf36103bd3db822f9d3c0e44890fd69", | ||||||
|  |         "zrxTreasury": "0x0000000000000000000000000000000000000000", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0xe309d011cc6f189a3e8dcba85922715a019fed38", |             "wethTransformer": "0xe309d011cc6f189a3e8dcba85922715a019fed38", | ||||||
|             "payTakerTransformer": "0x5ba7b9be86cda01cfbf56e0fb97184783be9dda1", |             "payTakerTransformer": "0x5ba7b9be86cda01cfbf56e0fb97184783be9dda1", | ||||||
| @@ -319,6 +326,7 @@ | |||||||
|         "exchangeProxyTransformerDeployer": "0xa8220408bcb5b327875fd82145d379a83dfd7d61", |         "exchangeProxyTransformerDeployer": "0xa8220408bcb5b327875fd82145d379a83dfd7d61", | ||||||
|         "exchangeProxyFlashWallet": "0xdb6f1920a889355780af7570773609bd8cb1f498", |         "exchangeProxyFlashWallet": "0xdb6f1920a889355780af7570773609bd8cb1f498", | ||||||
|         "exchangeProxyLiquidityProviderSandbox": "0xe6f76f5090f8d64015113841a0c9bc5d14755d6f", |         "exchangeProxyLiquidityProviderSandbox": "0xe6f76f5090f8d64015113841a0c9bc5d14755d6f", | ||||||
|  |         "zrxTreasury": "0x0000000000000000000000000000000000000000", | ||||||
|         "transformers": { |         "transformers": { | ||||||
|             "wethTransformer": "0x44a65ee6b33f70eda7b854abe8d81e925984c932", |             "wethTransformer": "0x44a65ee6b33f70eda7b854abe8d81e925984c932", | ||||||
|             "payTakerTransformer": "0x2f4868ed9cae9a4cdba063818dce19f411be4e75", |             "payTakerTransformer": "0x2f4868ed9cae9a4cdba063818dce19f411be4e75", | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contract-addresses", |     "name": "@0x/contract-addresses", | ||||||
|     "version": "6.4.0", |     "version": "6.6.0", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
|   | |||||||
| @@ -33,6 +33,7 @@ export interface ContractAddresses { | |||||||
|     exchangeProxyTransformerDeployer: string; |     exchangeProxyTransformerDeployer: string; | ||||||
|     exchangeProxyFlashWallet: string; |     exchangeProxyFlashWallet: string; | ||||||
|     exchangeProxyLiquidityProviderSandbox: string; |     exchangeProxyLiquidityProviderSandbox: string; | ||||||
|  |     zrxTreasury: string; | ||||||
|     transformers: { |     transformers: { | ||||||
|         wethTransformer: string; |         wethTransformer: string; | ||||||
|         payTakerTransformer: string; |         payTakerTransformer: string; | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contract-wrappers-test", |     "name": "@0x/contract-wrappers-test", | ||||||
|     "version": "12.2.50", |     "version": "12.2.52", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -31,11 +31,11 @@ | |||||||
|     }, |     }, | ||||||
|     "homepage": "https://github.com/0xProject/protocol/tree/main/packages/contract-wrappers-test", |     "homepage": "https://github.com/0xProject/protocol/tree/main/packages/contract-wrappers-test", | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "@0x/contract-wrappers": "^13.17.2", |         "@0x/contract-wrappers": "^13.17.4", | ||||||
|         "@0x/contracts-test-utils": "^5.4.5", |         "@0x/contracts-test-utils": "^5.4.7", | ||||||
|         "@0x/dev-utils": "^4.2.7", |         "@0x/dev-utils": "^4.2.7", | ||||||
|         "@0x/migrations": "^8.0.11", |         "@0x/migrations": "^8.1.0", | ||||||
|         "@0x/order-utils": "^10.4.26", |         "@0x/order-utils": "^10.4.28", | ||||||
|         "@0x/subproviders": "^6.5.3", |         "@0x/subproviders": "^6.5.3", | ||||||
|         "@0x/ts-doc-gen": "^0.0.28", |         "@0x/ts-doc-gen": "^0.0.28", | ||||||
|         "@0x/tslint-config": "^4.1.4", |         "@0x/tslint-config": "^4.1.4", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "13.17.4", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "13.17.3", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "13.17.2", |         "version": "13.17.2", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v13.17.4 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v13.17.3 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v13.17.2 - _June 22, 2021_ | ## v13.17.2 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/contract-wrappers", |     "name": "@0x/contract-wrappers", | ||||||
|     "version": "13.17.2", |     "version": "13.17.4", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -57,7 +57,7 @@ | |||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/assert": "^3.0.27", |         "@0x/assert": "^3.0.27", | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/json-schemas": "^6.1.3", |         "@0x/json-schemas": "^6.1.3", | ||||||
|         "@0x/types": "^3.3.3", |         "@0x/types": "^3.3.3", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|   | |||||||
| @@ -1,4 +1,23 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "version": "8.1.0", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Add zrxTreasury address", | ||||||
|  |                 "pr": 301 | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1628665757 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "8.0.12", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "8.0.11", |         "version": "8.0.11", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v8.1.0 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Add zrxTreasury address (#301) | ||||||
|  |  | ||||||
|  | ## v8.0.12 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v8.0.11 - _June 22, 2021_ | ## v8.0.11 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/migrations", |     "name": "@0x/migrations", | ||||||
|     "version": "8.0.11", |     "version": "8.1.0", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -68,20 +68,20 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/base-contract": "^6.4.0", |         "@0x/base-contract": "^6.4.0", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contracts-asset-proxy": "^3.7.16", |         "@0x/contracts-asset-proxy": "^3.7.18", | ||||||
|         "@0x/contracts-coordinator": "^3.1.35", |         "@0x/contracts-coordinator": "^3.1.37", | ||||||
|         "@0x/contracts-dev-utils": "^1.3.33", |         "@0x/contracts-dev-utils": "^1.3.35", | ||||||
|         "@0x/contracts-erc1155": "^2.1.34", |         "@0x/contracts-erc1155": "^2.1.36", | ||||||
|         "@0x/contracts-erc20": "^3.3.13", |         "@0x/contracts-erc20": "^3.3.15", | ||||||
|         "@0x/contracts-erc721": "^3.1.34", |         "@0x/contracts-erc721": "^3.1.36", | ||||||
|         "@0x/contracts-exchange": "^3.2.35", |         "@0x/contracts-exchange": "^3.2.37", | ||||||
|         "@0x/contracts-exchange-forwarder": "^4.2.35", |         "@0x/contracts-exchange-forwarder": "^4.2.37", | ||||||
|         "@0x/contracts-extensions": "^6.2.29", |         "@0x/contracts-extensions": "^6.2.31", | ||||||
|         "@0x/contracts-multisig": "^4.1.35", |         "@0x/contracts-multisig": "^4.1.37", | ||||||
|         "@0x/contracts-staking": "^2.0.42", |         "@0x/contracts-staking": "^2.0.44", | ||||||
|         "@0x/contracts-utils": "^4.7.13", |         "@0x/contracts-utils": "^4.7.15", | ||||||
|         "@0x/contracts-zero-ex": "^0.26.0", |         "@0x/contracts-zero-ex": "^0.27.1", | ||||||
|         "@0x/sol-compiler": "^4.7.3", |         "@0x/sol-compiler": "^4.7.3", | ||||||
|         "@0x/subproviders": "^6.5.3", |         "@0x/subproviders": "^6.5.3", | ||||||
|         "@0x/typescript-typings": "^5.2.0", |         "@0x/typescript-typings": "^5.2.0", | ||||||
|   | |||||||
| @@ -384,6 +384,7 @@ export async function runMigrationsAsync( | |||||||
|         exchangeProxyTransformerDeployer: txDefaults.from, |         exchangeProxyTransformerDeployer: txDefaults.from, | ||||||
|         exchangeProxyFlashWallet: exchangeProxyFlashWalletAddress, |         exchangeProxyFlashWallet: exchangeProxyFlashWalletAddress, | ||||||
|         exchangeProxyLiquidityProviderSandbox: NULL_ADDRESS, |         exchangeProxyLiquidityProviderSandbox: NULL_ADDRESS, | ||||||
|  |         zrxTreasury: NULL_ADDRESS, | ||||||
|         transformers: { |         transformers: { | ||||||
|             wethTransformer: wethTransformer.address, |             wethTransformer: wethTransformer.address, | ||||||
|             payTakerTransformer: payTakerTransformer.address, |             payTakerTransformer: payTakerTransformer.address, | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "10.4.28", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628225642, | ||||||
|  |         "version": "10.4.27", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "10.4.26", |         "version": "10.4.26", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v10.4.28 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v10.4.27 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
| ## v10.4.26 - _June 22, 2021_ | ## v10.4.26 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/order-utils", |     "name": "@0x/order-utils", | ||||||
|     "version": "10.4.26", |     "version": "10.4.28", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -69,8 +69,8 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/assert": "^3.0.27", |         "@0x/assert": "^3.0.27", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contract-wrappers": "^13.17.2", |         "@0x/contract-wrappers": "^13.17.4", | ||||||
|         "@0x/json-schemas": "^6.1.3", |         "@0x/json-schemas": "^6.1.3", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|         "@0x/web3-wrapper": "^7.5.3", |         "@0x/web3-wrapper": "^7.5.3", | ||||||
|   | |||||||
| @@ -1,4 +1,22 @@ | |||||||
| [ | [ | ||||||
|  |     { | ||||||
|  |         "timestamp": 1628665757, | ||||||
|  |         "version": "1.8.1", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Dependencies updated" | ||||||
|  |             } | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "version": "1.8.0", | ||||||
|  |         "changes": [ | ||||||
|  |             { | ||||||
|  |                 "note": "Add `Clipper`" | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "timestamp": 1628225642 | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         "timestamp": 1624356181, |         "timestamp": 1624356181, | ||||||
|         "version": "1.7.2", |         "version": "1.7.2", | ||||||
|   | |||||||
| @@ -5,6 +5,14 @@ Edit the package's CHANGELOG.json file only. | |||||||
|  |  | ||||||
| CHANGELOG | CHANGELOG | ||||||
|  |  | ||||||
|  | ## v1.8.1 - _August 11, 2021_ | ||||||
|  |  | ||||||
|  |     * Dependencies updated | ||||||
|  |  | ||||||
|  | ## v1.8.0 - _August 6, 2021_ | ||||||
|  |  | ||||||
|  |     * Add `Clipper` | ||||||
|  |  | ||||||
| ## v1.7.2 - _June 22, 2021_ | ## v1.7.2 - _June 22, 2021_ | ||||||
|  |  | ||||||
|     * Dependencies updated |     * Dependencies updated | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|     "name": "@0x/protocol-utils", |     "name": "@0x/protocol-utils", | ||||||
|     "version": "1.7.2", |     "version": "1.8.1", | ||||||
|     "engines": { |     "engines": { | ||||||
|         "node": ">=6.12" |         "node": ">=6.12" | ||||||
|     }, |     }, | ||||||
| @@ -63,8 +63,8 @@ | |||||||
|     }, |     }, | ||||||
|     "dependencies": { |     "dependencies": { | ||||||
|         "@0x/assert": "^3.0.27", |         "@0x/assert": "^3.0.27", | ||||||
|         "@0x/contract-addresses": "^6.4.0", |         "@0x/contract-addresses": "^6.6.0", | ||||||
|         "@0x/contract-wrappers": "^13.17.2", |         "@0x/contract-wrappers": "^13.17.4", | ||||||
|         "@0x/json-schemas": "^6.1.3", |         "@0x/json-schemas": "^6.1.3", | ||||||
|         "@0x/subproviders": "^6.5.3", |         "@0x/subproviders": "^6.5.3", | ||||||
|         "@0x/utils": "^6.4.3", |         "@0x/utils": "^6.4.3", | ||||||
|   | |||||||
| @@ -131,6 +131,7 @@ export enum BridgeProtocol { | |||||||
|     KyberDmm, |     KyberDmm, | ||||||
|     CurveV2, |     CurveV2, | ||||||
|     Lido, |     Lido, | ||||||
|  |     Clipper, | ||||||
| } | } | ||||||
| // tslint:enable: enum-naming | // tslint:enable: enum-naming | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user