Compare commits
	
		
			165 Commits
		
	
	
		
			@0x/contra
			...
			protocol@b
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					bb04726e7f | ||
| 
						 | 
					220ca370c2 | ||
| 
						 | 
					63af4e3e98 | ||
| 
						 | 
					9754e12d82 | ||
| 
						 | 
					d72ebed246 | ||
| 
						 | 
					587fc71058 | ||
| 
						 | 
					7d34e09a12 | ||
| 
						 | 
					7d15baad0f | ||
| 
						 | 
					1e6476ada7 | ||
| 
						 | 
					1d6ca5f6b5 | ||
| 
						 | 
					fb249f02fc | ||
| 
						 | 
					fdf04ef275 | ||
| 
						 | 
					b0f5f634f2 | ||
| 
						 | 
					6ee0108565 | ||
| 
						 | 
					c73097e688 | ||
| 
						 | 
					a2d42b07b5 | ||
| 
						 | 
					f9a794af93 | ||
| 
						 | 
					a2643674ca | ||
| 
						 | 
					c00ce9daac | ||
| 
						 | 
					c68b5d7844 | ||
| 
						 | 
					09ed106d4c | ||
| 
						 | 
					a6b92fc658 | ||
| 
						 | 
					4be4a1a30b | ||
| 
						 | 
					9bede5d331 | ||
| 
						 | 
					b50d4aee6d | ||
| 
						 | 
					55bc367bd6 | ||
| 
						 | 
					7a59b7eafe | ||
| 
						 | 
					9e59d41e44 | ||
| 
						 | 
					475e6c7bca | ||
| 
						 | 
					dbc5a5293e | ||
| 
						 | 
					f4bd2bd0d8 | ||
| 
						 | 
					f1782a83ba | ||
| 
						 | 
					cbade0d558 | ||
| 
						 | 
					fe0c26387c | ||
| 
						 | 
					c03a014740 | ||
| 
						 | 
					84e6d788aa | ||
| 
						 | 
					cd296b8767 | ||
| 
						 | 
					5946d32a7d | ||
| 
						 | 
					842dd8572b | ||
| 
						 | 
					33e260f9db | ||
| 
						 | 
					c44f8d0060 | ||
| 
						 | 
					411548a33e | ||
| 
						 | 
					9a17ce1383 | ||
| 
						 | 
					2b120d0669 | ||
| 
						 | 
					6d877d5242 | ||
| 
						 | 
					e4abd690e7 | ||
| 
						 | 
					2a194384b6 | ||
| 
						 | 
					1e069e6f8a | ||
| 
						 | 
					a019bb913d | ||
| 
						 | 
					9ce73931f7 | ||
| 
						 | 
					97020df178 | ||
| 
						 | 
					dfb7b3de8f | ||
| 
						 | 
					9e152912fe | ||
| 
						 | 
					b2c2f1e1aa | ||
| 
						 | 
					629c7d8e92 | ||
| 
						 | 
					62f24d4356 | ||
| 
						 | 
					ae281c33ca | ||
| 
						 | 
					5d034dd106 | ||
| 
						 | 
					c1f8df0eca | ||
| 
						 | 
					76dda9eeda | ||
| 
						 | 
					a9b84a92ac | ||
| 
						 | 
					0f7e881899 | ||
| 
						 | 
					6045f777ab | ||
| 
						 | 
					5a15044ead | ||
| 
						 | 
					a69d76e487 | ||
| 
						 | 
					3adfcdffa8 | ||
| 
						 | 
					164a5d44d9 | ||
| 
						 | 
					70ddab0231 | ||
| 
						 | 
					7bf009fbf6 | ||
| 
						 | 
					525bc8197b | ||
| 
						 | 
					24397c51a8 | ||
| 
						 | 
					06b3464756 | ||
| 
						 | 
					bbaa90bd9a | ||
| 
						 | 
					5c683cbc0f | ||
| 
						 | 
					95345f18bc | ||
| 
						 | 
					4c3fbe83ac | ||
| 
						 | 
					7caa43d02c | ||
| 
						 | 
					3d4c03c9df | ||
| 
						 | 
					22e1ed35d3 | ||
| 
						 | 
					dabe6fd793 | ||
| 
						 | 
					3cc639c8d0 | ||
| 
						 | 
					22c8e0b6db | ||
| 
						 | 
					f3ca4293bc | ||
| 
						 | 
					db3e076d03 | ||
| 
						 | 
					1a6759820a | ||
| 
						 | 
					61c5e7b948 | ||
| 
						 | 
					5fd78ef32f | ||
| 
						 | 
					14ff9b827c | ||
| 
						 | 
					598dc2cd71 | ||
| 
						 | 
					08e1c5109f | ||
| 
						 | 
					6f7a843742 | ||
| 
						 | 
					c9c9615bb5 | ||
| 
						 | 
					f98609686d | ||
| 
						 | 
					5b8bbc34e8 | ||
| 
						 | 
					49cb00a9ab | ||
| 
						 | 
					74b240fb88 | ||
| 
						 | 
					514f9d2621 | ||
| 
						 | 
					fa78d1092a | ||
| 
						 | 
					297342092b | ||
| 
						 | 
					076f263a86 | ||
| 
						 | 
					0c56207abc | ||
| 
						 | 
					23953d8a5a | ||
| 
						 | 
					c6919eb25a | ||
| 
						 | 
					d509604b52 | ||
| 
						 | 
					a74a3450eb | ||
| 
						 | 
					72c5399b9d | ||
| 
						 | 
					b29196b983 | ||
| 
						 | 
					ce76a7033d | ||
| 
						 | 
					3f4bb933d1 | ||
| 
						 | 
					501b7b9b65 | ||
| 
						 | 
					c0ea88e864 | ||
| 
						 | 
					48f8bea460 | ||
| 
						 | 
					f4e5b6e38d | ||
| 
						 | 
					477cb0a48d | ||
| 
						 | 
					d6bc0a3368 | ||
| 
						 | 
					e544a804c2 | ||
| 
						 | 
					96e0ad7899 | ||
| 
						 | 
					5a1fee5d31 | ||
| 
						 | 
					3557a5e5a9 | ||
| 
						 | 
					0bd43d5265 | ||
| 
						 | 
					8fd7c1b386 | ||
| 
						 | 
					50068750f5 | ||
| 
						 | 
					a7a905de4c | ||
| 
						 | 
					f283108586 | ||
| 
						 | 
					9afe05095a | ||
| 
						 | 
					3dab892978 | ||
| 
						 | 
					e40ddb800e | ||
| 
						 | 
					72a74e7c66 | ||
| 
						 | 
					e8ae64673f | ||
| 
						 | 
					2451f419c8 | ||
| 
						 | 
					2394eb62aa | ||
| 
						 | 
					f9078bb1c3 | ||
| 
						 | 
					bf25c81f1c | ||
| 
						 | 
					03ecc530c3 | ||
| 
						 | 
					d52b1d24d0 | ||
| 
						 | 
					5083fab06a | ||
| 
						 | 
					1249bf9ccc | ||
| 
						 | 
					681f6b3f07 | ||
| 
						 | 
					d3ca1fe96b | ||
| 
						 | 
					9e4f5815e4 | ||
| 
						 | 
					c3c27eaedc | ||
| 
						 | 
					4bf6a23d23 | ||
| 
						 | 
					aaaf0d02de | ||
| 
						 | 
					825cc4d035 | ||
| 
						 | 
					c2d44e5c10 | ||
| 
						 | 
					0efd0860c8 | ||
| 
						 | 
					a890a06664 | ||
| 
						 | 
					5befb87071 | ||
| 
						 | 
					12ba4c373a | ||
| 
						 | 
					7fd25be02e | ||
| 
						 | 
					aa688c4a92 | ||
| 
						 | 
					fb437551c9 | ||
| 
						 | 
					6fa1de7889 | ||
| 
						 | 
					7a42df9a65 | ||
| 
						 | 
					15a508f3ea | ||
| 
						 | 
					b3c20ff909 | ||
| 
						 | 
					682c07cb73 | ||
| 
						 | 
					602605ab4b | ||
| 
						 | 
					0eff2548d5 | ||
| 
						 | 
					93ee681204 | ||
| 
						 | 
					d7bea98075 | ||
| 
						 | 
					437a3b048d | ||
| 
						 | 
					f55a9454b5 | ||
| 
						 | 
					3b03ad0db4 | ||
| 
						 | 
					27d679e1f1 | 
@@ -1,25 +1,25 @@
 | 
				
			|||||||
version: 2
 | 
					version: 2.1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
jobs:
 | 
					jobs:
 | 
				
			||||||
    build:
 | 
					    build:
 | 
				
			||||||
        resource_class: medium+
 | 
					        resource_class: large
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        environment:
 | 
					        environment:
 | 
				
			||||||
            CONTRACTS_COMMIT_HASH: '9ed05f5'
 | 
					            NODE_OPTIONS: '--max-old-space-size=6442'
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - checkout
 | 
					            - checkout
 | 
				
			||||||
            - run: echo 'export PATH=$HOME/CIRCLE_PROJECT_REPONAME/node_modules/.bin:$PATH' >> $BASH_ENV
 | 
					            - run: echo 'export PATH=$HOME/CIRCLE_PROJECT_REPONAME/node_modules/.bin:$PATH' >> $BASH_ENV
 | 
				
			||||||
            - run:
 | 
					            - run:
 | 
				
			||||||
                  name: install-yarn
 | 
					                  name: install-yarn
 | 
				
			||||||
                  command: npm install --force --global yarn@1.17.0
 | 
					                  command: npm install --force --global yarn@1.22.0
 | 
				
			||||||
            - run:
 | 
					            - run:
 | 
				
			||||||
                  name: yarn
 | 
					                  name: yarn
 | 
				
			||||||
                  command: yarn --frozen-lockfile --ignore-engines install || yarn --frozen-lockfile --ignore-engines install
 | 
					                  command: yarn --frozen-lockfile --ignore-engines install || yarn --frozen-lockfile --ignore-engines install
 | 
				
			||||||
            - setup_remote_docker
 | 
					            - setup_remote_docker
 | 
				
			||||||
            - run: yarn build:ci
 | 
					            - run: yarn build:ci || yarn build:ci || yarn build:ci
 | 
				
			||||||
            - run: yarn build:ts
 | 
					            - run: yarn build:ts || yarn build:ts || yarn build:ts
 | 
				
			||||||
            - save_cache:
 | 
					            - save_cache:
 | 
				
			||||||
                  key: repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                  key: repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
                  paths:
 | 
					                  paths:
 | 
				
			||||||
@@ -31,57 +31,59 @@ jobs:
 | 
				
			|||||||
    test-exchange-ganache:
 | 
					    test-exchange-ganache:
 | 
				
			||||||
        resource_class: medium+
 | 
					        resource_class: medium+
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
                  keys:
 | 
					                  keys:
 | 
				
			||||||
                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contracts-exchange
 | 
					            - run: yarn wsrun -p @0x/contracts-exchange -m --serial -c test:circleci
 | 
				
			||||||
    test-integrations-ganache:
 | 
					    test-integrations-ganache:
 | 
				
			||||||
        resource_class: medium+
 | 
					        resource_class: medium+
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
                  keys:
 | 
					                  keys:
 | 
				
			||||||
                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contracts-integrations
 | 
					            - run: yarn wsrun -p @0x/contracts-integrations -m --serial -c test:circleci
 | 
				
			||||||
    test-contracts-staking-ganache:
 | 
					    test-contracts-staking-ganache:
 | 
				
			||||||
        resource_class: medium+
 | 
					        resource_class: medium+
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
                  keys:
 | 
					                  keys:
 | 
				
			||||||
                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contracts-staking
 | 
					            - run: yarn wsrun -p @0x/contracts-staking -m --serial -c test:circleci
 | 
				
			||||||
    test-contracts-extra-ganache:
 | 
					    test-contracts-extra-ganache:
 | 
				
			||||||
        resource_class: medium+
 | 
					        resource_class: medium+
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
                  keys:
 | 
					                  keys:
 | 
				
			||||||
                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contracts-exchange-forwarder @0x/contracts-coordinator
 | 
					            - run: yarn wsrun -p @0x/contracts-exchange-forwarder -p @0x/contracts-coordinator -m --serial -c test:circleci
 | 
				
			||||||
    test-contracts-rest-ganache:
 | 
					    test-contracts-rest-ganache:
 | 
				
			||||||
        resource_class: medium+
 | 
					        resource_class: medium+
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
                  keys:
 | 
					                  keys:
 | 
				
			||||||
                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contracts-multisig @0x/contracts-utils @0x/contracts-exchange-libs @0x/contracts-erc20 @0x/contracts-erc721 @0x/contracts-erc1155 @0x/contracts-asset-proxy @0x/contracts-broker @0x/contracts-zero-ex
 | 
					            - run: yarn wsrun -p @0x/contracts-multisig -p @0x/contracts-utils -p @0x/contracts-exchange-libs -p  @0x/contracts-erc20 -p @0x/contracts-erc721 -p @0x/contracts-erc1155 -p @0x/contracts-asset-proxy -p @0x/contracts-broker -p @0x/contracts-zero-ex -m --serial -c test:circleci
 | 
				
			||||||
    test-publish:
 | 
					    test-publish:
 | 
				
			||||||
        resource_class: medium+
 | 
					        resource_class: large
 | 
				
			||||||
 | 
					        environment:
 | 
				
			||||||
 | 
					            NODE_OPTIONS: '--max-old-space-size=6442'
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
            - image: 0xorg/verdaccio
 | 
					            - image: 0xorg/verdaccio
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
@@ -95,7 +97,7 @@ jobs:
 | 
				
			|||||||
                  path: ~/.npm/_logs
 | 
					                  path: ~/.npm/_logs
 | 
				
			||||||
    test-doc-generation:
 | 
					    test-doc-generation:
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
@@ -106,18 +108,18 @@ jobs:
 | 
				
			|||||||
                  no_output_timeout: 1200
 | 
					                  no_output_timeout: 1200
 | 
				
			||||||
    test-rest:
 | 
					    test-rest:
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
                  keys:
 | 
					                  keys:
 | 
				
			||||||
                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                      - repo-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contracts-test-utils
 | 
					            - run: yarn wsrun -p @0x/contracts-test-utils -m --serial -c test:circleci
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contract-artifacts
 | 
					            - run: yarn wsrun -p @0x/contract-artifacts -m --serial -c test:circleci
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/contract-wrappers-test
 | 
					            - run: yarn wsrun -p @0x/contract-wrappers-test -m --serial -c test:circleci
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/migrations
 | 
					            - run: yarn wsrun -p @0x/migrations -m --serial -c test:circleci
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/order-utils
 | 
					            - run: yarn wsrun -p @0x/order-utils -m --serial -c test:circleci
 | 
				
			||||||
            - run: yarn wsrun test:circleci @0x/asset-swapper
 | 
					            - run: yarn wsrun -p @0x/asset-swapper -m --serial -c test:circleci
 | 
				
			||||||
            - save_cache:
 | 
					            - save_cache:
 | 
				
			||||||
                  key: coverage-contract-wrappers-test-{{ .Environment.CIRCLE_SHA1 }}
 | 
					                  key: coverage-contract-wrappers-test-{{ .Environment.CIRCLE_SHA1 }}
 | 
				
			||||||
                  paths:
 | 
					                  paths:
 | 
				
			||||||
@@ -134,7 +136,7 @@ jobs:
 | 
				
			|||||||
        resource_class: large
 | 
					        resource_class: large
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
                  keys:
 | 
					                  keys:
 | 
				
			||||||
@@ -145,7 +147,7 @@ jobs:
 | 
				
			|||||||
            - run: yarn diff_md_docs:ci
 | 
					            - run: yarn diff_md_docs:ci
 | 
				
			||||||
    submit-coverage:
 | 
					    submit-coverage:
 | 
				
			||||||
        docker:
 | 
					        docker:
 | 
				
			||||||
            - image: nikolaik/python-nodejs:python3.7-nodejs10
 | 
					            - image: node:12
 | 
				
			||||||
        working_directory: ~/repo
 | 
					        working_directory: ~/repo
 | 
				
			||||||
        steps:
 | 
					        steps:
 | 
				
			||||||
            - restore_cache:
 | 
					            - restore_cache:
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										7
									
								
								.github/workflows/publish.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/workflows/publish.yml
									
									
									
									
										vendored
									
									
								
							@@ -7,6 +7,9 @@ on:
 | 
				
			|||||||
              description: 'required CI status'
 | 
					              description: 'required CI status'
 | 
				
			||||||
              default: 'success'
 | 
					              default: 'success'
 | 
				
			||||||
              required: true
 | 
					              required: true
 | 
				
			||||||
 | 
					          prerelease:
 | 
				
			||||||
 | 
					              description: 'prerelease name'
 | 
				
			||||||
 | 
					              required: false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
jobs:
 | 
					jobs:
 | 
				
			||||||
    publish:
 | 
					    publish:
 | 
				
			||||||
@@ -21,7 +24,7 @@ jobs:
 | 
				
			|||||||
                  (echo "::error ::${{ github.ref }} does not have a successful CI status" && false)
 | 
					                  (echo "::error ::${{ github.ref }} does not have a successful CI status" && false)
 | 
				
			||||||
            - uses: actions/checkout@v2
 | 
					            - uses: actions/checkout@v2
 | 
				
			||||||
              with:
 | 
					              with:
 | 
				
			||||||
                ref: 'development'
 | 
					                ref: ${{ github.ref }}
 | 
				
			||||||
                fetch-depth: 0
 | 
					                fetch-depth: 0
 | 
				
			||||||
            - uses: actions/setup-node@v1
 | 
					            - uses: actions/setup-node@v1
 | 
				
			||||||
              with:
 | 
					              with:
 | 
				
			||||||
@@ -41,7 +44,9 @@ jobs:
 | 
				
			|||||||
              env:
 | 
					              env:
 | 
				
			||||||
                  NPM_TOKEN: ${{ secrets.NPM_PUBLISH_TOKEN }}
 | 
					                  NPM_TOKEN: ${{ secrets.NPM_PUBLISH_TOKEN }}
 | 
				
			||||||
                  GITHUB_TOKEN: ${{ github.token }}
 | 
					                  GITHUB_TOKEN: ${{ github.token }}
 | 
				
			||||||
 | 
					                  PUBLISH_PRERELEASE: ${{ github.event.inputs.prerelease }}
 | 
				
			||||||
            - name: 'merge into main branch'
 | 
					            - name: 'merge into main branch'
 | 
				
			||||||
 | 
					              if: github.event.inputs.prerelease == '' # unless it's a prerelease
 | 
				
			||||||
              run: |
 | 
					              run: |
 | 
				
			||||||
                  git checkout main && \
 | 
					                  git checkout main && \
 | 
				
			||||||
                  git merge ${{ github.ref }} && \
 | 
					                  git merge ${{ github.ref }} && \
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -113,6 +113,8 @@ contracts/dev-utils/generated-artifacts/
 | 
				
			|||||||
contracts/dev-utils/test/generated-artifacts/
 | 
					contracts/dev-utils/test/generated-artifacts/
 | 
				
			||||||
contracts/zero-ex/generated-artifacts/
 | 
					contracts/zero-ex/generated-artifacts/
 | 
				
			||||||
contracts/zero-ex/test/generated-artifacts/
 | 
					contracts/zero-ex/test/generated-artifacts/
 | 
				
			||||||
 | 
					contracts/treasury/generated-artifacts/
 | 
				
			||||||
 | 
					contracts/treasury/test/generated-artifacts/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# generated truffle contract artifacts/
 | 
					# generated truffle contract artifacts/
 | 
				
			||||||
contracts/broker/build/
 | 
					contracts/broker/build/
 | 
				
			||||||
@@ -167,6 +169,8 @@ contracts/dev-utils/generated-wrappers/
 | 
				
			|||||||
contracts/dev-utils/test/generated-wrappers/
 | 
					contracts/dev-utils/test/generated-wrappers/
 | 
				
			||||||
contracts/zero-ex/generated-wrappers/
 | 
					contracts/zero-ex/generated-wrappers/
 | 
				
			||||||
contracts/zero-ex/test/generated-wrappers/
 | 
					contracts/zero-ex/test/generated-wrappers/
 | 
				
			||||||
 | 
					contracts/treasury/generated-wrappers/
 | 
				
			||||||
 | 
					contracts/treasury/test/generated-wrappers/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Doc README copy
 | 
					# Doc README copy
 | 
				
			||||||
packages/*/docs/README.md
 | 
					packages/*/docs/README.md
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -64,6 +64,10 @@ lib
 | 
				
			|||||||
/contracts/zero-ex/test/generated-wrappers
 | 
					/contracts/zero-ex/test/generated-wrappers
 | 
				
			||||||
/contracts/zero-ex/generated-artifacts
 | 
					/contracts/zero-ex/generated-artifacts
 | 
				
			||||||
/contracts/zero-ex/test/generated-artifacts
 | 
					/contracts/zero-ex/test/generated-artifacts
 | 
				
			||||||
 | 
					/contracts/treasury/generated-wrappers
 | 
				
			||||||
 | 
					/contracts/treasury/test/generated-wrappers
 | 
				
			||||||
 | 
					/contracts/treasury/generated-artifacts
 | 
				
			||||||
 | 
					/contracts/treasury/test/generated-artifacts
 | 
				
			||||||
/contracts/staking/build/
 | 
					/contracts/staking/build/
 | 
				
			||||||
/contracts/coordinator/build/
 | 
					/contracts/coordinator/build/
 | 
				
			||||||
/contracts/exchange/build/
 | 
					/contracts/exchange/build/
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -13,7 +13,6 @@
 | 
				
			|||||||
        "indent": ["error", 4],
 | 
					        "indent": ["error", 4],
 | 
				
			||||||
        "max-line-length": ["warn", 160],
 | 
					        "max-line-length": ["warn", 160],
 | 
				
			||||||
        "no-inline-assembly": false,
 | 
					        "no-inline-assembly": false,
 | 
				
			||||||
        "no-empty-blocks": false,
 | 
					 | 
				
			||||||
        "quotes": ["error", "double"],
 | 
					        "quotes": ["error", "double"],
 | 
				
			||||||
        "separate-by-one-line-in-contract": "error",
 | 
					        "separate-by-one-line-in-contract": "error",
 | 
				
			||||||
        "space-after-comma": "error",
 | 
					        "space-after-comma": "error",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,113 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "3.7.11",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "3.7.10",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "3.7.9",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "3.7.8",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "3.7.7",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "3.7.6",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "3.7.5",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "3.7.4",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "3.7.3",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "3.7.2",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "3.7.1",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "version": "3.7.0",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Fix Bancor support of ETH",
 | 
				
			||||||
 | 
					                "pr": 88
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "timestamp": 1608105788
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "3.6.9",
 | 
					        "version": "3.6.9",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.11 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.10 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.9 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.8 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.7 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.6 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.5 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.4 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.3 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.2 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.1 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.7.0 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Fix Bancor support of ETH (#88)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v3.6.9 - _December 9, 2020_
 | 
					## v3.6.9 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -21,6 +21,7 @@ pragma solidity ^0.5.9;
 | 
				
			|||||||
pragma experimental ABIEncoderV2;
 | 
					pragma experimental ABIEncoderV2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import "@0x/contracts-erc20/contracts/src/interfaces/IERC20Token.sol";
 | 
					import "@0x/contracts-erc20/contracts/src/interfaces/IERC20Token.sol";
 | 
				
			||||||
 | 
					import "@0x/contracts-erc20/contracts/src/interfaces/IEtherToken.sol";
 | 
				
			||||||
import "@0x/contracts-erc20/contracts/src/LibERC20Token.sol";
 | 
					import "@0x/contracts-erc20/contracts/src/LibERC20Token.sol";
 | 
				
			||||||
import "@0x/contracts-exchange-libs/contracts/src/IWallet.sol";
 | 
					import "@0x/contracts-exchange-libs/contracts/src/IWallet.sol";
 | 
				
			||||||
import "@0x/contracts-utils/contracts/src/DeploymentConstants.sol";
 | 
					import "@0x/contracts-utils/contracts/src/DeploymentConstants.sol";
 | 
				
			||||||
@@ -36,6 +37,20 @@ contract BancorBridge is
 | 
				
			|||||||
    struct TransferState {
 | 
					    struct TransferState {
 | 
				
			||||||
        address bancorNetworkAddress;
 | 
					        address bancorNetworkAddress;
 | 
				
			||||||
        address[] path;
 | 
					        address[] path;
 | 
				
			||||||
 | 
					        IEtherToken weth;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Bancor ETH pseudo-address.
 | 
				
			||||||
 | 
					    address constant public BANCOR_ETH_ADDRESS = 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // solhint-disable no-empty-blocks
 | 
				
			||||||
 | 
					    /// @dev Payable fallback to receive ETH from Bancor/WETH.
 | 
				
			||||||
 | 
					    function ()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        payable
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        // Poor man's receive in 0.5.9
 | 
				
			||||||
 | 
					        require(msg.data.length == 0);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /// @dev Callback for `IERC20Bridge`. Tries to buy `amount` of
 | 
					    /// @dev Callback for `IERC20Bridge`. Tries to buy `amount` of
 | 
				
			||||||
@@ -60,7 +75,6 @@ contract BancorBridge is
 | 
				
			|||||||
    {
 | 
					    {
 | 
				
			||||||
        // hold variables to get around stack depth limitations
 | 
					        // hold variables to get around stack depth limitations
 | 
				
			||||||
        TransferState memory state;
 | 
					        TransferState memory state;
 | 
				
			||||||
 | 
					 | 
				
			||||||
        // Decode the bridge data.
 | 
					        // Decode the bridge data.
 | 
				
			||||||
        (
 | 
					        (
 | 
				
			||||||
            state.path,
 | 
					            state.path,
 | 
				
			||||||
@@ -68,34 +82,42 @@ contract BancorBridge is
 | 
				
			|||||||
        // solhint-disable indent
 | 
					        // solhint-disable indent
 | 
				
			||||||
        ) = abi.decode(bridgeData, (address[], address));
 | 
					        ) = abi.decode(bridgeData, (address[], address));
 | 
				
			||||||
        // solhint-enable indent
 | 
					        // solhint-enable indent
 | 
				
			||||||
 | 
					        state.weth = IEtherToken(_getWethAddress());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        require(state.path.length > 0, "BancorBridge/PATH_MUST_EXIST");
 | 
					        require(state.path.length >= 2, "BancorBridge/PATH_LENGTH_MUST_BE_GREATER_THAN_TWO");
 | 
				
			||||||
        // Just transfer the tokens if they're the same.
 | 
					
 | 
				
			||||||
        if (state.path[0] == toTokenAddress) {
 | 
					        // Grant an allowance to the Bancor Network to spend `fromTokenAddress` token.
 | 
				
			||||||
            LibERC20Token.transfer(state.path[0], to, amount);
 | 
					        uint256 fromTokenBalance;
 | 
				
			||||||
            return BRIDGE_SUCCESS;
 | 
					        uint256 payableAmount = 0;
 | 
				
			||||||
 | 
					        // If it's ETH in the path then withdraw from WETH
 | 
				
			||||||
 | 
					        // The Bancor path will have ETH as the 0xeee address
 | 
				
			||||||
 | 
					        // Bancor expects to be paid in ETH not WETH
 | 
				
			||||||
 | 
					        if (state.path[0] == BANCOR_ETH_ADDRESS) {
 | 
				
			||||||
 | 
					            fromTokenBalance = state.weth.balanceOf(address(this));
 | 
				
			||||||
 | 
					            state.weth.withdraw(fromTokenBalance);
 | 
				
			||||||
 | 
					            payableAmount = fromTokenBalance;
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            fromTokenBalance = IERC20Token(state.path[0]).balanceOf(address(this));
 | 
				
			||||||
 | 
					            LibERC20Token.approveIfBelow(state.path[0], state.bancorNetworkAddress, fromTokenBalance);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        // Otherwise use Bancor to convert
 | 
					 | 
				
			||||||
        require(state.path.length > 2, "BancorBridge/PATH_LENGTH_MUST_BE_GREATER_THAN_TWO");
 | 
					 | 
				
			||||||
        require(state.path[state.path.length - 1] == toTokenAddress, "BancorBridge/LAST_ELEMENT_OF_PATH_MUST_MATCH_OUTPUT_TOKEN");
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
        // // Grant an allowance to the Bancor Network to spend `fromTokenAddress` token.
 | 
					 | 
				
			||||||
        uint256 fromTokenBalance = IERC20Token(state.path[0]).balanceOf(address(this));
 | 
					 | 
				
			||||||
        LibERC20Token.approveIfBelow(state.path[0], state.bancorNetworkAddress, fromTokenBalance);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        // Convert the tokens
 | 
					        // Convert the tokens
 | 
				
			||||||
        uint256 boughtAmount = IBancorNetwork(state.bancorNetworkAddress).convertByPath(
 | 
					        uint256 boughtAmount = IBancorNetwork(state.bancorNetworkAddress).convertByPath.value(payableAmount)(
 | 
				
			||||||
            state.path, // path originating with source token and terminating in destination token
 | 
					            state.path, // path originating with source token and terminating in destination token
 | 
				
			||||||
            fromTokenBalance, // amount of source token to trade
 | 
					            fromTokenBalance, // amount of source token to trade
 | 
				
			||||||
            amount, // minimum amount of destination token expected to receive
 | 
					            amount, // minimum amount of destination token expected to receive
 | 
				
			||||||
            to, // beneficiary
 | 
					            state.path[state.path.length-1] == BANCOR_ETH_ADDRESS ? address(this) : to, // beneficiary
 | 
				
			||||||
            address(0), // affiliateAccount; no fee paid
 | 
					            address(0), // affiliateAccount; no fee paid
 | 
				
			||||||
            0 // affiliateFee; no fee paid
 | 
					            0 // affiliateFee; no fee paid
 | 
				
			||||||
        );
 | 
					        );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (state.path[state.path.length-1] == BANCOR_ETH_ADDRESS) {
 | 
				
			||||||
 | 
					            state.weth.deposit.value(boughtAmount)();
 | 
				
			||||||
 | 
					            state.weth.transfer(to, boughtAmount);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        emit ERC20BridgeTransfer(
 | 
					        emit ERC20BridgeTransfer(
 | 
				
			||||||
            state.path[0], // fromTokenAddress
 | 
					            state.path[0] == BANCOR_ETH_ADDRESS ? address(state.weth) : state.path[0],
 | 
				
			||||||
            toTokenAddress,
 | 
					            toTokenAddress,
 | 
				
			||||||
            fromTokenBalance,
 | 
					            fromTokenBalance,
 | 
				
			||||||
            boughtAmount,
 | 
					            boughtAmount,
 | 
				
			||||||
@@ -118,5 +140,5 @@ contract BancorBridge is
 | 
				
			|||||||
    {
 | 
					    {
 | 
				
			||||||
        return LEGACY_WALLET_MAGIC_VALUE;
 | 
					        return LEGACY_WALLET_MAGIC_VALUE;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -56,11 +56,14 @@ contract KyberBridge is
 | 
				
			|||||||
    uint256 constant private KYBER_RATE_BASE = 10 ** 18;
 | 
					    uint256 constant private KYBER_RATE_BASE = 10 ** 18;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // solhint-disable no-empty-blocks
 | 
					    // solhint-disable no-empty-blocks
 | 
				
			||||||
    /// @dev Payable fallback to receive ETH from Kyber.
 | 
					    /// @dev Payable fallback to receive ETH from Kyber/WETH.
 | 
				
			||||||
    function ()
 | 
					    function ()
 | 
				
			||||||
        external
 | 
					        external
 | 
				
			||||||
        payable
 | 
					        payable
 | 
				
			||||||
    {}
 | 
					    {
 | 
				
			||||||
 | 
					        // Poor man's receive in 0.5.9
 | 
				
			||||||
 | 
					        require(msg.data.length == 0);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /// @dev Callback for `IKyberBridge`. Tries to buy `amount` of
 | 
					    /// @dev Callback for `IKyberBridge`. Tries to buy `amount` of
 | 
				
			||||||
    ///      `toTokenAddress` tokens by selling the entirety of the opposing asset
 | 
					    ///      `toTokenAddress` tokens by selling the entirety of the opposing asset
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-asset-proxy",
 | 
					    "name": "@0x/contracts-asset-proxy",
 | 
				
			||||||
    "version": "3.6.9",
 | 
					    "version": "3.7.11",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -51,15 +51,15 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contract-wrappers": "^13.11.0",
 | 
					        "@0x/contract-wrappers": "^13.16.1",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -67,7 +67,7 @@
 | 
				
			|||||||
        "chai-as-promised": "^7.1.0",
 | 
					        "chai-as-promised": "^7.1.0",
 | 
				
			||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereumjs-util": "^5.1.1",
 | 
					        "ethereumjs-util": "^7.0.10",
 | 
				
			||||||
        "make-promises-safe": "^1.1.0",
 | 
					        "make-promises-safe": "^1.1.0",
 | 
				
			||||||
        "mocha": "^6.2.0",
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
        "npm-run-all": "^4.1.2",
 | 
					        "npm-run-all": "^4.1.2",
 | 
				
			||||||
@@ -76,20 +76,20 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contracts-erc1155": "^2.1.18",
 | 
					        "@0x/contracts-erc1155": "^2.1.29",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-erc721": "^3.1.18",
 | 
					        "@0x/contracts-erc721": "^3.1.29",
 | 
				
			||||||
        "@0x/contracts-exchange-libs": "^4.3.18",
 | 
					        "@0x/contracts-exchange-libs": "^4.3.29",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "lodash": "^4.17.11"
 | 
					        "lodash": "^4.17.11"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -12,13 +12,11 @@ import { DecodedLogs } from 'ethereum-types';
 | 
				
			|||||||
import * as _ from 'lodash';
 | 
					import * as _ from 'lodash';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import { artifacts } from './artifacts';
 | 
					import { artifacts } from './artifacts';
 | 
				
			||||||
 | 
					 | 
				
			||||||
import { TestBancorBridgeContract } from './generated-wrappers/test_bancor_bridge';
 | 
					import { TestBancorBridgeContract } from './generated-wrappers/test_bancor_bridge';
 | 
				
			||||||
import {
 | 
					import {
 | 
				
			||||||
    TestBancorBridgeConvertByPathInputEventArgs as ConvertByPathArgs,
 | 
					    TestBancorBridgeConvertByPathInputEventArgs as ConvertByPathArgs,
 | 
				
			||||||
    TestBancorBridgeEvents as ContractEvents,
 | 
					    TestBancorBridgeEvents as ContractEvents,
 | 
				
			||||||
    TestBancorBridgeTokenApproveEventArgs as TokenApproveArgs,
 | 
					    TestBancorBridgeTokenApproveEventArgs as TokenApproveArgs,
 | 
				
			||||||
    TestBancorBridgeTokenTransferEventArgs as TokenTransferArgs,
 | 
					 | 
				
			||||||
} from './wrappers';
 | 
					} from './wrappers';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
blockchainTests.resets('Bancor unit tests', env => {
 | 
					blockchainTests.resets('Bancor unit tests', env => {
 | 
				
			||||||
@@ -128,24 +126,6 @@ blockchainTests.resets('Bancor unit tests', env => {
 | 
				
			|||||||
            expect(result).to.eq(AssetProxyId.ERC20Bridge);
 | 
					            expect(result).to.eq(AssetProxyId.ERC20Bridge);
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        it('performs transfer when both tokens are the same', async () => {
 | 
					 | 
				
			||||||
            const createTokenFn = testContract.createToken(constants.NULL_ADDRESS);
 | 
					 | 
				
			||||||
            const tokenAddress = await createTokenFn.callAsync();
 | 
					 | 
				
			||||||
            await createTokenFn.awaitTransactionSuccessAsync();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            const { opts, result, logs } = await transferFromAsync({
 | 
					 | 
				
			||||||
                tokenAddressesPath: [tokenAddress, tokenAddress],
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            expect(result).to.eq(AssetProxyId.ERC20Bridge, 'asset proxy id');
 | 
					 | 
				
			||||||
            const transfers = filterLogsToArguments<TokenTransferArgs>(logs, ContractEvents.TokenTransfer);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            expect(transfers.length).to.eq(1);
 | 
					 | 
				
			||||||
            expect(transfers[0].token).to.eq(tokenAddress, 'input token address');
 | 
					 | 
				
			||||||
            expect(transfers[0].from).to.eq(testContract.address);
 | 
					 | 
				
			||||||
            expect(transfers[0].to).to.eq(opts.toAddress, 'recipient address');
 | 
					 | 
				
			||||||
            expect(transfers[0].amount).to.bignumber.eq(opts.amount, 'amount');
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        describe('token -> token', async () => {
 | 
					        describe('token -> token', async () => {
 | 
				
			||||||
            it('calls BancorNetwork.convertByPath()', async () => {
 | 
					            it('calls BancorNetwork.convertByPath()', async () => {
 | 
				
			||||||
                const { opts, result, logs } = await transferFromAsync();
 | 
					                const { opts, result, logs } = await transferFromAsync();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,354 +0,0 @@
 | 
				
			|||||||
import { ContractTxFunctionObj } from '@0x/contract-wrappers';
 | 
					 | 
				
			||||||
import {
 | 
					 | 
				
			||||||
    blockchainTests,
 | 
					 | 
				
			||||||
    constants,
 | 
					 | 
				
			||||||
    expect,
 | 
					 | 
				
			||||||
    filterLogsToArguments,
 | 
					 | 
				
			||||||
    getRandomInteger,
 | 
					 | 
				
			||||||
    randomAddress,
 | 
					 | 
				
			||||||
    shortZip,
 | 
					 | 
				
			||||||
} from '@0x/contracts-test-utils';
 | 
					 | 
				
			||||||
import { BigNumber, hexUtils, NULL_ADDRESS } from '@0x/utils';
 | 
					 | 
				
			||||||
import { DecodedLogs } from 'ethereum-types';
 | 
					 | 
				
			||||||
import * as _ from 'lodash';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import { DexForwarderBridgeCall, dexForwarderBridgeDataEncoder } from '../src/dex_forwarder_bridge';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import { artifacts } from './artifacts';
 | 
					 | 
				
			||||||
import {
 | 
					 | 
				
			||||||
    TestDexForwarderBridgeBridgeTransferFromCalledEventArgs as BtfCalledEventArgs,
 | 
					 | 
				
			||||||
    TestDexForwarderBridgeContract,
 | 
					 | 
				
			||||||
    TestDexForwarderBridgeEvents as TestEvents,
 | 
					 | 
				
			||||||
} from './wrappers';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
const { ZERO_AMOUNT } = constants;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
blockchainTests.resets('DexForwarderBridge unit tests', env => {
 | 
					 | 
				
			||||||
    let testContract: TestDexForwarderBridgeContract;
 | 
					 | 
				
			||||||
    let inputToken: string;
 | 
					 | 
				
			||||||
    let outputToken: string;
 | 
					 | 
				
			||||||
    const BRIDGE_SUCCESS = '0xdc1600f3';
 | 
					 | 
				
			||||||
    const BRIDGE_FAILURE = '0xffffffff';
 | 
					 | 
				
			||||||
    const BRIDGE_REVERT_ERROR = 'oopsie';
 | 
					 | 
				
			||||||
    const NOT_AUTHORIZED_REVERT = 'DexForwarderBridge/SENDER_NOT_AUTHORIZED';
 | 
					 | 
				
			||||||
    const DEFAULTS = {
 | 
					 | 
				
			||||||
        toAddress: randomAddress(),
 | 
					 | 
				
			||||||
    };
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    before(async () => {
 | 
					 | 
				
			||||||
        testContract = await TestDexForwarderBridgeContract.deployFrom0xArtifactAsync(
 | 
					 | 
				
			||||||
            artifacts.TestDexForwarderBridge,
 | 
					 | 
				
			||||||
            env.provider,
 | 
					 | 
				
			||||||
            env.txDefaults,
 | 
					 | 
				
			||||||
            artifacts,
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
        // Create test tokens.
 | 
					 | 
				
			||||||
        [inputToken, outputToken] = [
 | 
					 | 
				
			||||||
            await callAndTransactAsync(testContract.createToken()),
 | 
					 | 
				
			||||||
            await callAndTransactAsync(testContract.createToken()),
 | 
					 | 
				
			||||||
        ];
 | 
					 | 
				
			||||||
        await callAndTransactAsync(testContract.setAuthorized(env.txDefaults.from as string));
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    async function callAndTransactAsync<TResult>(fnCall: ContractTxFunctionObj<TResult>): Promise<TResult> {
 | 
					 | 
				
			||||||
        const result = await fnCall.callAsync();
 | 
					 | 
				
			||||||
        await fnCall.awaitTransactionSuccessAsync({}, { shouldValidate: false });
 | 
					 | 
				
			||||||
        return result;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    function getRandomBridgeCall(
 | 
					 | 
				
			||||||
        bridgeAddress: string,
 | 
					 | 
				
			||||||
        fields: Partial<DexForwarderBridgeCall> = {},
 | 
					 | 
				
			||||||
    ): DexForwarderBridgeCall {
 | 
					 | 
				
			||||||
        return {
 | 
					 | 
				
			||||||
            target: bridgeAddress,
 | 
					 | 
				
			||||||
            inputTokenAmount: getRandomInteger(1, '100e18'),
 | 
					 | 
				
			||||||
            outputTokenAmount: getRandomInteger(1, '100e18'),
 | 
					 | 
				
			||||||
            bridgeData: hexUtils.leftPad(inputToken),
 | 
					 | 
				
			||||||
            ...fields,
 | 
					 | 
				
			||||||
        };
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    describe('bridgeTransferFrom()', () => {
 | 
					 | 
				
			||||||
        let goodBridgeCalls: DexForwarderBridgeCall[];
 | 
					 | 
				
			||||||
        let revertingBridgeCall: DexForwarderBridgeCall;
 | 
					 | 
				
			||||||
        let failingBridgeCall: DexForwarderBridgeCall;
 | 
					 | 
				
			||||||
        let allBridgeCalls: DexForwarderBridgeCall[];
 | 
					 | 
				
			||||||
        let totalFillableOutputAmount: BigNumber;
 | 
					 | 
				
			||||||
        let totalFillableInputAmount: BigNumber;
 | 
					 | 
				
			||||||
        let recipientOutputBalance: BigNumber;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        beforeEach(async () => {
 | 
					 | 
				
			||||||
            goodBridgeCalls = [];
 | 
					 | 
				
			||||||
            for (let i = 0; i < 4; ++i) {
 | 
					 | 
				
			||||||
                goodBridgeCalls.push(await createBridgeCallAsync({ returnCode: BRIDGE_SUCCESS }));
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            revertingBridgeCall = await createBridgeCallAsync({ revertError: BRIDGE_REVERT_ERROR });
 | 
					 | 
				
			||||||
            failingBridgeCall = await createBridgeCallAsync({ returnCode: BRIDGE_FAILURE });
 | 
					 | 
				
			||||||
            allBridgeCalls = _.shuffle([failingBridgeCall, revertingBridgeCall, ...goodBridgeCalls]);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            totalFillableInputAmount = BigNumber.sum(...goodBridgeCalls.map(c => c.inputTokenAmount));
 | 
					 | 
				
			||||||
            totalFillableOutputAmount = BigNumber.sum(...goodBridgeCalls.map(c => c.outputTokenAmount));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            // Grant the taker some output tokens.
 | 
					 | 
				
			||||||
            await testContract.setTokenBalance(
 | 
					 | 
				
			||||||
                outputToken,
 | 
					 | 
				
			||||||
                DEFAULTS.toAddress,
 | 
					 | 
				
			||||||
                (recipientOutputBalance = getRandomInteger(1, '100e18')),
 | 
					 | 
				
			||||||
            );
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        async function setForwarderInputBalanceAsync(amount: BigNumber): Promise<void> {
 | 
					 | 
				
			||||||
            await testContract
 | 
					 | 
				
			||||||
                .setTokenBalance(inputToken, testContract.address, amount)
 | 
					 | 
				
			||||||
                .awaitTransactionSuccessAsync({}, { shouldValidate: false });
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        async function createBridgeCallAsync(
 | 
					 | 
				
			||||||
            opts: Partial<{
 | 
					 | 
				
			||||||
                returnCode: string;
 | 
					 | 
				
			||||||
                revertError: string;
 | 
					 | 
				
			||||||
                callFields: Partial<DexForwarderBridgeCall>;
 | 
					 | 
				
			||||||
                outputFillAmount: BigNumber;
 | 
					 | 
				
			||||||
            }>,
 | 
					 | 
				
			||||||
        ): Promise<DexForwarderBridgeCall> {
 | 
					 | 
				
			||||||
            const { returnCode, revertError, callFields, outputFillAmount } = {
 | 
					 | 
				
			||||||
                returnCode: BRIDGE_SUCCESS,
 | 
					 | 
				
			||||||
                revertError: '',
 | 
					 | 
				
			||||||
                ...opts,
 | 
					 | 
				
			||||||
            };
 | 
					 | 
				
			||||||
            const bridge = await callAndTransactAsync(testContract.createBridge(returnCode, revertError));
 | 
					 | 
				
			||||||
            const call = getRandomBridgeCall(bridge, callFields);
 | 
					 | 
				
			||||||
            await testContract
 | 
					 | 
				
			||||||
                .setBridgeTransferAmount(call.target, outputFillAmount || call.outputTokenAmount)
 | 
					 | 
				
			||||||
                .awaitTransactionSuccessAsync({}, { shouldValidate: false });
 | 
					 | 
				
			||||||
            return call;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        async function callBridgeTransferFromAsync(opts: {
 | 
					 | 
				
			||||||
            bridgeData: string;
 | 
					 | 
				
			||||||
            sellAmount?: BigNumber;
 | 
					 | 
				
			||||||
            buyAmount?: BigNumber;
 | 
					 | 
				
			||||||
        }): Promise<DecodedLogs> {
 | 
					 | 
				
			||||||
            // Fund the forwarder with input tokens to sell.
 | 
					 | 
				
			||||||
            await setForwarderInputBalanceAsync(opts.sellAmount || totalFillableInputAmount);
 | 
					 | 
				
			||||||
            const call = testContract.bridgeTransferFrom(
 | 
					 | 
				
			||||||
                outputToken,
 | 
					 | 
				
			||||||
                testContract.address,
 | 
					 | 
				
			||||||
                DEFAULTS.toAddress,
 | 
					 | 
				
			||||||
                opts.buyAmount || totalFillableOutputAmount,
 | 
					 | 
				
			||||||
                opts.bridgeData,
 | 
					 | 
				
			||||||
            );
 | 
					 | 
				
			||||||
            const returnCode = await call.callAsync();
 | 
					 | 
				
			||||||
            if (returnCode !== BRIDGE_SUCCESS) {
 | 
					 | 
				
			||||||
                throw new Error('Expected BRIDGE_SUCCESS');
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            const receipt = await call.awaitTransactionSuccessAsync({}, { shouldValidate: false });
 | 
					 | 
				
			||||||
            // tslint:disable-next-line: no-unnecessary-type-assertion
 | 
					 | 
				
			||||||
            return receipt.logs as DecodedLogs;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('succeeds with no bridge calls and no input balance', async () => {
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls: [],
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({ bridgeData, sellAmount: ZERO_AMOUNT });
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('succeeds with bridge calls and no input balance', async () => {
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls: allBridgeCalls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({ bridgeData, sellAmount: ZERO_AMOUNT });
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('succeeds with no bridge calls and an input balance', async () => {
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls: [],
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({
 | 
					 | 
				
			||||||
                bridgeData,
 | 
					 | 
				
			||||||
                sellAmount: new BigNumber(1),
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('succeeds if entire input token balance is not consumed', async () => {
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls: allBridgeCalls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({
 | 
					 | 
				
			||||||
                bridgeData,
 | 
					 | 
				
			||||||
                sellAmount: totalFillableInputAmount.plus(1),
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('fails if not authorized', async () => {
 | 
					 | 
				
			||||||
            const calls = goodBridgeCalls.slice(0, 1);
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callAndTransactAsync(testContract.setAuthorized(NULL_ADDRESS));
 | 
					 | 
				
			||||||
            return expect(callBridgeTransferFromAsync({ bridgeData, sellAmount: new BigNumber(1) })).to.revertWith(
 | 
					 | 
				
			||||||
                NOT_AUTHORIZED_REVERT,
 | 
					 | 
				
			||||||
            );
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('succeeds with one bridge call', async () => {
 | 
					 | 
				
			||||||
            const calls = goodBridgeCalls.slice(0, 1);
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({ bridgeData, sellAmount: calls[0].inputTokenAmount });
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('succeeds with many bridge calls', async () => {
 | 
					 | 
				
			||||||
            const calls = goodBridgeCalls;
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('swallows a failing bridge call', async () => {
 | 
					 | 
				
			||||||
            const calls = _.shuffle([...goodBridgeCalls, failingBridgeCall]);
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('consumes input tokens for output tokens', async () => {
 | 
					 | 
				
			||||||
            const calls = allBridgeCalls;
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
            const currentBridgeInputBalance = await testContract
 | 
					 | 
				
			||||||
                .balanceOf(inputToken, testContract.address)
 | 
					 | 
				
			||||||
                .callAsync();
 | 
					 | 
				
			||||||
            expect(currentBridgeInputBalance).to.bignumber.eq(0);
 | 
					 | 
				
			||||||
            const currentRecipientOutputBalance = await testContract
 | 
					 | 
				
			||||||
                .balanceOf(outputToken, DEFAULTS.toAddress)
 | 
					 | 
				
			||||||
                .callAsync();
 | 
					 | 
				
			||||||
            expect(currentRecipientOutputBalance).to.bignumber.eq(totalFillableOutputAmount);
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it("transfers only up to each call's input amount to each bridge", async () => {
 | 
					 | 
				
			||||||
            const calls = goodBridgeCalls;
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const logs = await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
            const btfs = filterLogsToArguments<BtfCalledEventArgs>(logs, TestEvents.BridgeTransferFromCalled);
 | 
					 | 
				
			||||||
            for (const [call, btf] of shortZip(goodBridgeCalls, btfs)) {
 | 
					 | 
				
			||||||
                expect(btf.inputTokenBalance).to.bignumber.eq(call.inputTokenAmount);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('transfers only up to outstanding sell amount to each bridge', async () => {
 | 
					 | 
				
			||||||
            // Prepend an extra bridge call.
 | 
					 | 
				
			||||||
            const calls = [
 | 
					 | 
				
			||||||
                await createBridgeCallAsync({
 | 
					 | 
				
			||||||
                    callFields: {
 | 
					 | 
				
			||||||
                        inputTokenAmount: new BigNumber(1),
 | 
					 | 
				
			||||||
                        outputTokenAmount: new BigNumber(1),
 | 
					 | 
				
			||||||
                    },
 | 
					 | 
				
			||||||
                }),
 | 
					 | 
				
			||||||
                ...goodBridgeCalls,
 | 
					 | 
				
			||||||
            ];
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const logs = await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
            const btfs = filterLogsToArguments<BtfCalledEventArgs>(logs, TestEvents.BridgeTransferFromCalled);
 | 
					 | 
				
			||||||
            expect(btfs).to.be.length(goodBridgeCalls.length + 1);
 | 
					 | 
				
			||||||
            // The last call will receive 1 less token.
 | 
					 | 
				
			||||||
            const lastCall = calls.slice(-1)[0];
 | 
					 | 
				
			||||||
            const lastBtf = btfs.slice(-1)[0];
 | 
					 | 
				
			||||||
            expect(lastBtf.inputTokenBalance).to.bignumber.eq(lastCall.inputTokenAmount.minus(1));
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('recoups funds from a bridge that fails', async () => {
 | 
					 | 
				
			||||||
            // Prepend a call that will take the whole input amount but will
 | 
					 | 
				
			||||||
            // fail.
 | 
					 | 
				
			||||||
            const badCall = await createBridgeCallAsync({
 | 
					 | 
				
			||||||
                callFields: { inputTokenAmount: totalFillableInputAmount },
 | 
					 | 
				
			||||||
                returnCode: BRIDGE_FAILURE,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const calls = [badCall, ...goodBridgeCalls];
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const logs = await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
            const btfs = filterLogsToArguments<BtfCalledEventArgs>(logs, TestEvents.BridgeTransferFromCalled);
 | 
					 | 
				
			||||||
            expect(btfs).to.be.length(goodBridgeCalls.length);
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('recoups funds from a bridge that reverts', async () => {
 | 
					 | 
				
			||||||
            // Prepend a call that will take the whole input amount but will
 | 
					 | 
				
			||||||
            // revert.
 | 
					 | 
				
			||||||
            const badCall = await createBridgeCallAsync({
 | 
					 | 
				
			||||||
                callFields: { inputTokenAmount: totalFillableInputAmount },
 | 
					 | 
				
			||||||
                revertError: BRIDGE_REVERT_ERROR,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const calls = [badCall, ...goodBridgeCalls];
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const logs = await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
            const btfs = filterLogsToArguments<BtfCalledEventArgs>(logs, TestEvents.BridgeTransferFromCalled);
 | 
					 | 
				
			||||||
            expect(btfs).to.be.length(goodBridgeCalls.length);
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        it('recoups funds from a bridge that under-pays', async () => {
 | 
					 | 
				
			||||||
            // Prepend a call that will take the whole input amount but will
 | 
					 | 
				
			||||||
            // underpay the output amount..
 | 
					 | 
				
			||||||
            const badCall = await createBridgeCallAsync({
 | 
					 | 
				
			||||||
                callFields: {
 | 
					 | 
				
			||||||
                    inputTokenAmount: totalFillableInputAmount,
 | 
					 | 
				
			||||||
                    outputTokenAmount: new BigNumber(2),
 | 
					 | 
				
			||||||
                },
 | 
					 | 
				
			||||||
                outputFillAmount: new BigNumber(1),
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const calls = [badCall, ...goodBridgeCalls];
 | 
					 | 
				
			||||||
            const bridgeData = dexForwarderBridgeDataEncoder.encode({
 | 
					 | 
				
			||||||
                inputToken,
 | 
					 | 
				
			||||||
                calls,
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
            const logs = await callBridgeTransferFromAsync({ bridgeData });
 | 
					 | 
				
			||||||
            const btfs = filterLogsToArguments<BtfCalledEventArgs>(logs, TestEvents.BridgeTransferFromCalled);
 | 
					 | 
				
			||||||
            expect(btfs).to.be.length(goodBridgeCalls.length);
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    describe('executeBridgeCall()', () => {
 | 
					 | 
				
			||||||
        it('cannot be called externally', async () => {
 | 
					 | 
				
			||||||
            return expect(
 | 
					 | 
				
			||||||
                testContract
 | 
					 | 
				
			||||||
                    .executeBridgeCall(
 | 
					 | 
				
			||||||
                        randomAddress(),
 | 
					 | 
				
			||||||
                        randomAddress(),
 | 
					 | 
				
			||||||
                        randomAddress(),
 | 
					 | 
				
			||||||
                        randomAddress(),
 | 
					 | 
				
			||||||
                        new BigNumber(1),
 | 
					 | 
				
			||||||
                        new BigNumber(1),
 | 
					 | 
				
			||||||
                        constants.NULL_BYTES,
 | 
					 | 
				
			||||||
                    )
 | 
					 | 
				
			||||||
                    .callAsync(),
 | 
					 | 
				
			||||||
            ).to.revertWith('DexForwarderBridge/ONLY_SELF');
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
@@ -168,7 +168,7 @@ describe('StaticCallProxy', () => {
 | 
				
			|||||||
        it('should revert if the hash of the output is different than expected expected', async () => {
 | 
					        it('should revert if the hash of the output is different than expected expected', async () => {
 | 
				
			||||||
            const staticCallData = staticCallTarget.isOddNumber(new BigNumber(0)).getABIEncodedTransactionData();
 | 
					            const staticCallData = staticCallTarget.isOddNumber(new BigNumber(0)).getABIEncodedTransactionData();
 | 
				
			||||||
            const trueAsBuffer = ethUtil.toBuffer('0x0000000000000000000000000000000000000000000000000000000000000001');
 | 
					            const trueAsBuffer = ethUtil.toBuffer('0x0000000000000000000000000000000000000000000000000000000000000001');
 | 
				
			||||||
            const expectedResultHash = ethUtil.bufferToHex(ethUtil.sha3(trueAsBuffer));
 | 
					            const expectedResultHash = ethUtil.bufferToHex(ethUtil.keccak256(trueAsBuffer));
 | 
				
			||||||
            const assetData = assetDataInterface
 | 
					            const assetData = assetDataInterface
 | 
				
			||||||
                .StaticCall(staticCallTarget.address, staticCallData, expectedResultHash)
 | 
					                .StaticCall(staticCallTarget.address, staticCallData, expectedResultHash)
 | 
				
			||||||
                .getABIEncodedTransactionData();
 | 
					                .getABIEncodedTransactionData();
 | 
				
			||||||
@@ -199,7 +199,7 @@ describe('StaticCallProxy', () => {
 | 
				
			|||||||
        it('should be successful if a function call with one static input returns the correct value', async () => {
 | 
					        it('should be successful if a function call with one static input returns the correct value', async () => {
 | 
				
			||||||
            const staticCallData = staticCallTarget.isOddNumber(new BigNumber(1)).getABIEncodedTransactionData();
 | 
					            const staticCallData = staticCallTarget.isOddNumber(new BigNumber(1)).getABIEncodedTransactionData();
 | 
				
			||||||
            const trueAsBuffer = ethUtil.toBuffer('0x0000000000000000000000000000000000000000000000000000000000000001');
 | 
					            const trueAsBuffer = ethUtil.toBuffer('0x0000000000000000000000000000000000000000000000000000000000000001');
 | 
				
			||||||
            const expectedResultHash = ethUtil.bufferToHex(ethUtil.sha3(trueAsBuffer));
 | 
					            const expectedResultHash = ethUtil.bufferToHex(ethUtil.keccak256(trueAsBuffer));
 | 
				
			||||||
            const assetData = assetDataInterface
 | 
					            const assetData = assetDataInterface
 | 
				
			||||||
                .StaticCall(staticCallTarget.address, staticCallData, expectedResultHash)
 | 
					                .StaticCall(staticCallTarget.address, staticCallData, expectedResultHash)
 | 
				
			||||||
                .getABIEncodedTransactionData();
 | 
					                .getABIEncodedTransactionData();
 | 
				
			||||||
@@ -232,7 +232,7 @@ describe('StaticCallProxy', () => {
 | 
				
			|||||||
            const offset = '0000000000000000000000000000000000000000000000000000000000000020';
 | 
					            const offset = '0000000000000000000000000000000000000000000000000000000000000020';
 | 
				
			||||||
            const encodedExpectedResultWithOffset = `0x${offset}${abiEncoder.encode(expectedResults).slice(2)}`;
 | 
					            const encodedExpectedResultWithOffset = `0x${offset}${abiEncoder.encode(expectedResults).slice(2)}`;
 | 
				
			||||||
            const expectedResultHash = ethUtil.bufferToHex(
 | 
					            const expectedResultHash = ethUtil.bufferToHex(
 | 
				
			||||||
                ethUtil.sha3(ethUtil.toBuffer(encodedExpectedResultWithOffset)),
 | 
					                ethUtil.keccak256(ethUtil.toBuffer(encodedExpectedResultWithOffset)),
 | 
				
			||||||
            );
 | 
					            );
 | 
				
			||||||
            const assetData = assetDataInterface
 | 
					            const assetData = assetDataInterface
 | 
				
			||||||
                .StaticCall(staticCallTarget.address, staticCallData, expectedResultHash)
 | 
					                .StaticCall(staticCallTarget.address, staticCallData, expectedResultHash)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,112 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "1.1.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "1.1.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "1.1.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "1.1.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "1.1.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "1.1.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "1.1.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "1.1.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "1.1.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "1.1.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "1.1.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "1.1.18",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "1.1.17",
 | 
					        "version": "1.1.17",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.29 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.28 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.27 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.26 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.25 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.24 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.23 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.22 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.21 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.20 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.19 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.18 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v1.1.17 - _December 9, 2020_
 | 
					## v1.1.17 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-broker",
 | 
					    "name": "@0x/contracts-broker",
 | 
				
			||||||
    "version": "1.1.17",
 | 
					    "version": "1.1.29",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -51,20 +51,20 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-erc721": "^3.1.18",
 | 
					        "@0x/contracts-erc721": "^3.1.29",
 | 
				
			||||||
        "@0x/contracts-exchange": "^3.2.18",
 | 
					        "@0x/contracts-exchange": "^3.2.30",
 | 
				
			||||||
        "@0x/contracts-exchange-libs": "^4.3.18",
 | 
					        "@0x/contracts-exchange-libs": "^4.3.29",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -81,14 +81,14 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "ethereum-types": "^3.4.0"
 | 
					        "ethereum-types": "^3.5.0"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,112 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "3.1.30",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "3.1.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "3.1.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "3.1.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "3.1.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "3.1.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "3.1.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "3.1.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "3.1.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "3.1.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "3.1.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "3.1.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "3.1.18",
 | 
					        "version": "3.1.18",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.30 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.29 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.28 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.27 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.26 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.25 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.24 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.23 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.22 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.21 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.20 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.19 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v3.1.18 - _December 9, 2020_
 | 
					## v3.1.18 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-coordinator",
 | 
					    "name": "@0x/contracts-coordinator",
 | 
				
			||||||
    "version": "3.1.18",
 | 
					    "version": "3.1.30",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -52,17 +52,17 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-dev-utils": "^1.3.16",
 | 
					        "@0x/contracts-dev-utils": "^1.3.28",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -79,20 +79,20 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/assert": "^3.0.19",
 | 
					        "@0x/assert": "^3.0.27",
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contract-addresses": "^5.6.0",
 | 
					        "@0x/contract-addresses": "^6.1.0",
 | 
				
			||||||
        "@0x/contracts-exchange": "^3.2.18",
 | 
					        "@0x/contracts-exchange": "^3.2.30",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/json-schemas": "^5.3.4",
 | 
					        "@0x/json-schemas": "^6.1.3",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "http-status-codes": "^1.3.2"
 | 
					        "http-status-codes": "^1.3.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,4 @@
 | 
				
			|||||||
import { assert as sharedAssert } from '@0x/assert';
 | 
					import { assert as sharedAssert } from '@0x/assert';
 | 
				
			||||||
// HACK: We need those two unused imports because they're actually used by sharedAssert which gets injected here
 | 
					 | 
				
			||||||
import { Schema } from '@0x/json-schemas'; // tslint:disable-line:no-unused-variable
 | 
					 | 
				
			||||||
import { Order } from '@0x/types'; // tslint:disable-line:no-unused-variable
 | 
					 | 
				
			||||||
import { BigNumber } from '@0x/utils'; // tslint:disable-line:no-unused-variable
 | 
					 | 
				
			||||||
import { Web3Wrapper } from '@0x/web3-wrapper';
 | 
					import { Web3Wrapper } from '@0x/web3-wrapper';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export const assert = {
 | 
					export const assert = {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,112 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "1.3.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "1.3.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "1.3.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "1.3.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "1.3.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "1.3.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "1.3.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "1.3.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "1.3.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "1.3.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "1.3.18",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "1.3.17",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "1.3.16",
 | 
					        "version": "1.3.16",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.28 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.27 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.26 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.25 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.24 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.23 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.22 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.21 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.20 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.19 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.18 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.3.17 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v1.3.16 - _December 9, 2020_
 | 
					## v1.3.16 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-dev-utils",
 | 
					    "name": "@0x/contracts-dev-utils",
 | 
				
			||||||
    "version": "1.3.16",
 | 
					    "version": "1.3.28",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -41,18 +41,18 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/dev-utils",
 | 
					    "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/dev-utils",
 | 
				
			||||||
    "devDependencies": {
 | 
					    "devDependencies": {
 | 
				
			||||||
        "@0x/abi-gen": "^5.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/assert": "^3.0.19",
 | 
					        "@0x/assert": "^3.0.27",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "ethers": "~4.0.4",
 | 
					        "ethers": "~4.0.4",
 | 
				
			||||||
        "npm-run-all": "^4.1.2",
 | 
					        "npm-run-all": "^4.1.2",
 | 
				
			||||||
        "shx": "^0.2.2",
 | 
					        "shx": "^0.2.2",
 | 
				
			||||||
@@ -60,10 +60,10 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@types/node": "12.12.54"
 | 
					        "@types/node": "12.12.54"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,103 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "2.1.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "2.1.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "2.1.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "2.1.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "2.1.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "2.1.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "2.1.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "2.1.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "2.1.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "2.1.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "2.1.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "2.1.18",
 | 
					        "version": "2.1.18",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,50 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.29 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.28 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.27 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.26 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.25 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.24 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.23 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.22 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.21 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.20 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.1.19 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v2.1.18 - _December 9, 2020_
 | 
					## v2.1.18 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-erc1155",
 | 
					    "name": "@0x/contracts-erc1155",
 | 
				
			||||||
    "version": "2.1.18",
 | 
					    "version": "2.1.29",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -52,15 +52,15 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -68,7 +68,7 @@
 | 
				
			|||||||
        "chai-as-promised": "^7.1.0",
 | 
					        "chai-as-promised": "^7.1.0",
 | 
				
			||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "make-promises-safe": "^1.1.0",
 | 
					        "make-promises-safe": "^1.1.0",
 | 
				
			||||||
        "mocha": "^6.2.0",
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
        "npm-run-all": "^4.1.2",
 | 
					        "npm-run-all": "^4.1.2",
 | 
				
			||||||
@@ -77,13 +77,13 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "lodash": "^4.17.11"
 | 
					        "lodash": "^4.17.11"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,108 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "3.3.8",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "3.3.7",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "3.3.6",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "3.3.5",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "3.3.4",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "3.3.3",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "3.3.2",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "3.3.1",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "version": "3.3.0",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Add SPDX license identifiers to solidity files",
 | 
				
			||||||
 | 
					                "pr": 105
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Allow for excess return data in `LibERC20TokenV06` compat* functions",
 | 
				
			||||||
 | 
					                "pr": 97
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "timestamp": 1609802516
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "3.2.14",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "3.2.13",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "3.2.12",
 | 
					        "version": "3.2.12",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,51 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.8 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.7 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.6 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.5 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.4 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.3 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.2 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.1 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.3.0 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Add SPDX license identifiers to solidity files (#105)
 | 
				
			||||||
 | 
					    * Allow for excess return data in `LibERC20TokenV06` compat* functions (#97)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.14 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.13 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v3.2.12 - _December 9, 2020_
 | 
					## v3.2.12 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,3 +1,4 @@
 | 
				
			|||||||
 | 
					// SPDX-License-Identifier: Apache-2.0
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Copyright 2020 ZeroEx Intl.
 | 
					  Copyright 2020 ZeroEx Intl.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,3 +1,4 @@
 | 
				
			|||||||
 | 
					// SPDX-License-Identifier: Apache-2.0
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Copyright 2020 ZeroEx Intl.
 | 
					  Copyright 2020 ZeroEx Intl.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,3 +1,4 @@
 | 
				
			|||||||
 | 
					// SPDX-License-Identifier: Apache-2.0
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Copyright 2020 ZeroEx Intl.
 | 
					  Copyright 2020 ZeroEx Intl.
 | 
				
			||||||
@@ -118,7 +119,7 @@ library LibERC20TokenV06 {
 | 
				
			|||||||
    {
 | 
					    {
 | 
				
			||||||
        tokenDecimals = 18;
 | 
					        tokenDecimals = 18;
 | 
				
			||||||
        (bool didSucceed, bytes memory resultData) = address(token).staticcall(DECIMALS_CALL_DATA);
 | 
					        (bool didSucceed, bytes memory resultData) = address(token).staticcall(DECIMALS_CALL_DATA);
 | 
				
			||||||
        if (didSucceed && resultData.length == 32) {
 | 
					        if (didSucceed && resultData.length >= 32) {
 | 
				
			||||||
            tokenDecimals = uint8(LibBytesV06.readUint256(resultData, 0));
 | 
					            tokenDecimals = uint8(LibBytesV06.readUint256(resultData, 0));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -141,7 +142,7 @@ library LibERC20TokenV06 {
 | 
				
			|||||||
                spender
 | 
					                spender
 | 
				
			||||||
            )
 | 
					            )
 | 
				
			||||||
        );
 | 
					        );
 | 
				
			||||||
        if (didSucceed && resultData.length == 32) {
 | 
					        if (didSucceed && resultData.length >= 32) {
 | 
				
			||||||
            allowance_ = LibBytesV06.readUint256(resultData, 0);
 | 
					            allowance_ = LibBytesV06.readUint256(resultData, 0);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -162,7 +163,7 @@ library LibERC20TokenV06 {
 | 
				
			|||||||
                owner
 | 
					                owner
 | 
				
			||||||
            )
 | 
					            )
 | 
				
			||||||
        );
 | 
					        );
 | 
				
			||||||
        if (didSucceed && resultData.length == 32) {
 | 
					        if (didSucceed && resultData.length >= 32) {
 | 
				
			||||||
            balance = LibBytesV06.readUint256(resultData, 0);
 | 
					            balance = LibBytesV06.readUint256(resultData, 0);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -180,7 +181,7 @@ library LibERC20TokenV06 {
 | 
				
			|||||||
        if (resultData.length == 0) {
 | 
					        if (resultData.length == 0) {
 | 
				
			||||||
            return true;
 | 
					            return true;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        if (resultData.length == 32) {
 | 
					        if (resultData.length >= 32) {
 | 
				
			||||||
            uint256 result = LibBytesV06.readUint256(resultData, 0);
 | 
					            uint256 result = LibBytesV06.readUint256(resultData, 0);
 | 
				
			||||||
            if (result == 1) {
 | 
					            if (result == 1) {
 | 
				
			||||||
                return true;
 | 
					                return true;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-erc20",
 | 
					    "name": "@0x/contracts-erc20",
 | 
				
			||||||
    "version": "3.2.12",
 | 
					    "version": "3.3.8",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -51,18 +51,18 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -70,7 +70,7 @@
 | 
				
			|||||||
        "chai-as-promised": "^7.1.0",
 | 
					        "chai-as-promised": "^7.1.0",
 | 
				
			||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "lodash": "^4.17.11",
 | 
					        "lodash": "^4.17.11",
 | 
				
			||||||
        "make-promises-safe": "^1.1.0",
 | 
					        "make-promises-safe": "^1.1.0",
 | 
				
			||||||
        "mocha": "^6.2.0",
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
@@ -79,10 +79,10 @@
 | 
				
			|||||||
        "solhint": "^1.4.1",
 | 
					        "solhint": "^1.4.1",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14"
 | 
					        "@0x/base-contract": "^6.4.0"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -6,6 +6,7 @@ export {
 | 
				
			|||||||
    WETH9Events,
 | 
					    WETH9Events,
 | 
				
			||||||
    WETH9DepositEventArgs,
 | 
					    WETH9DepositEventArgs,
 | 
				
			||||||
    WETH9TransferEventArgs,
 | 
					    WETH9TransferEventArgs,
 | 
				
			||||||
 | 
					    WETH9WithdrawalEventArgs,
 | 
				
			||||||
    ZRXTokenContract,
 | 
					    ZRXTokenContract,
 | 
				
			||||||
    DummyERC20TokenTransferEventArgs,
 | 
					    DummyERC20TokenTransferEventArgs,
 | 
				
			||||||
    ERC20TokenEventArgs,
 | 
					    ERC20TokenEventArgs,
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -39,8 +39,8 @@ describe('EtherToken', () => {
 | 
				
			|||||||
            artifacts.WETH9,
 | 
					            artifacts.WETH9,
 | 
				
			||||||
            provider,
 | 
					            provider,
 | 
				
			||||||
            {
 | 
					            {
 | 
				
			||||||
                gasPrice,
 | 
					 | 
				
			||||||
                ...txDefaults,
 | 
					                ...txDefaults,
 | 
				
			||||||
 | 
					                gasPrice,
 | 
				
			||||||
            },
 | 
					            },
 | 
				
			||||||
            artifacts,
 | 
					            artifacts,
 | 
				
			||||||
        );
 | 
					        );
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,103 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "3.1.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "3.1.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "3.1.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "3.1.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "3.1.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "3.1.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "3.1.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "3.1.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "3.1.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "3.1.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "3.1.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "3.1.18",
 | 
					        "version": "3.1.18",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,50 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.29 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.28 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.27 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.26 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.25 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.24 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.23 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.22 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.21 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.20 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.1.19 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v3.1.18 - _December 9, 2020_
 | 
					## v3.1.18 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-erc721",
 | 
					    "name": "@0x/contracts-erc721",
 | 
				
			||||||
    "version": "3.1.18",
 | 
					    "version": "3.1.29",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -52,18 +52,18 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -71,7 +71,7 @@
 | 
				
			|||||||
        "chai-as-promised": "^7.1.0",
 | 
					        "chai-as-promised": "^7.1.0",
 | 
				
			||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "lodash": "^4.17.11",
 | 
					        "lodash": "^4.17.11",
 | 
				
			||||||
        "make-promises-safe": "^1.1.0",
 | 
					        "make-promises-safe": "^1.1.0",
 | 
				
			||||||
        "mocha": "^6.2.0",
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
@@ -81,10 +81,10 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14"
 | 
					        "@0x/base-contract": "^6.4.0"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,112 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "4.2.30",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "4.2.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "4.2.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "4.2.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "4.2.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "4.2.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "4.2.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "4.2.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "4.2.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "4.2.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "4.2.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "4.2.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "4.2.18",
 | 
					        "version": "4.2.18",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.30 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.29 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.28 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.27 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.26 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.25 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.24 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.23 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.22 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.21 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.20 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.19 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v4.2.18 - _December 9, 2020_
 | 
					## v4.2.18 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-exchange-forwarder",
 | 
					    "name": "@0x/contracts-exchange-forwarder",
 | 
				
			||||||
    "version": "4.2.18",
 | 
					    "version": "4.2.30",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -52,25 +52,25 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-dev-utils": "^1.3.16",
 | 
					        "@0x/contracts-dev-utils": "^1.3.28",
 | 
				
			||||||
        "@0x/contracts-erc1155": "^2.1.18",
 | 
					        "@0x/contracts-erc1155": "^2.1.29",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-erc721": "^3.1.18",
 | 
					        "@0x/contracts-erc721": "^3.1.29",
 | 
				
			||||||
        "@0x/contracts-exchange": "^3.2.18",
 | 
					        "@0x/contracts-exchange": "^3.2.30",
 | 
				
			||||||
        "@0x/contracts-exchange-libs": "^4.3.18",
 | 
					        "@0x/contracts-exchange-libs": "^4.3.29",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -87,12 +87,12 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "ethereum-types": "^3.4.0"
 | 
					        "ethereum-types": "^3.5.0"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,103 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "4.3.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "4.3.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "4.3.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "4.3.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "4.3.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "4.3.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "4.3.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "4.3.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "4.3.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "4.3.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "4.3.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "4.3.18",
 | 
					        "version": "4.3.18",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,50 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.29 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.28 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.27 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.26 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.25 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.24 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.23 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.22 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.21 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.20 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.3.19 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v4.3.18 - _December 9, 2020_
 | 
					## v4.3.18 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-exchange-libs",
 | 
					    "name": "@0x/contracts-exchange-libs",
 | 
				
			||||||
    "version": "4.3.18",
 | 
					    "version": "4.3.29",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -52,14 +52,14 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/libs",
 | 
					    "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/libs",
 | 
				
			||||||
    "devDependencies": {
 | 
					    "devDependencies": {
 | 
				
			||||||
        "@0x/abi-gen": "^5.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@0x/sol-compiler": "^4.7.3",
 | 
				
			||||||
        "@0x/subproviders": "^6.2.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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -67,7 +67,7 @@
 | 
				
			|||||||
        "chai-as-promised": "^7.1.0",
 | 
					        "chai-as-promised": "^7.1.0",
 | 
				
			||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereumjs-util": "^5.1.1",
 | 
					        "ethereumjs-util": "^7.0.10",
 | 
				
			||||||
        "lodash": "^4.17.11",
 | 
					        "lodash": "^4.17.11",
 | 
				
			||||||
        "make-promises-safe": "^1.1.0",
 | 
					        "make-promises-safe": "^1.1.0",
 | 
				
			||||||
        "mocha": "^6.2.0",
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
@@ -77,17 +77,17 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "ethereum-types": "^3.4.0"
 | 
					        "ethereum-types": "^3.5.0"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,112 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "3.2.30",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "3.2.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "3.2.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "3.2.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "3.2.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "3.2.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "3.2.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "3.2.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "3.2.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "3.2.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "3.2.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "3.2.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "3.2.18",
 | 
					        "version": "3.2.18",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.30 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.29 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.28 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.27 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.26 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.25 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.24 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.23 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.22 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.21 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.20 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v3.2.19 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v3.2.18 - _December 9, 2020_
 | 
					## v3.2.18 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-exchange",
 | 
					    "name": "@0x/contracts-exchange",
 | 
				
			||||||
    "version": "3.2.18",
 | 
					    "version": "3.2.30",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -52,21 +52,21 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-exchange-libs": "^4.3.18",
 | 
					        "@0x/contracts-exchange-libs": "^4.3.29",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-multisig": "^4.1.18",
 | 
					        "@0x/contracts-multisig": "^4.1.30",
 | 
				
			||||||
        "@0x/contracts-staking": "^2.0.25",
 | 
					        "@0x/contracts-staking": "^2.0.37",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -74,8 +74,8 @@
 | 
				
			|||||||
        "chai-as-promised": "^7.1.0",
 | 
					        "chai-as-promised": "^7.1.0",
 | 
				
			||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "ethereumjs-util": "^5.1.1",
 | 
					        "ethereumjs-util": "^7.0.10",
 | 
				
			||||||
        "js-combinatorics": "^0.5.3",
 | 
					        "js-combinatorics": "^0.5.3",
 | 
				
			||||||
        "make-promises-safe": "^1.1.0",
 | 
					        "make-promises-safe": "^1.1.0",
 | 
				
			||||||
        "mocha": "^6.2.0",
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
@@ -85,16 +85,16 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contracts-dev-utils": "^1.3.16",
 | 
					        "@0x/contracts-dev-utils": "^1.3.28",
 | 
				
			||||||
        "@0x/contracts-erc1155": "^2.1.18",
 | 
					        "@0x/contracts-erc1155": "^2.1.29",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-erc721": "^3.1.18",
 | 
					        "@0x/contracts-erc721": "^3.1.29",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "lodash": "^4.17.11"
 | 
					        "lodash": "^4.17.11"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -86,7 +86,7 @@ blockchainTests.resets('MixinSignatureValidator', env => {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    const SIGNATURE_LENGTH = 65;
 | 
					    const SIGNATURE_LENGTH = 65;
 | 
				
			||||||
    const generateRandomSignature = (): string => hexUtils.random(SIGNATURE_LENGTH);
 | 
					    const generateRandomSignature = (): string => hexUtils.random(SIGNATURE_LENGTH);
 | 
				
			||||||
    const hashBytes = (bytesHex: string): string => ethUtil.bufferToHex(ethUtil.sha3(ethUtil.toBuffer(bytesHex)));
 | 
					    const hashBytes = (bytesHex: string): string => hexUtils.hash(bytesHex);
 | 
				
			||||||
    const signDataHex = (dataHex: string, privateKey: Buffer): string => {
 | 
					    const signDataHex = (dataHex: string, privateKey: Buffer): string => {
 | 
				
			||||||
        const ecSignature = ethUtil.ecsign(ethUtil.toBuffer(dataHex), privateKey);
 | 
					        const ecSignature = ethUtil.ecsign(ethUtil.toBuffer(dataHex), privateKey);
 | 
				
			||||||
        return hexUtils.concat(ecSignature.v, ecSignature.r, ecSignature.s);
 | 
					        return hexUtils.concat(ecSignature.v, ecSignature.r, ecSignature.s);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -12,12 +12,12 @@ export abstract class AbstractBalanceAndProxyAllowanceFetcher {
 | 
				
			|||||||
     * @param userAddress Ethereum address for which to fetch the balance
 | 
					     * @param userAddress Ethereum address for which to fetch the balance
 | 
				
			||||||
     * @return Balance amount in base units
 | 
					     * @return Balance amount in base units
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public abstract async getBalanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
					    public abstract getBalanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Get the 0x asset proxy allowance of assetData for userAddress
 | 
					     * Get the 0x asset proxy allowance of assetData for userAddress
 | 
				
			||||||
     * @param assetData AssetData for which to fetch the allowance
 | 
					     * @param assetData AssetData for which to fetch the allowance
 | 
				
			||||||
     * @param userAddress Ethereum address for which to fetch the allowance
 | 
					     * @param userAddress Ethereum address for which to fetch the allowance
 | 
				
			||||||
     * @return Allowance amount in base units
 | 
					     * @return Allowance amount in base units
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public abstract async getProxyAllowanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
					    public abstract getProxyAllowanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,8 @@
 | 
				
			|||||||
import { BigNumber } from '@0x/utils';
 | 
					import { BigNumber } from '@0x/utils';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export abstract class AbstractBalanceAndProxyAllowanceLazyStore {
 | 
					export abstract class AbstractBalanceAndProxyAllowanceLazyStore {
 | 
				
			||||||
    public abstract async getBalanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
					    public abstract getBalanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
				
			||||||
    public abstract async getProxyAllowanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
					    public abstract getProxyAllowanceAsync(assetData: string, userAddress: string): Promise<BigNumber>;
 | 
				
			||||||
    public abstract setBalance(assetData: string, userAddress: string, balance: BigNumber): void;
 | 
					    public abstract setBalance(assetData: string, userAddress: string, balance: BigNumber): void;
 | 
				
			||||||
    public abstract deleteBalance(assetData: string, userAddress: string): void;
 | 
					    public abstract deleteBalance(assetData: string, userAddress: string): void;
 | 
				
			||||||
    public abstract setProxyAllowance(assetData: string, userAddress: string, proxyAllowance: BigNumber): void;
 | 
					    public abstract setProxyAllowance(assetData: string, userAddress: string, proxyAllowance: BigNumber): void;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,5 +11,5 @@ export abstract class AbstractOrderFilledCancelledFetcher {
 | 
				
			|||||||
     * @param orderHash OrderHash of order we are interested in
 | 
					     * @param orderHash OrderHash of order we are interested in
 | 
				
			||||||
     * @return FilledTakerAmount
 | 
					     * @return FilledTakerAmount
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public abstract async getFilledTakerAmountAsync(orderHash: string): Promise<BigNumber>;
 | 
					    public abstract getFilledTakerAmountAsync(orderHash: string): Promise<BigNumber>;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,7 +1,7 @@
 | 
				
			|||||||
import { BigNumber } from '@0x/utils';
 | 
					import { BigNumber } from '@0x/utils';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export abstract class AbstractOrderFilledCancelledLazyStore {
 | 
					export abstract class AbstractOrderFilledCancelledLazyStore {
 | 
				
			||||||
    public abstract async getFilledTakerAmountAsync(orderHash: string): Promise<BigNumber>;
 | 
					    public abstract getFilledTakerAmountAsync(orderHash: string): Promise<BigNumber>;
 | 
				
			||||||
    public abstract setFilledTakerAmount(orderHash: string, balance: BigNumber): void;
 | 
					    public abstract setFilledTakerAmount(orderHash: string, balance: BigNumber): void;
 | 
				
			||||||
    public abstract deleteFilledTakerAmount(orderHash: string): void;
 | 
					    public abstract deleteFilledTakerAmount(orderHash: string): void;
 | 
				
			||||||
    public abstract setIsCancelled(orderHash: string, isCancelled: boolean): void;
 | 
					    public abstract setIsCancelled(orderHash: string, isCancelled: boolean): void;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,6 +18,7 @@ import {
 | 
				
			|||||||
    IsolatedExchangeFillEventArgs as FillEventArgs,
 | 
					    IsolatedExchangeFillEventArgs as FillEventArgs,
 | 
				
			||||||
} from '../wrappers';
 | 
					} from '../wrappers';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export { Order } from '@0x/types';
 | 
				
			||||||
export interface AssetBalances {
 | 
					export interface AssetBalances {
 | 
				
			||||||
    [assetData: string]: { [address: string]: BigNumber };
 | 
					    [assetData: string]: { [address: string]: BigNumber };
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -27,7 +28,6 @@ export interface IsolatedExchangeEvents {
 | 
				
			|||||||
    transferFromCalls: DispatchTransferFromCallArgs[];
 | 
					    transferFromCalls: DispatchTransferFromCallArgs[];
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export type Order = Order;
 | 
					 | 
				
			||||||
export type Numberish = string | number | BigNumber;
 | 
					export type Numberish = string | number | BigNumber;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export const DEFAULT_GOOD_SIGNATURE = createGoodSignature();
 | 
					export const DEFAULT_GOOD_SIGNATURE = createGoodSignature();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -12,7 +12,6 @@ import { ReferenceFunctions as UtilReferenceFunctions, SafeMathRevertErrors } fr
 | 
				
			|||||||
import { FillResults, Order } from '@0x/types';
 | 
					import { FillResults, Order } from '@0x/types';
 | 
				
			||||||
import { AnyRevertError, BigNumber, ExchangeRevertErrors, hexUtils, StringRevertError } from '@0x/utils';
 | 
					import { AnyRevertError, BigNumber, ExchangeRevertErrors, hexUtils, StringRevertError } from '@0x/utils';
 | 
				
			||||||
import { LogEntry, LogWithDecodedArgs } from 'ethereum-types';
 | 
					import { LogEntry, LogWithDecodedArgs } from 'ethereum-types';
 | 
				
			||||||
import * as ethjs from 'ethereumjs-util';
 | 
					 | 
				
			||||||
import * as _ from 'lodash';
 | 
					import * as _ from 'lodash';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import { artifacts } from './artifacts';
 | 
					import { artifacts } from './artifacts';
 | 
				
			||||||
@@ -104,7 +103,7 @@ blockchainTests('Exchange wrapper functions unit tests.', env => {
 | 
				
			|||||||
    // Creates a deterministic order signature, even though no signature validation
 | 
					    // Creates a deterministic order signature, even though no signature validation
 | 
				
			||||||
    // actually occurs in the test contract.
 | 
					    // actually occurs in the test contract.
 | 
				
			||||||
    function createOrderSignature(order: Order): string {
 | 
					    function createOrderSignature(order: Order): string {
 | 
				
			||||||
        return ethjs.bufferToHex(ethjs.sha3(ethjs.toBuffer(orderHashUtils.getOrderHashHex(order))));
 | 
					        return hexUtils.hash(orderHashUtils.getOrderHashHex(order));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // Asserts that `_fillOrder()` was called in the same order and with the same
 | 
					    // Asserts that `_fillOrder()` was called in the same order and with the same
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,112 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "6.2.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "6.2.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "6.2.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "6.2.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "6.2.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "6.2.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "6.2.18",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "6.2.17",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "6.2.16",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "6.2.15",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "6.2.14",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "6.2.13",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "6.2.12",
 | 
					        "version": "6.2.12",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.24 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.23 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.22 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.21 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.20 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.19 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.18 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.17 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.16 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.15 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.14 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v6.2.13 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v6.2.12 - _December 9, 2020_
 | 
					## v6.2.12 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-extensions",
 | 
					    "name": "@0x/contracts-extensions",
 | 
				
			||||||
    "version": "6.2.12",
 | 
					    "version": "6.2.24",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -52,23 +52,23 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-dev-utils": "^1.3.16",
 | 
					        "@0x/contracts-dev-utils": "^1.3.28",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-erc721": "^3.1.18",
 | 
					        "@0x/contracts-erc721": "^3.1.29",
 | 
				
			||||||
        "@0x/contracts-exchange": "^3.2.18",
 | 
					        "@0x/contracts-exchange": "^3.2.30",
 | 
				
			||||||
        "@0x/contracts-exchange-libs": "^4.3.18",
 | 
					        "@0x/contracts-exchange-libs": "^4.3.29",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -77,7 +77,7 @@
 | 
				
			|||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereumjs-abi": "0.6.5",
 | 
					        "ethereumjs-abi": "0.6.5",
 | 
				
			||||||
        "ethereumjs-util": "^5.1.1",
 | 
					        "ethereumjs-util": "^7.0.10",
 | 
				
			||||||
        "lodash": "^4.17.11",
 | 
					        "lodash": "^4.17.11",
 | 
				
			||||||
        "make-promises-safe": "^1.1.0",
 | 
					        "make-promises-safe": "^1.1.0",
 | 
				
			||||||
        "mocha": "^6.2.0",
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
@@ -87,13 +87,13 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "ethereum-types": "^3.4.0"
 | 
					        "ethereum-types": "^3.5.0"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-integrations",
 | 
					    "name": "@0x/contracts-integrations",
 | 
				
			||||||
    "version": "2.7.15",
 | 
					    "version": "2.7.42",
 | 
				
			||||||
    "private": true,
 | 
					    "private": true,
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
@@ -52,25 +52,25 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contract-addresses": "^5.6.0",
 | 
					        "@0x/contract-addresses": "^6.1.0",
 | 
				
			||||||
        "@0x/contract-wrappers": "^13.11.0",
 | 
					        "@0x/contract-wrappers": "^13.16.1",
 | 
				
			||||||
        "@0x/contracts-broker": "^1.1.17",
 | 
					        "@0x/contracts-broker": "^1.1.29",
 | 
				
			||||||
        "@0x/contracts-coordinator": "^3.1.18",
 | 
					        "@0x/contracts-coordinator": "^3.1.30",
 | 
				
			||||||
        "@0x/contracts-dev-utils": "^1.3.16",
 | 
					        "@0x/contracts-dev-utils": "^1.3.28",
 | 
				
			||||||
        "@0x/contracts-exchange-forwarder": "^4.2.18",
 | 
					        "@0x/contracts-exchange-forwarder": "^4.2.30",
 | 
				
			||||||
        "@0x/contracts-exchange-libs": "^4.3.18",
 | 
					        "@0x/contracts-exchange-libs": "^4.3.29",
 | 
				
			||||||
        "@0x/contracts-extensions": "^6.2.12",
 | 
					        "@0x/contracts-extensions": "^6.2.24",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/coordinator-server": "^1.0.5",
 | 
					        "@0x/coordinator-server": "^1.0.5",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/migrations": "^6.5.4",
 | 
					        "@0x/migrations": "^8.0.6",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/protocol-utils": "^1.0.1",
 | 
					        "@0x/protocol-utils": "^1.6.0",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@0x/sol-compiler": "^4.7.3",
 | 
				
			||||||
        "@0x/tslint-config": "^4.1.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@azure/core-asynciterator-polyfill": "^1.0.0",
 | 
					        "@azure/core-asynciterator-polyfill": "^1.0.0",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
@@ -90,26 +90,26 @@
 | 
				
			|||||||
        "solhint": "^1.4.1",
 | 
					        "solhint": "^1.4.1",
 | 
				
			||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/asset-swapper": "^5.4.2",
 | 
					        "@0x/asset-swapper": "^6.12.0",
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-erc1155": "^2.1.18",
 | 
					        "@0x/contracts-erc1155": "^2.1.29",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-erc721": "^3.1.18",
 | 
					        "@0x/contracts-erc721": "^3.1.29",
 | 
				
			||||||
        "@0x/contracts-exchange": "^3.2.18",
 | 
					        "@0x/contracts-exchange": "^3.2.30",
 | 
				
			||||||
        "@0x/contracts-multisig": "^4.1.18",
 | 
					        "@0x/contracts-multisig": "^4.1.30",
 | 
				
			||||||
        "@0x/contracts-staking": "^2.0.25",
 | 
					        "@0x/contracts-staking": "^2.0.37",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-zero-ex": "^0.12.0",
 | 
					        "@0x/contracts-zero-ex": "^0.23.0",
 | 
				
			||||||
        "@0x/subproviders": "^6.2.3",
 | 
					        "@0x/subproviders": "^6.5.3",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "ethereumjs-util": "^6.2.0",
 | 
					        "ethereumjs-util": "^7.0.10",
 | 
				
			||||||
        "lodash": "^4.17.11"
 | 
					        "lodash": "^4.17.11"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,239 +0,0 @@
 | 
				
			|||||||
import { MarketBuySwapQuote, MarketSellSwapQuote, Orderbook, SwapQuoter } from '@0x/asset-swapper';
 | 
					 | 
				
			||||||
import { blockchainTests, expect, Numberish } from '@0x/contracts-test-utils';
 | 
					 | 
				
			||||||
import { assetDataUtils } from '@0x/order-utils';
 | 
					 | 
				
			||||||
import { FillResults, SignedOrder } from '@0x/types';
 | 
					 | 
				
			||||||
import { BigNumber, logUtils } from '@0x/utils';
 | 
					 | 
				
			||||||
import * as _ from 'lodash';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import { TestMainnetAggregatorFillsContract } from '../wrappers';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import { tokens } from './tokens';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
blockchainTests.live('Aggregator Mainnet Tests', env => {
 | 
					 | 
				
			||||||
    // Mainnet address of the `TestMainnetAggregatorFills` contract.
 | 
					 | 
				
			||||||
    const TEST_CONTRACT_ADDRESS = '0x37Ca306F42748b7fe105F89FCBb2CD03D27c8146';
 | 
					 | 
				
			||||||
    const TAKER_ADDRESS = '0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B'; // Vitalik
 | 
					 | 
				
			||||||
    const ORDERBOOK_POLLING_MS = 1000;
 | 
					 | 
				
			||||||
    const GAS_PRICE = new BigNumber(1);
 | 
					 | 
				
			||||||
    const TAKER_ASSET_ETH_VALUE = 500e18;
 | 
					 | 
				
			||||||
    const MIN_BALANCE = 500.1e18;
 | 
					 | 
				
			||||||
    const SYMBOLS = ['ETH', 'DAI', 'USDC', 'FOAM'];
 | 
					 | 
				
			||||||
    const TEST_PAIRS = _.flatten(SYMBOLS.map(m => SYMBOLS.filter(t => t !== m).map(t => [m, t])));
 | 
					 | 
				
			||||||
    const FILL_VALUES = [1, 10, 1e2, 1e3, 1e4, 2.5e4, 5e4];
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    let testContract: TestMainnetAggregatorFillsContract;
 | 
					 | 
				
			||||||
    let swapQuoter: SwapQuoter;
 | 
					 | 
				
			||||||
    let takerEthBalance: BigNumber;
 | 
					 | 
				
			||||||
    const orderbooks: { [name: string]: Orderbook } = {};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    async function getTakerOrdersAsync(takerAssetSymbol: string): Promise<SignedOrder[]> {
 | 
					 | 
				
			||||||
        if (takerAssetSymbol === 'ETH') {
 | 
					 | 
				
			||||||
            return [];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return getOrdersAsync(takerAssetSymbol, 'ETH');
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // Fetches ETH -> taker asset orders for the forwarder contract.
 | 
					 | 
				
			||||||
    async function getOrdersAsync(makerAssetSymbol: string, takerAssetSymbol: string): Promise<SignedOrder[]> {
 | 
					 | 
				
			||||||
        const takerTokenAddress = tokens[takerAssetSymbol].address;
 | 
					 | 
				
			||||||
        const makerTokenAddress = tokens[makerAssetSymbol].address;
 | 
					 | 
				
			||||||
        const makerAssetData = assetDataUtils.encodeERC20AssetData(makerTokenAddress);
 | 
					 | 
				
			||||||
        const takerAssetData = assetDataUtils.encodeERC20AssetData(takerTokenAddress);
 | 
					 | 
				
			||||||
        const orders = _.flatten(
 | 
					 | 
				
			||||||
            await Promise.all(
 | 
					 | 
				
			||||||
                Object.keys(orderbooks).map(async name =>
 | 
					 | 
				
			||||||
                    getOrdersFromOrderBookAsync(name, makerAssetData, takerAssetData),
 | 
					 | 
				
			||||||
                ),
 | 
					 | 
				
			||||||
            ),
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
        const uniqueOrders: SignedOrder[] = [];
 | 
					 | 
				
			||||||
        for (const order of orders) {
 | 
					 | 
				
			||||||
            if (!order.makerFee.eq(0) || !order.takerFee.eq(0)) {
 | 
					 | 
				
			||||||
                continue;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            if (uniqueOrders.findIndex(o => isSameOrder(order, o)) === -1) {
 | 
					 | 
				
			||||||
                uniqueOrders.push(order);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return uniqueOrders;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    async function getOrdersFromOrderBookAsync(
 | 
					 | 
				
			||||||
        name: string,
 | 
					 | 
				
			||||||
        makerAssetData: string,
 | 
					 | 
				
			||||||
        takerAssetData: string,
 | 
					 | 
				
			||||||
    ): Promise<SignedOrder[]> {
 | 
					 | 
				
			||||||
        try {
 | 
					 | 
				
			||||||
            return (await orderbooks[name].getOrdersAsync(makerAssetData, takerAssetData)).map(r => r.order);
 | 
					 | 
				
			||||||
        } catch (err) {
 | 
					 | 
				
			||||||
            logUtils.warn(`Failed to retrieve orders from orderbook "${name}".`);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return [];
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    function isSameOrder(a: SignedOrder, b: SignedOrder): boolean {
 | 
					 | 
				
			||||||
        for (const [k, v] of Object.entries(a)) {
 | 
					 | 
				
			||||||
            if (k in (b as any)) {
 | 
					 | 
				
			||||||
                if (BigNumber.isBigNumber(v) && !v.eq((b as any)[k])) {
 | 
					 | 
				
			||||||
                    return false;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                if (v !== (b as any)[k]) {
 | 
					 | 
				
			||||||
                    return false;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return true;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    function toTokenUnits(symbol: string, weis: Numberish): BigNumber {
 | 
					 | 
				
			||||||
        return new BigNumber(weis).div(new BigNumber(10).pow(tokens[symbol].decimals));
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    function fromTokenUnits(symbol: string, units: Numberish): BigNumber {
 | 
					 | 
				
			||||||
        return new BigNumber(units)
 | 
					 | 
				
			||||||
            .times(new BigNumber(10).pow(tokens[symbol].decimals))
 | 
					 | 
				
			||||||
            .integerValue(BigNumber.ROUND_DOWN);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    interface MarketOperationResult {
 | 
					 | 
				
			||||||
        makerAssetBalanceBefore: BigNumber;
 | 
					 | 
				
			||||||
        takerAssetBalanceBefore: BigNumber;
 | 
					 | 
				
			||||||
        makerAssetBalanceAfter: BigNumber;
 | 
					 | 
				
			||||||
        takerAssetBalanceAfter: BigNumber;
 | 
					 | 
				
			||||||
        fillResults: FillResults;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // Liquidity is low right now so it's possible we didn't have
 | 
					 | 
				
			||||||
    // enough taker assets to cover the orders, so occasionally we'll get incomplete
 | 
					 | 
				
			||||||
    // fills. This function will catch those cases.
 | 
					 | 
				
			||||||
    // TODO(dorothy-zbornak): Remove this special case when liquidity is up.
 | 
					 | 
				
			||||||
    function checkHadEnoughTakerAsset(
 | 
					 | 
				
			||||||
        quote: MarketBuySwapQuote | MarketSellSwapQuote,
 | 
					 | 
				
			||||||
        result: MarketOperationResult,
 | 
					 | 
				
			||||||
    ): boolean {
 | 
					 | 
				
			||||||
        if (result.takerAssetBalanceBefore.gte(quote.worstCaseQuoteInfo.takerAssetAmount)) {
 | 
					 | 
				
			||||||
            return true;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        const takerAssetPct = result.takerAssetBalanceBefore
 | 
					 | 
				
			||||||
            .div(quote.worstCaseQuoteInfo.takerAssetAmount)
 | 
					 | 
				
			||||||
            .times(100)
 | 
					 | 
				
			||||||
            .toNumber()
 | 
					 | 
				
			||||||
            .toFixed(1);
 | 
					 | 
				
			||||||
        logUtils.warn(`Could not acquire enough taker asset to complete the fill: ${takerAssetPct}%`);
 | 
					 | 
				
			||||||
        expect(result.fillResults.makerAssetFilledAmount).to.bignumber.lt(quote.worstCaseQuoteInfo.makerAssetAmount);
 | 
					 | 
				
			||||||
        return false;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    before(async () => {
 | 
					 | 
				
			||||||
        testContract = new TestMainnetAggregatorFillsContract(TEST_CONTRACT_ADDRESS, env.provider, {
 | 
					 | 
				
			||||||
            ...env.txDefaults,
 | 
					 | 
				
			||||||
            gasPrice: GAS_PRICE,
 | 
					 | 
				
			||||||
            gas: 10e6,
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
        swapQuoter = SwapQuoter.getSwapQuoterForStandardRelayerAPIUrl(env.provider, 'https://api.0x.org/sra');
 | 
					 | 
				
			||||||
        // Pool orderbooks because we're desperate for liquidity.
 | 
					 | 
				
			||||||
        orderbooks.swapQuoter = swapQuoter.orderbook;
 | 
					 | 
				
			||||||
        orderbooks.bamboo = Orderbook.getOrderbookForPollingProvider({
 | 
					 | 
				
			||||||
            httpEndpoint: 'https://sra.bamboorelay.com/0x/v3',
 | 
					 | 
				
			||||||
            pollingIntervalMs: ORDERBOOK_POLLING_MS,
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
        // TODO(dorothy-zbornak): Uncomment when radar's SRA is up.
 | 
					 | 
				
			||||||
        // orderbooks.radar = Orderbook.getOrderbookForPollingProvider({
 | 
					 | 
				
			||||||
        //     httpEndpoint: 'https://api-v3.radarrelay.com/v3',
 | 
					 | 
				
			||||||
        //     pollingIntervalMs: ORDERBOOK_POLLING_MS,
 | 
					 | 
				
			||||||
        // });
 | 
					 | 
				
			||||||
        takerEthBalance = await env.web3Wrapper.getBalanceInWeiAsync(TAKER_ADDRESS);
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    it('taker has minimum ETH', async () => {
 | 
					 | 
				
			||||||
        expect(takerEthBalance).to.bignumber.gte(MIN_BALANCE);
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    describe('market sells', () => {
 | 
					 | 
				
			||||||
        for (const [makerSymbol, takerSymbol] of TEST_PAIRS) {
 | 
					 | 
				
			||||||
            for (const fillValue of FILL_VALUES) {
 | 
					 | 
				
			||||||
                const fillAmount = fromTokenUnits(takerSymbol, new BigNumber(fillValue).div(tokens[takerSymbol].price));
 | 
					 | 
				
			||||||
                it(`sell ${toTokenUnits(takerSymbol, fillAmount)} ${takerSymbol} for ${makerSymbol}`, async () => {
 | 
					 | 
				
			||||||
                    const [quote, takerOrders] = await Promise.all([
 | 
					 | 
				
			||||||
                        swapQuoter.getMarketSellSwapQuoteAsync(
 | 
					 | 
				
			||||||
                            tokens[makerSymbol].address,
 | 
					 | 
				
			||||||
                            tokens[takerSymbol].address,
 | 
					 | 
				
			||||||
                            fillAmount,
 | 
					 | 
				
			||||||
                            { gasPrice: GAS_PRICE },
 | 
					 | 
				
			||||||
                        ),
 | 
					 | 
				
			||||||
                        getTakerOrdersAsync(takerSymbol),
 | 
					 | 
				
			||||||
                    ]);
 | 
					 | 
				
			||||||
                    // Buy taker assets from `takerOrders` and and perform a
 | 
					 | 
				
			||||||
                    // market sell on the bridge orders.
 | 
					 | 
				
			||||||
                    const fill = await testContract
 | 
					 | 
				
			||||||
                        .marketSell(
 | 
					 | 
				
			||||||
                            tokens[makerSymbol].address,
 | 
					 | 
				
			||||||
                            tokens[takerSymbol].address,
 | 
					 | 
				
			||||||
                            quote.orders,
 | 
					 | 
				
			||||||
                            takerOrders,
 | 
					 | 
				
			||||||
                            quote.orders.map(o => o.signature),
 | 
					 | 
				
			||||||
                            takerOrders.map(o => o.signature),
 | 
					 | 
				
			||||||
                            quote.takerAssetFillAmount,
 | 
					 | 
				
			||||||
                        )
 | 
					 | 
				
			||||||
                        .callAsync({
 | 
					 | 
				
			||||||
                            value: quote.worstCaseQuoteInfo.protocolFeeInWeiAmount.plus(TAKER_ASSET_ETH_VALUE),
 | 
					 | 
				
			||||||
                            from: TAKER_ADDRESS,
 | 
					 | 
				
			||||||
                            gasPrice: quote.gasPrice,
 | 
					 | 
				
			||||||
                        });
 | 
					 | 
				
			||||||
                    if (checkHadEnoughTakerAsset(quote, fill)) {
 | 
					 | 
				
			||||||
                        expect(fill.fillResults.makerAssetFilledAmount, 'makerAssetFilledAmount').to.bignumber.gte(
 | 
					 | 
				
			||||||
                            quote.worstCaseQuoteInfo.makerAssetAmount,
 | 
					 | 
				
			||||||
                        );
 | 
					 | 
				
			||||||
                        expect(fill.fillResults.takerAssetFilledAmount, 'takerAssetFilledAmount').to.bignumber.lte(
 | 
					 | 
				
			||||||
                            quote.takerAssetFillAmount,
 | 
					 | 
				
			||||||
                        );
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                });
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    describe('market buys', () => {
 | 
					 | 
				
			||||||
        for (const [makerSymbol, takerSymbol] of TEST_PAIRS) {
 | 
					 | 
				
			||||||
            for (const fillValue of FILL_VALUES) {
 | 
					 | 
				
			||||||
                const fillAmount = fromTokenUnits(makerSymbol, new BigNumber(fillValue).div(tokens[makerSymbol].price));
 | 
					 | 
				
			||||||
                it(`buy ${toTokenUnits(makerSymbol, fillAmount)} ${makerSymbol} with ${takerSymbol}`, async () => {
 | 
					 | 
				
			||||||
                    const [quote, takerOrders] = await Promise.all([
 | 
					 | 
				
			||||||
                        swapQuoter.getMarketBuySwapQuoteAsync(
 | 
					 | 
				
			||||||
                            tokens[makerSymbol].address,
 | 
					 | 
				
			||||||
                            tokens[takerSymbol].address,
 | 
					 | 
				
			||||||
                            fillAmount,
 | 
					 | 
				
			||||||
                            { gasPrice: GAS_PRICE },
 | 
					 | 
				
			||||||
                        ),
 | 
					 | 
				
			||||||
                        getTakerOrdersAsync(takerSymbol),
 | 
					 | 
				
			||||||
                    ]);
 | 
					 | 
				
			||||||
                    // Buy taker assets from `takerOrders` and and perform a
 | 
					 | 
				
			||||||
                    // market buy on the bridge orders.
 | 
					 | 
				
			||||||
                    const fill = await testContract
 | 
					 | 
				
			||||||
                        .marketBuy(
 | 
					 | 
				
			||||||
                            tokens[makerSymbol].address,
 | 
					 | 
				
			||||||
                            tokens[takerSymbol].address,
 | 
					 | 
				
			||||||
                            quote.orders,
 | 
					 | 
				
			||||||
                            takerOrders,
 | 
					 | 
				
			||||||
                            quote.orders.map(o => o.signature),
 | 
					 | 
				
			||||||
                            takerOrders.map(o => o.signature),
 | 
					 | 
				
			||||||
                            quote.makerAssetFillAmount,
 | 
					 | 
				
			||||||
                        )
 | 
					 | 
				
			||||||
                        .callAsync({
 | 
					 | 
				
			||||||
                            value: quote.worstCaseQuoteInfo.protocolFeeInWeiAmount.plus(TAKER_ASSET_ETH_VALUE),
 | 
					 | 
				
			||||||
                            from: TAKER_ADDRESS,
 | 
					 | 
				
			||||||
                            gasPrice: quote.gasPrice,
 | 
					 | 
				
			||||||
                        });
 | 
					 | 
				
			||||||
                    if (checkHadEnoughTakerAsset(quote, fill)) {
 | 
					 | 
				
			||||||
                        expect(fill.fillResults.takerAssetFilledAmount, 'takerAssetFilledAmount').to.bignumber.lte(
 | 
					 | 
				
			||||||
                            quote.worstCaseQuoteInfo.takerAssetAmount,
 | 
					 | 
				
			||||||
                        );
 | 
					 | 
				
			||||||
                        expect(fill.fillResults.makerAssetFilledAmount, 'makerAssetFilledAmount').to.bignumber.gte(
 | 
					 | 
				
			||||||
                            quote.makerAssetFillAmount,
 | 
					 | 
				
			||||||
                        );
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                });
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
@@ -1,77 +0,0 @@
 | 
				
			|||||||
export const tokens: { [symbol: string]: { address: string; decimals: number; price: number } } = {
 | 
					 | 
				
			||||||
    ETH: {
 | 
					 | 
				
			||||||
        address: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 133,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    SAI: {
 | 
					 | 
				
			||||||
        address: '0x89d24A6b4CcB1B6fAA2625fE562bDD9a23260359',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 1,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    DAI: {
 | 
					 | 
				
			||||||
        address: '0x6B175474E89094C44Da98b954EedeAC495271d0F',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 1,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    USDC: {
 | 
					 | 
				
			||||||
        address: '0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48',
 | 
					 | 
				
			||||||
        decimals: 6,
 | 
					 | 
				
			||||||
        price: 1,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    WBTC: {
 | 
					 | 
				
			||||||
        address: '0x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C599',
 | 
					 | 
				
			||||||
        decimals: 8,
 | 
					 | 
				
			||||||
        price: 6900,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    MKR: {
 | 
					 | 
				
			||||||
        address: '0x9f8F72aA9304c8B593d555F12eF6589cC3A579A2',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 454,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    BAT: {
 | 
					 | 
				
			||||||
        address: '0x0D8775F648430679A709E98d2b0Cb6250d2887EF',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 0.17,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    OMG: {
 | 
					 | 
				
			||||||
        address: '0xd26114cd6EE289AccF82350c8d8487fedB8A0C07',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 0.65,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    ZRX: {
 | 
					 | 
				
			||||||
        address: '0xE41d2489571d322189246DaFA5ebDe1F4699F498',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 0.19,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    ZIL: {
 | 
					 | 
				
			||||||
        address: '0x05f4a42e251f2d52b8ed15E9FEdAacFcEF1FAD27',
 | 
					 | 
				
			||||||
        decimals: 12,
 | 
					 | 
				
			||||||
        price: 0.004,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    FOAM: {
 | 
					 | 
				
			||||||
        address: '0x4946Fcea7C692606e8908002e55A582af44AC121',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 0.004,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    USDT: {
 | 
					 | 
				
			||||||
        address: '0xdAC17F958D2ee523a2206206994597C13D831ec7',
 | 
					 | 
				
			||||||
        decimals: 6,
 | 
					 | 
				
			||||||
        price: 0.019,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    REP: {
 | 
					 | 
				
			||||||
        address: '0x1985365e9f78359a9B6AD760e32412f4a445E862',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 8.9,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    MANA: {
 | 
					 | 
				
			||||||
        address: '0x0F5D2fB29fb7d3CFeE444a200298f468908cC942',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 0.025,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    LINK: {
 | 
					 | 
				
			||||||
        address: '0x514910771AF9Ca656af840dff83E8264EcF986CA',
 | 
					 | 
				
			||||||
        decimals: 18,
 | 
					 | 
				
			||||||
        price: 1.8,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
@@ -63,11 +63,9 @@ blockchainTests.fork('DevUtils dydx order validation tests', env => {
 | 
				
			|||||||
    let dai: ERC20TokenContract;
 | 
					    let dai: ERC20TokenContract;
 | 
				
			||||||
    let usdc: ERC20TokenContract;
 | 
					    let usdc: ERC20TokenContract;
 | 
				
			||||||
    let devUtils: DevUtilsContract;
 | 
					    let devUtils: DevUtilsContract;
 | 
				
			||||||
    let accountOwner: string;
 | 
					 | 
				
			||||||
    let minMarginRatio: number;
 | 
					    let minMarginRatio: number;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    before(async () => {
 | 
					    before(async () => {
 | 
				
			||||||
        [accountOwner] = await env.getAccountAddressesAsync();
 | 
					 | 
				
			||||||
        dydx = new IDydxContract(DYDX_ADDRESS, env.provider, env.txDefaults);
 | 
					        dydx = new IDydxContract(DYDX_ADDRESS, env.provider, env.txDefaults);
 | 
				
			||||||
        dai = new ERC20TokenContract(DAI_ADDRESS, env.provider, env.txDefaults);
 | 
					        dai = new ERC20TokenContract(DAI_ADDRESS, env.provider, env.txDefaults);
 | 
				
			||||||
        usdc = new ERC20TokenContract(USDC_ADDRESS, env.provider, env.txDefaults);
 | 
					        usdc = new ERC20TokenContract(USDC_ADDRESS, env.provider, env.txDefaults);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,360 +0,0 @@
 | 
				
			|||||||
import { ContractAddresses } from '@0x/contract-addresses';
 | 
					 | 
				
			||||||
import { artifacts as erc20Artifacts, DummyERC20TokenContract } from '@0x/contracts-erc20';
 | 
					 | 
				
			||||||
import { IExchangeContract } from '@0x/contracts-exchange';
 | 
					 | 
				
			||||||
import { blockchainTests, constants, expect, getRandomPortion, verifyEventsFromLogs } from '@0x/contracts-test-utils';
 | 
					 | 
				
			||||||
import {
 | 
					 | 
				
			||||||
    artifacts as exchangeProxyArtifacts,
 | 
					 | 
				
			||||||
    IZeroExContract,
 | 
					 | 
				
			||||||
    LogMetadataTransformerContract,
 | 
					 | 
				
			||||||
} from '@0x/contracts-zero-ex';
 | 
					 | 
				
			||||||
import { migrateOnceAsync } from '@0x/migrations';
 | 
					 | 
				
			||||||
import { assetDataUtils, signatureUtils, SignedExchangeProxyMetaTransaction } from '@0x/order-utils';
 | 
					 | 
				
			||||||
import {
 | 
					 | 
				
			||||||
    encodeFillQuoteTransformerData,
 | 
					 | 
				
			||||||
    encodePayTakerTransformerData,
 | 
					 | 
				
			||||||
    ETH_TOKEN_ADDRESS,
 | 
					 | 
				
			||||||
    FillQuoteTransformerSide,
 | 
					 | 
				
			||||||
    findTransformerNonce,
 | 
					 | 
				
			||||||
    Signature,
 | 
					 | 
				
			||||||
} from '@0x/protocol-utils';
 | 
					 | 
				
			||||||
import { AssetProxyId, Order, SignedOrder } from '@0x/types';
 | 
					 | 
				
			||||||
import { BigNumber, hexUtils } from '@0x/utils';
 | 
					 | 
				
			||||||
import * as ethjs from 'ethereumjs-util';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
const { MAX_UINT256, NULL_ADDRESS, NULL_BYTES, ZERO_AMOUNT } = constants;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
function sigstruct(signature: string): Signature {
 | 
					 | 
				
			||||||
    return {
 | 
					 | 
				
			||||||
        v: parseInt(hexUtils.slice(signature, 0, 1), 16),
 | 
					 | 
				
			||||||
        signatureType: parseInt(hexUtils.slice(signature, 65, 66), 16),
 | 
					 | 
				
			||||||
        r: hexUtils.slice(signature, 1, 33),
 | 
					 | 
				
			||||||
        s: hexUtils.slice(signature, 33, 65),
 | 
					 | 
				
			||||||
    };
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
blockchainTests.resets('exchange proxy - meta-transactions', env => {
 | 
					 | 
				
			||||||
    const quoteSignerKey = hexUtils.random();
 | 
					 | 
				
			||||||
    const quoteSigner = hexUtils.toHex(ethjs.privateToAddress(ethjs.toBuffer(quoteSignerKey)));
 | 
					 | 
				
			||||||
    let owner: string;
 | 
					 | 
				
			||||||
    let relayer: string;
 | 
					 | 
				
			||||||
    let maker: string;
 | 
					 | 
				
			||||||
    let taker: string;
 | 
					 | 
				
			||||||
    let flashWalletAddress: string;
 | 
					 | 
				
			||||||
    let zeroEx: IZeroExContract;
 | 
					 | 
				
			||||||
    let exchange: IExchangeContract;
 | 
					 | 
				
			||||||
    let inputToken: DummyERC20TokenContract;
 | 
					 | 
				
			||||||
    let outputToken: DummyERC20TokenContract;
 | 
					 | 
				
			||||||
    let feeToken: DummyERC20TokenContract;
 | 
					 | 
				
			||||||
    let addresses: ContractAddresses;
 | 
					 | 
				
			||||||
    let protocolFee: BigNumber;
 | 
					 | 
				
			||||||
    let metadataTransformer: LogMetadataTransformerContract;
 | 
					 | 
				
			||||||
    const GAS_PRICE = new BigNumber('1e9');
 | 
					 | 
				
			||||||
    const MAKER_BALANCE = new BigNumber('100e18');
 | 
					 | 
				
			||||||
    const TAKER_BALANCE = new BigNumber('100e18');
 | 
					 | 
				
			||||||
    const TAKER_FEE_BALANCE = new BigNumber('100e18');
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    before(async () => {
 | 
					 | 
				
			||||||
        [, relayer, maker, taker] = await env.getAccountAddressesAsync();
 | 
					 | 
				
			||||||
        addresses = await migrateOnceAsync(env.provider);
 | 
					 | 
				
			||||||
        zeroEx = new IZeroExContract(addresses.exchangeProxy, env.provider, env.txDefaults, {
 | 
					 | 
				
			||||||
            LogMetadataTransformer: LogMetadataTransformerContract.ABI(),
 | 
					 | 
				
			||||||
            DummyERC20Token: DummyERC20TokenContract.ABI(),
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
        exchange = new IExchangeContract(addresses.exchange, env.provider, env.txDefaults);
 | 
					 | 
				
			||||||
        [inputToken, outputToken, feeToken] = await Promise.all(
 | 
					 | 
				
			||||||
            [...new Array(3)].map(i =>
 | 
					 | 
				
			||||||
                DummyERC20TokenContract.deployFrom0xArtifactAsync(
 | 
					 | 
				
			||||||
                    erc20Artifacts.DummyERC20Token,
 | 
					 | 
				
			||||||
                    env.provider,
 | 
					 | 
				
			||||||
                    env.txDefaults,
 | 
					 | 
				
			||||||
                    {},
 | 
					 | 
				
			||||||
                    `DummyToken-${i}`,
 | 
					 | 
				
			||||||
                    `TOK${i}`,
 | 
					 | 
				
			||||||
                    new BigNumber(18),
 | 
					 | 
				
			||||||
                    BigNumber.max(MAKER_BALANCE, TAKER_BALANCE),
 | 
					 | 
				
			||||||
                ),
 | 
					 | 
				
			||||||
            ),
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
        // LogMetadataTransformer is not deployed in migrations.
 | 
					 | 
				
			||||||
        metadataTransformer = await LogMetadataTransformerContract.deployFrom0xArtifactAsync(
 | 
					 | 
				
			||||||
            exchangeProxyArtifacts.LogMetadataTransformer,
 | 
					 | 
				
			||||||
            env.provider,
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                ...env.txDefaults,
 | 
					 | 
				
			||||||
                from: addresses.exchangeProxyTransformerDeployer,
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
            {},
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
        owner = await zeroEx.owner().callAsync();
 | 
					 | 
				
			||||||
        protocolFee = await exchange.protocolFeeMultiplier().callAsync();
 | 
					 | 
				
			||||||
        flashWalletAddress = await zeroEx.getTransformWallet().callAsync();
 | 
					 | 
				
			||||||
        const erc20Proxy = await exchange.getAssetProxy(AssetProxyId.ERC20).callAsync();
 | 
					 | 
				
			||||||
        const allowanceTarget = await zeroEx.getAllowanceTarget().callAsync();
 | 
					 | 
				
			||||||
        await outputToken.mint(MAKER_BALANCE).awaitTransactionSuccessAsync({ from: maker });
 | 
					 | 
				
			||||||
        await inputToken.mint(TAKER_BALANCE).awaitTransactionSuccessAsync({ from: taker });
 | 
					 | 
				
			||||||
        await feeToken.mint(TAKER_FEE_BALANCE).awaitTransactionSuccessAsync({ from: taker });
 | 
					 | 
				
			||||||
        await outputToken.approve(erc20Proxy, MAX_UINT256).awaitTransactionSuccessAsync({ from: maker });
 | 
					 | 
				
			||||||
        await inputToken.approve(allowanceTarget, MAX_UINT256).awaitTransactionSuccessAsync({ from: taker });
 | 
					 | 
				
			||||||
        await feeToken.approve(allowanceTarget, MAX_UINT256).awaitTransactionSuccessAsync({ from: taker });
 | 
					 | 
				
			||||||
        await zeroEx.setQuoteSigner(quoteSigner).awaitTransactionSuccessAsync({ from: owner });
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    interface Transformation {
 | 
					 | 
				
			||||||
        deploymentNonce: number;
 | 
					 | 
				
			||||||
        data: string;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    interface SwapInfo {
 | 
					 | 
				
			||||||
        inputTokenAddress: string;
 | 
					 | 
				
			||||||
        outputTokenAddress: string;
 | 
					 | 
				
			||||||
        inputTokenAmount: BigNumber;
 | 
					 | 
				
			||||||
        minOutputTokenAmount: BigNumber;
 | 
					 | 
				
			||||||
        transformations: Transformation[];
 | 
					 | 
				
			||||||
        orders: SignedOrder[];
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    async function generateSwapAsync(orderFields: Partial<Order> = {}, isRfqt: boolean = false): Promise<SwapInfo> {
 | 
					 | 
				
			||||||
        const order = await signatureUtils.ecSignTypedDataOrderAsync(
 | 
					 | 
				
			||||||
            env.provider,
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                chainId: 1337,
 | 
					 | 
				
			||||||
                exchangeAddress: exchange.address,
 | 
					 | 
				
			||||||
                expirationTimeSeconds: new BigNumber(Date.now()),
 | 
					 | 
				
			||||||
                salt: new BigNumber(hexUtils.random()),
 | 
					 | 
				
			||||||
                feeRecipientAddress: NULL_ADDRESS,
 | 
					 | 
				
			||||||
                senderAddress: NULL_ADDRESS,
 | 
					 | 
				
			||||||
                takerAddress: isRfqt ? flashWalletAddress : NULL_ADDRESS,
 | 
					 | 
				
			||||||
                makerAddress: maker,
 | 
					 | 
				
			||||||
                makerAssetData: assetDataUtils.encodeERC20AssetData(outputToken.address),
 | 
					 | 
				
			||||||
                takerAssetData: assetDataUtils.encodeERC20AssetData(inputToken.address),
 | 
					 | 
				
			||||||
                makerFeeAssetData: NULL_BYTES,
 | 
					 | 
				
			||||||
                takerFeeAssetData: NULL_BYTES,
 | 
					 | 
				
			||||||
                takerAssetAmount: getRandomPortion(TAKER_BALANCE),
 | 
					 | 
				
			||||||
                makerAssetAmount: getRandomPortion(MAKER_BALANCE),
 | 
					 | 
				
			||||||
                makerFee: ZERO_AMOUNT,
 | 
					 | 
				
			||||||
                takerFee: ZERO_AMOUNT,
 | 
					 | 
				
			||||||
                ...orderFields,
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
            maker,
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
        const transformations = [
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                deploymentNonce: findTransformerNonce(
 | 
					 | 
				
			||||||
                    addresses.transformers.fillQuoteTransformer,
 | 
					 | 
				
			||||||
                    addresses.exchangeProxyTransformerDeployer,
 | 
					 | 
				
			||||||
                ),
 | 
					 | 
				
			||||||
                data: encodeFillQuoteTransformerData({
 | 
					 | 
				
			||||||
                    orders: [order],
 | 
					 | 
				
			||||||
                    signatures: [order.signature],
 | 
					 | 
				
			||||||
                    buyToken: outputToken.address,
 | 
					 | 
				
			||||||
                    sellToken: inputToken.address,
 | 
					 | 
				
			||||||
                    fillAmount: order.takerAssetAmount,
 | 
					 | 
				
			||||||
                    maxOrderFillAmounts: [],
 | 
					 | 
				
			||||||
                    refundReceiver: hexUtils.leftPad(2, 20), // Send refund to sender.
 | 
					 | 
				
			||||||
                    rfqtTakerAddress: isRfqt ? taker : NULL_ADDRESS,
 | 
					 | 
				
			||||||
                    side: FillQuoteTransformerSide.Sell,
 | 
					 | 
				
			||||||
                }),
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                deploymentNonce: findTransformerNonce(
 | 
					 | 
				
			||||||
                    addresses.transformers.payTakerTransformer,
 | 
					 | 
				
			||||||
                    addresses.exchangeProxyTransformerDeployer,
 | 
					 | 
				
			||||||
                ),
 | 
					 | 
				
			||||||
                data: encodePayTakerTransformerData({
 | 
					 | 
				
			||||||
                    tokens: [inputToken.address, outputToken.address, ETH_TOKEN_ADDRESS],
 | 
					 | 
				
			||||||
                    amounts: [MAX_UINT256, MAX_UINT256, MAX_UINT256],
 | 
					 | 
				
			||||||
                }),
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                deploymentNonce: findTransformerNonce(
 | 
					 | 
				
			||||||
                    metadataTransformer.address,
 | 
					 | 
				
			||||||
                    addresses.exchangeProxyTransformerDeployer,
 | 
					 | 
				
			||||||
                ),
 | 
					 | 
				
			||||||
                data: NULL_BYTES,
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
        ];
 | 
					 | 
				
			||||||
        return {
 | 
					 | 
				
			||||||
            transformations,
 | 
					 | 
				
			||||||
            orders: [order],
 | 
					 | 
				
			||||||
            inputTokenAddress: inputToken.address,
 | 
					 | 
				
			||||||
            outputTokenAddress: outputToken.address,
 | 
					 | 
				
			||||||
            inputTokenAmount: order.takerAssetAmount,
 | 
					 | 
				
			||||||
            minOutputTokenAmount: order.makerAssetAmount,
 | 
					 | 
				
			||||||
        };
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    function getSwapData(swap: SwapInfo): string {
 | 
					 | 
				
			||||||
        return zeroEx
 | 
					 | 
				
			||||||
            .transformERC20(
 | 
					 | 
				
			||||||
                swap.inputTokenAddress,
 | 
					 | 
				
			||||||
                swap.outputTokenAddress,
 | 
					 | 
				
			||||||
                swap.inputTokenAmount,
 | 
					 | 
				
			||||||
                swap.minOutputTokenAmount,
 | 
					 | 
				
			||||||
                swap.transformations,
 | 
					 | 
				
			||||||
            )
 | 
					 | 
				
			||||||
            .getABIEncodedTransactionData();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    async function createMetaTransactionAsync(
 | 
					 | 
				
			||||||
        data: string,
 | 
					 | 
				
			||||||
        value: BigNumber,
 | 
					 | 
				
			||||||
        fee?: BigNumber | number,
 | 
					 | 
				
			||||||
    ): Promise<SignedExchangeProxyMetaTransaction> {
 | 
					 | 
				
			||||||
        return signatureUtils.ecSignTypedDataExchangeProxyMetaTransactionAsync(
 | 
					 | 
				
			||||||
            env.provider,
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                value,
 | 
					 | 
				
			||||||
                signer: taker,
 | 
					 | 
				
			||||||
                sender: relayer,
 | 
					 | 
				
			||||||
                minGasPrice: GAS_PRICE,
 | 
					 | 
				
			||||||
                maxGasPrice: GAS_PRICE,
 | 
					 | 
				
			||||||
                expirationTimeSeconds: new BigNumber(Math.floor(Date.now() / 1000) + 60),
 | 
					 | 
				
			||||||
                salt: new BigNumber(hexUtils.random()),
 | 
					 | 
				
			||||||
                callData: data,
 | 
					 | 
				
			||||||
                feeToken: feeToken.address,
 | 
					 | 
				
			||||||
                feeAmount: fee !== undefined ? new BigNumber(fee) : getRandomPortion(TAKER_FEE_BALANCE),
 | 
					 | 
				
			||||||
                domain: {
 | 
					 | 
				
			||||||
                    chainId: 1,
 | 
					 | 
				
			||||||
                    name: 'ZeroEx',
 | 
					 | 
				
			||||||
                    version: '1.0.0',
 | 
					 | 
				
			||||||
                    verifyingContract: zeroEx.address,
 | 
					 | 
				
			||||||
                },
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
            taker,
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    it('can call `transformERC20()` with calldata and no relayer fee', async () => {
 | 
					 | 
				
			||||||
        const swap = await generateSwapAsync();
 | 
					 | 
				
			||||||
        const _protocolFee = protocolFee.times(GAS_PRICE).times(swap.orders.length + 1); // Pay a little more fee than needed.
 | 
					 | 
				
			||||||
        const mtx = await createMetaTransactionAsync(getSwapData(swap), _protocolFee, 0);
 | 
					 | 
				
			||||||
        const relayerEthBalanceBefore = await env.web3Wrapper.getBalanceInWeiAsync(relayer);
 | 
					 | 
				
			||||||
        const receipt = await zeroEx
 | 
					 | 
				
			||||||
            .executeMetaTransaction(mtx, sigstruct(mtx.signature))
 | 
					 | 
				
			||||||
            .awaitTransactionSuccessAsync({ from: relayer, value: mtx.value, gasPrice: GAS_PRICE });
 | 
					 | 
				
			||||||
        const relayerEthRefund = relayerEthBalanceBefore
 | 
					 | 
				
			||||||
            .minus(await env.web3Wrapper.getBalanceInWeiAsync(relayer))
 | 
					 | 
				
			||||||
            .minus(GAS_PRICE.times(receipt.gasUsed));
 | 
					 | 
				
			||||||
        // Ensure the relayer got back the unused protocol fees.
 | 
					 | 
				
			||||||
        expect(relayerEthRefund).to.bignumber.eq(protocolFee.times(GAS_PRICE));
 | 
					 | 
				
			||||||
        // Ensure the relayer got paid no mtx fees.
 | 
					 | 
				
			||||||
        expect(await feeToken.balanceOf(relayer).callAsync()).to.bignumber.eq(0);
 | 
					 | 
				
			||||||
        // Ensure the taker got output tokens.
 | 
					 | 
				
			||||||
        expect(await outputToken.balanceOf(taker).callAsync()).to.bignumber.eq(swap.minOutputTokenAmount);
 | 
					 | 
				
			||||||
        // Ensure the maker got input tokens.
 | 
					 | 
				
			||||||
        expect(await inputToken.balanceOf(maker).callAsync()).to.bignumber.eq(swap.inputTokenAmount);
 | 
					 | 
				
			||||||
        // Check events.
 | 
					 | 
				
			||||||
        verifyEventsFromLogs(
 | 
					 | 
				
			||||||
            receipt.logs,
 | 
					 | 
				
			||||||
            [
 | 
					 | 
				
			||||||
                {
 | 
					 | 
				
			||||||
                    taker,
 | 
					 | 
				
			||||||
                    sender: zeroEx.address,
 | 
					 | 
				
			||||||
                    data: NULL_BYTES,
 | 
					 | 
				
			||||||
                },
 | 
					 | 
				
			||||||
            ],
 | 
					 | 
				
			||||||
            'TransformerMetadata',
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    it('can call `transformERC20()` with calldata and a relayer fee', async () => {
 | 
					 | 
				
			||||||
        const swap = await generateSwapAsync();
 | 
					 | 
				
			||||||
        const _protocolFee = protocolFee.times(GAS_PRICE).times(swap.orders.length + 1); // Pay a little more fee than needed.
 | 
					 | 
				
			||||||
        const mtx = await createMetaTransactionAsync(getSwapData(swap), _protocolFee);
 | 
					 | 
				
			||||||
        const relayerEthBalanceBefore = await env.web3Wrapper.getBalanceInWeiAsync(relayer);
 | 
					 | 
				
			||||||
        const receipt = await zeroEx
 | 
					 | 
				
			||||||
            .executeMetaTransaction(mtx, sigstruct(mtx.signature))
 | 
					 | 
				
			||||||
            .awaitTransactionSuccessAsync({ from: relayer, value: mtx.value, gasPrice: GAS_PRICE });
 | 
					 | 
				
			||||||
        const relayerEthRefund = relayerEthBalanceBefore
 | 
					 | 
				
			||||||
            .minus(await env.web3Wrapper.getBalanceInWeiAsync(relayer))
 | 
					 | 
				
			||||||
            .minus(GAS_PRICE.times(receipt.gasUsed));
 | 
					 | 
				
			||||||
        // Ensure the relayer got back the unused protocol fees.
 | 
					 | 
				
			||||||
        expect(relayerEthRefund).to.bignumber.eq(protocolFee.times(GAS_PRICE));
 | 
					 | 
				
			||||||
        // Ensure the relayer got paid mtx fees.
 | 
					 | 
				
			||||||
        expect(await feeToken.balanceOf(relayer).callAsync()).to.bignumber.eq(mtx.feeAmount);
 | 
					 | 
				
			||||||
        // Ensure the taker got output tokens.
 | 
					 | 
				
			||||||
        expect(await outputToken.balanceOf(taker).callAsync()).to.bignumber.eq(swap.minOutputTokenAmount);
 | 
					 | 
				
			||||||
        // Ensure the maker got input tokens.
 | 
					 | 
				
			||||||
        expect(await inputToken.balanceOf(maker).callAsync()).to.bignumber.eq(swap.inputTokenAmount);
 | 
					 | 
				
			||||||
        // Check events.
 | 
					 | 
				
			||||||
        verifyEventsFromLogs(
 | 
					 | 
				
			||||||
            receipt.logs,
 | 
					 | 
				
			||||||
            [
 | 
					 | 
				
			||||||
                {
 | 
					 | 
				
			||||||
                    taker,
 | 
					 | 
				
			||||||
                    sender: zeroEx.address,
 | 
					 | 
				
			||||||
                    data: NULL_BYTES,
 | 
					 | 
				
			||||||
                },
 | 
					 | 
				
			||||||
            ],
 | 
					 | 
				
			||||||
            'TransformerMetadata',
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    it('`transformERC20()` can fill RFQT order', async () => {
 | 
					 | 
				
			||||||
        const swap = await generateSwapAsync({}, true);
 | 
					 | 
				
			||||||
        const _protocolFee = protocolFee.times(GAS_PRICE).times(swap.orders.length + 1); // Pay a little more fee than needed.
 | 
					 | 
				
			||||||
        const mtx = await createMetaTransactionAsync(getSwapData(swap), _protocolFee, 0);
 | 
					 | 
				
			||||||
        const relayerEthBalanceBefore = await env.web3Wrapper.getBalanceInWeiAsync(relayer);
 | 
					 | 
				
			||||||
        const receipt = await zeroEx
 | 
					 | 
				
			||||||
            .executeMetaTransaction(mtx, sigstruct(mtx.signature))
 | 
					 | 
				
			||||||
            .awaitTransactionSuccessAsync({ from: relayer, value: mtx.value, gasPrice: GAS_PRICE });
 | 
					 | 
				
			||||||
        const relayerEthRefund = relayerEthBalanceBefore
 | 
					 | 
				
			||||||
            .minus(await env.web3Wrapper.getBalanceInWeiAsync(relayer))
 | 
					 | 
				
			||||||
            .minus(GAS_PRICE.times(receipt.gasUsed));
 | 
					 | 
				
			||||||
        // Ensure the relayer got back the unused protocol fees.
 | 
					 | 
				
			||||||
        expect(relayerEthRefund).to.bignumber.eq(protocolFee.times(GAS_PRICE));
 | 
					 | 
				
			||||||
        // Ensure the relayer got paid no mtx fees.
 | 
					 | 
				
			||||||
        expect(await feeToken.balanceOf(relayer).callAsync()).to.bignumber.eq(0);
 | 
					 | 
				
			||||||
        // Ensure the taker got output tokens.
 | 
					 | 
				
			||||||
        expect(await outputToken.balanceOf(taker).callAsync()).to.bignumber.eq(swap.minOutputTokenAmount);
 | 
					 | 
				
			||||||
        // Ensure the maker got input tokens.
 | 
					 | 
				
			||||||
        expect(await inputToken.balanceOf(maker).callAsync()).to.bignumber.eq(swap.inputTokenAmount);
 | 
					 | 
				
			||||||
        // Check events.
 | 
					 | 
				
			||||||
        verifyEventsFromLogs(
 | 
					 | 
				
			||||||
            receipt.logs,
 | 
					 | 
				
			||||||
            [
 | 
					 | 
				
			||||||
                {
 | 
					 | 
				
			||||||
                    taker,
 | 
					 | 
				
			||||||
                    sender: zeroEx.address,
 | 
					 | 
				
			||||||
                    data: NULL_BYTES,
 | 
					 | 
				
			||||||
                },
 | 
					 | 
				
			||||||
            ],
 | 
					 | 
				
			||||||
            'TransformerMetadata',
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    it('`transformERC20()` can fill RFQT order if quote signer configured', async () => {
 | 
					 | 
				
			||||||
        const swap = await generateSwapAsync({}, true);
 | 
					 | 
				
			||||||
        const callData = getSwapData(swap);
 | 
					 | 
				
			||||||
        const _protocolFee = protocolFee.times(GAS_PRICE).times(swap.orders.length + 1); // Pay a little more fee than needed.
 | 
					 | 
				
			||||||
        const mtx = await createMetaTransactionAsync(callData, _protocolFee, 0);
 | 
					 | 
				
			||||||
        const relayerEthBalanceBefore = await env.web3Wrapper.getBalanceInWeiAsync(relayer);
 | 
					 | 
				
			||||||
        await zeroEx.setQuoteSigner(NULL_ADDRESS).awaitTransactionSuccessAsync({ from: owner });
 | 
					 | 
				
			||||||
        const receipt = await zeroEx
 | 
					 | 
				
			||||||
            .executeMetaTransaction(mtx, sigstruct(mtx.signature))
 | 
					 | 
				
			||||||
            .awaitTransactionSuccessAsync({ from: relayer, value: mtx.value, gasPrice: GAS_PRICE });
 | 
					 | 
				
			||||||
        const relayerEthRefund = relayerEthBalanceBefore
 | 
					 | 
				
			||||||
            .minus(await env.web3Wrapper.getBalanceInWeiAsync(relayer))
 | 
					 | 
				
			||||||
            .minus(GAS_PRICE.times(receipt.gasUsed));
 | 
					 | 
				
			||||||
        // Ensure the relayer got back the unused protocol fees.
 | 
					 | 
				
			||||||
        expect(relayerEthRefund).to.bignumber.eq(protocolFee.times(GAS_PRICE));
 | 
					 | 
				
			||||||
        // Ensure the relayer got paid no mtx fees.
 | 
					 | 
				
			||||||
        expect(await feeToken.balanceOf(relayer).callAsync()).to.bignumber.eq(0);
 | 
					 | 
				
			||||||
        // Ensure the taker got output tokens.
 | 
					 | 
				
			||||||
        expect(await outputToken.balanceOf(taker).callAsync()).to.bignumber.eq(swap.minOutputTokenAmount);
 | 
					 | 
				
			||||||
        // Ensure the maker got input tokens.
 | 
					 | 
				
			||||||
        expect(await inputToken.balanceOf(maker).callAsync()).to.bignumber.eq(swap.inputTokenAmount);
 | 
					 | 
				
			||||||
        // Check events.
 | 
					 | 
				
			||||||
        verifyEventsFromLogs(
 | 
					 | 
				
			||||||
            receipt.logs,
 | 
					 | 
				
			||||||
            [
 | 
					 | 
				
			||||||
                {
 | 
					 | 
				
			||||||
                    taker,
 | 
					 | 
				
			||||||
                    sender: zeroEx.address,
 | 
					 | 
				
			||||||
                    data: NULL_BYTES,
 | 
					 | 
				
			||||||
                },
 | 
					 | 
				
			||||||
            ],
 | 
					 | 
				
			||||||
            'TransformerMetadata',
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
@@ -19,5 +19,5 @@ export function filterActorsByRole<TClass extends Constructor>(
 | 
				
			|||||||
    actors: Actor[],
 | 
					    actors: Actor[],
 | 
				
			||||||
    role: TClass,
 | 
					    role: TClass,
 | 
				
			||||||
): Array<InstanceType<typeof role>> {
 | 
					): Array<InstanceType<typeof role>> {
 | 
				
			||||||
    return actors.filter(actor => actor.mixins.includes(role.name)) as InstanceType<typeof role>;
 | 
					    return actors.filter(actor => actor.mixins.includes(role.name)) as Array<InstanceType<typeof role>>;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,112 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "4.1.30",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "4.1.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "4.1.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "4.1.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "4.1.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "4.1.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "4.1.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "4.1.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "4.1.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "4.1.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "4.1.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "4.1.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "4.1.18",
 | 
					        "version": "4.1.18",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.30 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.29 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.28 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.27 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.26 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.25 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.24 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.23 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.22 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.21 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.20 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.1.19 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v4.1.18 - _December 9, 2020_
 | 
					## v4.1.18 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-multisig",
 | 
					    "name": "@0x/contracts-multisig",
 | 
				
			||||||
    "version": "4.1.18",
 | 
					    "version": "4.1.30",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -49,18 +49,18 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@0x/sol-compiler": "^4.7.3",
 | 
				
			||||||
        "@0x/tslint-config": "^4.1.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/mocha": "^5.2.7",
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
@@ -75,12 +75,12 @@
 | 
				
			|||||||
        "shx": "^0.2.2",
 | 
					        "shx": "^0.2.2",
 | 
				
			||||||
        "solhint": "^1.4.1",
 | 
					        "solhint": "^1.4.1",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "ethereum-types": "^3.4.0"
 | 
					        "ethereum-types": "^3.5.0"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,113 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "version": "2.0.37",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Patch epoch finalization issue",
 | 
				
			||||||
 | 
					                "pr": 221
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "timestamp": 1620214333
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "2.0.36",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "2.0.35",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "2.0.34",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "2.0.33",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "2.0.32",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "2.0.31",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "2.0.30",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "2.0.29",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "2.0.28",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "2.0.27",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608105788,
 | 
				
			||||||
 | 
					        "version": "2.0.26",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "2.0.25",
 | 
					        "version": "2.0.25",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,54 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.37 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Patch epoch finalization issue (#221)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.36 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.35 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.34 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.33 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.32 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.31 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.30 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.29 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.28 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.27 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v2.0.26 - _December 16, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v2.0.25 - _December 9, 2020_
 | 
					## v2.0.25 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										55
									
								
								contracts/staking/contracts/src/StakingPatch.sol
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								contracts/staking/contracts/src/StakingPatch.sol
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,55 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Copyright 2019 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.5.9;
 | 
				
			||||||
 | 
					pragma experimental ABIEncoderV2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import "./interfaces/IStaking.sol";
 | 
				
			||||||
 | 
					import "./sys/MixinParams.sol";
 | 
				
			||||||
 | 
					import "./stake/MixinStake.sol";
 | 
				
			||||||
 | 
					import "./fees/MixinExchangeFees.sol";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					contract StakingPatch is
 | 
				
			||||||
 | 
					    IStaking,
 | 
				
			||||||
 | 
					    MixinParams,
 | 
				
			||||||
 | 
					    MixinStake,
 | 
				
			||||||
 | 
					    MixinExchangeFees
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    /// @dev Initialize storage owned by this contract.
 | 
				
			||||||
 | 
					    ///      This function should not be called directly.
 | 
				
			||||||
 | 
					    ///      The StakingProxy contract will call it in `attachStakingContract()`.
 | 
				
			||||||
 | 
					    function init()
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					        onlyAuthorized
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        uint256 currentEpoch_ = currentEpoch;
 | 
				
			||||||
 | 
					        uint256 prevEpoch = currentEpoch_.safeSub(1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // Patch corrupted state
 | 
				
			||||||
 | 
					        aggregatedStatsByEpoch[prevEpoch].numPoolsToFinalize = 0;
 | 
				
			||||||
 | 
					        this.endEpoch();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        uint256 lastPoolId_ = 57;
 | 
				
			||||||
 | 
					        for (uint256 i = 1; i <= lastPoolId_; i++) {
 | 
				
			||||||
 | 
					            this.finalizePool(bytes32(i));
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // Ensure that current epoch's state is not corrupted
 | 
				
			||||||
 | 
					        aggregatedStatsByEpoch[currentEpoch_].numPoolsToFinalize = 0;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -53,6 +53,10 @@ contract MixinExchangeFees is
 | 
				
			|||||||
    {
 | 
					    {
 | 
				
			||||||
        _assertValidProtocolFee(protocolFee);
 | 
					        _assertValidProtocolFee(protocolFee);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (protocolFee == 0) {
 | 
				
			||||||
 | 
					            return;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        // Transfer the protocol fee to this address if it should be paid in
 | 
					        // Transfer the protocol fee to this address if it should be paid in
 | 
				
			||||||
        // WETH.
 | 
					        // WETH.
 | 
				
			||||||
        if (msg.value == 0) {
 | 
					        if (msg.value == 0) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-staking",
 | 
					    "name": "@0x/contracts-staking",
 | 
				
			||||||
    "version": "2.0.25",
 | 
					    "version": "2.0.37",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -41,7 +41,7 @@
 | 
				
			|||||||
    "config": {
 | 
					    "config": {
 | 
				
			||||||
        "publicInterfaceContracts": "IStaking,IStakingEvents,IStakingProxy,IZrxVault,LibStakingRichErrors,Staking,StakingProxy,ZrxVault,TestStaking",
 | 
					        "publicInterfaceContracts": "IStaking,IStakingEvents,IStakingProxy,IZrxVault,LibStakingRichErrors,Staking,StakingProxy,ZrxVault,TestStaking",
 | 
				
			||||||
        "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/@(IStaking|IStakingEvents|IStakingProxy|IStorage|IStorageInit|IStructs|IZrxVault|LibCobbDouglas|LibFixedMath|LibFixedMathRichErrors|LibSafeDowncast|LibStakingRichErrors|MixinAbstract|MixinConstants|MixinCumulativeRewards|MixinDeploymentConstants|MixinExchangeFees|MixinExchangeManager|MixinFinalizer|MixinParams|MixinScheduler|MixinStake|MixinStakeBalances|MixinStakeStorage|MixinStakingPool|MixinStakingPoolRewards|MixinStorage|Staking|StakingProxy|TestAssertStorageParams|TestCobbDouglas|TestCumulativeRewardTracking|TestDelegatorRewards|TestExchangeManager|TestFinalizer|TestInitTarget|TestLibFixedMath|TestLibSafeDowncast|TestMixinCumulativeRewards|TestMixinParams|TestMixinScheduler|TestMixinStake|TestMixinStakeBalances|TestMixinStakeStorage|TestMixinStakingPool|TestMixinStakingPoolRewards|TestProtocolFees|TestProxyDestination|TestStaking|TestStakingNoWETH|TestStakingProxy|TestStakingProxyUnit|TestStorageLayoutAndConstants|ZrxVault).json"
 | 
					        "abis": "./test/generated-artifacts/@(IStaking|IStakingEvents|IStakingProxy|IStorage|IStorageInit|IStructs|IZrxVault|LibCobbDouglas|LibFixedMath|LibFixedMathRichErrors|LibSafeDowncast|LibStakingRichErrors|MixinAbstract|MixinConstants|MixinCumulativeRewards|MixinDeploymentConstants|MixinExchangeFees|MixinExchangeManager|MixinFinalizer|MixinParams|MixinScheduler|MixinStake|MixinStakeBalances|MixinStakeStorage|MixinStakingPool|MixinStakingPoolRewards|MixinStorage|Staking|StakingPatch|StakingProxy|TestAssertStorageParams|TestCobbDouglas|TestCumulativeRewardTracking|TestDelegatorRewards|TestExchangeManager|TestFinalizer|TestInitTarget|TestLibFixedMath|TestLibSafeDowncast|TestMixinCumulativeRewards|TestMixinParams|TestMixinScheduler|TestMixinStake|TestMixinStakeBalances|TestMixinStakeStorage|TestMixinStakingPool|TestMixinStakingPoolRewards|TestProtocolFees|TestProxyDestination|TestStaking|TestStakingNoWETH|TestStakingProxy|TestStakingProxyUnit|TestStorageLayoutAndConstants|ZrxVault).json"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "repository": {
 | 
					    "repository": {
 | 
				
			||||||
        "type": "git",
 | 
					        "type": "git",
 | 
				
			||||||
@@ -53,20 +53,20 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "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.4.13",
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
        "@0x/contracts-asset-proxy": "^3.6.9",
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
        "@0x/contracts-dev-utils": "^1.3.16",
 | 
					        "@0x/contracts-dev-utils": "^1.3.28",
 | 
				
			||||||
        "@0x/contracts-erc20": "^3.2.12",
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
        "@0x/contracts-exchange-libs": "^4.3.18",
 | 
					        "@0x/contracts-exchange-libs": "^4.3.29",
 | 
				
			||||||
        "@0x/contracts-gen": "^2.0.24",
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
        "@0x/contracts-utils": "^4.6.3",
 | 
					        "@0x/contracts-utils": "^4.7.8",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@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.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
        "@types/node": "12.12.54",
 | 
					        "@types/node": "12.12.54",
 | 
				
			||||||
        "chai": "^4.0.1",
 | 
					        "chai": "^4.0.1",
 | 
				
			||||||
@@ -84,15 +84,15 @@
 | 
				
			|||||||
        "truffle": "^5.0.32",
 | 
					        "truffle": "^5.0.32",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typedoc": "~0.16.11",
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contracts-test-utils": "^5.3.15",
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "ethereumjs-util": "^5.1.1"
 | 
					        "ethereumjs-util": "^7.0.10"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "publishConfig": {
 | 
					    "publishConfig": {
 | 
				
			||||||
        "access": "public"
 | 
					        "access": "public"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,6 +4,7 @@ import { DecodedLogArgs, LogWithDecodedArgs } from 'ethereum-types';
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import { constants as stakingConstants } from './constants';
 | 
					import { constants as stakingConstants } from './constants';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export { Numberish } from '@0x/contracts-test-utils';
 | 
				
			||||||
// tslint:disable:max-classes-per-file
 | 
					// tslint:disable:max-classes-per-file
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export interface StakingParams {
 | 
					export interface StakingParams {
 | 
				
			||||||
@@ -259,5 +260,3 @@ export class AggregatedStats {
 | 
				
			|||||||
export interface AggregatedStatsByEpoch {
 | 
					export interface AggregatedStatsByEpoch {
 | 
				
			||||||
    [epoch: string]: AggregatedStats;
 | 
					    [epoch: string]: AggregatedStats;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
export type Numberish = Numberish;
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,6 +33,7 @@ import * as MixinStakingPool from '../test/generated-artifacts/MixinStakingPool.
 | 
				
			|||||||
import * as MixinStakingPoolRewards from '../test/generated-artifacts/MixinStakingPoolRewards.json';
 | 
					import * as MixinStakingPoolRewards from '../test/generated-artifacts/MixinStakingPoolRewards.json';
 | 
				
			||||||
import * as MixinStorage from '../test/generated-artifacts/MixinStorage.json';
 | 
					import * as MixinStorage from '../test/generated-artifacts/MixinStorage.json';
 | 
				
			||||||
import * as Staking from '../test/generated-artifacts/Staking.json';
 | 
					import * as Staking from '../test/generated-artifacts/Staking.json';
 | 
				
			||||||
 | 
					import * as StakingPatch from '../test/generated-artifacts/StakingPatch.json';
 | 
				
			||||||
import * as StakingProxy from '../test/generated-artifacts/StakingProxy.json';
 | 
					import * as StakingProxy from '../test/generated-artifacts/StakingProxy.json';
 | 
				
			||||||
import * as TestAssertStorageParams from '../test/generated-artifacts/TestAssertStorageParams.json';
 | 
					import * as TestAssertStorageParams from '../test/generated-artifacts/TestAssertStorageParams.json';
 | 
				
			||||||
import * as TestCobbDouglas from '../test/generated-artifacts/TestCobbDouglas.json';
 | 
					import * as TestCobbDouglas from '../test/generated-artifacts/TestCobbDouglas.json';
 | 
				
			||||||
@@ -61,6 +62,7 @@ import * as TestStorageLayoutAndConstants from '../test/generated-artifacts/Test
 | 
				
			|||||||
import * as ZrxVault from '../test/generated-artifacts/ZrxVault.json';
 | 
					import * as ZrxVault from '../test/generated-artifacts/ZrxVault.json';
 | 
				
			||||||
export const artifacts = {
 | 
					export const artifacts = {
 | 
				
			||||||
    Staking: Staking as ContractArtifact,
 | 
					    Staking: Staking as ContractArtifact,
 | 
				
			||||||
 | 
					    StakingPatch: StakingPatch as ContractArtifact,
 | 
				
			||||||
    StakingProxy: StakingProxy as ContractArtifact,
 | 
					    StakingProxy: StakingProxy as ContractArtifact,
 | 
				
			||||||
    ZrxVault: ZrxVault as ContractArtifact,
 | 
					    ZrxVault: ZrxVault as ContractArtifact,
 | 
				
			||||||
    MixinExchangeFees: MixinExchangeFees as ContractArtifact,
 | 
					    MixinExchangeFees: MixinExchangeFees as ContractArtifact,
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										66
									
								
								contracts/staking/test/patch_mainnet_test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								contracts/staking/test/patch_mainnet_test.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,66 @@
 | 
				
			|||||||
 | 
					import { blockchainTests, constants, expect, filterLogsToArguments } from '@0x/contracts-test-utils';
 | 
				
			||||||
 | 
					import { BigNumber, logUtils } from '@0x/utils';
 | 
				
			||||||
 | 
					import * as _ from 'lodash';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import { artifacts } from './artifacts';
 | 
				
			||||||
 | 
					import { StakingEvents, StakingPatchContract, StakingProxyContract, StakingProxyEvents } from './wrappers';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const abis = _.mapValues(artifacts, v => v.compilerOutput.abi);
 | 
				
			||||||
 | 
					const STAKING_PROXY = '0xa26e80e7dea86279c6d778d702cc413e6cffa777';
 | 
				
			||||||
 | 
					const STAKING_OWNER = '0x7d3455421bbc5ed534a83c88fd80387dc8271392';
 | 
				
			||||||
 | 
					const EXCHANGE_PROXY = '0xdef1c0ded9bec7f1a1670819833240f027b25eff';
 | 
				
			||||||
 | 
					blockchainTests.configure({
 | 
				
			||||||
 | 
					    fork: {
 | 
				
			||||||
 | 
					        unlockedAccounts: [STAKING_OWNER, EXCHANGE_PROXY],
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					blockchainTests.fork('Staking patch mainnet fork tests', env => {
 | 
				
			||||||
 | 
					    let stakingProxyContract: StakingProxyContract;
 | 
				
			||||||
 | 
					    let patchedStakingPatchContract: StakingPatchContract;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    before(async () => {
 | 
				
			||||||
 | 
					        stakingProxyContract = new StakingProxyContract(STAKING_PROXY, env.provider, undefined, abis);
 | 
				
			||||||
 | 
					        patchedStakingPatchContract = await StakingPatchContract.deployFrom0xArtifactAsync(
 | 
				
			||||||
 | 
					            artifacts.Staking,
 | 
				
			||||||
 | 
					            env.provider,
 | 
				
			||||||
 | 
					            env.txDefaults,
 | 
				
			||||||
 | 
					            artifacts,
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    it('Staking proxy successfully attaches to patched logic', async () => {
 | 
				
			||||||
 | 
					        const tx = await stakingProxyContract
 | 
				
			||||||
 | 
					            .attachStakingContract(patchedStakingPatchContract.address)
 | 
				
			||||||
 | 
					            .awaitTransactionSuccessAsync({ from: STAKING_OWNER, gasPrice: 0 }, { shouldValidate: false });
 | 
				
			||||||
 | 
					        expect(filterLogsToArguments(tx.logs, StakingProxyEvents.StakingContractAttachedToProxy)).to.deep.equal([
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                newStakingPatchContractAddress: patchedStakingPatchContract.address,
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					        ]);
 | 
				
			||||||
 | 
					        expect(filterLogsToArguments(tx.logs, StakingEvents.EpochEnded).length).to.equal(1);
 | 
				
			||||||
 | 
					        expect(filterLogsToArguments(tx.logs, StakingEvents.EpochFinalized).length).to.equal(1);
 | 
				
			||||||
 | 
					        logUtils.log(`${tx.gasUsed} gas used`);
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    it('Patched staking handles 0 gas protocol fees', async () => {
 | 
				
			||||||
 | 
					        const staking = new StakingPatchContract(STAKING_PROXY, env.provider, undefined, abis);
 | 
				
			||||||
 | 
					        const maker = '0x7b1886e49ab5433bb46f7258548092dc8cdca28b';
 | 
				
			||||||
 | 
					        const zeroFeeTx = await staking
 | 
				
			||||||
 | 
					            .payProtocolFee(maker, constants.NULL_ADDRESS, constants.ZERO_AMOUNT)
 | 
				
			||||||
 | 
					            .awaitTransactionSuccessAsync({ from: EXCHANGE_PROXY, gasPrice: 0 }, { shouldValidate: false });
 | 
				
			||||||
 | 
					        // StakingPoolEarnedRewardsInEpoch should _not_ be emitted for a zero protocol fee.
 | 
				
			||||||
 | 
					        // tslint:disable-next-line:no-unused-expression
 | 
				
			||||||
 | 
					        expect(filterLogsToArguments(zeroFeeTx.logs, StakingEvents.StakingPoolEarnedRewardsInEpoch)).to.be.empty;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // Coincidentally there's some ETH in the ExchangeProxy
 | 
				
			||||||
 | 
					        const nonZeroFeeTx = await staking
 | 
				
			||||||
 | 
					            .payProtocolFee(maker, constants.NULL_ADDRESS, new BigNumber(1))
 | 
				
			||||||
 | 
					            .awaitTransactionSuccessAsync({ from: EXCHANGE_PROXY, gasPrice: 0, value: 1 }, { shouldValidate: false });
 | 
				
			||||||
 | 
					        // StakingPoolEarnedRewardsInEpoch _should_ be emitted for a non-zero protocol fee.
 | 
				
			||||||
 | 
					        expect(
 | 
				
			||||||
 | 
					            filterLogsToArguments(nonZeroFeeTx.logs, StakingEvents.StakingPoolEarnedRewardsInEpoch),
 | 
				
			||||||
 | 
					        ).to.have.lengthOf(1);
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					// tslint:enable:no-unnecessary-type-assertion
 | 
				
			||||||
@@ -12,7 +12,6 @@ import {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
blockchainTests.resets('Exchange Unit Tests', env => {
 | 
					blockchainTests.resets('Exchange Unit Tests', env => {
 | 
				
			||||||
    // Addresses
 | 
					    // Addresses
 | 
				
			||||||
    let nonOwner: string;
 | 
					 | 
				
			||||||
    let owner: string;
 | 
					    let owner: string;
 | 
				
			||||||
    let nonExchange: string;
 | 
					    let nonExchange: string;
 | 
				
			||||||
    let exchange: string;
 | 
					    let exchange: string;
 | 
				
			||||||
@@ -24,7 +23,7 @@ blockchainTests.resets('Exchange Unit Tests', env => {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    before(async () => {
 | 
					    before(async () => {
 | 
				
			||||||
        // Set up addresses for testing.
 | 
					        // Set up addresses for testing.
 | 
				
			||||||
        [nonOwner, owner, nonExchange, exchange, nonAuthority, authority] = await env.getAccountAddressesAsync();
 | 
					        [, owner, nonExchange, exchange, nonAuthority, authority] = await env.getAccountAddressesAsync();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        // Deploy the Exchange Manager contract.
 | 
					        // Deploy the Exchange Manager contract.
 | 
				
			||||||
        exchangeManager = await TestExchangeManagerContract.deployFrom0xArtifactAsync(
 | 
					        exchangeManager = await TestExchangeManagerContract.deployFrom0xArtifactAsync(
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -543,7 +543,7 @@ blockchainTests.resets('Finalizer unit tests', env => {
 | 
				
			|||||||
            const expectedPoolRewards = await calculatePoolRewardsAsync(INITIAL_BALANCE, pools);
 | 
					            const expectedPoolRewards = await calculatePoolRewardsAsync(INITIAL_BALANCE, pools);
 | 
				
			||||||
            const [pool, reward] = _.sampleSize(shortZip(pools, expectedPoolRewards), 1)[0];
 | 
					            const [pool, reward] = _.sampleSize(shortZip(pools, expectedPoolRewards), 1)[0];
 | 
				
			||||||
            return assertUnfinalizedPoolRewardsAsync(pool.poolId, {
 | 
					            return assertUnfinalizedPoolRewardsAsync(pool.poolId, {
 | 
				
			||||||
                totalReward: (reward as any) as BigNumber,
 | 
					                totalReward: reward,
 | 
				
			||||||
                membersStake: pool.membersStake,
 | 
					                membersStake: pool.membersStake,
 | 
				
			||||||
            });
 | 
					            });
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -12,17 +12,13 @@ import * as _ from 'lodash';
 | 
				
			|||||||
import { artifacts } from '../artifacts';
 | 
					import { artifacts } from '../artifacts';
 | 
				
			||||||
import { TestCobbDouglasContract } from '../wrappers';
 | 
					import { TestCobbDouglasContract } from '../wrappers';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// tslint:disable: no-unnecessary-type-assertion
 | 
					 | 
				
			||||||
blockchainTests('LibCobbDouglas unit tests', env => {
 | 
					blockchainTests('LibCobbDouglas unit tests', env => {
 | 
				
			||||||
    const FUZZ_COUNT = 1024;
 | 
					    const FUZZ_COUNT = 1024;
 | 
				
			||||||
    const PRECISION = 15;
 | 
					    const PRECISION = 15;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    let testContract: TestCobbDouglasContract;
 | 
					    let testContract: TestCobbDouglasContract;
 | 
				
			||||||
    let ownerAddress: string;
 | 
					 | 
				
			||||||
    let notOwnerAddress: string;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    before(async () => {
 | 
					    before(async () => {
 | 
				
			||||||
        [ownerAddress, notOwnerAddress] = await env.getAccountAddressesAsync();
 | 
					 | 
				
			||||||
        testContract = await TestCobbDouglasContract.deployFrom0xArtifactAsync(
 | 
					        testContract = await TestCobbDouglasContract.deployFrom0xArtifactAsync(
 | 
				
			||||||
            artifacts.TestCobbDouglas,
 | 
					            artifacts.TestCobbDouglas,
 | 
				
			||||||
            env.provider,
 | 
					            env.provider,
 | 
				
			||||||
@@ -211,4 +207,3 @@ blockchainTests('LibCobbDouglas unit tests', env => {
 | 
				
			|||||||
        });
 | 
					        });
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
// tslint:enable:no-unnecessary-type-assertion
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -31,6 +31,7 @@ export * from '../test/generated-wrappers/mixin_staking_pool';
 | 
				
			|||||||
export * from '../test/generated-wrappers/mixin_staking_pool_rewards';
 | 
					export * from '../test/generated-wrappers/mixin_staking_pool_rewards';
 | 
				
			||||||
export * from '../test/generated-wrappers/mixin_storage';
 | 
					export * from '../test/generated-wrappers/mixin_storage';
 | 
				
			||||||
export * from '../test/generated-wrappers/staking';
 | 
					export * from '../test/generated-wrappers/staking';
 | 
				
			||||||
 | 
					export * from '../test/generated-wrappers/staking_patch';
 | 
				
			||||||
export * from '../test/generated-wrappers/staking_proxy';
 | 
					export * from '../test/generated-wrappers/staking_proxy';
 | 
				
			||||||
export * from '../test/generated-wrappers/test_assert_storage_params';
 | 
					export * from '../test/generated-wrappers/test_assert_storage_params';
 | 
				
			||||||
export * from '../test/generated-wrappers/test_cobb_douglas';
 | 
					export * from '../test/generated-wrappers/test_cobb_douglas';
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -40,6 +40,7 @@
 | 
				
			|||||||
        "test/generated-artifacts/MixinStakingPoolRewards.json",
 | 
					        "test/generated-artifacts/MixinStakingPoolRewards.json",
 | 
				
			||||||
        "test/generated-artifacts/MixinStorage.json",
 | 
					        "test/generated-artifacts/MixinStorage.json",
 | 
				
			||||||
        "test/generated-artifacts/Staking.json",
 | 
					        "test/generated-artifacts/Staking.json",
 | 
				
			||||||
 | 
					        "test/generated-artifacts/StakingPatch.json",
 | 
				
			||||||
        "test/generated-artifacts/StakingProxy.json",
 | 
					        "test/generated-artifacts/StakingProxy.json",
 | 
				
			||||||
        "test/generated-artifacts/TestAssertStorageParams.json",
 | 
					        "test/generated-artifacts/TestAssertStorageParams.json",
 | 
				
			||||||
        "test/generated-artifacts/TestCobbDouglas.json",
 | 
					        "test/generated-artifacts/TestCobbDouglas.json",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,104 @@
 | 
				
			|||||||
[
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "version": "5.4.0",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Set default ganache gas limit to 100e6",
 | 
				
			||||||
 | 
					                "pr": 197
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "timestamp": 1620214333
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "5.3.25",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "5.3.24",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1616005394,
 | 
				
			||||||
 | 
					        "version": "5.3.23",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "5.3.22",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "5.3.21",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1611648096,
 | 
				
			||||||
 | 
					        "version": "5.3.20",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1610510890,
 | 
				
			||||||
 | 
					        "version": "5.3.19",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1609802516,
 | 
				
			||||||
 | 
					        "version": "5.3.18",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608692071,
 | 
				
			||||||
 | 
					        "version": "5.3.17",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1608245516,
 | 
				
			||||||
 | 
					        "version": "5.3.16",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "timestamp": 1607485227,
 | 
					        "timestamp": 1607485227,
 | 
				
			||||||
        "version": "5.3.15",
 | 
					        "version": "5.3.15",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,50 @@ Edit the package's CHANGELOG.json file only.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CHANGELOG
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.4.0 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Set default ganache gas limit to 100e6 (#197)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.25 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.24 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.23 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.22 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.21 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.20 - _January 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.19 - _January 13, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.18 - _January 4, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.17 - _December 23, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v5.3.16 - _December 17, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v5.3.15 - _December 9, 2020_
 | 
					## v5.3.15 - _December 9, 2020_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    * Dependencies updated
 | 
					    * Dependencies updated
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    "name": "@0x/contracts-test-utils",
 | 
					    "name": "@0x/contracts-test-utils",
 | 
				
			||||||
    "version": "5.3.15",
 | 
					    "version": "5.4.0",
 | 
				
			||||||
    "engines": {
 | 
					    "engines": {
 | 
				
			||||||
        "node": ">=6.12"
 | 
					        "node": ">=6.12"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -34,28 +34,28 @@
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/test-utils",
 | 
					    "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/test-utils",
 | 
				
			||||||
    "devDependencies": {
 | 
					    "devDependencies": {
 | 
				
			||||||
        "@0x/sol-compiler": "^4.4.1",
 | 
					        "@0x/sol-compiler": "^4.7.3",
 | 
				
			||||||
        "@0x/tslint-config": "^4.1.3",
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
        "npm-run-all": "^4.1.2",
 | 
					        "npm-run-all": "^4.1.2",
 | 
				
			||||||
        "shx": "^0.2.2",
 | 
					        "shx": "^0.2.2",
 | 
				
			||||||
        "tslint": "5.11.0",
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
        "typescript": "3.0.1"
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "@0x/assert": "^3.0.19",
 | 
					        "@0x/assert": "^3.0.27",
 | 
				
			||||||
        "@0x/base-contract": "^6.2.14",
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
        "@0x/contract-addresses": "^5.6.0",
 | 
					        "@0x/contract-addresses": "^6.1.0",
 | 
				
			||||||
        "@0x/dev-utils": "^4.1.3",
 | 
					        "@0x/dev-utils": "^4.2.7",
 | 
				
			||||||
        "@0x/json-schemas": "^5.3.4",
 | 
					        "@0x/json-schemas": "^6.1.3",
 | 
				
			||||||
        "@0x/order-utils": "^10.4.10",
 | 
					        "@0x/order-utils": "^10.4.21",
 | 
				
			||||||
        "@0x/sol-coverage": "^4.0.24",
 | 
					        "@0x/sol-coverage": "^4.0.37",
 | 
				
			||||||
        "@0x/sol-profiler": "^4.1.14",
 | 
					        "@0x/sol-profiler": "^4.1.27",
 | 
				
			||||||
        "@0x/sol-trace": "^3.0.24",
 | 
					        "@0x/sol-trace": "^3.0.37",
 | 
				
			||||||
        "@0x/subproviders": "^6.2.3",
 | 
					        "@0x/subproviders": "^6.5.3",
 | 
				
			||||||
        "@0x/types": "^3.3.1",
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
        "@0x/typescript-typings": "^5.1.6",
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
        "@0x/utils": "^6.1.1",
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
        "@0x/web3-wrapper": "^7.3.0",
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
        "@types/bn.js": "^4.11.0",
 | 
					        "@types/bn.js": "^4.11.0",
 | 
				
			||||||
        "@types/js-combinatorics": "^0.5.29",
 | 
					        "@types/js-combinatorics": "^0.5.29",
 | 
				
			||||||
        "@types/lodash": "4.14.104",
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
@@ -67,8 +67,8 @@
 | 
				
			|||||||
        "chai-bignumber": "^3.0.0",
 | 
					        "chai-bignumber": "^3.0.0",
 | 
				
			||||||
        "decimal.js": "^10.2.0",
 | 
					        "decimal.js": "^10.2.0",
 | 
				
			||||||
        "dirty-chai": "^2.0.1",
 | 
					        "dirty-chai": "^2.0.1",
 | 
				
			||||||
        "ethereum-types": "^3.4.0",
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
        "ethereumjs-util": "^5.1.1",
 | 
					        "ethereumjs-util": "^7.0.10",
 | 
				
			||||||
        "ethers": "~4.0.4",
 | 
					        "ethers": "~4.0.4",
 | 
				
			||||||
        "js-combinatorics": "^0.5.3",
 | 
					        "js-combinatorics": "^0.5.3",
 | 
				
			||||||
        "lodash": "^4.17.11",
 | 
					        "lodash": "^4.17.11",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -77,7 +77,7 @@ export const constants = {
 | 
				
			|||||||
    ZERO_AMOUNT: new BigNumber(0),
 | 
					    ZERO_AMOUNT: new BigNumber(0),
 | 
				
			||||||
    PERCENTAGE_DENOMINATOR: new BigNumber(10).pow(18),
 | 
					    PERCENTAGE_DENOMINATOR: new BigNumber(10).pow(18),
 | 
				
			||||||
    TIME_BUFFER: new BigNumber(1000),
 | 
					    TIME_BUFFER: new BigNumber(1000),
 | 
				
			||||||
    KECCAK256_NULL: ethUtil.addHexPrefix(ethUtil.bufferToHex(ethUtil.SHA3_NULL)),
 | 
					    KECCAK256_NULL: ethUtil.bufferToHex(ethUtil.keccak256(Buffer.alloc(0))),
 | 
				
			||||||
    MAX_UINT256_ROOT: new BigNumber('340282366920938463463374607431768211456'),
 | 
					    MAX_UINT256_ROOT: new BigNumber('340282366920938463463374607431768211456'),
 | 
				
			||||||
    ONE_ETHER: new BigNumber(1e18),
 | 
					    ONE_ETHER: new BigNumber(1e18),
 | 
				
			||||||
    EIP712_DOMAIN_NAME: '0x Protocol',
 | 
					    EIP712_DOMAIN_NAME: '0x Protocol',
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -14,6 +14,6 @@ export function shortZip<T1, T2>(a: T1[], b: T2[]): Array<[T1, T2]> {
 | 
				
			|||||||
export function replaceKeysDeep(obj: {}, mapKeys: (key: string) => string | void): _.Dictionary<{}> {
 | 
					export function replaceKeysDeep(obj: {}, mapKeys: (key: string) => string | void): _.Dictionary<{}> {
 | 
				
			||||||
    return _.transform(obj, (result, value, key) => {
 | 
					    return _.transform(obj, (result, value, key) => {
 | 
				
			||||||
        const currentKey = mapKeys(key) || key;
 | 
					        const currentKey = mapKeys(key) || key;
 | 
				
			||||||
        result[currentKey] = _.isObject(value) ? replaceKeysDeep(value, mapKeys) : value;
 | 
					        result[currentKey] = _.isObject(value) ? replaceKeysDeep(value as {}, mapKeys) : (value as {});
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -22,14 +22,14 @@ export class OrderFactory {
 | 
				
			|||||||
    ): Promise<SignedOrder> {
 | 
					    ): Promise<SignedOrder> {
 | 
				
			||||||
        const fifteenMinutesInSeconds = 15 * 60;
 | 
					        const fifteenMinutesInSeconds = 15 * 60;
 | 
				
			||||||
        const currentBlockTimestamp = await getLatestBlockTimestampAsync();
 | 
					        const currentBlockTimestamp = await getLatestBlockTimestampAsync();
 | 
				
			||||||
        const order = ({
 | 
					        const order = {
 | 
				
			||||||
            takerAddress: constants.NULL_ADDRESS,
 | 
					            takerAddress: constants.NULL_ADDRESS,
 | 
				
			||||||
            senderAddress: constants.NULL_ADDRESS,
 | 
					            senderAddress: constants.NULL_ADDRESS,
 | 
				
			||||||
            expirationTimeSeconds: new BigNumber(currentBlockTimestamp).plus(fifteenMinutesInSeconds),
 | 
					            expirationTimeSeconds: new BigNumber(currentBlockTimestamp).plus(fifteenMinutesInSeconds),
 | 
				
			||||||
            salt: generatePseudoRandomSalt(),
 | 
					            salt: generatePseudoRandomSalt(),
 | 
				
			||||||
            ...this._defaultOrderParams,
 | 
					            ...this._defaultOrderParams,
 | 
				
			||||||
            ...customOrderParams,
 | 
					            ...customOrderParams,
 | 
				
			||||||
        } as any) as Order;
 | 
					        } as Order; // tslint:disable-line:no-object-literal-type-assertion
 | 
				
			||||||
        const orderHashBuff = orderHashUtils.getOrderHashBuffer(order);
 | 
					        const orderHashBuff = orderHashUtils.getOrderHashBuffer(order);
 | 
				
			||||||
        const signature = signingUtils.signMessage(orderHashBuff, this._privateKey, signatureType);
 | 
					        const signature = signingUtils.signMessage(orderHashBuff, this._privateKey, signatureType);
 | 
				
			||||||
        const signedOrder = {
 | 
					        const signedOrder = {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -30,7 +30,8 @@ export const orderUtils = {
 | 
				
			|||||||
        return cancel;
 | 
					        return cancel;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    createOrderWithoutSignature(signedOrder: SignedOrder): Order {
 | 
					    createOrderWithoutSignature(signedOrder: SignedOrder): Order {
 | 
				
			||||||
        return _.omit(signedOrder, ['signature']) as Order;
 | 
					        const { signature, ...order } = signedOrder;
 | 
				
			||||||
 | 
					        return order;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    createBatchMatchOrders(signedOrdersLeft: SignedOrder[], signedOrdersRight: SignedOrder[]): BatchMatchOrder {
 | 
					    createBatchMatchOrders(signedOrdersLeft: SignedOrder[], signedOrdersRight: SignedOrder[]): BatchMatchOrder {
 | 
				
			||||||
        return {
 | 
					        return {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,6 +20,7 @@ export let providerConfigs: Web3Config = {
 | 
				
			|||||||
    shouldUseInProcessGanache: true,
 | 
					    shouldUseInProcessGanache: true,
 | 
				
			||||||
    shouldAllowUnlimitedContractSize: true,
 | 
					    shouldAllowUnlimitedContractSize: true,
 | 
				
			||||||
    hardfork: 'istanbul',
 | 
					    hardfork: 'istanbul',
 | 
				
			||||||
 | 
					    gasLimit: 100e6,
 | 
				
			||||||
    unlocked_accounts: [
 | 
					    unlocked_accounts: [
 | 
				
			||||||
        '0x6cc5f688a315f3dc28a7781717a9a798a59fda7b',
 | 
					        '0x6cc5f688a315f3dc28a7781717a9a798a59fda7b',
 | 
				
			||||||
        '0x55dc8f21d20d4c6ed3c82916a438a413ca68e335',
 | 
					        '0x55dc8f21d20d4c6ed3c82916a438a413ca68e335',
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -57,9 +57,7 @@ describe('Order hashing', () => {
 | 
				
			|||||||
                ...order,
 | 
					                ...order,
 | 
				
			||||||
                takerAddress: (null as any) as string,
 | 
					                takerAddress: (null as any) as string,
 | 
				
			||||||
            };
 | 
					            };
 | 
				
			||||||
            const expectedErrorMessage = `Order taker must be of type string. If you want anyone to be able to fill an order - pass ${
 | 
					            const expectedErrorMessage = `Expected order to conform to schema`;
 | 
				
			||||||
                constants.NULL_ADDRESS
 | 
					 | 
				
			||||||
            }`;
 | 
					 | 
				
			||||||
            expect(() => orderHashUtils.getOrderHashHex(orderWithInvalidtakerFormat)).to.throw(expectedErrorMessage);
 | 
					            expect(() => orderHashUtils.getOrderHashHex(orderWithInvalidtakerFormat)).to.throw(expectedErrorMessage);
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										10
									
								
								contracts/treasury/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								contracts/treasury/.npmignore
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,10 @@
 | 
				
			|||||||
 | 
					# Blacklist all files
 | 
				
			||||||
 | 
					.*
 | 
				
			||||||
 | 
					*
 | 
				
			||||||
 | 
					# Whitelist lib
 | 
				
			||||||
 | 
					!lib/**/*
 | 
				
			||||||
 | 
					# Whitelist Solidity contracts
 | 
				
			||||||
 | 
					!contracts/src/**/*
 | 
				
			||||||
 | 
					# Blacklist tests in lib
 | 
				
			||||||
 | 
					/lib/test/*
 | 
				
			||||||
 | 
					# Package specific ignore
 | 
				
			||||||
							
								
								
									
										95
									
								
								contracts/treasury/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								contracts/treasury/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,95 @@
 | 
				
			|||||||
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1620214333,
 | 
				
			||||||
 | 
					        "version": "1.1.6",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "version": "1.1.5",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Patched votingPower logic",
 | 
				
			||||||
 | 
					                "pr": 214
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "timestamp": 1619825976
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619596077,
 | 
				
			||||||
 | 
					        "version": "1.1.4",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1619481586,
 | 
				
			||||||
 | 
					        "version": "1.1.3",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1618259868,
 | 
				
			||||||
 | 
					        "version": "1.1.2",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1617311315,
 | 
				
			||||||
 | 
					        "version": "1.1.1",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "version": "1.1.0",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Make the proposal/quorum thresholds updatable",
 | 
				
			||||||
 | 
					                "pr": 165
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "timestamp": 1616005394
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1614141718,
 | 
				
			||||||
 | 
					        "version": "1.0.2",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "timestamp": 1612950500,
 | 
				
			||||||
 | 
					        "version": "1.0.1",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Dependencies updated"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "version": "1.0.0",
 | 
				
			||||||
 | 
					        "changes": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "note": "Create this package",
 | 
				
			||||||
 | 
					                "pr": 120
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "timestamp": 1611869778
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					]
 | 
				
			||||||
							
								
								
									
										46
									
								
								contracts/treasury/CHANGELOG.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								contracts/treasury/CHANGELOG.md
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,46 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					changelogUtils.file is auto-generated using the monorepo-scripts package. Don't edit directly.
 | 
				
			||||||
 | 
					Edit the package's CHANGELOG.json file only.
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					CHANGELOG
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.6 - _May 5, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.5 - _April 30, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Patched votingPower logic (#214)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.4 - _April 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.3 - _April 26, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.2 - _April 12, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.1 - _April 1, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.1.0 - _March 17, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Make the proposal/quorum thresholds updatable (#165)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.0.2 - _February 24, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.0.1 - _February 10, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Dependencies updated
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v1.0.0 - _January 28, 2021_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    * Create this package (#120)
 | 
				
			||||||
							
								
								
									
										1
									
								
								contracts/treasury/DEPLOYS.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								contracts/treasury/DEPLOYS.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
				
			|||||||
 | 
					[]
 | 
				
			||||||
							
								
								
									
										65
									
								
								contracts/treasury/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								contracts/treasury/README.md
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,65 @@
 | 
				
			|||||||
 | 
					## Governance
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					This package contains contracts for the governance of the 0x ZRX treasury.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Installation
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					**Install**
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					npm install @0x/contracts-treasury --save
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Contributing
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					We strongly recommend that the community help us make improvements and determine the future direction of the protocol. To report bugs within this package, please create an issue in this repository.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					For proposals regarding the 0x protocol's smart contract architecture, message format, or additional functionality, go to the [0x Improvement Proposals (ZEIPs)](https://github.com/0xProject/ZEIPs) repository and follow the contribution guidelines provided therein.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Please read our [contribution guidelines](../../CONTRIBUTING.md) before getting started.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Install Dependencies
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					If you don't have yarn workspaces enabled (Yarn < v1.0) - enable them:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					yarn config set workspaces-experimental true
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Then install dependencies
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					yarn install
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Build
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					To build this package and all other monorepo packages that it depends on, run the following from the monorepo root directory:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					PKG=@0x/contracts-treasury yarn build
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Or continuously rebuild on change:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					PKG=@0x/contracts-treasury yarn watch
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Clean
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					yarn clean
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Lint
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					yarn lint
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Run Tests
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					yarn test
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
							
								
								
									
										29
									
								
								contracts/treasury/compiler.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								contracts/treasury/compiler.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
				
			|||||||
 | 
					{
 | 
				
			||||||
 | 
					    "artifactsDir": "./test/generated-artifacts",
 | 
				
			||||||
 | 
					    "contractsDir": "./contracts",
 | 
				
			||||||
 | 
					    "useDockerisedSolc": false,
 | 
				
			||||||
 | 
					    "isOfflineMode": false,
 | 
				
			||||||
 | 
					    "shouldSaveStandardInput": true,
 | 
				
			||||||
 | 
					    "shouldCompileIndependently": true,
 | 
				
			||||||
 | 
					    "compilerSettings": {
 | 
				
			||||||
 | 
					        "evmVersion": "istanbul",
 | 
				
			||||||
 | 
					        "optimizer": {
 | 
				
			||||||
 | 
					            "enabled": true,
 | 
				
			||||||
 | 
					            "runs": 1000000,
 | 
				
			||||||
 | 
					            "details": { "yul": true, "deduplicate": true, "cse": true, "constantOptimizer": true }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "outputSelection": {
 | 
				
			||||||
 | 
					            "*": {
 | 
				
			||||||
 | 
					                "*": [
 | 
				
			||||||
 | 
					                    "abi",
 | 
				
			||||||
 | 
					                    "devdoc",
 | 
				
			||||||
 | 
					                    "evm.bytecode.object",
 | 
				
			||||||
 | 
					                    "evm.bytecode.sourceMap",
 | 
				
			||||||
 | 
					                    "evm.deployedBytecode.object",
 | 
				
			||||||
 | 
					                    "evm.deployedBytecode.sourceMap",
 | 
				
			||||||
 | 
					                    "evm.methodIdentifiers"
 | 
				
			||||||
 | 
					                ]
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										63
									
								
								contracts/treasury/contracts/src/DefaultPoolOperator.sol
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								contracts/treasury/contracts/src/DefaultPoolOperator.sol
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,63 @@
 | 
				
			|||||||
 | 
					// 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.12;
 | 
				
			||||||
 | 
					pragma experimental ABIEncoderV2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import "@0x/contracts-erc20/contracts/src/v06/IERC20TokenV06.sol";
 | 
				
			||||||
 | 
					import "@0x/contracts-erc20/contracts/src/v06/LibERC20TokenV06.sol";
 | 
				
			||||||
 | 
					import "./IStaking.sol";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					contract DefaultPoolOperator {
 | 
				
			||||||
 | 
					    using LibERC20TokenV06 for IERC20TokenV06;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Immutables
 | 
				
			||||||
 | 
					    IStaking public immutable stakingProxy;
 | 
				
			||||||
 | 
					    IERC20TokenV06 public immutable weth;
 | 
				
			||||||
 | 
					    bytes32 public immutable poolId;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Initializes this contract and creates a staking pool.
 | 
				
			||||||
 | 
					    /// @param stakingProxy_ The 0x staking proxy contract.
 | 
				
			||||||
 | 
					    /// @param weth_ The WETH token contract.
 | 
				
			||||||
 | 
					    constructor(
 | 
				
			||||||
 | 
					        IStaking stakingProxy_,
 | 
				
			||||||
 | 
					        IERC20TokenV06 weth_
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        stakingProxy = stakingProxy_;
 | 
				
			||||||
 | 
					        weth = weth_;
 | 
				
			||||||
 | 
					        // operator share = 100%
 | 
				
			||||||
 | 
					        poolId = stakingProxy_.createStakingPool(10 ** 6, false);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Sends this contract's entire WETH balance to the
 | 
				
			||||||
 | 
					    ///      staking proxy contract. This function exists in case
 | 
				
			||||||
 | 
					    ///      someone joins the default staking pool and starts
 | 
				
			||||||
 | 
					    ///      market making for some reason, thus earning this contract
 | 
				
			||||||
 | 
					    ///      some staking rewards. Note that anyone can call this
 | 
				
			||||||
 | 
					    ///      function at any time.
 | 
				
			||||||
 | 
					    function returnStakingRewards()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        uint256 wethBalance = weth.compatBalanceOf(address(this));
 | 
				
			||||||
 | 
					        weth.compatTransfer(address(stakingProxy), wethBalance);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										127
									
								
								contracts/treasury/contracts/src/IStaking.sol
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								contracts/treasury/contracts/src/IStaking.sol
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,127 @@
 | 
				
			|||||||
 | 
					// 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.12;
 | 
				
			||||||
 | 
					pragma experimental ABIEncoderV2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					interface IStaking {
 | 
				
			||||||
 | 
					    /// @dev Statuses that stake can exist in.
 | 
				
			||||||
 | 
					    ///      Any stake can be (re)delegated effective at the next epoch
 | 
				
			||||||
 | 
					    ///      Undelegated stake can be withdrawn if it is available in both the current and next epoch
 | 
				
			||||||
 | 
					    enum StakeStatus {
 | 
				
			||||||
 | 
					        UNDELEGATED,
 | 
				
			||||||
 | 
					        DELEGATED
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Encapsulates a balance for the current and next epochs.
 | 
				
			||||||
 | 
					    /// Note that these balances may be stale if the current epoch
 | 
				
			||||||
 | 
					    /// is greater than `currentEpoch`.
 | 
				
			||||||
 | 
					    /// @param currentEpoch The current epoch
 | 
				
			||||||
 | 
					    /// @param currentEpochBalance Balance in the current epoch.
 | 
				
			||||||
 | 
					    /// @param nextEpochBalance Balance in `currentEpoch+1`.
 | 
				
			||||||
 | 
					    struct StoredBalance {
 | 
				
			||||||
 | 
					        uint64 currentEpoch;
 | 
				
			||||||
 | 
					        uint96 currentEpochBalance;
 | 
				
			||||||
 | 
					        uint96 nextEpochBalance;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Holds the metadata for a staking pool.
 | 
				
			||||||
 | 
					    /// @param operator Operator of the pool.
 | 
				
			||||||
 | 
					    /// @param operatorShare Fraction of the total balance owned by the operator, in ppm.
 | 
				
			||||||
 | 
					    struct Pool {
 | 
				
			||||||
 | 
					        address operator;
 | 
				
			||||||
 | 
					        uint32 operatorShare;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Create a new staking pool. The sender will be the operator of this pool.
 | 
				
			||||||
 | 
					    /// Note that an operator must be payable.
 | 
				
			||||||
 | 
					    /// @param operatorShare Portion of rewards owned by the operator, in ppm.
 | 
				
			||||||
 | 
					    /// @param addOperatorAsMaker Adds operator to the created pool as a maker for convenience iff true.
 | 
				
			||||||
 | 
					    /// @return poolId The unique pool id generated for this pool.
 | 
				
			||||||
 | 
					    function createStakingPool(uint32 operatorShare, bool addOperatorAsMaker)
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        returns (bytes32 poolId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns the current staking epoch number.
 | 
				
			||||||
 | 
					    /// @return epoch The current epoch.
 | 
				
			||||||
 | 
					    function currentEpoch()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256 epoch);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns the time (in seconds) at which the current staking epoch started.
 | 
				
			||||||
 | 
					    /// @return startTime The start time of the current epoch, in seconds.
 | 
				
			||||||
 | 
					    function currentEpochStartTimeInSeconds()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256 startTime);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns the duration of an epoch in seconds. This value can be updated.
 | 
				
			||||||
 | 
					    /// @return duration The duration of an epoch, in seconds.
 | 
				
			||||||
 | 
					    function epochDurationInSeconds()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256 duration);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns a staking pool
 | 
				
			||||||
 | 
					    /// @param poolId Unique id of pool.
 | 
				
			||||||
 | 
					    function getStakingPool(bytes32 poolId)
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (Pool memory);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Gets global stake for a given status.
 | 
				
			||||||
 | 
					    /// @param stakeStatus UNDELEGATED or DELEGATED
 | 
				
			||||||
 | 
					    /// @return balance Global stake for given status.
 | 
				
			||||||
 | 
					    function getGlobalStakeByStatus(StakeStatus stakeStatus)
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (StoredBalance memory balance);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Gets an owner's stake balances by status.
 | 
				
			||||||
 | 
					    /// @param staker Owner of stake.
 | 
				
			||||||
 | 
					    /// @param stakeStatus UNDELEGATED or DELEGATED
 | 
				
			||||||
 | 
					    /// @return balance Owner's stake balances for given status.
 | 
				
			||||||
 | 
					    function getOwnerStakeByStatus(
 | 
				
			||||||
 | 
					        address staker,
 | 
				
			||||||
 | 
					        StakeStatus stakeStatus
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (StoredBalance memory balance);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns the total stake delegated to a specific staking pool,
 | 
				
			||||||
 | 
					    ///      across all members.
 | 
				
			||||||
 | 
					    /// @param poolId Unique Id of pool.
 | 
				
			||||||
 | 
					    /// @return balance Total stake delegated to pool.
 | 
				
			||||||
 | 
					    function getTotalStakeDelegatedToPool(bytes32 poolId)
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (StoredBalance memory balance);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns the stake delegated to a specific staking pool, by a given staker.
 | 
				
			||||||
 | 
					    /// @param staker of stake.
 | 
				
			||||||
 | 
					    /// @param poolId Unique Id of pool.
 | 
				
			||||||
 | 
					    /// @return balance Stake delegated to pool by staker.
 | 
				
			||||||
 | 
					    function getStakeDelegatedToPoolByOwner(address staker, bytes32 poolId)
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (StoredBalance memory balance);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										182
									
								
								contracts/treasury/contracts/src/IZrxTreasury.sol
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										182
									
								
								contracts/treasury/contracts/src/IZrxTreasury.sol
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,182 @@
 | 
				
			|||||||
 | 
					// 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.12;
 | 
				
			||||||
 | 
					pragma experimental ABIEncoderV2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import "./DefaultPoolOperator.sol";
 | 
				
			||||||
 | 
					import "./IStaking.sol";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					interface IZrxTreasury {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct TreasuryParameters {
 | 
				
			||||||
 | 
					        uint256 votingPeriod;
 | 
				
			||||||
 | 
					        uint256 proposalThreshold;
 | 
				
			||||||
 | 
					        uint256 quorumThreshold;
 | 
				
			||||||
 | 
					        bytes32 defaultPoolId;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct ProposedAction {
 | 
				
			||||||
 | 
					        address target;
 | 
				
			||||||
 | 
					        bytes data;
 | 
				
			||||||
 | 
					        uint256 value;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct Proposal {
 | 
				
			||||||
 | 
					        bytes32 actionsHash;
 | 
				
			||||||
 | 
					        uint256 executionEpoch;
 | 
				
			||||||
 | 
					        uint256 voteEpoch;
 | 
				
			||||||
 | 
					        uint256 votesFor;
 | 
				
			||||||
 | 
					        uint256 votesAgainst;
 | 
				
			||||||
 | 
					        bool executed;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    event ProposalCreated(
 | 
				
			||||||
 | 
					        address proposer,
 | 
				
			||||||
 | 
					        bytes32[] operatedPoolIds,
 | 
				
			||||||
 | 
					        uint256 proposalId,
 | 
				
			||||||
 | 
					        ProposedAction[] actions,
 | 
				
			||||||
 | 
					        uint256 executionEpoch,
 | 
				
			||||||
 | 
					        string description
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    event VoteCast(
 | 
				
			||||||
 | 
					        address voter,
 | 
				
			||||||
 | 
					        bytes32[] operatedPoolIds,
 | 
				
			||||||
 | 
					        uint256 proposalId,
 | 
				
			||||||
 | 
					        bool support,
 | 
				
			||||||
 | 
					        uint256 votingPower
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    event ProposalExecuted(uint256 proposalId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    function stakingProxy()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (IStaking);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    function defaultPoolOperator()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (DefaultPoolOperator);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    function defaultPoolId()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (bytes32);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    function votingPeriod()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    function proposalThreshold()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    function quorumThreshold()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Updates the proposal and quorum thresholds to the given
 | 
				
			||||||
 | 
					    ///      values. Note that this function is only callable by the
 | 
				
			||||||
 | 
					    ///      treasury contract itself, so the threshold can only be
 | 
				
			||||||
 | 
					    ///      updated via a successful treasury proposal.
 | 
				
			||||||
 | 
					    /// @param newProposalThreshold The new value for the proposal threshold.
 | 
				
			||||||
 | 
					    /// @param newQuorumThreshold The new value for the quorum threshold.
 | 
				
			||||||
 | 
					    function updateThresholds(
 | 
				
			||||||
 | 
					        uint256 newProposalThreshold,
 | 
				
			||||||
 | 
					        uint256 newQuorumThreshold
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        external;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Creates a proposal to send ZRX from this treasury on the
 | 
				
			||||||
 | 
					    ///      the given actions. Must have at least `proposalThreshold`
 | 
				
			||||||
 | 
					    ///      of voting power to call this function. See `getVotingPower`
 | 
				
			||||||
 | 
					    ///      for how voting power is computed. If a proposal is successfully
 | 
				
			||||||
 | 
					    ///      created, voting starts at the epoch after next (currentEpoch + 2).
 | 
				
			||||||
 | 
					    ///      If the vote passes, the proposal is executable during the
 | 
				
			||||||
 | 
					    ///      `executionEpoch`. See `hasProposalPassed` for the passing criteria.
 | 
				
			||||||
 | 
					    /// @param actions The proposed ZRX actions. An action specifies a
 | 
				
			||||||
 | 
					    ///        contract call.
 | 
				
			||||||
 | 
					    /// @param executionEpoch The epoch during which the proposal is to
 | 
				
			||||||
 | 
					    ///        be executed if it passes. Must be at least two epochs
 | 
				
			||||||
 | 
					    ///        from the current epoch.
 | 
				
			||||||
 | 
					    /// @param description A text description for the proposal.
 | 
				
			||||||
 | 
					    /// @param operatedPoolIds The pools operated by `msg.sender`. The
 | 
				
			||||||
 | 
					    ///        ZRX currently delegated to those pools will be accounted
 | 
				
			||||||
 | 
					    ///        for in the voting power.
 | 
				
			||||||
 | 
					    /// @return proposalId The ID of the newly created proposal.
 | 
				
			||||||
 | 
					    function propose(
 | 
				
			||||||
 | 
					        ProposedAction[] calldata actions,
 | 
				
			||||||
 | 
					        uint256 executionEpoch,
 | 
				
			||||||
 | 
					        string calldata description,
 | 
				
			||||||
 | 
					        bytes32[] calldata operatedPoolIds
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        returns (uint256 proposalId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Casts a vote for the given proposal. Only callable
 | 
				
			||||||
 | 
					    ///      during the voting period for that proposal. See
 | 
				
			||||||
 | 
					    ///      `getVotingPower` for how voting power is computed.
 | 
				
			||||||
 | 
					    /// @param proposalId The ID of the proposal to vote on.
 | 
				
			||||||
 | 
					    /// @param support Whether to support the proposal or not.
 | 
				
			||||||
 | 
					    /// @param operatedPoolIds The pools operated by `msg.sender`. The
 | 
				
			||||||
 | 
					    ///        ZRX currently delegated to those pools will be accounted
 | 
				
			||||||
 | 
					    ///        for in the voting power.
 | 
				
			||||||
 | 
					    function castVote(
 | 
				
			||||||
 | 
					        uint256 proposalId,
 | 
				
			||||||
 | 
					        bool support,
 | 
				
			||||||
 | 
					        bytes32[] calldata operatedPoolIds
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        external;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Executes a proposal that has passed and is
 | 
				
			||||||
 | 
					    ///      currently executable.
 | 
				
			||||||
 | 
					    /// @param proposalId The ID of the proposal to execute.
 | 
				
			||||||
 | 
					    /// @param actions Actions associated with the proposal to execute.
 | 
				
			||||||
 | 
					    function execute(uint256 proposalId, ProposedAction[] memory actions)
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        payable;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns the total number of proposals.
 | 
				
			||||||
 | 
					    /// @return count The number of proposals.
 | 
				
			||||||
 | 
					    function proposalCount()
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256 count);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Computes the current voting power of the given account.
 | 
				
			||||||
 | 
					    ///      Voting power is equal to:
 | 
				
			||||||
 | 
					    ///      (ZRX delegated to the default pool) +
 | 
				
			||||||
 | 
					    ///      0.5 * (ZRX delegated to other pools) +
 | 
				
			||||||
 | 
					    ///      0.5 * (ZRX delegated to pools operated by account)
 | 
				
			||||||
 | 
					    /// @param account The address of the account.
 | 
				
			||||||
 | 
					    /// @param operatedPoolIds The pools operated by `account`. The
 | 
				
			||||||
 | 
					    ///        ZRX currently delegated to those pools will be accounted
 | 
				
			||||||
 | 
					    ///        for in the voting power.
 | 
				
			||||||
 | 
					    /// @return votingPower The current voting power of the given account.
 | 
				
			||||||
 | 
					    function getVotingPower(address account, bytes32[] calldata operatedPoolIds)
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256 votingPower);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										376
									
								
								contracts/treasury/contracts/src/ZrxTreasury.sol
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										376
									
								
								contracts/treasury/contracts/src/ZrxTreasury.sol
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,376 @@
 | 
				
			|||||||
 | 
					// 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.12;
 | 
				
			||||||
 | 
					pragma experimental ABIEncoderV2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import "@0x/contracts-utils/contracts/src/v06/LibBytesV06.sol";
 | 
				
			||||||
 | 
					import "@0x/contracts-utils/contracts/src/v06/LibSafeMathV06.sol";
 | 
				
			||||||
 | 
					import "@0x/contracts-utils/contracts/src/v06/errors/LibRichErrorsV06.sol";
 | 
				
			||||||
 | 
					import "@0x/contracts-zero-ex/contracts/src/features/libs/LibSignature.sol";
 | 
				
			||||||
 | 
					import "./IZrxTreasury.sol";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					contract ZrxTreasury is
 | 
				
			||||||
 | 
					    IZrxTreasury
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    using LibSafeMathV06 for uint256;
 | 
				
			||||||
 | 
					    using LibRichErrorsV06 for bytes;
 | 
				
			||||||
 | 
					    using LibBytesV06 for bytes;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Immutables
 | 
				
			||||||
 | 
					    IStaking public immutable override stakingProxy;
 | 
				
			||||||
 | 
					    DefaultPoolOperator public immutable override defaultPoolOperator;
 | 
				
			||||||
 | 
					    bytes32 public immutable override defaultPoolId;
 | 
				
			||||||
 | 
					    uint256 public immutable override votingPeriod;
 | 
				
			||||||
 | 
					    uint256 public override proposalThreshold;
 | 
				
			||||||
 | 
					    uint256 public override quorumThreshold;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Storage
 | 
				
			||||||
 | 
					    Proposal[] public proposals;
 | 
				
			||||||
 | 
					    mapping (uint256 => mapping (address => bool)) public hasVoted;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Initializes the ZRX treasury and creates the default
 | 
				
			||||||
 | 
					    ///      staking pool.
 | 
				
			||||||
 | 
					    /// @param stakingProxy_ The 0x staking proxy contract.
 | 
				
			||||||
 | 
					    /// @param params Immutable treasury parameters.
 | 
				
			||||||
 | 
					    constructor(
 | 
				
			||||||
 | 
					        IStaking stakingProxy_,
 | 
				
			||||||
 | 
					        TreasuryParameters memory params
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            params.votingPeriod < stakingProxy_.epochDurationInSeconds(),
 | 
				
			||||||
 | 
					            "VOTING_PERIOD_TOO_LONG"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        stakingProxy = stakingProxy_;
 | 
				
			||||||
 | 
					        votingPeriod = params.votingPeriod;
 | 
				
			||||||
 | 
					        proposalThreshold = params.proposalThreshold;
 | 
				
			||||||
 | 
					        quorumThreshold = params.quorumThreshold;
 | 
				
			||||||
 | 
					        defaultPoolId = params.defaultPoolId;
 | 
				
			||||||
 | 
					        IStaking.Pool memory defaultPool = stakingProxy_.getStakingPool(params.defaultPoolId);
 | 
				
			||||||
 | 
					        defaultPoolOperator = DefaultPoolOperator(defaultPool.operator);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // solhint-disable
 | 
				
			||||||
 | 
					    /// @dev Allows this contract to receive ether.
 | 
				
			||||||
 | 
					    receive() external payable {}
 | 
				
			||||||
 | 
					    // solhint-enable
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Updates the proposal and quorum thresholds to the given
 | 
				
			||||||
 | 
					    ///      values. Note that this function is only callable by the
 | 
				
			||||||
 | 
					    ///      treasury contract itself, so the threshold can only be
 | 
				
			||||||
 | 
					    ///      updated via a successful treasury proposal.
 | 
				
			||||||
 | 
					    /// @param newProposalThreshold The new value for the proposal threshold.
 | 
				
			||||||
 | 
					    /// @param newQuorumThreshold The new value for the quorum threshold.
 | 
				
			||||||
 | 
					    function updateThresholds(
 | 
				
			||||||
 | 
					        uint256 newProposalThreshold,
 | 
				
			||||||
 | 
					        uint256 newQuorumThreshold
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        external
 | 
				
			||||||
 | 
					        override
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        require(msg.sender == address(this), "updateThresholds/ONLY_SELF");
 | 
				
			||||||
 | 
					        proposalThreshold = newProposalThreshold;
 | 
				
			||||||
 | 
					        quorumThreshold = newQuorumThreshold;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Creates a proposal to send ZRX from this treasury on the
 | 
				
			||||||
 | 
					    ///      the given actions. Must have at least `proposalThreshold`
 | 
				
			||||||
 | 
					    ///      of voting power to call this function. See `getVotingPower`
 | 
				
			||||||
 | 
					    ///      for how voting power is computed. If a proposal is successfully
 | 
				
			||||||
 | 
					    ///      created, voting starts at the epoch after next (currentEpoch + 2).
 | 
				
			||||||
 | 
					    ///      If the vote passes, the proposal is executable during the
 | 
				
			||||||
 | 
					    ///      `executionEpoch`. See `hasProposalPassed` for the passing criteria.
 | 
				
			||||||
 | 
					    /// @param actions The proposed ZRX actions. An action specifies a
 | 
				
			||||||
 | 
					    ///        contract call.
 | 
				
			||||||
 | 
					    /// @param executionEpoch The epoch during which the proposal is to
 | 
				
			||||||
 | 
					    ///        be executed if it passes. Must be at least two epochs
 | 
				
			||||||
 | 
					    ///        from the current epoch.
 | 
				
			||||||
 | 
					    /// @param description A text description for the proposal.
 | 
				
			||||||
 | 
					    /// @param operatedPoolIds The pools operated by `msg.sender`. The
 | 
				
			||||||
 | 
					    ///        ZRX currently delegated to those pools will be accounted
 | 
				
			||||||
 | 
					    ///        for in the voting power.
 | 
				
			||||||
 | 
					    /// @return proposalId The ID of the newly created proposal.
 | 
				
			||||||
 | 
					    function propose(
 | 
				
			||||||
 | 
					        ProposedAction[] memory actions,
 | 
				
			||||||
 | 
					        uint256 executionEpoch,
 | 
				
			||||||
 | 
					        string memory description,
 | 
				
			||||||
 | 
					        bytes32[] memory operatedPoolIds
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					        override
 | 
				
			||||||
 | 
					        returns (uint256 proposalId)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            getVotingPower(msg.sender, operatedPoolIds) >= proposalThreshold,
 | 
				
			||||||
 | 
					            "propose/INSUFFICIENT_VOTING_POWER"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            actions.length > 0,
 | 
				
			||||||
 | 
					            "propose/NO_ACTIONS_PROPOSED"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        uint256 currentEpoch = stakingProxy.currentEpoch();
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            executionEpoch >= currentEpoch + 2,
 | 
				
			||||||
 | 
					            "propose/INVALID_EXECUTION_EPOCH"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        proposalId = proposalCount();
 | 
				
			||||||
 | 
					        Proposal storage newProposal = proposals.push();
 | 
				
			||||||
 | 
					        newProposal.actionsHash = keccak256(abi.encode(actions));
 | 
				
			||||||
 | 
					        newProposal.executionEpoch = executionEpoch;
 | 
				
			||||||
 | 
					        newProposal.voteEpoch = currentEpoch + 2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        emit ProposalCreated(
 | 
				
			||||||
 | 
					            msg.sender,
 | 
				
			||||||
 | 
					            operatedPoolIds,
 | 
				
			||||||
 | 
					            proposalId,
 | 
				
			||||||
 | 
					            actions,
 | 
				
			||||||
 | 
					            executionEpoch,
 | 
				
			||||||
 | 
					            description
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Casts a vote for the given proposal. Only callable
 | 
				
			||||||
 | 
					    ///      during the voting period for that proposal. See
 | 
				
			||||||
 | 
					    ///      `getVotingPower` for how voting power is computed.
 | 
				
			||||||
 | 
					    /// @param proposalId The ID of the proposal to vote on.
 | 
				
			||||||
 | 
					    /// @param support Whether to support the proposal or not.
 | 
				
			||||||
 | 
					    /// @param operatedPoolIds The pools operated by `msg.sender`. The
 | 
				
			||||||
 | 
					    ///        ZRX currently delegated to those pools will be accounted
 | 
				
			||||||
 | 
					    ///        for in the voting power.
 | 
				
			||||||
 | 
					    function castVote(
 | 
				
			||||||
 | 
					        uint256 proposalId,
 | 
				
			||||||
 | 
					        bool support,
 | 
				
			||||||
 | 
					        bytes32[] memory operatedPoolIds
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					        override
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        if (proposalId >= proposalCount()) {
 | 
				
			||||||
 | 
					            revert("castVote/INVALID_PROPOSAL_ID");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (hasVoted[proposalId][msg.sender]) {
 | 
				
			||||||
 | 
					            revert("castVote/ALREADY_VOTED");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        Proposal memory proposal = proposals[proposalId];
 | 
				
			||||||
 | 
					        if (
 | 
				
			||||||
 | 
					            proposal.voteEpoch != stakingProxy.currentEpoch() ||
 | 
				
			||||||
 | 
					            _hasVoteEnded(proposal.voteEpoch)
 | 
				
			||||||
 | 
					        ) {
 | 
				
			||||||
 | 
					            revert("castVote/VOTING_IS_CLOSED");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        uint256 votingPower = getVotingPower(msg.sender, operatedPoolIds);
 | 
				
			||||||
 | 
					        if (votingPower == 0) {
 | 
				
			||||||
 | 
					            revert("castVote/NO_VOTING_POWER");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (support) {
 | 
				
			||||||
 | 
					            proposals[proposalId].votesFor = proposals[proposalId].votesFor
 | 
				
			||||||
 | 
					                .safeAdd(votingPower);
 | 
				
			||||||
 | 
					            hasVoted[proposalId][msg.sender] = true;
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            proposals[proposalId].votesAgainst = proposals[proposalId].votesAgainst
 | 
				
			||||||
 | 
					                .safeAdd(votingPower);
 | 
				
			||||||
 | 
					            hasVoted[proposalId][msg.sender] = true;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        emit VoteCast(
 | 
				
			||||||
 | 
					            msg.sender,
 | 
				
			||||||
 | 
					            operatedPoolIds,
 | 
				
			||||||
 | 
					            proposalId,
 | 
				
			||||||
 | 
					            support,
 | 
				
			||||||
 | 
					            votingPower
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Executes a proposal that has passed and is
 | 
				
			||||||
 | 
					    ///      currently executable.
 | 
				
			||||||
 | 
					    /// @param proposalId The ID of the proposal to execute.
 | 
				
			||||||
 | 
					    /// @param actions Actions associated with the proposal to execute.
 | 
				
			||||||
 | 
					    function execute(uint256 proposalId, ProposedAction[] memory actions)
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					        payable
 | 
				
			||||||
 | 
					        override
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        if (proposalId >= proposalCount()) {
 | 
				
			||||||
 | 
					            revert("execute/INVALID_PROPOSAL_ID");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        Proposal memory proposal = proposals[proposalId];
 | 
				
			||||||
 | 
					        _assertProposalExecutable(proposal, actions);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        proposals[proposalId].executed = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (uint256 i = 0; i != actions.length; i++) {
 | 
				
			||||||
 | 
					            ProposedAction memory action = actions[i];
 | 
				
			||||||
 | 
					            (bool didSucceed, ) = action.target.call{value: action.value}(action.data);
 | 
				
			||||||
 | 
					            require(
 | 
				
			||||||
 | 
					                didSucceed,
 | 
				
			||||||
 | 
					                "execute/ACTION_EXECUTION_FAILED"
 | 
				
			||||||
 | 
					            );
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        emit ProposalExecuted(proposalId);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Returns the total number of proposals.
 | 
				
			||||||
 | 
					    /// @return count The number of proposals.
 | 
				
			||||||
 | 
					    function proposalCount()
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					        override
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256 count)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return proposals.length;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Computes the current voting power of the given account.
 | 
				
			||||||
 | 
					    ///      Voting power is equal to:
 | 
				
			||||||
 | 
					    ///      (ZRX delegated to the default pool) +
 | 
				
			||||||
 | 
					    ///      0.5 * (ZRX delegated to other pools) +
 | 
				
			||||||
 | 
					    ///      0.5 * (ZRX delegated to pools operated by account)
 | 
				
			||||||
 | 
					    /// @param account The address of the account.
 | 
				
			||||||
 | 
					    /// @param operatedPoolIds The pools operated by `account`. The
 | 
				
			||||||
 | 
					    ///        ZRX currently delegated to those pools will be accounted
 | 
				
			||||||
 | 
					    ///        for in the voting power.
 | 
				
			||||||
 | 
					    /// @return votingPower The current voting power of the given account.
 | 
				
			||||||
 | 
					    function getVotingPower(address account, bytes32[] memory operatedPoolIds)
 | 
				
			||||||
 | 
					        public
 | 
				
			||||||
 | 
					        override
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (uint256 votingPower)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        uint256 delegatedBalance = stakingProxy.getOwnerStakeByStatus(
 | 
				
			||||||
 | 
					            account,
 | 
				
			||||||
 | 
					            IStaking.StakeStatus.DELEGATED
 | 
				
			||||||
 | 
					        ).currentEpochBalance;
 | 
				
			||||||
 | 
					        uint256 balanceDelegatedToDefaultPool = stakingProxy.getStakeDelegatedToPoolByOwner(
 | 
				
			||||||
 | 
					            account,
 | 
				
			||||||
 | 
					            defaultPoolId
 | 
				
			||||||
 | 
					        ).currentEpochBalance;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // Voting power for ZRX delegated to the default pool is not diluted,
 | 
				
			||||||
 | 
					        // so we double-count the balance delegated to the default pool before
 | 
				
			||||||
 | 
					        // dividing by 2.
 | 
				
			||||||
 | 
					        votingPower = delegatedBalance
 | 
				
			||||||
 | 
					            .safeAdd(balanceDelegatedToDefaultPool)
 | 
				
			||||||
 | 
					            .safeDiv(2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // Add voting power for operated staking pools.
 | 
				
			||||||
 | 
					        for (uint256 i = 0; i != operatedPoolIds.length; i++) {
 | 
				
			||||||
 | 
					            for (uint256 j = 0; j != i; j++) {
 | 
				
			||||||
 | 
					                require(
 | 
				
			||||||
 | 
					                    operatedPoolIds[i] != operatedPoolIds[j],
 | 
				
			||||||
 | 
					                    "getVotingPower/DUPLICATE_POOL_ID"
 | 
				
			||||||
 | 
					                );
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            IStaking.Pool memory pool = stakingProxy.getStakingPool(operatedPoolIds[i]);
 | 
				
			||||||
 | 
					            require(
 | 
				
			||||||
 | 
					                pool.operator == account,
 | 
				
			||||||
 | 
					                "getVotingPower/POOL_NOT_OPERATED_BY_ACCOUNT"
 | 
				
			||||||
 | 
					            );
 | 
				
			||||||
 | 
					            uint96 stakeDelegatedToPool = stakingProxy
 | 
				
			||||||
 | 
					                .getTotalStakeDelegatedToPool(operatedPoolIds[i])
 | 
				
			||||||
 | 
					                .currentEpochBalance;
 | 
				
			||||||
 | 
					            uint256 poolVotingPower = uint256(stakeDelegatedToPool).safeDiv(2);
 | 
				
			||||||
 | 
					            votingPower = votingPower.safeAdd(poolVotingPower);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return votingPower;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Checks whether the given proposal is executable.
 | 
				
			||||||
 | 
					    ///      Reverts if not.
 | 
				
			||||||
 | 
					    /// @param proposal The proposal to check.
 | 
				
			||||||
 | 
					    function _assertProposalExecutable(
 | 
				
			||||||
 | 
					        Proposal memory proposal,
 | 
				
			||||||
 | 
					        ProposedAction[] memory actions
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					        private
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            keccak256(abi.encode(actions)) == proposal.actionsHash,
 | 
				
			||||||
 | 
					            "_assertProposalExecutable/INVALID_ACTIONS"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            _hasProposalPassed(proposal),
 | 
				
			||||||
 | 
					            "_assertProposalExecutable/PROPOSAL_HAS_NOT_PASSED"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            !proposal.executed,
 | 
				
			||||||
 | 
					            "_assertProposalExecutable/PROPOSAL_ALREADY_EXECUTED"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        require(
 | 
				
			||||||
 | 
					            stakingProxy.currentEpoch() == proposal.executionEpoch,
 | 
				
			||||||
 | 
					            "_assertProposalExecutable/CANNOT_EXECUTE_THIS_EPOCH"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Checks whether the given proposal has passed or not.
 | 
				
			||||||
 | 
					    /// @param proposal The proposal to check.
 | 
				
			||||||
 | 
					    /// @return hasPassed Whether the proposal has passed.
 | 
				
			||||||
 | 
					    function _hasProposalPassed(Proposal memory proposal)
 | 
				
			||||||
 | 
					        private
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (bool hasPassed)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        // Proposal is not passed until the vote is over.
 | 
				
			||||||
 | 
					        if (!_hasVoteEnded(proposal.voteEpoch)) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // Must have >50% support.
 | 
				
			||||||
 | 
					        if (proposal.votesFor <= proposal.votesAgainst) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // Must reach quorum threshold.
 | 
				
			||||||
 | 
					        if (proposal.votesFor < quorumThreshold) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return true;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /// @dev Checks whether a vote starting at the given
 | 
				
			||||||
 | 
					    ///      epoch has ended or not.
 | 
				
			||||||
 | 
					    /// @param voteEpoch The epoch at which the vote started.
 | 
				
			||||||
 | 
					    /// @return hasEnded Whether the vote has ended.
 | 
				
			||||||
 | 
					    function _hasVoteEnded(uint256 voteEpoch)
 | 
				
			||||||
 | 
					        private
 | 
				
			||||||
 | 
					        view
 | 
				
			||||||
 | 
					        returns (bool hasEnded)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        uint256 currentEpoch = stakingProxy.currentEpoch();
 | 
				
			||||||
 | 
					        if (currentEpoch < voteEpoch) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (currentEpoch > voteEpoch) {
 | 
				
			||||||
 | 
					            return true;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // voteEpoch == currentEpoch
 | 
				
			||||||
 | 
					        // Vote ends at currentEpochStartTime + votingPeriod
 | 
				
			||||||
 | 
					        uint256 voteEndTime = stakingProxy
 | 
				
			||||||
 | 
					            .currentEpochStartTimeInSeconds()
 | 
				
			||||||
 | 
					            .safeAdd(votingPeriod);
 | 
				
			||||||
 | 
					        return block.timestamp > voteEndTime;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										88
									
								
								contracts/treasury/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								contracts/treasury/package.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,88 @@
 | 
				
			|||||||
 | 
					{
 | 
				
			||||||
 | 
					    "name": "@0x/contracts-treasury",
 | 
				
			||||||
 | 
					    "version": "1.1.6",
 | 
				
			||||||
 | 
					    "engines": {
 | 
				
			||||||
 | 
					        "node": ">=6.12"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "description": "Smart contracts for governing the 0x ZRX treasury",
 | 
				
			||||||
 | 
					    "main": "lib/src/index.js",
 | 
				
			||||||
 | 
					    "directories": {
 | 
				
			||||||
 | 
					        "test": "test"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "scripts": {
 | 
				
			||||||
 | 
					        "build": "yarn pre_build && yarn build:ts",
 | 
				
			||||||
 | 
					        "build:ci": "yarn build",
 | 
				
			||||||
 | 
					        "build:ts": "tsc -b",
 | 
				
			||||||
 | 
					        "pre_build": "run-s compile contracts:gen generate_contract_wrappers contracts:copy",
 | 
				
			||||||
 | 
					        "test": "yarn run_mocha",
 | 
				
			||||||
 | 
					        "rebuild_and_test": "run-s build test",
 | 
				
			||||||
 | 
					        "run_mocha": "mocha --require source-map-support/register --require make-promises-safe 'lib/test/**/*.js' --timeout 100000 --bail --exit",
 | 
				
			||||||
 | 
					        "compile": "sol-compiler",
 | 
				
			||||||
 | 
					        "watch": "sol-compiler -w",
 | 
				
			||||||
 | 
					        "clean": "shx rm -rf lib test/generated-artifacts test/generated-wrappers generated-artifacts generated-wrappers",
 | 
				
			||||||
 | 
					        "generate_contract_wrappers": "abi-gen --debug --abis  ${npm_package_config_abis} --output test/generated-wrappers --backend ethers",
 | 
				
			||||||
 | 
					        "lint": "tslint --format stylish --project . --exclude ./generated-wrappers/**/* --exclude ./test/generated-wrappers/**/* --exclude ./generated-artifacts/**/* --exclude ./test/generated-artifacts/**/* --exclude **/lib/**/* && yarn lint-contracts",
 | 
				
			||||||
 | 
					        "fix": "tslint --fix --format stylish --project . --exclude ./generated-wrappers/**/* --exclude ./generated-artifacts/**/* --exclude ./test/generated-wrappers/**/* --exclude ./test/generated-artifacts/**/* --exclude **/lib/**/* && yarn lint-contracts",
 | 
				
			||||||
 | 
					        "test:circleci": "yarn test",
 | 
				
			||||||
 | 
					        "contracts:gen": "contracts-gen generate",
 | 
				
			||||||
 | 
					        "contracts:copy": "contracts-gen copy",
 | 
				
			||||||
 | 
					        "lint-contracts": "#solhint -c ../.solhint.json contracts/**/**/**/**/*.sol",
 | 
				
			||||||
 | 
					        "docs:md": "ts-doc-gen --sourceDir='$PROJECT_FILES' --output=$MD_FILE_DIR --fileExtension=mdx --tsconfig=./typedoc-tsconfig.json",
 | 
				
			||||||
 | 
					        "docs:json": "typedoc --excludePrivate --excludeExternals --excludeProtected --ignoreCompilerErrors --target ES5 --tsconfig typedoc-tsconfig.json --json $JSON_FILE_PATH $PROJECT_FILES",
 | 
				
			||||||
 | 
					        "publish:private": "yarn build && gitpkg publish"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "config": {
 | 
				
			||||||
 | 
					        "publicInterfaceContracts": "ZrxTreasury,DefaultPoolOperator",
 | 
				
			||||||
 | 
					        "abis:comment": "This list is auto-generated by contracts-gen. Don't edit manually.",
 | 
				
			||||||
 | 
					        "abis": "./test/generated-artifacts/@(DefaultPoolOperator|IStaking|IZrxTreasury|ZrxTreasury).json"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "repository": {
 | 
				
			||||||
 | 
					        "type": "git",
 | 
				
			||||||
 | 
					        "url": "https://github.com/0xProject/protocol.git"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "license": "Apache-2.0",
 | 
				
			||||||
 | 
					    "bugs": {
 | 
				
			||||||
 | 
					        "url": "https://github.com/0xProject/protocol/issues"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "homepage": "https://github.com/0xProject/protocol/tree/main/contracts/treasury",
 | 
				
			||||||
 | 
					    "devDependencies": {
 | 
				
			||||||
 | 
					        "@0x/abi-gen": "^5.6.0",
 | 
				
			||||||
 | 
					        "@0x/contract-addresses": "^6.1.0",
 | 
				
			||||||
 | 
					        "@0x/contracts-asset-proxy": "^3.7.11",
 | 
				
			||||||
 | 
					        "@0x/contracts-erc20": "^3.3.8",
 | 
				
			||||||
 | 
					        "@0x/contracts-gen": "^2.0.38",
 | 
				
			||||||
 | 
					        "@0x/contracts-staking": "^2.0.37",
 | 
				
			||||||
 | 
					        "@0x/contracts-test-utils": "^5.4.0",
 | 
				
			||||||
 | 
					        "@0x/sol-compiler": "^4.7.3",
 | 
				
			||||||
 | 
					        "@0x/ts-doc-gen": "^0.0.28",
 | 
				
			||||||
 | 
					        "@0x/tslint-config": "^4.1.4",
 | 
				
			||||||
 | 
					        "@types/isomorphic-fetch": "^0.0.35",
 | 
				
			||||||
 | 
					        "@types/lodash": "4.14.104",
 | 
				
			||||||
 | 
					        "@types/mocha": "^5.2.7",
 | 
				
			||||||
 | 
					        "@types/prompts": "^2.0.9",
 | 
				
			||||||
 | 
					        "isomorphic-fetch": "^3.0.0",
 | 
				
			||||||
 | 
					        "lodash": "^4.17.11",
 | 
				
			||||||
 | 
					        "mocha": "^6.2.0",
 | 
				
			||||||
 | 
					        "npm-run-all": "^4.1.2",
 | 
				
			||||||
 | 
					        "prompts": "^2.4.0",
 | 
				
			||||||
 | 
					        "shx": "^0.2.2",
 | 
				
			||||||
 | 
					        "solhint": "^1.4.1",
 | 
				
			||||||
 | 
					        "tslint": "5.11.0",
 | 
				
			||||||
 | 
					        "typedoc": "~0.16.11",
 | 
				
			||||||
 | 
					        "typescript": "4.2.2"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "dependencies": {
 | 
				
			||||||
 | 
					        "@0x/base-contract": "^6.4.0",
 | 
				
			||||||
 | 
					        "@0x/protocol-utils": "^1.6.0",
 | 
				
			||||||
 | 
					        "@0x/subproviders": "^6.5.3",
 | 
				
			||||||
 | 
					        "@0x/types": "^3.3.3",
 | 
				
			||||||
 | 
					        "@0x/typescript-typings": "^5.2.0",
 | 
				
			||||||
 | 
					        "@0x/utils": "^6.4.3",
 | 
				
			||||||
 | 
					        "@0x/web3-wrapper": "^7.5.3",
 | 
				
			||||||
 | 
					        "ethereum-types": "^3.5.0",
 | 
				
			||||||
 | 
					        "ethereumjs-util": "^7.0.10"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "publishConfig": {
 | 
				
			||||||
 | 
					        "access": "public"
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										13
									
								
								contracts/treasury/src/artifacts.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								contracts/treasury/src/artifacts.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,13 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * -----------------------------------------------------------------------------
 | 
				
			||||||
 | 
					 * Warning: This file is auto-generated by contracts-gen. Don't edit manually.
 | 
				
			||||||
 | 
					 * -----------------------------------------------------------------------------
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import { ContractArtifact } from 'ethereum-types';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import * as DefaultPoolOperator from '../generated-artifacts/DefaultPoolOperator.json';
 | 
				
			||||||
 | 
					import * as ZrxTreasury from '../generated-artifacts/ZrxTreasury.json';
 | 
				
			||||||
 | 
					export const artifacts = {
 | 
				
			||||||
 | 
					    ZrxTreasury: ZrxTreasury as ContractArtifact,
 | 
				
			||||||
 | 
					    DefaultPoolOperator: DefaultPoolOperator as ContractArtifact,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										2
									
								
								contracts/treasury/src/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								contracts/treasury/src/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,2 @@
 | 
				
			|||||||
 | 
					export { artifacts } from './artifacts';
 | 
				
			||||||
 | 
					export { DefaultPoolOperatorContract, ZrxTreasuryContract } from './wrappers';
 | 
				
			||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user