Compare commits
	
		
			256 Commits
		
	
	
		
			@0xproject
			...
			web3-types
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | d12352972e | ||
|  | 03d3d84db3 | ||
|  | 6d818c25c7 | ||
|  | 6a8f624e75 | ||
|  | 0801b1ddf9 | ||
|  | 4fd64ca492 | ||
|  | c4bcf24640 | ||
|  | 0114fc9608 | ||
|  | 8db098eaec | ||
|  | 05c3a66543 | ||
|  | 9349752baa | ||
|  | 974fab7284 | ||
|  | 8a52ffe7b7 | ||
|  | c6ecdbd86e | ||
|  | 03797545f9 | ||
|  | 2778f96483 | ||
|  | 6cd4e7a17e | ||
|  | 5c91b4bfc6 | ||
|  | e2b51c5dc4 | ||
|  | b610b7c192 | ||
|  | b75fdd6b66 | ||
|  | 060b02eaed | ||
|  | 003e5da00d | ||
|  | 02951d4813 | ||
|  | db52ed9941 | ||
|  | af333b1838 | ||
|  | f62762bd0e | ||
|  | 4b67352278 | ||
|  | e22788abe8 | ||
|  | bbfbfcda85 | ||
|  | 0dfb36e675 | ||
|  | 95a9d77301 | ||
|  | ab1f070901 | ||
|  | 8201d5d1f8 | ||
|  | 8704c34a0f | ||
|  | 599adaf1bf | ||
|  | 778e399438 | ||
|  | 485ae4d997 | ||
|  | 8cd2ba3ad6 | ||
|  | dbad7d1869 | ||
|  | 18e1c2dea5 | ||
|  | 91ae01e484 | ||
|  | 2897b72967 | ||
|  | 3510985cf4 | ||
|  | 5927e65045 | ||
|  | 13e2041d50 | ||
|  | 4bf530ed9e | ||
|  | 4c797405ad | ||
|  | 713c922e35 | ||
|  | 7f1e789264 | ||
|  | 07d00cc515 | ||
|  | cd55e346af | ||
|  | 6746428fb1 | ||
|  | 634032d5be | ||
|  | 602abc53dd | ||
|  | fdbaa9768a | ||
|  | 293d7261e0 | ||
|  | efb6eb28ce | ||
|  | ac5531ce85 | ||
|  | bc2415c70e | ||
|  | 0fd411f83f | ||
|  | b74ad0ad12 | ||
|  | 4c58836735 | ||
|  | 3206b80dbd | ||
|  | 4910f7a61e | ||
|  | 6e9109eaec | ||
|  | a04ec14cf0 | ||
|  | 7d3df3c117 | ||
|  | b3a03f8e3e | ||
|  | e5668c1e5c | ||
|  | 92e74bc4fa | ||
|  | 7e12269baf | ||
|  | f3f264f5fd | ||
|  | 2e3c9b87df | ||
|  | 0a113e1cf7 | ||
|  | fd772c48cf | ||
|  | 1c7dce6054 | ||
|  | 0a2947b860 | ||
|  | c80877af43 | ||
|  | e68b9c7e81 | ||
|  | 19198737a5 | ||
|  | fea4b6aecd | ||
|  | 20e2673b82 | ||
|  | ef1375b9dd | ||
|  | 58f1939ec1 | ||
|  | ba57c34adb | ||
|  | 936f6ac10f | ||
|  | 7e04c4f24b | ||
|  | 9495c8f46c | ||
|  | b3f91600d3 | ||
|  | ddf4437fb6 | ||
|  | 4153d57849 | ||
|  | 0652790703 | ||
|  | 9c934d903d | ||
|  | d7a7e28925 | ||
|  | 6dec29e214 | ||
|  | 43cf8d30bd | ||
|  | 254d3f53e2 | ||
|  | ec198343b5 | ||
|  | 876517d458 | ||
|  | 1233c33116 | ||
|  | eebf205817 | ||
|  | e666bb44c6 | ||
|  | 39cb0b5122 | ||
|  | 58003a2811 | ||
|  | 7f2a7cfa77 | ||
|  | 8fba0477a6 | ||
|  | 7ca1ba7e1e | ||
|  | e6f2c7a382 | ||
|  | 69f5f5e946 | ||
|  | 68a8acbe7b | ||
|  | 852811b314 | ||
|  | 2404ff0304 | ||
|  | 9ff4cacf0f | ||
|  | e443cb2a3b | ||
|  | f3c6cce455 | ||
|  | ae14b0a71d | ||
|  | 3c7ebe2697 | ||
|  | 10fb6061cc | ||
|  | 223df8006a | ||
|  | 1c9428cbba | ||
|  | 18dc5d17b5 | ||
|  | 4d50933189 | ||
|  | 9b3680780f | ||
|  | a26e77074f | ||
|  | 568e4d33f2 | ||
|  | fd004032cb | ||
|  | 4b6324050d | ||
|  | 12d62e1157 | ||
|  | 063c6b66b6 | ||
|  | d9b1d31e73 | ||
|  | 0bad911a16 | ||
|  | 518efa8ad2 | ||
|  | 6e87c9e713 | ||
|  | b61852b1f5 | ||
|  | fcbe24a126 | ||
|  | 55312d00ef | ||
|  | a96e3f3222 | ||
|  | e35519b50f | ||
|  | ae775f9664 | ||
|  | 071b1c47d1 | ||
|  | 4cc5bbaf19 | ||
|  | a264c36a48 | ||
|  | 0c2ab22656 | ||
|  | 47adad5122 | ||
|  | 745f209f7e | ||
|  | 2287597712 | ||
|  | eea8b15180 | ||
|  | 600a2b40af | ||
|  | a7c51593e4 | ||
|  | 218876ac19 | ||
|  | 6cda67df10 | ||
|  | 897515c002 | ||
|  | 9deaf612f1 | ||
|  | b7676d8c46 | ||
|  | 05aa2fa421 | ||
|  | 03f5c9b950 | ||
|  | 4c9c4c487a | ||
|  | c172b9e080 | ||
|  | 5533a84dcd | ||
|  | 562bcb8571 | ||
|  | 00c07b38a4 | ||
|  | f44bfa9682 | ||
|  | 7357a0a324 | ||
|  | 36a49966eb | ||
|  | f818d06b43 | ||
|  | 548246c05f | ||
|  | 2bf1aa975a | ||
|  | 4be8eca3fe | ||
|  | e17ace397c | ||
|  | 6bdabe72b9 | ||
|  | 00bfc7f889 | ||
|  | 5fcb77e591 | ||
|  | df8de7ff51 | ||
|  | 67d7540907 | ||
|  | 83d0bad3a1 | ||
|  | 9d80a62bb1 | ||
|  | 629653425d | ||
|  | 03ce1d8641 | ||
|  | 225baeb5cb | ||
|  | cf171d28c7 | ||
|  | 61434a9121 | ||
|  | 20590b7d35 | ||
|  | fce7081215 | ||
|  | 83c7c8110d | ||
|  | c4680a97a8 | ||
|  | 91a5bcf380 | ||
|  | 7e9ae458e2 | ||
|  | 4e284f5e6c | ||
|  | 75ded89790 | ||
|  | 598ce0d401 | ||
|  | fc3058c1e2 | ||
|  | d14ae70776 | ||
|  | 882816d609 | ||
|  | 2205e2b9a0 | ||
|  | 855fdd7921 | ||
|  | 99b1f81e89 | ||
|  | 46ad7b1b38 | ||
|  | 7e5b7a7f2a | ||
|  | 156e85a6b3 | ||
|  | 6fce02d25e | ||
|  | 4ddb86df53 | ||
|  | 3565e96f42 | ||
|  | 2c7db23022 | ||
|  | fe51c9a9a2 | ||
|  | 5324dfa5a7 | ||
|  | 881d32e733 | ||
|  | 1f4cbb7479 | ||
|  | b17bbdaa7d | ||
|  | 5458a1c1b7 | ||
|  | fa98450754 | ||
|  | 7b4f2b47de | ||
|  | 400a97e7a8 | ||
|  | a816fb5958 | ||
|  | c7ad6ebad6 | ||
|  | 85b4a82a4b | ||
|  | f18fa8e947 | ||
|  | 44cd185c66 | ||
|  | 890f414b5a | ||
|  | 03b1b12ef1 | ||
|  | dae6f28f8a | ||
|  | 5aca3a2d7d | ||
|  | 7f257e258f | ||
|  | 6a9d3de0f9 | ||
|  | 05aae36813 | ||
|  | d5d6079b67 | ||
|  | bb4c8bf8eb | ||
|  | 3eb40db498 | ||
|  | 576f63d5e4 | ||
|  | cda1dc82e9 | ||
|  | 2721252d6a | ||
|  | 45ac960308 | ||
|  | 47d74aa24a | ||
|  | 48aa1ad57d | ||
|  | 2eccb28dee | ||
|  | 9c3bfd920f | ||
|  | 76eb1e9e7f | ||
|  | b7af597668 | ||
|  | d635559a30 | ||
|  | 58dd90b7b7 | ||
|  | ead990a734 | ||
|  | 27400fcd5b | ||
|  | 0c6cbb66b1 | ||
|  | f09393d4f4 | ||
|  | f6d963d45a | ||
|  | 39e3733be4 | ||
|  | 09659cc304 | ||
|  | 6577d60733 | ||
|  | c7db837214 | ||
|  | 03cb7233dc | ||
|  | 3a1ca32ff1 | ||
|  | 44162811bd | ||
|  | 1c1f2ef1ff | ||
|  | 4fa774f866 | ||
|  | 4671999ea0 | ||
|  | 0a73bbe279 | 
							
								
								
									
										12
									
								
								.editorconfig
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.editorconfig
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| # EditorConfig  http://EditorConfig.org | ||||
|  | ||||
| # top-most EditorConfig file | ||||
| root = true | ||||
|  | ||||
| # All files | ||||
| [*] | ||||
| end_of_line = lf | ||||
| insert_final_newline = true | ||||
| charset = utf-8 | ||||
| indent_style = space | ||||
| indent_size = 4 | ||||
| @@ -1,6 +0,0 @@ | ||||
| .* | ||||
| tsconfig.json | ||||
| tslint.json | ||||
| webpack.config.js | ||||
| yarn.lock | ||||
| docs | ||||
							
								
								
									
										1
									
								
								CODEOWNERS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								CODEOWNERS
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| *        @abandeali1 @BMillman19 @dekz @fabioberger @LogvinovLeon @Recmo | ||||
| @@ -22,15 +22,21 @@ | ||||
|  | ||||
| ## Types of changes | ||||
|  | ||||
| <!--- What types of changes does your code introduce? Put an `x` in all the boxes that apply: | ||||
| - [ ] Bug fix (non-breaking change which fixes an issue) | ||||
| - [ ] New feature (non-breaking change which adds functionality) | ||||
| - [ ] Breaking change (fix or feature that would cause existing functionality to change) | ||||
| <!--- What types of changes does your code introduce? Put an `x` in all the boxes that apply: --> | ||||
|  | ||||
| * [ ] Bug fix (non-breaking change which fixes an issue) | ||||
| * [ ] New feature (non-breaking change which adds functionality) | ||||
| * [ ] Breaking change (fix or feature that would cause existing functionality to change) | ||||
|  | ||||
| ## Checklist: | ||||
|  | ||||
| <!--- Go over all the following points, and put an `x` in all the boxes that apply. --> | ||||
|  | ||||
| <!--- If you're unsure about any of these, don't hesitate to ask. We're here to help! --> | ||||
|  | ||||
| * [ ] Change requires a change to the documentation. | ||||
| * [ ] Added tests to cover my changes. | ||||
| * [ ] Added new entries to the relevant CHANGELOGs. | ||||
| * [ ] Updated the new versions of the changed packages in the relevant CHANGELOGs. | ||||
| * [ ] Labeled this PR with the 'WIP' label if it is a work in progress. | ||||
| * [ ] Labeled this PR with the labels corresponding to the changed package. | ||||
|   | ||||
| @@ -81,6 +81,12 @@ Build all packages | ||||
| yarn lerna:run build | ||||
| ``` | ||||
|  | ||||
| Continuously rebuild on exchange | ||||
|  | ||||
| ```bash | ||||
| yarn dev | ||||
| ``` | ||||
|  | ||||
| ### Lint | ||||
|  | ||||
| Lint all packages | ||||
|   | ||||
| @@ -2,6 +2,11 @@ | ||||
|     "lerna": "2.5.1", | ||||
|     "packages": ["packages/*"], | ||||
|     "version": "independent", | ||||
|     "commands": { | ||||
|         "publish": { | ||||
|             "ignore": ["test/**/*", "*.md", "scripts", "lib", "tslint.json", "tsconfig.json"] | ||||
|         } | ||||
|     }, | ||||
|     "npmClient": "yarn", | ||||
|     "useWorkspaces": true | ||||
| } | ||||
|   | ||||
| @@ -3,6 +3,7 @@ | ||||
|     "name": "0x.js", | ||||
|     "workspaces": ["packages/*"], | ||||
|     "scripts": { | ||||
|         "dev": "lerna run --parallel build:watch", | ||||
|         "testrpc": "testrpc -p 8545 --networkId 50 -m \"${npm_package_config_mnemonic}\"", | ||||
|         "prettier": "prettier --write '**/*.{ts,tsx,json,md}' --config .prettierrc", | ||||
|         "prettier:ci": "prettier --list-different '**/*.{ts,tsx,json,md}' --config .prettierrc", | ||||
| @@ -15,7 +16,7 @@ | ||||
|         "mnemonic": "concert load couple harbor equip island argue ramp clarify fence smart topic" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/utils": "^0.2.0", | ||||
|         "@0xproject/utils": "^0.3.2", | ||||
|         "async-child-process": "^1.1.1", | ||||
|         "ethereumjs-testrpc": "^6.0.3", | ||||
|         "lerna": "^2.5.1", | ||||
|   | ||||
							
								
								
									
										10
									
								
								packages/0x.js/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								packages/0x.js/.npmignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| .* | ||||
| tsconfig.json | ||||
| webpack.config.js | ||||
| yarn-error.log | ||||
| test/ | ||||
| /src/ | ||||
| /_bundles/ | ||||
| /contract_templates/ | ||||
| /generated_docs/ | ||||
| /scripts/ | ||||
| @@ -1,8 +1,22 @@ | ||||
| # CHANGELOG | ||||
|  | ||||
| ## v0.32.2 - _February 9, 2018_ | ||||
|  | ||||
|     * Fix publishing issue where .npmignore was not properly excluding undesired content (#389) | ||||
|  | ||||
| ## v0.32.1 - _February 7, 2018_ | ||||
|  | ||||
|     * Reorganized `BlockParamLiteral` export into `@0xproject/types` package (#355) | ||||
|     * Now using `abi-gen` package to generate ContractEventArgs types (#371) | ||||
|  | ||||
| ## v0.32.0 - _February 5, 2018_ | ||||
|  | ||||
|     * Add `zeroEx.etherToken.getContractAddressIfExists` (#350) | ||||
|     * Fixed the bug causing order watcher to throw if there is an event with the same signature but different indexed fields (#366) | ||||
|  | ||||
| ## v0.31.1 - _February 1, 2018_ | ||||
|  | ||||
|     * Fix the bug causing order watcher to throw is makerToken === zrx (#357) | ||||
|     * Fix the bug causing order watcher to throw if makerToken === zrx (#357) | ||||
|  | ||||
| ## v0.31.0 - _January 30, 2018_ | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| /** | ||||
|  * This file is auto-generated using abi-gen. Don't edit directly. | ||||
|  * Templates can be found at https://github.com/0xProject/0x.js/tree/development/packages/abi-gen-templates. | ||||
|  * Templates can be found at https://github.com/0xProject/0x.js/tree/development/packages/0x.js/contract_templates. | ||||
|  */ | ||||
| // tslint:disable:no-consecutive-blank-lines | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { TxData, TxDataPayable } from '@0xproject/types'; | ||||
| import { BigNumber, classUtils, promisify } from '@0xproject/utils'; | ||||
| @@ -9,6 +10,24 @@ import * as Web3 from 'web3'; | ||||
|  | ||||
| import {BaseContract} from './base_contract'; | ||||
|  | ||||
| {{#if events}} | ||||
| export type {{contractName}}ContractEventArgs = | ||||
| {{#each events}} | ||||
|     | {{name}}ContractEventArgs{{#if @last}};{{/if}} | ||||
| {{/each}} | ||||
|  | ||||
| export enum {{contractName}}Events { | ||||
|     {{#each events}} | ||||
|     {{name}} = '{{name}}', | ||||
|     {{/each}} | ||||
| } | ||||
|  | ||||
| {{#each events}} | ||||
| {{> event}} | ||||
|  | ||||
| {{/each}} | ||||
| {{/if}} | ||||
|  | ||||
| export class {{contractName}}Contract extends BaseContract { | ||||
| {{#each methods}} | ||||
|     {{#this.constant}} | ||||
|   | ||||
| @@ -0,0 +1,5 @@ | ||||
| export interface {{name}}ContractEventArgs { | ||||
|     {{#each inputs}} | ||||
|     {{name}}: {{#returnType type}}{{/returnType}}; | ||||
|     {{/each}} | ||||
| } | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "0x.js", | ||||
|     "version": "0.31.1", | ||||
|     "version": "0.32.3", | ||||
|     "description": "A javascript library for interacting with the 0x protocol", | ||||
|     "keywords": [ | ||||
|         "0x.js", | ||||
| @@ -12,6 +12,7 @@ | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "build:watch": "tsc -w", | ||||
|         "prebuild": "run-s clean generate_contract_wrappers", | ||||
|         "build": "run-p build:umd:prod build:commonjs; exit 0;", | ||||
|         "docs:json": "typedoc --excludePrivate --excludeExternals --target ES5 --json $JSON_FILE_PATH $PROJECT_DIR", | ||||
| @@ -41,9 +42,9 @@ | ||||
|         "node": ">=6.0.0" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/abi-gen": "^0.1.6", | ||||
|         "@0xproject/dev-utils": "^0.0.9", | ||||
|         "@0xproject/tslint-config": "^0.4.6", | ||||
|         "@0xproject/abi-gen": "^0.2.2", | ||||
|         "@0xproject/dev-utils": "^0.0.13", | ||||
|         "@0xproject/tslint-config": "^0.4.9", | ||||
|         "@types/bintrees": "^1.0.2", | ||||
|         "@types/jsonschema": "^1.1.1", | ||||
|         "@types/lodash": "^4.14.86", | ||||
| @@ -54,9 +55,9 @@ | ||||
|         "awesome-typescript-loader": "^3.1.3", | ||||
|         "chai": "^4.0.1", | ||||
|         "chai-as-promised": "^7.1.0", | ||||
|         "chai-as-promised-typescript-typings": "^0.0.8", | ||||
|         "chai-as-promised-typescript-typings": "^0.0.9", | ||||
|         "chai-bignumber": "^2.0.1", | ||||
|         "chai-typescript-typings": "^0.0.2", | ||||
|         "chai-typescript-typings": "^0.0.3", | ||||
|         "copyfiles": "^1.2.0", | ||||
|         "coveralls": "^3.0.0", | ||||
|         "dirty-chai": "^2.0.1", | ||||
| @@ -73,17 +74,18 @@ | ||||
|         "truffle-hdwallet-provider": "^0.0.3", | ||||
|         "tslint": "5.8.0", | ||||
|         "typedoc": "~0.8.0", | ||||
|         "typescript": "~2.6.1", | ||||
|         "types-bn": "^0.0.1", | ||||
|         "typescript": "2.7.1", | ||||
|         "web3-provider-engine": "^13.0.1", | ||||
|         "web3-typescript-typings": "^0.9.8", | ||||
|         "web3-typescript-typings": "^0.9.10", | ||||
|         "webpack": "^3.1.0" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0xproject/assert": "^0.0.15", | ||||
|         "@0xproject/json-schemas": "^0.7.7", | ||||
|         "@0xproject/types": "^0.1.8", | ||||
|         "@0xproject/utils": "^0.2.4", | ||||
|         "@0xproject/web3-wrapper": "^0.1.9", | ||||
|         "@0xproject/assert": "^0.0.19", | ||||
|         "@0xproject/json-schemas": "^0.7.11", | ||||
|         "@0xproject/types": "^0.2.2", | ||||
|         "@0xproject/utils": "^0.3.3", | ||||
|         "@0xproject/web3-wrapper": "^0.1.13", | ||||
|         "bintrees": "^1.0.2", | ||||
|         "bn.js": "^4.11.8", | ||||
|         "ethereumjs-abi": "^0.6.4", | ||||
|   | ||||
| @@ -15,7 +15,7 @@ postpublish_utils | ||||
|         version = result.version; | ||||
|         const releaseName = postpublish_utils.getReleaseName(subPackageName, version); | ||||
|         const assets = [__dirname + '/../_bundles/index.js', __dirname + '/../_bundles/index.min.js']; | ||||
|         return postpublish_utils.publishReleaseNotes(tag, releaseName, assets); | ||||
|         return postpublish_utils.publishReleaseNotesAsync(tag, releaseName, assets); | ||||
|     }) | ||||
|     .then(function(release) { | ||||
|         console.log('POSTPUBLISH: Release successful, generating docs...'); | ||||
|   | ||||
							
								
								
									
										24
									
								
								packages/0x.js/scripts/stagedocs.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								packages/0x.js/scripts/stagedocs.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| const execAsync = require('async-child-process').execAsync; | ||||
| const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
|  | ||||
| const cwd = __dirname + '/..'; | ||||
| const S3BucketPath = 's3://staging-0xjs-docs-jsons/'; | ||||
| const jsonFilePath = __dirname + '/../' + postpublish_utils.generatedDocsDirectoryName + '/index.json'; | ||||
| const version = process.env.DOCS_VERSION; | ||||
|  | ||||
| execAsync('JSON_FILE_PATH=' + jsonFilePath + ' PROJECT_DIR=' + __dirname + '/.. yarn docs:json', { | ||||
|     cwd, | ||||
| }) | ||||
| .then(function(result) { | ||||
|     if (result.stderr !== '') { | ||||
|         throw new Error(result.stderr); | ||||
|     } | ||||
|     const fileName = 'v' + version + '.json'; | ||||
|     const s3Url = S3BucketPath + fileName; | ||||
|     return execAsync('S3_URL=' + s3Url + ' yarn upload_docs_json', { | ||||
|         cwd, | ||||
|     }); | ||||
| }) | ||||
| .catch(function(err) { | ||||
|     console.log(err); | ||||
| }); | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { LogWithDecodedArgs, RawLog } from '@0xproject/types'; | ||||
| import { BlockParamLiteral, LogWithDecodedArgs, RawLog } from '@0xproject/types'; | ||||
| import { AbiDecoder, intervalUtils } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { Block, BlockAndLogStreamer } from 'ethereumjs-blockstream'; | ||||
| @@ -7,7 +7,6 @@ import * as Web3 from 'web3'; | ||||
|  | ||||
| import { | ||||
|     Artifact, | ||||
|     BlockParamLiteral, | ||||
|     BlockRange, | ||||
|     ContractEventArgs, | ||||
|     ContractEvents, | ||||
| @@ -32,10 +31,10 @@ const CONTRACT_NAME_TO_NOT_FOUND_ERROR: { | ||||
|  | ||||
| export class ContractWrapper { | ||||
|     protected _web3Wrapper: Web3Wrapper; | ||||
|     private _networkId: number; | ||||
|     protected _networkId: number; | ||||
|     private _abiDecoder?: AbiDecoder; | ||||
|     private _blockAndLogStreamerIfExists: BlockAndLogStreamer | undefined; | ||||
|     private _blockAndLogStreamInterval: NodeJS.Timer; | ||||
|     private _blockAndLogStreamerIfExists?: BlockAndLogStreamer; | ||||
|     private _blockAndLogStreamIntervalIfExists?: NodeJS.Timer; | ||||
|     private _filters: { [filterToken: string]: Web3.FilterObject }; | ||||
|     private _filterCallbacks: { | ||||
|         [filterToken: string]: EventCallback<ContractEventArgs>; | ||||
| @@ -162,7 +161,7 @@ export class ContractWrapper { | ||||
|         ); | ||||
|         const catchAllLogFilter = {}; | ||||
|         this._blockAndLogStreamerIfExists.addLogFilter(catchAllLogFilter); | ||||
|         this._blockAndLogStreamInterval = intervalUtils.setAsyncExcludingInterval( | ||||
|         this._blockAndLogStreamIntervalIfExists = intervalUtils.setAsyncExcludingInterval( | ||||
|             this._reconcileBlockAsync.bind(this), | ||||
|             constants.DEFAULT_BLOCK_POLLING_INTERVAL, | ||||
|             this._onReconcileBlockError.bind(this), | ||||
| @@ -191,7 +190,7 @@ export class ContractWrapper { | ||||
|         } | ||||
|         this._blockAndLogStreamerIfExists.unsubscribeFromOnLogAdded(this._onLogAddedSubscriptionToken as string); | ||||
|         this._blockAndLogStreamerIfExists.unsubscribeFromOnLogRemoved(this._onLogRemovedSubscriptionToken as string); | ||||
|         intervalUtils.clearAsyncExcludingInterval(this._blockAndLogStreamInterval); | ||||
|         intervalUtils.clearAsyncExcludingInterval(this._blockAndLogStreamIntervalIfExists as NodeJS.Timer); | ||||
|         delete this._blockAndLogStreamerIfExists; | ||||
|     } | ||||
|     private async _reconcileBlockAsync(): Promise<void> { | ||||
|   | ||||
| @@ -5,19 +5,11 @@ import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { | ||||
|     BlockRange, | ||||
|     EtherTokenContractEventArgs, | ||||
|     EtherTokenEvents, | ||||
|     EventCallback, | ||||
|     IndexedFilterValues, | ||||
|     TransactionOpts, | ||||
|     ZeroExError, | ||||
| } from '../types'; | ||||
| import { BlockRange, EventCallback, IndexedFilterValues, TransactionOpts, ZeroExError } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { EtherTokenContract } from './generated/ether_token'; | ||||
| import { EtherTokenContract, EtherTokenContractEventArgs, EtherTokenEvents } from './generated/ether_token'; | ||||
| import { TokenWrapper } from './token_wrapper'; | ||||
|  | ||||
| /** | ||||
| @@ -162,6 +154,19 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|     public _unsubscribeAll(): void { | ||||
|         super._unsubscribeAll(); | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves the Ethereum address of the EtherToken contract deployed on the network | ||||
|      * that the user-passed web3 provider is connected to. If it's not Kovan, Ropsten, Rinkeby, Mainnet or TestRPC | ||||
|      * (networkId: 50), it will return undefined (e.g a private network). | ||||
|      * @returns The Ethereum address of the EtherToken contract or undefined. | ||||
|      */ | ||||
|     public getContractAddressIfExists(): string | undefined { | ||||
|         const networkSpecificArtifact = artifacts.EtherTokenArtifact.networks[this._networkId]; | ||||
|         const contractAddressIfExists = _.isUndefined(networkSpecificArtifact) | ||||
|             ? undefined | ||||
|             : networkSpecificArtifact.address; | ||||
|         return contractAddressIfExists; | ||||
|     } | ||||
|     private _invalidateContractInstance(): void { | ||||
|         this._unsubscribeAll(); | ||||
|         this._etherTokenContractsByAddress = {}; | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { DecodedLogArgs, LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { BlockParamLiteral, DecodedLogArgs, LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { AbiDecoder, BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
| @@ -7,16 +7,12 @@ import * as Web3 from 'web3'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { | ||||
|     BlockParamLiteral, | ||||
|     BlockRange, | ||||
|     ECSignature, | ||||
|     EventCallback, | ||||
|     ExchangeContractErrCodes, | ||||
|     ExchangeContractErrs, | ||||
|     ExchangeContractEventArgs, | ||||
|     ExchangeEvents, | ||||
|     IndexedFilterValues, | ||||
|     LogErrorContractEventArgs, | ||||
|     MethodOpts, | ||||
|     Order, | ||||
|     OrderAddresses, | ||||
| @@ -34,7 +30,12 @@ import { OrderValidationUtils } from '../utils/order_validation_utils'; | ||||
| import { utils } from '../utils/utils'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { ExchangeContract } from './generated/exchange'; | ||||
| import { | ||||
|     ExchangeContract, | ||||
|     ExchangeContractEventArgs, | ||||
|     ExchangeEvents, | ||||
|     LogErrorContractEventArgs, | ||||
| } from './generated/exchange'; | ||||
| import { TokenWrapper } from './token_wrapper'; | ||||
|  | ||||
| const SHOULD_VALIDATE_BY_DEFAULT = true; | ||||
|   | ||||
| @@ -5,21 +5,12 @@ import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { | ||||
|     BlockRange, | ||||
|     EventCallback, | ||||
|     IndexedFilterValues, | ||||
|     MethodOpts, | ||||
|     TokenContractEventArgs, | ||||
|     TokenEvents, | ||||
|     TransactionOpts, | ||||
|     ZeroExError, | ||||
| } from '../types'; | ||||
| import { BlockRange, EventCallback, IndexedFilterValues, MethodOpts, TransactionOpts, ZeroExError } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
| import { constants } from '../utils/constants'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { TokenContract } from './generated/token'; | ||||
| import { TokenContract, TokenContractEventArgs, TokenEvents } from './generated/token'; | ||||
| import { TokenTransferProxyWrapper } from './token_transfer_proxy_wrapper'; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -2,7 +2,6 @@ export { ZeroEx } from './0x'; | ||||
|  | ||||
| export { | ||||
|     Order, | ||||
|     BlockParamLiteral, | ||||
|     SignedOrder, | ||||
|     ECSignature, | ||||
|     ZeroExError, | ||||
| @@ -10,27 +9,13 @@ export { | ||||
|     ExchangeContractErrs, | ||||
|     ContractEvent, | ||||
|     Token, | ||||
|     ExchangeEvents, | ||||
|     TokenEvents, | ||||
|     IndexedFilterValues, | ||||
|     BlockRange, | ||||
|     BlockParam, | ||||
|     OrderCancellationRequest, | ||||
|     OrderFillRequest, | ||||
|     LogErrorContractEventArgs, | ||||
|     LogCancelContractEventArgs, | ||||
|     LogFillContractEventArgs, | ||||
|     ExchangeContractEventArgs, | ||||
|     TransferContractEventArgs, | ||||
|     ApprovalContractEventArgs, | ||||
|     TokenContractEventArgs, | ||||
|     EtherTokenContractEventArgs, | ||||
|     WithdrawalContractEventArgs, | ||||
|     DepositContractEventArgs, | ||||
|     ContractEventArgs, | ||||
|     Web3Provider, | ||||
|     ZeroExConfig, | ||||
|     EtherTokenEvents, | ||||
|     MethodOpts, | ||||
|     OrderTransactionOpts, | ||||
|     TransactionOpts, | ||||
| @@ -44,6 +29,34 @@ export { | ||||
|     OrderState, | ||||
| } from './types'; | ||||
|  | ||||
| export { ContractEventArg, LogWithDecodedArgs, TransactionReceiptWithDecodedLogs } from '@0xproject/types'; | ||||
| export { | ||||
|     BlockParamLiteral, | ||||
|     BlockParam, | ||||
|     ContractEventArg, | ||||
|     LogWithDecodedArgs, | ||||
|     TransactionReceiptWithDecodedLogs, | ||||
| } from '@0xproject/types'; | ||||
|  | ||||
| export { | ||||
|     EtherTokenContractEventArgs, | ||||
|     WithdrawalContractEventArgs, | ||||
|     DepositContractEventArgs, | ||||
|     EtherTokenEvents, | ||||
| } from './contract_wrappers/generated/ether_token'; | ||||
|  | ||||
| export { | ||||
|     TransferContractEventArgs, | ||||
|     ApprovalContractEventArgs, | ||||
|     TokenContractEventArgs, | ||||
|     TokenEvents, | ||||
| } from './contract_wrappers/generated/token'; | ||||
|  | ||||
| export { | ||||
|     LogErrorContractEventArgs, | ||||
|     LogCancelContractEventArgs, | ||||
|     LogFillContractEventArgs, | ||||
|     ExchangeContractEventArgs, | ||||
|     ExchangeEvents, | ||||
| } from './contract_wrappers/generated/exchange'; | ||||
|  | ||||
| export { TransactionReceipt } from '@0xproject/types'; | ||||
|   | ||||
| @@ -3,7 +3,9 @@ import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { BlockParamLiteral, EventWatcherCallback, ZeroExError } from '../types'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
|  | ||||
| import { EventWatcherCallback, ZeroExError } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
|  | ||||
| const DEFAULT_EVENT_POLLING_INTERVAL_MS = 200; | ||||
|   | ||||
| @@ -1,32 +1,37 @@ | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { BlockParamLiteral, LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { AbiDecoder, intervalUtils } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { ZeroEx } from '../0x'; | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
| import { | ||||
|     DepositContractEventArgs, | ||||
|     EtherTokenEvents, | ||||
|     WithdrawalContractEventArgs, | ||||
| } from '../contract_wrappers/generated/ether_token'; | ||||
| import { | ||||
|     ExchangeEvents, | ||||
|     LogCancelContractEventArgs, | ||||
|     LogFillContractEventArgs, | ||||
| } from '../contract_wrappers/generated/exchange'; | ||||
| import { | ||||
|     ApprovalContractEventArgs, | ||||
|     TokenEvents, | ||||
|     TransferContractEventArgs, | ||||
| } from '../contract_wrappers/generated/token'; | ||||
| import { TokenWrapper } from '../contract_wrappers/token_wrapper'; | ||||
| import { BalanceAndProxyAllowanceLazyStore } from '../stores/balance_proxy_allowance_lazy_store'; | ||||
| import { OrderFilledCancelledLazyStore } from '../stores/order_filled_cancelled_lazy_store'; | ||||
| import { | ||||
|     ApprovalContractEventArgs, | ||||
|     BlockParamLiteral, | ||||
|     ContractEventArgs, | ||||
|     DepositContractEventArgs, | ||||
|     EtherTokenEvents, | ||||
|     ExchangeContractErrs, | ||||
|     ExchangeEvents, | ||||
|     LogCancelContractEventArgs, | ||||
|     LogEvent, | ||||
|     LogFillContractEventArgs, | ||||
|     OnOrderStateChangeCallback, | ||||
|     OrderState, | ||||
|     OrderStateWatcherConfig, | ||||
|     SignedOrder, | ||||
|     TokenEvents, | ||||
|     TransferContractEventArgs, | ||||
|     WithdrawalContractEventArgs, | ||||
|     ZeroExError, | ||||
| } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { TokenWrapper } from '../contract_wrappers/token_wrapper'; | ||||
| import { BlockParamLiteral } from '../types'; | ||||
|  | ||||
| /** | ||||
|  * Copy on read store for balances/proxyAllowances of tokens/accounts | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
| import { BlockParamLiteral } from '../types'; | ||||
|  | ||||
| /** | ||||
|  * Copy on read store for filled/cancelled taker amounts | ||||
|   | ||||
| @@ -1,7 +1,13 @@ | ||||
| import { ContractEventArg, LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { BlockParam, BlockParamLiteral, ContractEventArg, LogWithDecodedArgs } from '@0xproject/types'; | ||||
|  | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { EtherTokenContractEventArgs, EtherTokenEvents } from './contract_wrappers/generated/ether_token'; | ||||
| import { ExchangeContractEventArgs, ExchangeEvents } from './contract_wrappers/generated/exchange'; | ||||
| import { TokenContractEventArgs, TokenEvents } from './contract_wrappers/generated/token'; | ||||
|  | ||||
| export enum ZeroExError { | ||||
|     ExchangeContractDoesNotExist = 'EXCHANGE_CONTRACT_DOES_NOT_EXIST', | ||||
|     ZRXContractDoesNotExist = 'ZRX_CONTRACT_DOES_NOT_EXIST', | ||||
| @@ -99,60 +105,6 @@ export interface ContractEvent { | ||||
|     args: ContractEventArgs; | ||||
| } | ||||
|  | ||||
| export interface LogFillContractEventArgs { | ||||
|     maker: string; | ||||
|     taker: string; | ||||
|     feeRecipient: string; | ||||
|     makerToken: string; | ||||
|     takerToken: string; | ||||
|     filledMakerTokenAmount: BigNumber; | ||||
|     filledTakerTokenAmount: BigNumber; | ||||
|     paidMakerFee: BigNumber; | ||||
|     paidTakerFee: BigNumber; | ||||
|     tokens: string; | ||||
|     orderHash: string; | ||||
| } | ||||
| export interface LogCancelContractEventArgs { | ||||
|     maker: string; | ||||
|     feeRecipient: string; | ||||
|     makerToken: string; | ||||
|     takerToken: string; | ||||
|     cancelledMakerTokenAmount: BigNumber; | ||||
|     cancelledTakerTokenAmount: BigNumber; | ||||
|     tokens: string; | ||||
|     orderHash: string; | ||||
| } | ||||
| export interface LogErrorContractEventArgs { | ||||
|     errorId: BigNumber; | ||||
|     orderHash: string; | ||||
| } | ||||
| export type ExchangeContractEventArgs = | ||||
|     | LogFillContractEventArgs | ||||
|     | LogCancelContractEventArgs | ||||
|     | LogErrorContractEventArgs; | ||||
| export interface TransferContractEventArgs { | ||||
|     _from: string; | ||||
|     _to: string; | ||||
|     _value: BigNumber; | ||||
| } | ||||
| export interface ApprovalContractEventArgs { | ||||
|     _owner: string; | ||||
|     _spender: string; | ||||
|     _value: BigNumber; | ||||
| } | ||||
| export interface DepositContractEventArgs { | ||||
|     _owner: string; | ||||
|     _value: BigNumber; | ||||
| } | ||||
| export interface WithdrawalContractEventArgs { | ||||
|     _owner: string; | ||||
|     _value: BigNumber; | ||||
| } | ||||
| export type TokenContractEventArgs = TransferContractEventArgs | ApprovalContractEventArgs; | ||||
| export type EtherTokenContractEventArgs = | ||||
|     | TokenContractEventArgs | ||||
|     | DepositContractEventArgs | ||||
|     | WithdrawalContractEventArgs; | ||||
| export type ContractEventArgs = ExchangeContractEventArgs | TokenContractEventArgs | EtherTokenContractEventArgs; | ||||
|  | ||||
| export interface Order { | ||||
| @@ -195,40 +147,12 @@ export interface TokenAddressBySymbol { | ||||
|     [symbol: string]: string; | ||||
| } | ||||
|  | ||||
| export enum ExchangeEvents { | ||||
|     LogFill = 'LogFill', | ||||
|     LogCancel = 'LogCancel', | ||||
|     LogError = 'LogError', | ||||
| } | ||||
|  | ||||
| export enum TokenEvents { | ||||
|     Transfer = 'Transfer', | ||||
|     Approval = 'Approval', | ||||
| } | ||||
|  | ||||
| export enum EtherTokenEvents { | ||||
|     Transfer = 'Transfer', | ||||
|     Approval = 'Approval', | ||||
|     Deposit = 'Deposit', | ||||
|     Withdrawal = 'Withdrawal', | ||||
| } | ||||
|  | ||||
| export type ContractEvents = TokenEvents | ExchangeEvents | EtherTokenEvents; | ||||
|  | ||||
| export interface IndexedFilterValues { | ||||
|     [index: string]: ContractEventArg; | ||||
| } | ||||
|  | ||||
| // Earliest is omitted by design. It is simply an alias for the `0` constant and | ||||
| // is thus not very helpful. Moreover, this type is used in places that only accept | ||||
| // `latest` or `pending`. | ||||
| export enum BlockParamLiteral { | ||||
|     Latest = 'latest', | ||||
|     Pending = 'pending', | ||||
| } | ||||
|  | ||||
| export type BlockParam = BlockParamLiteral | number; | ||||
|  | ||||
| export interface BlockRange { | ||||
|     fromBlock: BlockParam; | ||||
|     toBlock: BlockParam; | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { TokenWrapper } from '../contract_wrappers/token_wrapper'; | ||||
| import { BalanceAndProxyAllowanceLazyStore } from '../stores/balance_proxy_allowance_lazy_store'; | ||||
| import { BlockParamLiteral, ExchangeContractErrs, TradeSide, TransferType } from '../types'; | ||||
| import { ExchangeContractErrs, TradeSide, TransferType } from '../types'; | ||||
|  | ||||
| enum FailureReason { | ||||
|     Balance = 'balance', | ||||
|   | ||||
| @@ -17,7 +17,6 @@ import { | ||||
|     ZeroEx, | ||||
|     ZeroExError, | ||||
| } from '../src'; | ||||
| import { artifacts } from '../src/artifacts'; | ||||
| import { DoneCallback } from '../src/types'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| @@ -60,7 +59,7 @@ describe('EtherTokenWrapper', () => { | ||||
|         tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         addressWithETH = userAddresses[0]; | ||||
|         wethContractAddress = (zeroEx.etherToken as any)._getContractAddress(artifacts.EtherTokenArtifact); | ||||
|         wethContractAddress = zeroEx.etherToken.getContractAddressIfExists() as string; | ||||
|         depositWeiAmount = (zeroEx as any)._web3Wrapper.toWei(new BigNumber(5)); | ||||
|         decimalPlaces = 7; | ||||
|         addressWithoutFunds = userAddresses[1]; | ||||
| @@ -71,6 +70,18 @@ describe('EtherTokenWrapper', () => { | ||||
|     afterEach(async () => { | ||||
|         await blockchainLifecycle.revertAsync(); | ||||
|     }); | ||||
|     describe('#getContractAddressIfExists', async () => { | ||||
|         it('should return contract address if connected to a known network', () => { | ||||
|             const contractAddressIfExists = zeroEx.etherToken.getContractAddressIfExists(); | ||||
|             expect(contractAddressIfExists).to.not.be.undefined(); | ||||
|         }); | ||||
|         it('should return undefined if connected to an unknown network', () => { | ||||
|             const UNKNOWN_NETWORK_NETWORK_ID = 10; | ||||
|             const unknownNetworkZeroEx = new ZeroEx(web3.currentProvider, { networkId: UNKNOWN_NETWORK_NETWORK_ID }); | ||||
|             const contractAddressIfExists = unknownNetworkZeroEx.etherToken.getContractAddressIfExists(); | ||||
|             expect(contractAddressIfExists).to.be.undefined(); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#depositAsync', () => { | ||||
|         it('should successfully deposit ETH and issue Wrapped ETH tokens', async () => { | ||||
|             const preETHBalance = await (zeroEx as any)._web3Wrapper.getBalanceInWeiAsync(addressWithETH); | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
|  | ||||
| import { ExchangeContractErrs, Token, ZeroEx } from '../src'; | ||||
| import { BlockParamLiteral, TradeSide, TransferType } from '../src/types'; | ||||
| import { TradeSide, TransferType } from '../src/types'; | ||||
| import { ExchangeTransferSimulator } from '../src/utils/exchange_transfer_simulator'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| @@ -18,7 +19,7 @@ import { | ||||
|     Token, | ||||
|     ZeroEx, | ||||
| } from '../src'; | ||||
| import { BlockParamLiteral, DoneCallback } from '../src/types'; | ||||
| import { DoneCallback } from '../src/types'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
|   | ||||
| @@ -1,11 +1,12 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as Sinon from 'sinon'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { ExchangeContractErrs, SignedOrder, Token, ZeroEx, ZeroExError } from '../src'; | ||||
| import { BlockParamLiteral, TradeSide, TransferType } from '../src/types'; | ||||
| import { TradeSide, TransferType } from '../src/types'; | ||||
| import { ExchangeTransferSimulator } from '../src/utils/exchange_transfer_simulator'; | ||||
| import { OrderValidationUtils } from '../src/utils/order_validation_utils'; | ||||
|  | ||||
|   | ||||
							
								
								
									
										5
									
								
								packages/abi-gen/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								packages/abi-gen/.npmignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| .* | ||||
| yarn-error.log | ||||
| /src/ | ||||
| /scripts/ | ||||
| tsconfig.json | ||||
| @@ -1,11 +1,16 @@ | ||||
| # CHANGELOG | ||||
|  | ||||
| ## v0.2.0 - _???_ | ||||
| ## v0.2.1 - _February 9, 2018_ | ||||
|  | ||||
| * Added CLI options for explicit specifying location of partials and main template (#346) | ||||
|     * Fix publishing issue where .npmignore was not properly excluding undesired content (#389) | ||||
|  | ||||
| ## v0.2.0 - _February 7, 2018_ | ||||
|  | ||||
|     * Added CLI options for explicit specifying location of partials and main template (#346) | ||||
|     * Added CLI option to specify networkId, adding support for the JSON artifact format found in @0xproject/contracts (#388) | ||||
|  | ||||
| ## v0.1.0 - _January 11, 2018_ | ||||
|  | ||||
| * Fixed array typings with union types (#295) | ||||
| * Add event ABIs to context data passed to templates (#302) | ||||
| * Add constructor ABIs to context data passed to templates (#304) | ||||
|     * Fixed array typings with union types (#295) | ||||
|     * Add event ABIs to context data passed to templates (#302) | ||||
|     * Add constructor ABIs to context data passed to templates (#304) | ||||
|   | ||||
| @@ -1,10 +1,11 @@ | ||||
| { | ||||
|     "name": "@0xproject/abi-gen", | ||||
|     "version": "0.1.6", | ||||
|     "version": "0.2.2", | ||||
|     "description": "Generate contract wrappers from ABI and handlebars templates", | ||||
|     "main": "lib/index.js", | ||||
|     "types": "lib/index.d.ts", | ||||
|     "scripts": { | ||||
|         "build:watch": "tsc -w", | ||||
|         "lint": "tslint --project . 'src/**/*.ts'", | ||||
|         "clean": "shx rm -rf lib", | ||||
|         "build": "tsc" | ||||
| @@ -22,7 +23,7 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x.js/packages/abi-gen/README.md", | ||||
|     "dependencies": { | ||||
|         "@0xproject/utils": "^0.2.4", | ||||
|         "@0xproject/utils": "^0.3.3", | ||||
|         "chalk": "^2.3.0", | ||||
|         "glob": "^7.1.2", | ||||
|         "handlebars": "^4.0.11", | ||||
| @@ -33,7 +34,7 @@ | ||||
|         "yargs": "^10.0.3" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/tslint-config": "^0.4.6", | ||||
|         "@0xproject/tslint-config": "^0.4.9", | ||||
|         "@types/glob": "^5.0.33", | ||||
|         "@types/handlebars": "^4.0.36", | ||||
|         "@types/mkdirp": "^0.5.1", | ||||
| @@ -42,7 +43,7 @@ | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "typescript": "~2.6.1", | ||||
|         "web3-typescript-typings": "^0.9.8" | ||||
|         "typescript": "2.7.1", | ||||
|         "web3-typescript-typings": "^0.9.10" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,14 +2,4 @@ const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const packageJSON = require('../package.json'); | ||||
|  | ||||
| const subPackageName = packageJSON.name; | ||||
|  | ||||
| postpublish_utils | ||||
|     .getLatestTagAndVersionAsync(subPackageName) | ||||
|     .then(function(result) { | ||||
|         const releaseName = postpublish_utils.getReleaseName(subPackageName, result.version); | ||||
|         const assets = []; | ||||
|         return postpublish_utils.publishReleaseNotes(result.tag, releaseName, assets); | ||||
|     }) | ||||
|     .catch(function(err) { | ||||
|         throw err; | ||||
|     }); | ||||
| postpublish_utils.standardPostPublishAsync(subPackageName); | ||||
| @@ -17,6 +17,7 @@ import { utils } from './utils'; | ||||
| const ABI_TYPE_CONSTRUCTOR = 'constructor'; | ||||
| const ABI_TYPE_METHOD = 'function'; | ||||
| const ABI_TYPE_EVENT = 'event'; | ||||
| const DEFAULT_NETWORK_ID = 50; | ||||
|  | ||||
| const args = yargs | ||||
|     .option('abis', { | ||||
| @@ -42,6 +43,11 @@ const args = yargs | ||||
|         demandOption: true, | ||||
|         normalize: true, | ||||
|     }) | ||||
|     .option('network-id', { | ||||
|         describe: 'ID of the network where contract ABIs are nested in artifacts', | ||||
|         type: 'number', | ||||
|         default: DEFAULT_NETWORK_ID, | ||||
|     }) | ||||
|     .example( | ||||
|         "$0 --abis 'src/artifacts/**/*.json' --out 'src/contracts/generated/' --partials 'src/templates/partials/**/*.handlebars' --template 'src/templates/contract.handlebars'", | ||||
|         'Full usage example', | ||||
| @@ -58,7 +64,10 @@ function registerPartials(partialsGlob: string) { | ||||
| } | ||||
|  | ||||
| function writeOutputFile(name: string, renderedTsCode: string): void { | ||||
|     const fileName = toSnakeCase(name); | ||||
|     let fileName = toSnakeCase(name); | ||||
|     if (fileName === 'z_r_x_token') { | ||||
|         fileName = 'zrx_token'; | ||||
|     } | ||||
|     const filePath = `${args.output}/${fileName}.ts`; | ||||
|     fs.writeFileSync(filePath, renderedTsCode); | ||||
|     utils.log(`Created: ${chalk.bold(filePath)}`); | ||||
| @@ -87,12 +96,19 @@ for (const abiFileName of abiFileNames) { | ||||
|     const namedContent = utils.getNamedContent(abiFileName); | ||||
|     utils.log(`Processing: ${chalk.bold(namedContent.name)}...`); | ||||
|     const parsedContent = JSON.parse(namedContent.content); | ||||
|     const ABI = _.isArray(parsedContent) | ||||
|         ? parsedContent // ABI file | ||||
|         : parsedContent.abi; // Truffle contracts file | ||||
|     let ABI; | ||||
|     if (_.isArray(parsedContent)) { | ||||
|         ABI = parsedContent; // ABI file | ||||
|     } else if (!_.isUndefined(parsedContent.abi)) { | ||||
|         ABI = parsedContent.abi; // Truffle artifact | ||||
|     } else if (!_.isUndefined(parsedContent.networks) && !_.isUndefined(parsedContent.networks[args.networkId])) { | ||||
|         ABI = parsedContent.networks[args.networkId].abi; // 0x contracts package artifact | ||||
|     } | ||||
|     if (_.isUndefined(ABI)) { | ||||
|         utils.log(`${chalk.red(`ABI not found in ${abiFileName}.`)}`); | ||||
|         utils.log(`Please make sure your ABI file is either an array with ABI entries or an object with the abi key`); | ||||
|         utils.log( | ||||
|             `Please make sure your ABI file is either an array with ABI entries or a truffle artifact or 0x deployer artifact`, | ||||
|         ); | ||||
|         process.exit(1); | ||||
|     } | ||||
|  | ||||
| @@ -103,10 +119,10 @@ for (const abiFileName of abiFileNames) { | ||||
|  | ||||
|     const methodAbis = ABI.filter((abi: Web3.AbiDefinition) => abi.type === ABI_TYPE_METHOD) as Web3.MethodAbi[]; | ||||
|     const methodsData = _.map(methodAbis, methodAbi => { | ||||
|         _.map(methodAbi.inputs, input => { | ||||
|         _.map(methodAbi.inputs, (input, i: number) => { | ||||
|             if (_.isEmpty(input.name)) { | ||||
|                 // Auto-generated getters don't have parameter names | ||||
|                 input.name = 'index'; | ||||
|                 input.name = `index_${i}`; | ||||
|             } | ||||
|         }); | ||||
|         // This will make templates simpler | ||||
|   | ||||
							
								
								
									
										6
									
								
								packages/assert/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								packages/assert/.npmignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| .* | ||||
| yarn-error.log | ||||
| /src/ | ||||
| /scripts/ | ||||
| test/ | ||||
| tsconfig.json | ||||
| @@ -1,6 +1,10 @@ | ||||
| # CHANGELOG | ||||
|  | ||||
| ## v0.0.4 - _Nov. 14, 2017_ | ||||
| ## v0.0.18 - _February 9, 2017_ | ||||
|  | ||||
|     * Fix publishing issue where .npmignore was not properly excluding undesired content (#389) | ||||
|  | ||||
| ## v0.0.4 - _November 14, 2017_ | ||||
|  | ||||
|     * Re-publish Assert previously published under NPM package @0xproject/0x-assert | ||||
|     * Added assertion isValidBaseUnitAmount which checks both that the value is a valid bigNumber and that it does not contain decimals. | ||||
|   | ||||
| @@ -1,10 +1,11 @@ | ||||
| { | ||||
|     "name": "@0xproject/assert", | ||||
|     "version": "0.0.15", | ||||
|     "version": "0.0.19", | ||||
|     "description": "Provides a standard way of performing type and schema validation across 0x projects", | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "build:watch": "tsc -w", | ||||
|         "build": "tsc", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp", | ||||
|         "lint": "tslint --project . 'src/**/*.ts' 'test/**/*.ts'", | ||||
| @@ -23,22 +24,22 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x.js/packages/assert/README.md", | ||||
|     "devDependencies": { | ||||
|         "@0xproject/tslint-config": "^0.4.6", | ||||
|         "@0xproject/tslint-config": "^0.4.9", | ||||
|         "@types/lodash": "^4.14.86", | ||||
|         "@types/mocha": "^2.2.42", | ||||
|         "@types/valid-url": "^1.0.2", | ||||
|         "chai": "^4.0.1", | ||||
|         "chai-typescript-typings": "^0.0.2", | ||||
|         "chai-typescript-typings": "^0.0.3", | ||||
|         "dirty-chai": "^2.0.1", | ||||
|         "mocha": "^4.0.1", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "typescript": "~2.6.1" | ||||
|         "typescript": "2.7.1" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0xproject/json-schemas": "^0.7.7", | ||||
|         "@0xproject/utils": "^0.2.4", | ||||
|         "@0xproject/json-schemas": "^0.7.11", | ||||
|         "@0xproject/utils": "^0.3.3", | ||||
|         "lodash": "^4.17.4", | ||||
|         "valid-url": "^1.0.9" | ||||
|     } | ||||
|   | ||||
| @@ -2,14 +2,4 @@ const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const packageJSON = require('../package.json'); | ||||
|  | ||||
| const subPackageName = packageJSON.name; | ||||
|  | ||||
| postpublish_utils | ||||
|     .getLatestTagAndVersionAsync(subPackageName) | ||||
|     .then(function(result) { | ||||
|         const releaseName = postpublish_utils.getReleaseName(subPackageName, result.version); | ||||
|         const assets = []; | ||||
|         return postpublish_utils.publishReleaseNotes(result.tag, releaseName, assets); | ||||
|     }) | ||||
|     .catch(function(err) { | ||||
|         throw err; | ||||
|     }); | ||||
| postpublish_utils.standardPostPublishAsync(subPackageName); | ||||
							
								
								
									
										3
									
								
								packages/chai-as-promised-typescript-typings/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								packages/chai-as-promised-typescript-typings/.npmignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| .* | ||||
| yarn-error.log | ||||
| /scripts/ | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "chai-as-promised-typescript-typings", | ||||
|     "version": "0.0.8", | ||||
|     "version": "0.0.9", | ||||
|     "description": "Typescript type definitions for chai-as-promised", | ||||
|     "main": "index.d.ts", | ||||
|     "types": "index.d.ts", | ||||
| @@ -18,6 +18,6 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x.js/packages/chai-as-promised-typescript-typings#readme", | ||||
|     "dependencies": { | ||||
|         "chai-typescript-typings": "^0.0.2" | ||||
|         "chai-typescript-typings": "^0.0.3" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,14 +2,4 @@ const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const packageJSON = require('../package.json'); | ||||
|  | ||||
| const subPackageName = packageJSON.name; | ||||
|  | ||||
| postpublish_utils | ||||
|     .getLatestTagAndVersionAsync(subPackageName) | ||||
|     .then(function(result) { | ||||
|         const releaseName = postpublish_utils.getReleaseName(subPackageName, result.version); | ||||
|         const assets = []; | ||||
|         return postpublish_utils.publishReleaseNotes(result.tag, releaseName, assets); | ||||
|     }) | ||||
|     .catch(function(err) { | ||||
|         throw err; | ||||
|     }); | ||||
| postpublish_utils.standardPostPublishAsync(subPackageName); | ||||
							
								
								
									
										3
									
								
								packages/chai-typescript-typings/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								packages/chai-typescript-typings/.npmignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| .* | ||||
| yarn-error.log | ||||
| /scripts/ | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "chai-typescript-typings", | ||||
|     "version": "0.0.2", | ||||
|     "version": "0.0.3", | ||||
|     "description": "Typescript type definitions for chai", | ||||
|     "main": "index.d.ts", | ||||
|     "types": "index.d.ts", | ||||
|   | ||||
| @@ -2,14 +2,4 @@ const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const packageJSON = require('../package.json'); | ||||
|  | ||||
| const subPackageName = packageJSON.name; | ||||
|  | ||||
| postpublish_utils | ||||
|     .getLatestTagAndVersionAsync(subPackageName) | ||||
|     .then(function(result) { | ||||
|         const releaseName = postpublish_utils.getReleaseName(subPackageName, result.version); | ||||
|         const assets = []; | ||||
|         return postpublish_utils.publishReleaseNotes(result.tag, releaseName, assets); | ||||
|     }) | ||||
|     .catch(function(err) { | ||||
|         throw err; | ||||
|     }); | ||||
| postpublish_utils.standardPostPublishAsync(subPackageName); | ||||
							
								
								
									
										7
									
								
								packages/connect/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								packages/connect/.npmignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| .* | ||||
| yarn-error.log | ||||
| /src/ | ||||
| /scripts/ | ||||
| /generated_docs/ | ||||
| test/ | ||||
| tsconfig.json | ||||
| @@ -1,5 +1,14 @@ | ||||
| # CHANGELOG | ||||
|  | ||||
| ## v0.6.0 - _February 16, 2018_ | ||||
|  | ||||
|     * Add pagination options to HttpClient methods (#393) | ||||
|     * Add heartbeat configuration to WebSocketOrderbookChannel constructor (#406) | ||||
|  | ||||
| ## v0.5.7 - _February 9, 2018_ | ||||
|  | ||||
|     * Fix publishing issue where .npmignore was not properly excluding undesired content (#389) | ||||
|  | ||||
| ## v0.5.0 - _January 17, 2018_ | ||||
|  | ||||
|     * Sanitize api endpoint url and remove trailing slashes (#318) | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0xproject/connect", | ||||
|     "version": "0.5.4", | ||||
|     "version": "0.5.8", | ||||
|     "description": "A javascript library for interacting with the standard relayer api", | ||||
|     "keywords": [ | ||||
|         "connect", | ||||
| @@ -12,6 +12,7 @@ | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "build:watch": "tsc -w", | ||||
|         "build": "tsc", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp", | ||||
|         "docs:json": "typedoc --excludePrivate --excludeExternals --target ES5 --json $JSON_FILE_PATH $PROJECT_DIR", | ||||
| @@ -36,16 +37,16 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x.js/packages/connect/README.md", | ||||
|     "dependencies": { | ||||
|         "@0xproject/assert": "^0.0.15", | ||||
|         "@0xproject/json-schemas": "^0.7.7", | ||||
|         "@0xproject/utils": "^0.2.4", | ||||
|         "@0xproject/assert": "^0.0.19", | ||||
|         "@0xproject/json-schemas": "^0.7.11", | ||||
|         "@0xproject/utils": "^0.3.3", | ||||
|         "isomorphic-fetch": "^2.2.1", | ||||
|         "lodash": "^4.17.4", | ||||
|         "query-string": "^5.0.1", | ||||
|         "websocket": "^1.0.25" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/tslint-config": "^0.4.6", | ||||
|         "@0xproject/tslint-config": "^0.4.9", | ||||
|         "@types/fetch-mock": "^5.12.1", | ||||
|         "@types/lodash": "^4.14.86", | ||||
|         "@types/mocha": "^2.2.42", | ||||
| @@ -53,8 +54,8 @@ | ||||
|         "@types/websocket": "^0.0.34", | ||||
|         "chai": "^4.0.1", | ||||
|         "chai-as-promised": "^7.1.0", | ||||
|         "chai-as-promised-typescript-typings": "^0.0.8", | ||||
|         "chai-typescript-typings": "^0.0.2", | ||||
|         "chai-as-promised-typescript-typings": "^0.0.9", | ||||
|         "chai-typescript-typings": "^0.0.3", | ||||
|         "copyfiles": "^1.2.0", | ||||
|         "dirty-chai": "^2.0.1", | ||||
|         "fetch-mock": "^5.13.1", | ||||
| @@ -63,7 +64,7 @@ | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "typedoc": "~0.8.0", | ||||
|         "typescript": "~2.6.1", | ||||
|         "web3-typescript-typings": "^0.9.8" | ||||
|         "typescript": "2.7.1", | ||||
|         "web3-typescript-typings": "^0.9.10" | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										24
									
								
								packages/connect/scripts/stagedocs.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								packages/connect/scripts/stagedocs.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| const execAsync = require('async-child-process').execAsync; | ||||
| const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
|  | ||||
| const cwd = __dirname + '/..'; | ||||
| const S3BucketPath = 's3://staging-connect-docs-jsons/'; | ||||
| const jsonFilePath = __dirname + '/../' + postpublish_utils.generatedDocsDirectoryName + '/index.json'; | ||||
| const version = process.env.DOCS_VERSION; | ||||
|  | ||||
| execAsync('JSON_FILE_PATH=' + jsonFilePath + ' PROJECT_DIR=' + __dirname + '/.. yarn docs:json', { | ||||
|     cwd, | ||||
| }) | ||||
| .then(function(result) { | ||||
|     if (result.stderr !== '') { | ||||
|         throw new Error(result.stderr); | ||||
|     } | ||||
|     const fileName = 'v' + version + '.json'; | ||||
|     const s3Url = S3BucketPath + fileName; | ||||
|     return execAsync('S3_URL=' + s3Url + ' yarn upload_docs_json', { | ||||
|         cwd, | ||||
|     }); | ||||
| }) | ||||
| .catch(function(err) { | ||||
|     console.log(err); | ||||
| }); | ||||
| @@ -13,20 +13,48 @@ import { | ||||
|     HttpRequestType, | ||||
|     OrderbookRequest, | ||||
|     OrderbookResponse, | ||||
|     OrdersRequest, | ||||
|     OrdersRequestOpts, | ||||
|     PagedRequestOpts, | ||||
|     SignedOrder, | ||||
|     TokenPairsItem, | ||||
|     TokenPairsRequest, | ||||
|     TokenPairsRequestOpts, | ||||
| } from './types'; | ||||
| import { relayerResponseJsonParsers } from './utils/relayer_response_json_parsers'; | ||||
|  | ||||
| const TRAILING_SLASHES_REGEX = /\/+$/; | ||||
| const DEFAULT_PAGED_REQUEST_OPTS: PagedRequestOpts = { | ||||
|     page: 1, | ||||
|     perPage: 100, | ||||
| }; | ||||
| /** | ||||
|  * This mapping defines how an option property name gets converted into an HTTP request query field | ||||
|  */ | ||||
| const OPTS_TO_QUERY_FIELD_MAP = { | ||||
|     perPage: 'per_page', | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * This class includes all the functionality related to interacting with a set of HTTP endpoints | ||||
|  * that implement the standard relayer API v0 | ||||
|  */ | ||||
| export class HttpClient implements Client { | ||||
|     private _apiEndpointUrl: string; | ||||
|     /** | ||||
|      * Format parameters to be appended to http requests into query string form | ||||
|      */ | ||||
|     private static _buildQueryStringFromHttpParams(params?: object): string { | ||||
|         // if params are undefined or empty, return an empty string | ||||
|         if (_.isUndefined(params) || _.isEmpty(params)) { | ||||
|             return ''; | ||||
|         } | ||||
|         // format params into a form the api expects | ||||
|         const formattedParams = _.mapKeys(params, (value: any, key: string) => { | ||||
|             return _.get(OPTS_TO_QUERY_FIELD_MAP, key, key); | ||||
|         }); | ||||
|         // stringify the formatted object | ||||
|         const stringifiedParams = queryString.stringify(formattedParams); | ||||
|         return `?${stringifiedParams}`; | ||||
|     } | ||||
|     /** | ||||
|      * Instantiates a new HttpClient instance | ||||
|      * @param   url    The relayer API base HTTP url you would like to interact with | ||||
| @@ -38,34 +66,35 @@ export class HttpClient implements Client { | ||||
|     } | ||||
|     /** | ||||
|      * Retrieve token pair info from the API | ||||
|      * @param   request     A TokenPairsRequest instance describing specific token information | ||||
|      *                      to retrieve | ||||
|      * @param   requestOpts     Options specifying token information to retrieve and page information, defaults to { page: 1, perPage: 100 } | ||||
|      * @return  The resulting TokenPairsItems that match the request | ||||
|      */ | ||||
|     public async getTokenPairsAsync(request?: TokenPairsRequest): Promise<TokenPairsItem[]> { | ||||
|         if (!_.isUndefined(request)) { | ||||
|             assert.doesConformToSchema('request', request, clientSchemas.relayerTokenPairsRequestSchema); | ||||
|     public async getTokenPairsAsync(requestOpts?: TokenPairsRequestOpts & PagedRequestOpts): Promise<TokenPairsItem[]> { | ||||
|         if (!_.isUndefined(requestOpts)) { | ||||
|             assert.doesConformToSchema('requestOpts', requestOpts, clientSchemas.tokenPairsRequestOptsSchema); | ||||
|             assert.doesConformToSchema('requestOpts', requestOpts, clientSchemas.pagedRequestOptsSchema); | ||||
|         } | ||||
|         const requestOpts = { | ||||
|             params: request, | ||||
|         const httpRequestOpts = { | ||||
|             params: _.defaults({}, requestOpts, DEFAULT_PAGED_REQUEST_OPTS), | ||||
|         }; | ||||
|         const responseJson = await this._requestAsync('/token_pairs', HttpRequestType.Get, requestOpts); | ||||
|         const responseJson = await this._requestAsync('/token_pairs', HttpRequestType.Get, httpRequestOpts); | ||||
|         const tokenPairs = relayerResponseJsonParsers.parseTokenPairsJson(responseJson); | ||||
|         return tokenPairs; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieve orders from the API | ||||
|      * @param   request     An OrdersRequest instance describing specific orders to retrieve | ||||
|      * @param   requestOpts     Options specifying orders to retrieve and page information, defaults to { page: 1, perPage: 100 } | ||||
|      * @return  The resulting SignedOrders that match the request | ||||
|      */ | ||||
|     public async getOrdersAsync(request?: OrdersRequest): Promise<SignedOrder[]> { | ||||
|         if (!_.isUndefined(request)) { | ||||
|             assert.doesConformToSchema('request', request, clientSchemas.relayerOrdersRequestSchema); | ||||
|     public async getOrdersAsync(requestOpts?: OrdersRequestOpts & PagedRequestOpts): Promise<SignedOrder[]> { | ||||
|         if (!_.isUndefined(requestOpts)) { | ||||
|             assert.doesConformToSchema('requestOpts', requestOpts, clientSchemas.ordersRequestOptsSchema); | ||||
|             assert.doesConformToSchema('requestOpts', requestOpts, clientSchemas.pagedRequestOptsSchema); | ||||
|         } | ||||
|         const requestOpts = { | ||||
|             params: request, | ||||
|         const httpRequestOpts = { | ||||
|             params: _.defaults({}, requestOpts, DEFAULT_PAGED_REQUEST_OPTS), | ||||
|         }; | ||||
|         const responseJson = await this._requestAsync(`/orders`, HttpRequestType.Get, requestOpts); | ||||
|         const responseJson = await this._requestAsync(`/orders`, HttpRequestType.Get, httpRequestOpts); | ||||
|         const orders = relayerResponseJsonParsers.parseOrdersJson(responseJson); | ||||
|         return orders; | ||||
|     } | ||||
| @@ -82,15 +111,22 @@ export class HttpClient implements Client { | ||||
|     } | ||||
|     /** | ||||
|      * Retrieve an orderbook from the API | ||||
|      * @param   request     An OrderbookRequest instance describing the specific orderbook to retrieve | ||||
|      * @param   request         An OrderbookRequest instance describing the specific orderbook to retrieve | ||||
|      * @param   requestOpts     Options specifying page information, defaults to { page: 1, perPage: 100 } | ||||
|      * @return  The resulting OrderbookResponse that matches the request | ||||
|      */ | ||||
|     public async getOrderbookAsync(request: OrderbookRequest): Promise<OrderbookResponse> { | ||||
|         assert.doesConformToSchema('request', request, clientSchemas.relayerOrderBookRequestSchema); | ||||
|         const requestOpts = { | ||||
|             params: request, | ||||
|     public async getOrderbookAsync( | ||||
|         request: OrderbookRequest, | ||||
|         requestOpts?: PagedRequestOpts, | ||||
|     ): Promise<OrderbookResponse> { | ||||
|         assert.doesConformToSchema('request', request, clientSchemas.orderBookRequestSchema); | ||||
|         if (!_.isUndefined(requestOpts)) { | ||||
|             assert.doesConformToSchema('requestOpts', requestOpts, clientSchemas.pagedRequestOptsSchema); | ||||
|         } | ||||
|         const httpRequestOpts = { | ||||
|             params: _.defaults({}, request, requestOpts, DEFAULT_PAGED_REQUEST_OPTS), | ||||
|         }; | ||||
|         const responseJson = await this._requestAsync('/orderbook', HttpRequestType.Get, requestOpts); | ||||
|         const responseJson = await this._requestAsync('/orderbook', HttpRequestType.Get, httpRequestOpts); | ||||
|         const orderbook = relayerResponseJsonParsers.parseOrderbookResponseJson(responseJson); | ||||
|         return orderbook; | ||||
|     } | ||||
| @@ -100,11 +136,11 @@ export class HttpClient implements Client { | ||||
|      * @return  The resulting FeesResponse that matches the request | ||||
|      */ | ||||
|     public async getFeesAsync(request: FeesRequest): Promise<FeesResponse> { | ||||
|         assert.doesConformToSchema('request', request, schemas.relayerApiFeesPayloadSchema); | ||||
|         const requestOpts = { | ||||
|         assert.doesConformToSchema('request', request, clientSchemas.feesRequestSchema); | ||||
|         const httpRequestOpts = { | ||||
|             payload: request, | ||||
|         }; | ||||
|         const responseJson = await this._requestAsync('/fees', HttpRequestType.Post, requestOpts); | ||||
|         const responseJson = await this._requestAsync('/fees', HttpRequestType.Post, httpRequestOpts); | ||||
|         const fees = relayerResponseJsonParsers.parseFeesResponseJson(responseJson); | ||||
|         return fees; | ||||
|     } | ||||
| @@ -126,11 +162,7 @@ export class HttpClient implements Client { | ||||
|     ): Promise<any> { | ||||
|         const params = _.get(requestOptions, 'params'); | ||||
|         const payload = _.get(requestOptions, 'payload'); | ||||
|         let query = ''; | ||||
|         if (!_.isUndefined(params) && !_.isEmpty(params)) { | ||||
|             const stringifiedParams = queryString.stringify(params); | ||||
|             query = `?${stringifiedParams}`; | ||||
|         } | ||||
|         const query = HttpClient._buildQueryStringFromHttpParams(params); | ||||
|         const url = `${this._apiEndpointUrl}${path}${query}`; | ||||
|         const headers = new Headers({ | ||||
|             'content-type': 'application/json', | ||||
|   | ||||
| @@ -11,9 +11,11 @@ export { | ||||
|     OrderbookChannelSubscriptionOpts, | ||||
|     OrderbookRequest, | ||||
|     OrderbookResponse, | ||||
|     OrdersRequest, | ||||
|     OrdersRequestOpts, | ||||
|     PagedRequestOpts, | ||||
|     SignedOrder, | ||||
|     TokenPairsItem, | ||||
|     TokenPairsRequest, | ||||
|     TokenPairsRequestOpts, | ||||
|     TokenTradeInfo, | ||||
|     WebSocketOrderbookChannelConfig, | ||||
| } from './types'; | ||||
|   | ||||
							
								
								
									
										26
									
								
								packages/connect/src/schemas/fees_request_schema.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								packages/connect/src/schemas/fees_request_schema.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| export const feesRequestSchema = { | ||||
|     id: '/FeesRequest', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         exchangeContractAddress: { $ref: '/Address' }, | ||||
|         maker: { $ref: '/Address' }, | ||||
|         taker: { $ref: '/Address' }, | ||||
|         makerTokenAddress: { $ref: '/Address' }, | ||||
|         takerTokenAddress: { $ref: '/Address' }, | ||||
|         makerTokenAmount: { $ref: '/Number' }, | ||||
|         takerTokenAmount: { $ref: '/Number' }, | ||||
|         expirationUnixTimestampSec: { $ref: '/Number' }, | ||||
|         salt: { $ref: '/Number' }, | ||||
|     }, | ||||
|     required: [ | ||||
|         'exchangeContractAddress', | ||||
|         'maker', | ||||
|         'taker', | ||||
|         'makerTokenAddress', | ||||
|         'takerTokenAddress', | ||||
|         'makerTokenAmount', | ||||
|         'takerTokenAmount', | ||||
|         'expirationUnixTimestampSec', | ||||
|         'salt', | ||||
|     ], | ||||
| }; | ||||
| @@ -1,8 +1,9 @@ | ||||
| export const relayerOrderBookRequestSchema = { | ||||
|     id: '/RelayerOrderBookRequest', | ||||
| export const orderBookRequestSchema = { | ||||
|     id: '/OrderBookRequest', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         baseTokenAddress: { $ref: '/Address' }, | ||||
|         quoteTokenAddress: { $ref: '/Address' }, | ||||
|     }, | ||||
|     required: ['baseTokenAddress', 'quoteTokenAddress'], | ||||
| }; | ||||
| @@ -1,5 +1,5 @@ | ||||
| export const relayerOrdersRequestSchema = { | ||||
|     id: '/RelayerOrdersRequest', | ||||
| export const ordersRequestOptsSchema = { | ||||
|     id: '/OrdersRequestOpts', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         exchangeContractAddress: { $ref: '/Address' }, | ||||
| @@ -0,0 +1,8 @@ | ||||
| export const pagedRequestOptsSchema = { | ||||
|     id: '/PagedRequestOpts', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         page: { type: 'number' }, | ||||
|         perPage: { type: 'number' }, | ||||
|     }, | ||||
| }; | ||||
| @@ -1,8 +0,0 @@ | ||||
| export const relayerOrderBookRequestSchema = { | ||||
|     id: '/RelayerOrderBookRequest', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         baseTokenAddress: { $ref: '/Address' }, | ||||
|         quoteTokenAddress: { $ref: '/Address' }, | ||||
|     }, | ||||
| }; | ||||
| @@ -1,9 +1,15 @@ | ||||
| import { relayerOrderBookRequestSchema } from './relayer_orderbook_request_schema'; | ||||
| import { relayerOrdersRequestSchema } from './relayer_orders_request_schema'; | ||||
| import { relayerTokenPairsRequestSchema } from './relayer_token_pairs_request_schema'; | ||||
| import { feesRequestSchema } from './fees_request_schema'; | ||||
| import { orderBookRequestSchema } from './orderbook_request_schema'; | ||||
| import { ordersRequestOptsSchema } from './orders_request_opts_schema'; | ||||
| import { pagedRequestOptsSchema } from './paged_request_opts_schema'; | ||||
| import { tokenPairsRequestOptsSchema } from './token_pairs_request_opts_schema'; | ||||
| import { webSocketOrderbookChannelConfigSchema } from './websocket_orderbook_channel_config_schema'; | ||||
|  | ||||
| export const schemas = { | ||||
|     relayerOrderBookRequestSchema, | ||||
|     relayerOrdersRequestSchema, | ||||
|     relayerTokenPairsRequestSchema, | ||||
|     feesRequestSchema, | ||||
|     orderBookRequestSchema, | ||||
|     ordersRequestOptsSchema, | ||||
|     pagedRequestOptsSchema, | ||||
|     tokenPairsRequestOptsSchema, | ||||
|     webSocketOrderbookChannelConfigSchema, | ||||
| }; | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| export const relayerTokenPairsRequestSchema = { | ||||
|     id: '/RelayerTokenPairsRequest', | ||||
| export const tokenPairsRequestOptsSchema = { | ||||
|     id: '/TokenPairsRequestOpts', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         tokenA: { $ref: '/Address' }, | ||||
| @@ -0,0 +1,10 @@ | ||||
| export const webSocketOrderbookChannelConfigSchema = { | ||||
|     id: '/WebSocketOrderbookChannelConfig', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         heartbeatIntervalMs: { | ||||
|             type: 'number', | ||||
|             minimum: 10, | ||||
|         }, | ||||
|     }, | ||||
| }; | ||||
| @@ -30,10 +30,10 @@ export interface ECSignature { | ||||
| } | ||||
|  | ||||
| export interface Client { | ||||
|     getTokenPairsAsync: (request?: TokenPairsRequest) => Promise<TokenPairsItem[]>; | ||||
|     getOrdersAsync: (request?: OrdersRequest) => Promise<SignedOrder[]>; | ||||
|     getTokenPairsAsync: (requestOpts?: TokenPairsRequestOpts & PagedRequestOpts) => Promise<TokenPairsItem[]>; | ||||
|     getOrdersAsync: (requestOpts?: OrdersRequestOpts & PagedRequestOpts) => Promise<SignedOrder[]>; | ||||
|     getOrderAsync: (orderHash: string) => Promise<SignedOrder>; | ||||
|     getOrderbookAsync: (request: OrderbookRequest) => Promise<OrderbookResponse>; | ||||
|     getOrderbookAsync: (request: OrderbookRequest, requestOpts?: PagedRequestOpts) => Promise<OrderbookResponse>; | ||||
|     getFeesAsync: (request: FeesRequest) => Promise<FeesResponse>; | ||||
|     submitOrderAsync: (signedOrder: SignedOrder) => Promise<void>; | ||||
| } | ||||
| @@ -43,6 +43,13 @@ export interface OrderbookChannel { | ||||
|     close: () => void; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * heartbeatInterval: Interval in milliseconds that the orderbook channel should ping the underlying websocket. Default: 15000 | ||||
|  */ | ||||
| export interface WebSocketOrderbookChannelConfig { | ||||
|     heartbeatIntervalMs?: number; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * baseTokenAddress: The address of token designated as the baseToken in the currency pair calculation of price | ||||
|  * quoteTokenAddress: The address of token designated as the quoteToken in the currency pair calculation of price | ||||
| @@ -111,7 +118,7 @@ export enum WebsocketClientEventType { | ||||
|     ConnectFailed = 'connectFailed', | ||||
| } | ||||
|  | ||||
| export interface TokenPairsRequest { | ||||
| export interface TokenPairsRequestOpts { | ||||
|     tokenA?: string; | ||||
|     tokenB?: string; | ||||
| } | ||||
| @@ -128,7 +135,7 @@ export interface TokenTradeInfo { | ||||
|     precision: number; | ||||
| } | ||||
|  | ||||
| export interface OrdersRequest { | ||||
| export interface OrdersRequestOpts { | ||||
|     exchangeContractAddress?: string; | ||||
|     tokenAddress?: string; | ||||
|     makerTokenAddress?: string; | ||||
| @@ -167,6 +174,11 @@ export interface FeesResponse { | ||||
|     takerFee: BigNumber; | ||||
| } | ||||
|  | ||||
| export interface PagedRequestOpts { | ||||
|     page?: number; | ||||
|     perPage?: number; | ||||
| } | ||||
|  | ||||
| export interface HttpRequestOptions { | ||||
|     params?: object; | ||||
|     payload?: object; | ||||
|   | ||||
| @@ -3,6 +3,7 @@ import { schemas } from '@0xproject/json-schemas'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as WebSocket from 'websocket'; | ||||
|  | ||||
| import { schemas as clientSchemas } from './schemas/schemas'; | ||||
| import { | ||||
|     OrderbookChannel, | ||||
|     OrderbookChannelHandler, | ||||
| @@ -10,9 +11,13 @@ import { | ||||
|     OrderbookChannelSubscriptionOpts, | ||||
|     WebsocketClientEventType, | ||||
|     WebsocketConnectionEventType, | ||||
|     WebSocketOrderbookChannelConfig, | ||||
| } from './types'; | ||||
| import { orderbookChannelMessageParser } from './utils/orderbook_channel_message_parser'; | ||||
|  | ||||
| const DEFAULT_HEARTBEAT_INTERVAL_MS = 15000; | ||||
| const MINIMUM_HEARTBEAT_INTERVAL_MS = 10; | ||||
|  | ||||
| /** | ||||
|  * This class includes all the functionality related to interacting with a websocket endpoint | ||||
|  * that implements the standard relayer API v0 | ||||
| @@ -21,15 +26,25 @@ export class WebSocketOrderbookChannel implements OrderbookChannel { | ||||
|     private _apiEndpointUrl: string; | ||||
|     private _client: WebSocket.client; | ||||
|     private _connectionIfExists?: WebSocket.connection; | ||||
|     private _heartbeatTimerIfExists?: NodeJS.Timer; | ||||
|     private _subscriptionCounter = 0; | ||||
|     private _heartbeatIntervalMs: number; | ||||
|     /** | ||||
|      * Instantiates a new WebSocketOrderbookChannel instance | ||||
|      * @param   url                 The relayer API base WS url you would like to interact with | ||||
|      * @param   url                 The configuration object. Look up the type for the description. | ||||
|      * @return  An instance of WebSocketOrderbookChannel | ||||
|      */ | ||||
|     constructor(url: string) { | ||||
|     constructor(url: string, config?: WebSocketOrderbookChannelConfig) { | ||||
|         assert.isUri('url', url); | ||||
|         if (!_.isUndefined(config)) { | ||||
|             assert.doesConformToSchema('config', config, clientSchemas.webSocketOrderbookChannelConfigSchema); | ||||
|         } | ||||
|         this._apiEndpointUrl = url; | ||||
|         this._heartbeatIntervalMs = | ||||
|             _.isUndefined(config) || _.isUndefined(config.heartbeatIntervalMs) | ||||
|                 ? DEFAULT_HEARTBEAT_INTERVAL_MS | ||||
|                 : config.heartbeatIntervalMs; | ||||
|         this._client = new WebSocket.client(); | ||||
|     } | ||||
|     /** | ||||
| @@ -63,7 +78,7 @@ export class WebSocketOrderbookChannel implements OrderbookChannel { | ||||
|                 connection.on(WebsocketConnectionEventType.Error, wsError => { | ||||
|                     handler.onError(this, subscriptionOpts, wsError); | ||||
|                 }); | ||||
|                 connection.on(WebsocketConnectionEventType.Close, () => { | ||||
|                 connection.on(WebsocketConnectionEventType.Close, (code: number, desc: string) => { | ||||
|                     handler.onClose(this, subscriptionOpts); | ||||
|                 }); | ||||
|                 connection.on(WebsocketConnectionEventType.Message, message => { | ||||
| @@ -80,6 +95,9 @@ export class WebSocketOrderbookChannel implements OrderbookChannel { | ||||
|         if (!_.isUndefined(this._connectionIfExists)) { | ||||
|             this._connectionIfExists.close(); | ||||
|         } | ||||
|         if (!_.isUndefined(this._heartbeatTimerIfExists)) { | ||||
|             clearInterval(this._heartbeatTimerIfExists); | ||||
|         } | ||||
|     } | ||||
|     private _getConnection(callback: (error?: Error, connection?: WebSocket.connection) => void) { | ||||
|         if (!_.isUndefined(this._connectionIfExists) && this._connectionIfExists.connected) { | ||||
| @@ -87,6 +105,20 @@ export class WebSocketOrderbookChannel implements OrderbookChannel { | ||||
|         } else { | ||||
|             this._client.on(WebsocketClientEventType.Connect, connection => { | ||||
|                 this._connectionIfExists = connection; | ||||
|                 if (this._heartbeatIntervalMs >= MINIMUM_HEARTBEAT_INTERVAL_MS) { | ||||
|                     this._heartbeatTimerIfExists = setInterval(() => { | ||||
|                         connection.ping(''); | ||||
|                     }, this._heartbeatIntervalMs); | ||||
|                 } else { | ||||
|                     callback( | ||||
|                         new Error( | ||||
|                             `Heartbeat interval is ${ | ||||
|                                 this._heartbeatIntervalMs | ||||
|                             }ms which is less than the required minimum of ${MINIMUM_HEARTBEAT_INTERVAL_MS}ms`, | ||||
|                         ), | ||||
|                         undefined, | ||||
|                     ); | ||||
|                 } | ||||
|                 callback(undefined, this._connectionIfExists); | ||||
|             }); | ||||
|             this._client.on(WebsocketClientEventType.ConnectFailed, error => { | ||||
|   | ||||
| @@ -40,19 +40,22 @@ describe('HttpClient', () => { | ||||
|     }); | ||||
|     describe('#getTokenPairsAsync', () => { | ||||
|         const url = `${relayUrl}/token_pairs`; | ||||
|         it('gets token pairs', async () => { | ||||
|             fetchMock.get(url, tokenPairsResponseJSON); | ||||
|         it('gets token pairs with default options when none are provided', async () => { | ||||
|             const urlWithQuery = `${url}?page=1&per_page=100`; | ||||
|             fetchMock.get(urlWithQuery, tokenPairsResponseJSON); | ||||
|             const tokenPairs = await relayerClient.getTokenPairsAsync(); | ||||
|             expect(tokenPairs).to.be.deep.equal(tokenPairsResponse); | ||||
|         }); | ||||
|         it('gets specific token pairs for request', async () => { | ||||
|         it('gets token pairs with specified request options', async () => { | ||||
|             const tokenAddress = '0x323b5d4c32345ced77393b3530b1eed0f346429d'; | ||||
|             const tokenPairsRequest = { | ||||
|             const tokenPairsRequestOpts = { | ||||
|                 tokenA: tokenAddress, | ||||
|                 page: 3, | ||||
|                 perPage: 50, | ||||
|             }; | ||||
|             const urlWithQuery = `${url}?tokenA=${tokenAddress}`; | ||||
|             const urlWithQuery = `${url}?page=3&per_page=50&tokenA=${tokenAddress}`; | ||||
|             fetchMock.get(urlWithQuery, tokenPairsResponseJSON); | ||||
|             const tokenPairs = await relayerClient.getTokenPairsAsync(tokenPairsRequest); | ||||
|             const tokenPairs = await relayerClient.getTokenPairsAsync(tokenPairsRequestOpts); | ||||
|             expect(tokenPairs).to.be.deep.equal(tokenPairsResponse); | ||||
|         }); | ||||
|         it('throws an error for invalid JSON response', async () => { | ||||
| @@ -62,17 +65,20 @@ describe('HttpClient', () => { | ||||
|     }); | ||||
|     describe('#getOrdersAsync', () => { | ||||
|         const url = `${relayUrl}/orders`; | ||||
|         it('gets orders', async () => { | ||||
|             fetchMock.get(url, ordersResponseJSON); | ||||
|         it('gets orders with default options when none are provided', async () => { | ||||
|             const urlWithQuery = `${url}?page=1&per_page=100`; | ||||
|             fetchMock.get(urlWithQuery, ordersResponseJSON); | ||||
|             const orders = await relayerClient.getOrdersAsync(); | ||||
|             expect(orders).to.be.deep.equal(ordersResponse); | ||||
|         }); | ||||
|         it('gets specific orders for request', async () => { | ||||
|         it('gets orders with specified request options', async () => { | ||||
|             const tokenAddress = '0x323b5d4c32345ced77393b3530b1eed0f346429d'; | ||||
|             const ordersRequest = { | ||||
|                 tokenAddress, | ||||
|                 page: 3, | ||||
|                 perPage: 50, | ||||
|             }; | ||||
|             const urlWithQuery = `${url}?tokenAddress=${tokenAddress}`; | ||||
|             const urlWithQuery = `${url}?page=3&per_page=50&tokenAddress=${tokenAddress}`; | ||||
|             fetchMock.get(urlWithQuery, ordersResponseJSON); | ||||
|             const orders = await relayerClient.getOrdersAsync(ordersRequest); | ||||
|             expect(orders).to.be.deep.equal(ordersResponse); | ||||
| @@ -100,14 +106,27 @@ describe('HttpClient', () => { | ||||
|             baseTokenAddress: '0x323b5d4c32345ced77393b3530b1eed0f346429d', | ||||
|             quoteTokenAddress: '0xa2b31dacf30a9c50ca473337c01d8a201ae33e32', | ||||
|         }; | ||||
|         const url = `${relayUrl}/orderbook?baseTokenAddress=${request.baseTokenAddress}"eTokenAddress=${ | ||||
|             request.quoteTokenAddress | ||||
|         }`; | ||||
|         it('gets order book', async () => { | ||||
|             fetchMock.get(url, orderbookJSON); | ||||
|         const url = `${relayUrl}/orderbook`; | ||||
|         it('gets orderbook with default page options when none are provided', async () => { | ||||
|             const urlWithQuery = `${url}?baseTokenAddress=${ | ||||
|                 request.baseTokenAddress | ||||
|             }&page=1&per_page=100"eTokenAddress=${request.quoteTokenAddress}`; | ||||
|             fetchMock.get(urlWithQuery, orderbookJSON); | ||||
|             const orderbook = await relayerClient.getOrderbookAsync(request); | ||||
|             expect(orderbook).to.be.deep.equal(orderbookResponse); | ||||
|         }); | ||||
|         it('gets orderbook with specified page options', async () => { | ||||
|             const urlWithQuery = `${url}?baseTokenAddress=${ | ||||
|                 request.baseTokenAddress | ||||
|             }&page=3&per_page=50"eTokenAddress=${request.quoteTokenAddress}`; | ||||
|             fetchMock.get(urlWithQuery, orderbookJSON); | ||||
|             const pagedRequestOptions = { | ||||
|                 page: 3, | ||||
|                 perPage: 50, | ||||
|             }; | ||||
|             const orderbook = await relayerClient.getOrderbookAsync(request, pagedRequestOptions); | ||||
|             expect(orderbook).to.be.deep.equal(orderbookResponse); | ||||
|         }); | ||||
|         it('throws an error for invalid JSON response', async () => { | ||||
|             fetchMock.get(url, { test: 'dummy' }); | ||||
|             expect(relayerClient.getOrderbookAsync(request)).to.be.rejected(); | ||||
|   | ||||
| @@ -38,6 +38,12 @@ yarn install | ||||
| yarn build | ||||
| ``` | ||||
|  | ||||
| or | ||||
|  | ||||
| ```bash | ||||
| yarn build:watch | ||||
| ``` | ||||
|  | ||||
| ### Clean | ||||
|  | ||||
| ```bash | ||||
|   | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -1,394 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "EtherToken", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "name", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "string" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "approve", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "totalSupply", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferFrom", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "amount", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "withdraw", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "decimals", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint8" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "balanceOf", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "symbol", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "string" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transfer", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [], | ||||
|       "name": "deposit", | ||||
|       "outputs": [], | ||||
|       "payable": true, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "allowance", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "payable": true, | ||||
|       "type": "fallback" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Transfer", | ||||
|       "type": "event" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Approval", | ||||
|       "type": "event" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x6060604052341561000c57fe5b5b6107598061001c6000396000f300606060405236156100935763ffffffff60e060020a60003504166306fdde0381146100a4578063095ea7b31461013457806318160ddd1461016757806323b872dd146101895780632e1a7d4d146101c2578063313ce567146101d757806370a08231146101fd57806395d89b411461022b578063a9059cbb146102bb578063d0e30db0146102ee578063dd62ed3e146102f8575b6100a25b61009f61032c565b5b565b005b34156100ac57fe5b6100b461037b565b6040805160208082528351818301528351919283929083019185019080838382156100fa575b8051825260208311156100fa57601f1990920191602091820191016100da565b505050905090810190601f1680156101265780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561013c57fe5b610153600160a060020a03600435166024356103a3565b604080519115158252519081900360200190f35b341561016f57fe5b61017761040e565b60408051918252519081900360200190f35b341561019157fe5b610153600160a060020a0360043581169060243516604435610414565b604080519115158252519081900360200190f35b34156101ca57fe5b6100a2600435610537565b005b34156101df57fe5b6101e76105b8565b6040805160ff9092168252519081900360200190f35b341561020557fe5b610177600160a060020a03600435166105bd565b60408051918252519081900360200190f35b341561023357fe5b6100b46105dc565b6040805160208082528351818301528351919283929083019185019080838382156100fa575b8051825260208311156100fa57601f1990920191602091820191016100da565b505050905090810190601f1680156101265780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156102c357fe5b610153600160a060020a03600435166024356105fd565b604080519115158252519081900360200190f35b6100a261032c565b005b341561030057fe5b610177600160a060020a03600435811690602435166106af565b60408051918252519081900360200190f35b600160a060020a03331660009081526020819052604090205461034f90346106dc565b600160a060020a03331660009081526020819052604090205560025461037590346106dc565b6002555b565b60408051808201909152600b815260a960020a6a22ba3432b9102a37b5b2b702602082015281565b600160a060020a03338116600081815260016020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060015b92915050565b60025481565b600160a060020a03808416600081815260016020908152604080832033909516835293815283822054928252819052918220548390108015906104575750828110155b801561047d5750600160a060020a03841660009081526020819052604090205483810110155b1561052957600160a060020a03808516600090815260208190526040808220805487019055918716815220805484900390556000198110156104e757600160a060020a03808616600090815260016020908152604080832033909416835292905220805484900390555b83600160a060020a031685600160a060020a031660008051602061070e833981519152856040518082815260200191505060405180910390a36001915061052e565b600091505b5b509392505050565b600160a060020a03331660009081526020819052604090205461055a90826106f6565b600160a060020a03331660009081526020819052604090205560025461058090826106f6565b600255604051600160a060020a0333169082156108fc029083906000818181858888f1935050505015156105b45760006000fd5b5b50565b601281565b600160a060020a0381166000908152602081905260409020545b919050565b604080518082019091526004815260e360020a630ae8aa8902602082015281565b600160a060020a0333166000908152602081905260408120548290108015906106405750600160a060020a03831660009081526020819052604090205482810110155b156106a057600160a060020a03338116600081815260208181526040808320805488900390559387168083529184902080548701905583518681529351919360008051602061070e833981519152929081900390910190a3506001610408565b506000610408565b5b92915050565b600160a060020a038083166000908152600160209081526040808320938516835292905220545b92915050565b6000828201838110156106eb57fe5b8091505b5092915050565b60008282111561070257fe5b508082035b929150505600ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa165627a7a7230582036b62e75991ca24307fbb7333dc79a1493b9acb6b3e146e3c707708262cfbe430029", | ||||
|   "networks": { | ||||
|     "1": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_from", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_to", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Transfer", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_owner", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_spender", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Approval", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1502488087000, | ||||
|       "address": "0x2956356cd2a2bf3202f771f50d3d14a367b48070" | ||||
|     }, | ||||
|     "42": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_from", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_to", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Transfer", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_owner", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_spender", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Approval", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1502391794392, | ||||
|       "address": "0x05d090b51c40b020eab3bfcb6a2dff130df22e9c" | ||||
|     }, | ||||
|     "50": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_from", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_to", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Transfer", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_owner", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_spender", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Approval", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1513088404209, | ||||
|       "address": "0x48bacb9266a570d521063ef5dd96e61686dbe788" | ||||
|     } | ||||
|   }, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088404209 | ||||
| } | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -1,227 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "MaliciousToken", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "approve", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "totalSupply", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferFrom", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "balanceOf", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transfer", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "allowance", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Transfer", | ||||
|       "type": "event" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Approval", | ||||
|       "type": "event" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x60606040526003805460ff19166001179055341561001957fe5b5b610467806100296000396000f3006060604052361561005c5763ffffffff60e060020a600035041663095ea7b3811461005e57806318160ddd1461009157806323b872dd146100b357806370a08231146100ec578063a9059cbb1461011a578063dd62ed3e1461014d575bfe5b341561006657fe5b61007d600160a060020a0360043516602435610181565b604080519115158252519081900360200190f35b341561009957fe5b6100a16101ec565b60408051918252519081900360200190f35b34156100bb57fe5b61007d600160a060020a03600435811690602435166044356101f2565b604080519115158252519081900360200190f35b34156100f457fe5b6100a1600160a060020a03600435166102ee565b60408051918252519081900360200190f35b341561012257fe5b61007d600160a060020a0360043516602435610318565b604080519115158252519081900360200190f35b341561015557fe5b6100a1600160a060020a03600435811690602435166103ca565b60408051918252519081900360200190f35b600160a060020a03338116600081815260016020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060015b92915050565b60025481565b600160a060020a0383166000908152602081905260408120548290108015906102425750600160a060020a0380851660009081526001602090815260408083203390941683529290522054829010155b80156102685750600160a060020a03831660009081526020819052604090205482810110155b156102e257600160a060020a03808416600081815260208181526040808320805488019055888516808452818420805489900390556001835281842033909616845294825291829020805487900390558151868152915192939260008051602061041c8339815191529281900390910190a35060016102e6565b5060005b5b9392505050565b60006102f8610402565b50600160a060020a0381166000908152602081905260409020545b919050565b600160a060020a03331660009081526020819052604081205482901080159061035b5750600160a060020a03831660009081526020819052604090205482810110155b156103bb57600160a060020a03338116600081815260208181526040808320805488900390559387168083529184902080548701905583518681529351919360008051602061041c833981519152929081900390910190a35060016101e6565b5060006101e6565b5b92915050565b60006103d4610402565b50600160a060020a038083166000908152600160209081526040808320938516835292905220545b92915050565b6003805460ff8082166001011660ff199091161790555b5600ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa165627a7a7230582078edadabd342b34dc605a47ad9eab0ab5ad8513193a546e042b2ab9c6101d5250029", | ||||
|   "networks": { | ||||
|     "50": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_from", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_to", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Transfer", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_owner", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_spender", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Approval", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1513088404210 | ||||
|     } | ||||
|   }, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088404210 | ||||
| } | ||||
| @@ -1,72 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "Migrations", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "new_address", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "upgrade", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "last_completed_migration", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "owner", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "completed", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "setCompleted", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "inputs": [], | ||||
|       "payable": false, | ||||
|       "type": "constructor" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x6060604052341561000c57fe5b5b60008054600160a060020a03191633600160a060020a03161790555b5b6101a0806100396000396000f300606060405263ffffffff60e060020a6000350416630900f0108114610042578063445df0ac146100605780638da5cb5b14610082578063fdacd576146100ae575bfe5b341561004a57fe5b61005e600160a060020a03600435166100c3565b005b341561006857fe5b61007061013d565b60408051918252519081900360200190f35b341561008a57fe5b610092610143565b60408051600160a060020a039092168252519081900360200190f35b34156100b657fe5b61005e600435610152565b005b6000805433600160a060020a03908116911614156101375781905080600160a060020a031663fdacd5766001546040518263ffffffff1660e060020a02815260040180828152602001915050600060405180830381600087803b151561012557fe5b6102c65a03f1151561013357fe5b5050505b5b5b5050565b60015481565b600054600160a060020a031681565b60005433600160a060020a039081169116141561016f5760018190555b5b5b505600a165627a7a72305820721709a2522264b5277c3048b17bea0e0f660776a386bacb5f36796ba40dac1c0029", | ||||
|   "networks": { | ||||
|     "50": { | ||||
|       "links": {}, | ||||
|       "events": {}, | ||||
|       "updated_at": 1513088404203 | ||||
|     } | ||||
|   }, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088404203 | ||||
| } | ||||
| @@ -1,189 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "Mintable", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "approve", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "totalSupply", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferFrom", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "balanceOf", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "mint", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transfer", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "allowance", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Transfer", | ||||
|       "type": "event" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Approval", | ||||
|       "type": "event" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x6060604052341561000c57fe5b5b6105018061001c6000396000f300606060405236156100675763ffffffff60e060020a600035041663095ea7b3811461006957806318160ddd1461009c57806323b872dd146100be57806370a08231146100f7578063a0712d6814610125578063a9059cbb1461013a578063dd62ed3e1461016d575bfe5b341561007157fe5b610088600160a060020a03600435166024356101a1565b604080519115158252519081900360200190f35b34156100a457fe5b6100ac61020c565b60408051918252519081900360200190f35b34156100c657fe5b610088600160a060020a0360043581169060243516604435610212565b604080519115158252519081900360200190f35b34156100ff57fe5b6100ac600160a060020a0360043516610335565b60408051918252519081900360200190f35b341561012d57fe5b610138600435610354565b005b341561014257fe5b610088600160a060020a03600435166024356103bc565b604080519115158252519081900360200190f35b341561017557fe5b6100ac600160a060020a036004358116906024351661046e565b60408051918252519081900360200190f35b600160a060020a03338116600081815260016020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060015b92915050565b60025481565b600160a060020a03808416600081815260016020908152604080832033909516835293815283822054928252819052918220548390108015906102555750828110155b801561027b5750600160a060020a03841660009081526020819052604090205483810110155b1561032757600160a060020a03808516600090815260208190526040808220805487019055918716815220805484900390556000198110156102e557600160a060020a03808616600090815260016020908152604080832033909416835292905220805484900390555b83600160a060020a031685600160a060020a03166000805160206104b6833981519152856040518082815260200191505060405180910390a36001915061032c565b600091505b5b509392505050565b600160a060020a0381166000908152602081905260409020545b919050565b68056bc75e2d6310000081111561036b5760006000fd5b600160a060020a03331660009081526020819052604090205461038f90829061049b565b600160a060020a0333166000908152602081905260409020556002546103b5908261049b565b6002555b50565b600160a060020a0333166000908152602081905260408120548290108015906103ff5750600160a060020a03831660009081526020819052604090205482810110155b1561045f57600160a060020a0333811660008181526020818152604080832080548890039055938716808352918490208054870190558351868152935191936000805160206104b6833981519152929081900390910190a3506001610206565b506000610206565b5b92915050565b600160a060020a038083166000908152600160209081526040808320938516835292905220545b92915050565b6000828201838110156104aa57fe5b8091505b50929150505600ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa165627a7a72305820b1c955ed24ff28cfa482298867cac2a83e25903b0100a429152919223fdf653f0029", | ||||
|   "networks": {}, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088402049 | ||||
| } | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -1,40 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "Ownable", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "owner", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "newOwner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferOwnership", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "inputs": [], | ||||
|       "payable": false, | ||||
|       "type": "constructor" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x6060604052341561000c57fe5b5b60008054600160a060020a03191633600160a060020a03161790555b5b60f3806100386000396000f300606060405263ffffffff60e060020a6000350416638da5cb5b8114602a578063f2fde38b146053575bfe5b3415603157fe5b6037606e565b60408051600160a060020a039092168252519081900360200190f35b3415605a57fe5b606c600160a060020a0360043516607d565b005b600054600160a060020a031681565b60005433600160a060020a0390811691161460985760006000fd5b600160a060020a0381161560c25760008054600160a060020a031916600160a060020a0383161790555b5b5b505600a165627a7a7230582048ccfb6ebb285c80c8b4030a0e4f2e6ec2a0619b363a2d7cd20692a0cfb170550029", | ||||
|   "networks": {}, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088402049 | ||||
| } | ||||
| @@ -1,8 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "SafeMath", | ||||
|   "abi": [], | ||||
|   "unlinked_binary": "0x60606040523415600b57fe5b5b60338060196000396000f30060606040525bfe00a165627a7a72305820becdc80300a4dbf834bb9ab115616eb459f82b51a9133d360eb1e6e5402072eb0029", | ||||
|   "networks": {}, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088402049 | ||||
| } | ||||
| @@ -1,176 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "StandardToken", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "approve", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "totalSupply", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferFrom", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "balanceOf", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transfer", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "allowance", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Transfer", | ||||
|       "type": "event" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Approval", | ||||
|       "type": "event" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x6060604052341561000c57fe5b5b6104388061001c6000396000f3006060604052361561005c5763ffffffff60e060020a600035041663095ea7b3811461005e57806318160ddd1461009157806323b872dd146100b357806370a08231146100ec578063a9059cbb1461011a578063dd62ed3e1461014d575bfe5b341561006657fe5b61007d600160a060020a0360043516602435610181565b604080519115158252519081900360200190f35b341561009957fe5b6100a16101ec565b60408051918252519081900360200190f35b34156100bb57fe5b61007d600160a060020a03600435811690602435166044356101f2565b604080519115158252519081900360200190f35b34156100f457fe5b6100a1600160a060020a03600435166102ee565b60408051918252519081900360200190f35b341561012257fe5b61007d600160a060020a036004351660243561030d565b604080519115158252519081900360200190f35b341561015557fe5b6100a1600160a060020a03600435811690602435166103bf565b60408051918252519081900360200190f35b600160a060020a03338116600081815260016020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060015b92915050565b60025481565b600160a060020a0383166000908152602081905260408120548290108015906102425750600160a060020a0380851660009081526001602090815260408083203390941683529290522054829010155b80156102685750600160a060020a03831660009081526020819052604090205482810110155b156102e257600160a060020a0380841660008181526020818152604080832080548801905588851680845281842080548990039055600183528184203390961684529482529182902080548790039055815186815291519293926000805160206103ed8339815191529281900390910190a35060016102e6565b5060005b5b9392505050565b600160a060020a0381166000908152602081905260409020545b919050565b600160a060020a0333166000908152602081905260408120548290108015906103505750600160a060020a03831660009081526020819052604090205482810110155b156103b057600160a060020a0333811660008181526020818152604080832080548890039055938716808352918490208054870190558351868152935191936000805160206103ed833981519152929081900390910190a35060016101e6565b5060006101e6565b5b92915050565b600160a060020a038083166000908152600160209081526040808320938516835292905220545b929150505600ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa165627a7a7230582056d411baf4691cc9a0a55ffa6b4a4e9308ea12187fd2fa738228bbd266709d4d0029", | ||||
|   "networks": {}, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088402049 | ||||
| } | ||||
| @@ -1,176 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "Token", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "approve", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "success", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "totalSupply", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "supply", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferFrom", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "success", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "balanceOf", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "balance", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transfer", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "success", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "allowance", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "remaining", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Transfer", | ||||
|       "type": "event" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Approval", | ||||
|       "type": "event" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x6060604052341561000c57fe5b5b6101e08061001c6000396000f3006060604052361561005c5763ffffffff60e060020a600035041663095ea7b3811461005e57806318160ddd1461009157806323b872dd146100b357806370a08231146100ec578063a9059cbb1461005e578063dd62ed3e1461014d575bfe5b341561006657fe5b61007d600160a060020a0360043516602435610181565b604080519115158252519081900360200190f35b341561009957fe5b6100a161018a565b60408051918252519081900360200190f35b34156100bb57fe5b61007d600160a060020a0360043581169060243516604435610190565b604080519115158252519081900360200190f35b34156100f457fe5b6100a1600160a060020a036004351661019a565b60408051918252519081900360200190f35b341561006657fe5b61007d600160a060020a0360043516602435610181565b604080519115158252519081900360200190f35b341561015557fe5b6100a1600160a060020a0360043581169060243516610181565b60408051918252519081900360200190f35b60005b92915050565b60005b90565b60005b9392505050565b60005b919050565b60005b92915050565b60005b929150505600a165627a7a72305820107c1e9e7aa669d21343c42639b4bb080602c349d00c1da14b8ea6b6dcc0b0f80029", | ||||
|   "networks": {}, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088402049 | ||||
| } | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -1,298 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "TokenTransferProxy", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "token", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferFrom", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "target", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "addAuthorizedAddress", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "authorities", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "target", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "removeAuthorizedAddress", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "owner", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "authorized", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "getAuthorizedAddresses", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "address[]" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "newOwner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferOwnership", | ||||
|       "outputs": [], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "target", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "caller", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "LogAuthorizedAddressAdded", | ||||
|       "type": "event" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "target", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "caller", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "LogAuthorizedAddressRemoved", | ||||
|       "type": "event" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x60606040525b60008054600160a060020a03191633600160a060020a03161790555b5b6106e6806100316000396000f300606060405236156100725763ffffffff60e060020a60003504166315dacbea811461007457806342f1181e146100b3578063494503d4146100d157806370712939146101005780638da5cb5b1461011e578063b91816111461014a578063d39de6e91461017a578063f2fde38b146101e5575bfe5b341561007c57fe5b61009f600160a060020a0360043581169060243581169060443516606435610203565b604080519115158252519081900360200190f35b34156100bb57fe5b6100cf600160a060020a03600435166102ae565b005b34156100d957fe5b6100e4600435610390565b60408051600160a060020a039092168252519081900360200190f35b341561010857fe5b6100cf600160a060020a03600435166103c2565b005b341561012657fe5b6100e461055a565b60408051600160a060020a039092168252519081900360200190f35b341561015257fe5b61009f600160a060020a0360043516610569565b604080519115158252519081900360200190f35b341561018257fe5b61018a61057e565b60408051602080825283518183015283519192839290830191858101910280838382156101d2575b8051825260208311156101d257601f1990920191602091820191016101b2565b5050509050019250505060405180910390f35b34156101ed57fe5b6100cf600160a060020a03600435166105e7565b005b600160a060020a03331660009081526001602052604081205460ff16151561022b5760006000fd5b6040805160006020918201819052825160e060020a6323b872dd028152600160a060020a0388811660048301528781166024830152604482018790529351938916936323b872dd9360648084019491938390030190829087803b151561028d57fe5b6102c65a03f1151561029b57fe5b5050604051519150505b5b949350505050565b60005433600160a060020a039081169116146102ca5760006000fd5b600160a060020a038116600090815260016020526040902054819060ff16156102f35760006000fd5b600160a060020a0382166000908152600160208190526040909120805460ff191682179055600280549091810161032a8382610633565b916000526020600020900160005b81546101009190910a600160a060020a0381810219909216868316918202179092556040513390911692507f94bb87f4c15c4587ff559a7584006fa01ddf9299359be6b512b94527aa961aca90600090a35b5b505b50565b600280548290811061039e57fe5b906000526020600020900160005b915054906101000a9004600160a060020a031681565b6000805433600160a060020a039081169116146103df5760006000fd5b600160a060020a038216600090815260016020526040902054829060ff1615156104095760006000fd5b600160a060020a0383166000908152600160205260408120805460ff1916905591505b6002548210156105195782600160a060020a031660028381548110151561044f57fe5b906000526020600020900160005b9054906101000a9004600160a060020a0316600160a060020a0316141561050d5760028054600019810190811061049057fe5b906000526020600020900160005b9054906101000a9004600160a060020a03166002838154811015156104bf57fe5b906000526020600020900160005b6101000a815481600160a060020a030219169083600160a060020a0316021790555060016002818180549050039150816105079190610633565b50610519565b5b60019091019061042c565b604051600160a060020a0333811691908516907ff5b347a1e40749dd050f5f07fbdbeb7e3efa9756903044dd29401fd1d4bb4a1c90600090a35b5b505b5050565b600054600160a060020a031681565b60016020526000908152604090205460ff1681565b610586610687565b60028054806020026020016040519081016040528092919081815260200182805480156105dc57602002820191906000526020600020905b8154600160a060020a031681526001909101906020018083116105be575b505050505090505b90565b60005433600160a060020a039081169116146106035760006000fd5b600160a060020a0381161561038d5760008054600160a060020a031916600160a060020a0383161790555b5b5b50565b81548183558181151161055357600083815260209020610553918101908301610699565b5b505050565b81548183558181151161055357600083815260209020610553918101908301610699565b5b505050565b60408051602081019091526000815290565b6105e491905b808211156106b3576000815560010161069f565b5090565b905600a165627a7a72305820f53c9547789a008ccb8f24999a7b6fb4c8fb20655522030c87ba624e1fdb67ea0029", | ||||
|   "networks": { | ||||
|     "1": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0x94bb87f4c15c4587ff559a7584006fa01ddf9299359be6b512b94527aa961aca": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "target", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "caller", | ||||
|               "type": "address" | ||||
|             } | ||||
|           ], | ||||
|           "name": "LogAuthorizedAddressAdded", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0xf5b347a1e40749dd050f5f07fbdbeb7e3efa9756903044dd29401fd1d4bb4a1c": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "target", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "caller", | ||||
|               "type": "address" | ||||
|             } | ||||
|           ], | ||||
|           "name": "LogAuthorizedAddressRemoved", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1502478966000, | ||||
|       "address": "0x8da0d80f5007ef1e431dd2127178d224e32c2ef4" | ||||
|     }, | ||||
|     "42": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0x94bb87f4c15c4587ff559a7584006fa01ddf9299359be6b512b94527aa961aca": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "target", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "caller", | ||||
|               "type": "address" | ||||
|             } | ||||
|           ], | ||||
|           "name": "LogAuthorizedAddressAdded", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0xf5b347a1e40749dd050f5f07fbdbeb7e3efa9756903044dd29401fd1d4bb4a1c": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "target", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "caller", | ||||
|               "type": "address" | ||||
|             } | ||||
|           ], | ||||
|           "name": "LogAuthorizedAddressRemoved", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1502391794384, | ||||
|       "address": "0x087Eed4Bc1ee3DE49BeFbd66C662B434B15d49d4" | ||||
|     }, | ||||
|     "50": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0x94bb87f4c15c4587ff559a7584006fa01ddf9299359be6b512b94527aa961aca": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "target", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "caller", | ||||
|               "type": "address" | ||||
|             } | ||||
|           ], | ||||
|           "name": "LogAuthorizedAddressAdded", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0xf5b347a1e40749dd050f5f07fbdbeb7e3efa9756903044dd29401fd1d4bb4a1c": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "target", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "caller", | ||||
|               "type": "address" | ||||
|             } | ||||
|           ], | ||||
|           "name": "LogAuthorizedAddressRemoved", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1513088404202, | ||||
|       "address": "0x871dd7c2b4b25e1aa18728e9d5f2af4c4e431f5c" | ||||
|     } | ||||
|   }, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088404202 | ||||
| } | ||||
| @@ -1,373 +0,0 @@ | ||||
| { | ||||
|   "contract_name": "ZRXToken", | ||||
|   "abi": [ | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "name", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "string" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "approve", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "totalSupply", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transferFrom", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "decimals", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint8" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "balanceOf", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [], | ||||
|       "name": "symbol", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "string" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "transfer", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "bool" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "constant": true, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         } | ||||
|       ], | ||||
|       "name": "allowance", | ||||
|       "outputs": [ | ||||
|         { | ||||
|           "name": "", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "payable": false, | ||||
|       "type": "function" | ||||
|     }, | ||||
|     { | ||||
|       "inputs": [], | ||||
|       "payable": false, | ||||
|       "type": "constructor" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_from", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_to", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Transfer", | ||||
|       "type": "event" | ||||
|     }, | ||||
|     { | ||||
|       "anonymous": false, | ||||
|       "inputs": [ | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_owner", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": true, | ||||
|           "name": "_spender", | ||||
|           "type": "address" | ||||
|         }, | ||||
|         { | ||||
|           "indexed": false, | ||||
|           "name": "_value", | ||||
|           "type": "uint256" | ||||
|         } | ||||
|       ], | ||||
|       "name": "Approval", | ||||
|       "type": "event" | ||||
|     } | ||||
|   ], | ||||
|   "unlinked_binary": "0x60606040526b033b2e3c9fd0803ce8000000600355341561001c57fe5b5b600354600160a060020a0333166000908152602081905260409020555b5b6106198061004a6000396000f3006060604052361561007d5763ffffffff60e060020a60003504166306fdde03811461007f578063095ea7b31461010f57806318160ddd1461014257806323b872dd14610164578063313ce5671461019d57806370a08231146101c357806395d89b41146101f1578063a9059cbb14610281578063dd62ed3e146102b4575bfe5b341561008757fe5b61008f6102e8565b6040805160208082528351818301528351919283929083019185019080838382156100d5575b8051825260208311156100d557601f1990920191602091820191016100b5565b505050905090810190601f1680156101015780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561011757fe5b61012e600160a060020a0360043516602435610316565b604080519115158252519081900360200190f35b341561014a57fe5b610152610381565b60408051918252519081900360200190f35b341561016c57fe5b61012e600160a060020a0360043581169060243516604435610387565b604080519115158252519081900360200190f35b34156101a557fe5b6101ad6104aa565b6040805160ff9092168252519081900360200190f35b34156101cb57fe5b610152600160a060020a03600435166104af565b60408051918252519081900360200190f35b34156101f957fe5b61008f6104ce565b6040805160208082528351818301528351919283929083019185019080838382156100d5575b8051825260208311156100d557601f1990920191602091820191016100b5565b505050905090810190601f1680156101015780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561028957fe5b61012e600160a060020a03600435166024356104ee565b604080519115158252519081900360200190f35b34156102bc57fe5b610152600160a060020a03600435811690602435166105a0565b60408051918252519081900360200190f35b6040805180820190915260118152607960020a70183c10283937ba37b1b7b6102a37b5b2b702602082015281565b600160a060020a03338116600081815260016020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060015b92915050565b60035481565b600160a060020a03808416600081815260016020908152604080832033909516835293815283822054928252819052918220548390108015906103ca5750828110155b80156103f05750600160a060020a03841660009081526020819052604090205483810110155b1561049c57600160a060020a038085166000908152602081905260408082208054870190559187168152208054849003905560001981101561045a57600160a060020a03808616600090815260016020908152604080832033909416835292905220805484900390555b83600160a060020a031685600160a060020a03166000805160206105ce833981519152856040518082815260200191505060405180910390a3600191506104a1565b600091505b5b509392505050565b601281565b600160a060020a0381166000908152602081905260409020545b919050565b604080518082019091526003815260eb60020a620b4a4b02602082015281565b600160a060020a0333166000908152602081905260408120548290108015906105315750600160a060020a03831660009081526020819052604090205482810110155b1561059157600160a060020a0333811660008181526020818152604080832080548890039055938716808352918490208054870190558351868152935191936000805160206105ce833981519152929081900390910190a350600161037b565b50600061037b565b5b92915050565b600160a060020a038083166000908152600160209081526040808320938516835292905220545b929150505600ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa165627a7a723058206964b3cfca2af9b1d1448e45eb8b04a5c1df55275a172242166d69e576e2a3b70029", | ||||
|   "networks": { | ||||
|     "1": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_from", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_to", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Transfer", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_owner", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_spender", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Approval", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1502477311000, | ||||
|       "address": "0xe41d2489571d322189246dafa5ebde1f4699f498" | ||||
|     }, | ||||
|     "42": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_from", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_to", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Transfer", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_owner", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_spender", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Approval", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1502391794391, | ||||
|       "address": "0x6ff6c0ff1d68b964901f986d4c9fa3ac68346570" | ||||
|     }, | ||||
|     "50": { | ||||
|       "links": {}, | ||||
|       "events": { | ||||
|         "0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_from", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_to", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Transfer", | ||||
|           "type": "event" | ||||
|         }, | ||||
|         "0x8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925": { | ||||
|           "anonymous": false, | ||||
|           "inputs": [ | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_owner", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": true, | ||||
|               "name": "_spender", | ||||
|               "type": "address" | ||||
|             }, | ||||
|             { | ||||
|               "indexed": false, | ||||
|               "name": "_value", | ||||
|               "type": "uint256" | ||||
|             } | ||||
|           ], | ||||
|           "name": "Approval", | ||||
|           "type": "event" | ||||
|         } | ||||
|       }, | ||||
|       "updated_at": 1513088404207 | ||||
|     } | ||||
|   }, | ||||
|   "schema_version": "0.0.5", | ||||
|   "updated_at": 1513088404207 | ||||
| } | ||||
							
								
								
									
										26
									
								
								packages/contracts/contract_templates/contract.handlebars
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								packages/contracts/contract_templates/contract.handlebars
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /** | ||||
|  * This file is auto-generated using abi-gen. Don't edit directly. | ||||
|  * Templates can be found at https://github.com/0xProject/0x.js/tree/development/packages/abi-gen-templates. | ||||
|  */ | ||||
| // tslint:disable:async-suffix member-ordering no-consecutive-blank-lines | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { TxData, TxDataPayable } from '@0xproject/types'; | ||||
| import { BigNumber, classUtils, promisify } from '@0xproject/utils'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import {BaseContract} from './base_contract'; | ||||
|  | ||||
| export class {{contractName}}Contract extends BaseContract { | ||||
| {{#each methods}} | ||||
|     {{#this.constant}} | ||||
|     {{> call contractName=../contractName}} | ||||
|     {{/this.constant}} | ||||
|     {{^this.constant}} | ||||
|     {{> tx contractName=../contractName}} | ||||
|     {{/this.constant}} | ||||
| {{/each}} | ||||
|     constructor(web3ContractInstance: Web3.ContractInstance, defaults?: Partial<TxData>) { | ||||
|         super(web3ContractInstance, defaults); | ||||
|         classUtils.bindAll(this, ['_web3ContractInstance', '_defaults']); | ||||
|     } | ||||
| } // tslint:disable:max-file-line-count | ||||
| @@ -0,0 +1,10 @@ | ||||
| public async {{this.name}}( | ||||
| {{> typed_params inputs=inputs}} | ||||
|     defaultBlock?: Web3.BlockParam, | ||||
| ): Promise<{{> return_type outputs=outputs}}> { | ||||
|     const self = this as {{contractName}}Contract; | ||||
|     const result = await self._web3ContractInstance.{{this.name}}.call( | ||||
|         {{> params inputs=inputs}} | ||||
|     ); | ||||
|     return result; | ||||
| } | ||||
| @@ -0,0 +1,3 @@ | ||||
| {{#each inputs}} | ||||
| {{name}}, | ||||
| {{/each}} | ||||
| @@ -0,0 +1,10 @@ | ||||
| {{#if outputs.length}} | ||||
| {{#singleReturnValue}} | ||||
| {{#returnType outputs.0.type}}{{/returnType}} | ||||
| {{/singleReturnValue}} | ||||
| {{^singleReturnValue}} | ||||
| [{{#each outputs}}{{#returnType type}}{{/returnType}}{{#unless @last}}, {{/unless}}{{/each}}] | ||||
| {{/singleReturnValue}} | ||||
| {{else}} | ||||
| void | ||||
| {{/if}} | ||||
							
								
								
									
										36
									
								
								packages/contracts/contract_templates/partials/tx.handlebars
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								packages/contracts/contract_templates/partials/tx.handlebars
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | ||||
| public {{this.name}} = { | ||||
|     async sendTransactionAsync( | ||||
|     {{> typed_params inputs=inputs}} | ||||
|     {{#this.payable}} | ||||
|         txData: TxDataPayable = {}, | ||||
|     {{/this.payable}} | ||||
|     {{^this.payable}} | ||||
|         txData: TxData = {}, | ||||
|     {{/this.payable}} | ||||
|     ): Promise<string> { | ||||
|         const self = this as {{contractName}}Contract; | ||||
|         const txDataWithDefaults = await self._applyDefaultsToTxDataAsync(txData); | ||||
|         const txHash = await self._web3ContractInstance.{{this.name}}( | ||||
|             {{> params inputs=inputs}} | ||||
|             txDataWithDefaults, | ||||
|         ); | ||||
|         return txHash; | ||||
|     }, | ||||
|     async callAsync( | ||||
|     {{> typed_params inputs=inputs}} | ||||
|     {{#this.payable}} | ||||
|         txData: TxDataPayable = {}, | ||||
|     {{/this.payable}} | ||||
|     {{^this.payable}} | ||||
|         txData: TxData = {}, | ||||
|     {{/this.payable}} | ||||
|     ): Promise<{{> return_type outputs=outputs}}> { | ||||
|         const self = this as {{contractName}}Contract; | ||||
|         const txDataWithDefaults = await self._applyDefaultsToTxDataAsync(txData); | ||||
|         const returnValue = await self._web3ContractInstance.{{this.name}}.call( | ||||
|             {{> params inputs=inputs}} | ||||
|             txDataWithDefaults, | ||||
|         ); | ||||
|         return returnValue; | ||||
|     }, | ||||
| }; | ||||
| @@ -0,0 +1,3 @@ | ||||
| {{#each inputs}} | ||||
|     {{name}}: {{#parameterType type}}{{/parameterType}}, | ||||
| {{/each}} | ||||
| @@ -1,38 +0,0 @@ | ||||
| pragma solidity 0.4.18; | ||||
|  | ||||
| import "./Mintable_v2.sol"; | ||||
| import "./../utils/Ownable_v2.sol"; | ||||
|  | ||||
| contract DummyToken_v2 is Mintable_v2, Ownable_v2 { | ||||
|     string public name; | ||||
|     string public symbol; | ||||
|     uint public decimals; | ||||
|  | ||||
|     function DummyToken_v2( | ||||
|         string _name, | ||||
|         string _symbol, | ||||
|         uint _decimals, | ||||
|         uint _totalSupply) | ||||
|         public | ||||
|     { | ||||
|         name = _name; | ||||
|         symbol = _symbol; | ||||
|         decimals = _decimals; | ||||
|         totalSupply = _totalSupply; | ||||
|         balances[msg.sender] = _totalSupply; | ||||
|     } | ||||
|  | ||||
|     function setBalance(address _target, uint _value)  | ||||
|         public | ||||
|         onlyOwner  | ||||
|     { | ||||
|         uint currBalance = balanceOf(_target); | ||||
|         if (_value < currBalance) { | ||||
|             totalSupply = safeSub(totalSupply, safeSub(currBalance, _value)); | ||||
|         } else { | ||||
|             totalSupply = safeAdd(totalSupply, safeSub(_value, currBalance)); | ||||
|         } | ||||
|         balances[_target] = _value; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -1,19 +0,0 @@ | ||||
| pragma solidity 0.4.18; | ||||
|  | ||||
| import "./../tokens/UnlimitedAllowanceToken_v2.sol"; | ||||
| import "./../utils/SafeMath_v2.sol"; | ||||
|  | ||||
| /* | ||||
|  * Mintable | ||||
|  * Base contract that creates a mintable UnlimitedAllowanceToken | ||||
|  */ | ||||
| contract Mintable_v2 is UnlimitedAllowanceToken_v2, SafeMath_v2 { | ||||
|     function mint(uint _value)  | ||||
|         public | ||||
|     { | ||||
|         require(_value <= 100000000000000000000); | ||||
|         balances[msg.sender] = safeAdd(_value, balances[msg.sender]); | ||||
|         totalSupply = safeAdd(totalSupply, _value); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -1,74 +0,0 @@ | ||||
| pragma solidity ^0.4.11; | ||||
|  | ||||
| contract SafeMath { | ||||
|     function safeMul(uint a, uint b) | ||||
|         internal | ||||
|         constant  | ||||
|         returns (uint256)  | ||||
|     { | ||||
|         uint c = a * b; | ||||
|         assert(a == 0 || c / a == b); | ||||
|         return c; | ||||
|     } | ||||
|  | ||||
|     function safeDiv(uint a, uint b) | ||||
|         internal  | ||||
|         constant  | ||||
|         returns (uint256)  | ||||
|     { | ||||
|         uint c = a / b; | ||||
|         return c; | ||||
|     } | ||||
|  | ||||
|     function safeSub(uint a, uint b)  | ||||
|         internal  | ||||
|         constant  | ||||
|         returns (uint256)  | ||||
|     { | ||||
|         assert(b <= a); | ||||
|         return a - b; | ||||
|     } | ||||
|  | ||||
|     function safeAdd(uint a, uint b)  | ||||
|         internal  | ||||
|         constant  | ||||
|         returns (uint256)  | ||||
|     { | ||||
|         uint c = a + b; | ||||
|         assert(c >= a); | ||||
|         return c; | ||||
|     } | ||||
|  | ||||
|     function max64(uint64 a, uint64 b)  | ||||
|         internal  | ||||
|         constant  | ||||
|         returns (uint64)  | ||||
|     { | ||||
|         return a >= b ? a : b; | ||||
|     } | ||||
|  | ||||
|     function min64(uint64 a, uint64 b)  | ||||
|         internal  | ||||
|         constant  | ||||
|         returns (uint64)  | ||||
|     { | ||||
|         return a < b ? a : b; | ||||
|     } | ||||
|  | ||||
|     function max256(uint256 a, uint256 b)  | ||||
|         internal  | ||||
|         constant  | ||||
|         returns (uint256)  | ||||
|     { | ||||
|         return a >= b ? a : b; | ||||
|     } | ||||
|  | ||||
|     function min256(uint256 a, uint256 b)  | ||||
|         internal  | ||||
|         constant  | ||||
|         returns (uint256)  | ||||
|     { | ||||
|         return a < b ? a : b; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -1,25 +1,30 @@ | ||||
| { | ||||
|     "private": true, | ||||
|     "name": "contracts", | ||||
|     "version": "2.1.8", | ||||
|     "version": "2.1.12", | ||||
|     "description": "Smart contract components of 0x protocol", | ||||
|     "main": "index.js", | ||||
|     "directories": { | ||||
|         "test": "test" | ||||
|     }, | ||||
|     "scripts": { | ||||
|         "prebuild": "run-s clean copy_artifacts", | ||||
|         "copy_artifacts": "copyfiles './build/**/*' './deploy/solc/solc_bin/*' './deploy/test/fixtures/contracts/**/*' './deploy/test/fixtures/contracts/*' ./lib", | ||||
|         "build:watch": "tsc -w", | ||||
|         "prebuild": "run-s clean copy_artifacts generate_contract_wrappers", | ||||
|         "copy_artifacts": "copyfiles './src/artifacts/**/*' ./lib", | ||||
|         "build": "tsc", | ||||
|         "test": "run-s compile build run_mocha", | ||||
|         "run_mocha": "mocha 'lib/test/**/*.js' --timeout 10000 --bail --exit", | ||||
|         "compile:comment": "Yarn workspaces do not link binaries correctly so we need to reference them directly https://github.com/yarnpkg/yarn/issues/3846", | ||||
|         "compile": "node ../deployer/lib/src/cli.js compile", | ||||
|         "clean": "rm -rf ./lib", | ||||
|         "compile": "node ../deployer/lib/src/cli.js compile --contracts ${npm_package_config_contracts} --contracts-dir src/contracts --artifacts-dir src/artifacts", | ||||
|         "clean": "shx rm -rf ./lib", | ||||
|         "generate_contract_wrappers": "node ../abi-gen/lib/index.js --abis 'src/artifacts/@(DummyToken|TokenTransferProxy|Exchange|TokenRegistry|MultiSigWallet|MultiSigWalletWithTimeLock|MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress|TokenRegistry|ZRXToken).json' --template contract_templates/contract.handlebars --partials 'contract_templates/partials/**/*.handlebars' --output src/contract_wrappers/generated", | ||||
|         "migrate": "node ../deployer/lib/src/cli.js migrate", | ||||
|         "lint": "tslint --project . 'migrations/**/*.ts' 'test/**/*.ts' 'util/**/*.ts' 'deploy/**/*.ts'", | ||||
|         "test:circleci": "yarn test" | ||||
|     }, | ||||
|     "config": { | ||||
|         "contracts": "Exchange,DummyToken,ZRXToken,Token,WETH9,TokenTransferProxy,MultiSigWallet,MultiSigWalletWithTimeLock,MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress,MaliciousToken,TokenRegistry" | ||||
|     }, | ||||
|     "repository": { | ||||
|         "type": "git", | ||||
|         "url": "https://github.com/0xProject/0x.js.git" | ||||
| @@ -31,9 +36,9 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x.js/packages/contracts/README.md", | ||||
|     "devDependencies": { | ||||
|         "@0xproject/dev-utils": "^0.0.9", | ||||
|         "@0xproject/tslint-config": "^0.4.6", | ||||
|         "@0xproject/types": "^0.1.8", | ||||
|         "@0xproject/dev-utils": "^0.0.13", | ||||
|         "@0xproject/tslint-config": "^0.4.9", | ||||
|         "@0xproject/types": "^0.2.2", | ||||
|         "@types/bluebird": "^3.5.3", | ||||
|         "@types/lodash": "^4.14.86", | ||||
|         "@types/node": "^8.0.53", | ||||
| @@ -41,27 +46,28 @@ | ||||
|         "@types/yargs": "^10.0.0", | ||||
|         "chai": "^4.0.1", | ||||
|         "chai-as-promised": "^7.1.0", | ||||
|         "chai-as-promised-typescript-typings": "^0.0.8", | ||||
|         "chai-as-promised-typescript-typings": "^0.0.9", | ||||
|         "chai-bignumber": "^2.0.1", | ||||
|         "chai-typescript-typings": "^0.0.2", | ||||
|         "chai-typescript-typings": "^0.0.3", | ||||
|         "copyfiles": "^1.2.0", | ||||
|         "dirty-chai": "^2.0.1", | ||||
|         "mocha": "^4.0.1", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "solc": "^0.4.18", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "types-bn": "^0.0.1", | ||||
|         "types-ethereumjs-util": "0xproject/types-ethereumjs-util", | ||||
|         "typescript": "~2.6.1", | ||||
|         "web3-typescript-typings": "^0.9.8", | ||||
|         "types-ethereumjs-util": "0xProject/types-ethereumjs-util", | ||||
|         "typescript": "2.7.1", | ||||
|         "web3-typescript-typings": "^0.9.10", | ||||
|         "yargs": "^10.0.3" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "0x.js": "^0.31.1", | ||||
|         "@0xproject/deployer": "^0.0.5", | ||||
|         "@0xproject/json-schemas": "^0.7.7", | ||||
|         "@0xproject/utils": "^0.2.4", | ||||
|         "@0xproject/web3-wrapper": "^0.1.9", | ||||
|         "0x.js": "^0.32.3", | ||||
|         "@0xproject/deployer": "^0.0.9", | ||||
|         "@0xproject/json-schemas": "^0.7.11", | ||||
|         "@0xproject/utils": "^0.3.3", | ||||
|         "@0xproject/web3-wrapper": "^0.1.13", | ||||
|         "bluebird": "^3.5.0", | ||||
|         "bn.js": "^4.11.8", | ||||
|         "ethereumjs-abi": "^0.6.4", | ||||
|   | ||||
							
								
								
									
										313
									
								
								packages/contracts/src/artifacts/DummyToken.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										313
									
								
								packages/contracts/src/artifacts/DummyToken.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										603
									
								
								packages/contracts/src/artifacts/Exchange.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										603
									
								
								packages/contracts/src/artifacts/Exchange.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										188
									
								
								packages/contracts/src/artifacts/MaliciousToken.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								packages/contracts/src/artifacts/MaliciousToken.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										523
									
								
								packages/contracts/src/artifacts/MultiSigWallet.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										523
									
								
								packages/contracts/src/artifacts/MultiSigWallet.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										600
									
								
								packages/contracts/src/artifacts/MultiSigWalletWithTimeLock.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										600
									
								
								packages/contracts/src/artifacts/MultiSigWalletWithTimeLock.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										174
									
								
								packages/contracts/src/artifacts/Token.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								packages/contracts/src/artifacts/Token.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,174 @@ | ||||
| { | ||||
|     "contract_name": "Token", | ||||
|     "networks": { | ||||
|         "50": { | ||||
|             "solc_version": "0.4.18", | ||||
|             "keccak256": "0xe43382be55ddb9c7a28567b4cc59e35072da198e6c49a90ff1396aa8399fd61e", | ||||
|             "optimizer_enabled": 0, | ||||
|             "abi": [ | ||||
|                 { | ||||
|                     "constant": false, | ||||
|                     "inputs": [ | ||||
|                         { | ||||
|                             "name": "_spender", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "name": "_value", | ||||
|                             "type": "uint256" | ||||
|                         } | ||||
|                     ], | ||||
|                     "name": "approve", | ||||
|                     "outputs": [ | ||||
|                         { | ||||
|                             "name": "", | ||||
|                             "type": "bool" | ||||
|                         } | ||||
|                     ], | ||||
|                     "payable": false, | ||||
|                     "stateMutability": "nonpayable", | ||||
|                     "type": "function" | ||||
|                 }, | ||||
|                 { | ||||
|                     "constant": false, | ||||
|                     "inputs": [ | ||||
|                         { | ||||
|                             "name": "_from", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "name": "_to", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "name": "_value", | ||||
|                             "type": "uint256" | ||||
|                         } | ||||
|                     ], | ||||
|                     "name": "transferFrom", | ||||
|                     "outputs": [ | ||||
|                         { | ||||
|                             "name": "", | ||||
|                             "type": "bool" | ||||
|                         } | ||||
|                     ], | ||||
|                     "payable": false, | ||||
|                     "stateMutability": "nonpayable", | ||||
|                     "type": "function" | ||||
|                 }, | ||||
|                 { | ||||
|                     "constant": true, | ||||
|                     "inputs": [ | ||||
|                         { | ||||
|                             "name": "_owner", | ||||
|                             "type": "address" | ||||
|                         } | ||||
|                     ], | ||||
|                     "name": "balanceOf", | ||||
|                     "outputs": [ | ||||
|                         { | ||||
|                             "name": "", | ||||
|                             "type": "uint256" | ||||
|                         } | ||||
|                     ], | ||||
|                     "payable": false, | ||||
|                     "stateMutability": "view", | ||||
|                     "type": "function" | ||||
|                 }, | ||||
|                 { | ||||
|                     "constant": false, | ||||
|                     "inputs": [ | ||||
|                         { | ||||
|                             "name": "_to", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "name": "_value", | ||||
|                             "type": "uint256" | ||||
|                         } | ||||
|                     ], | ||||
|                     "name": "transfer", | ||||
|                     "outputs": [ | ||||
|                         { | ||||
|                             "name": "", | ||||
|                             "type": "bool" | ||||
|                         } | ||||
|                     ], | ||||
|                     "payable": false, | ||||
|                     "stateMutability": "nonpayable", | ||||
|                     "type": "function" | ||||
|                 }, | ||||
|                 { | ||||
|                     "constant": true, | ||||
|                     "inputs": [ | ||||
|                         { | ||||
|                             "name": "_owner", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "name": "_spender", | ||||
|                             "type": "address" | ||||
|                         } | ||||
|                     ], | ||||
|                     "name": "allowance", | ||||
|                     "outputs": [ | ||||
|                         { | ||||
|                             "name": "", | ||||
|                             "type": "uint256" | ||||
|                         } | ||||
|                     ], | ||||
|                     "payable": false, | ||||
|                     "stateMutability": "view", | ||||
|                     "type": "function" | ||||
|                 }, | ||||
|                 { | ||||
|                     "anonymous": false, | ||||
|                     "inputs": [ | ||||
|                         { | ||||
|                             "indexed": true, | ||||
|                             "name": "_from", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "indexed": true, | ||||
|                             "name": "_to", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "indexed": false, | ||||
|                             "name": "_value", | ||||
|                             "type": "uint256" | ||||
|                         } | ||||
|                     ], | ||||
|                     "name": "Transfer", | ||||
|                     "type": "event" | ||||
|                 }, | ||||
|                 { | ||||
|                     "anonymous": false, | ||||
|                     "inputs": [ | ||||
|                         { | ||||
|                             "indexed": true, | ||||
|                             "name": "_owner", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "indexed": true, | ||||
|                             "name": "_spender", | ||||
|                             "type": "address" | ||||
|                         }, | ||||
|                         { | ||||
|                             "indexed": false, | ||||
|                             "name": "_value", | ||||
|                             "type": "uint256" | ||||
|                         } | ||||
|                     ], | ||||
|                     "name": "Approval", | ||||
|                     "type": "event" | ||||
|                 } | ||||
|             ], | ||||
|             "unlinked_binary": | ||||
|                 "0x6060604052341561000f57600080fd5b6102ac8061001e6000396000f30060606040526004361061006d576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063095ea7b31461007257806323b872dd146100cc57806370a0823114610145578063a9059cbb14610192578063dd62ed3e146101ec575b600080fd5b341561007d57600080fd5b6100b2600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610258565b604051808215151515815260200191505060405180910390f35b34156100d757600080fd5b61012b600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610260565b604051808215151515815260200191505060405180910390f35b341561015057600080fd5b61017c600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610269565b6040518082815260200191505060405180910390f35b341561019d57600080fd5b6101d2600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610270565b604051808215151515815260200191505060405180910390f35b34156101f757600080fd5b610242600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610278565b6040518082815260200191505060405180910390f35b600092915050565b60009392505050565b6000919050565b600092915050565b6000929150505600a165627a7a723058201ef98a5ecc619c89a935fee340b114a09fe44aa51aa765f4037dd3423f49d42d0029", | ||||
|             "updated_at": 1518645860796 | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										540
									
								
								packages/contracts/src/artifacts/TokenRegistry.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										540
									
								
								packages/contracts/src/artifacts/TokenRegistry.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										180
									
								
								packages/contracts/src/artifacts/TokenTransferProxy.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										180
									
								
								packages/contracts/src/artifacts/TokenTransferProxy.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										292
									
								
								packages/contracts/src/artifacts/WETH9.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										292
									
								
								packages/contracts/src/artifacts/WETH9.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										226
									
								
								packages/contracts/src/artifacts/ZRXToken.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										226
									
								
								packages/contracts/src/artifacts/ZRXToken.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										8
									
								
								packages/contracts/src/contract_wrappers/generated/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								packages/contracts/src/contract_wrappers/generated/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| dummy_token.ts | ||||
| exchange.ts | ||||
| multi_sig_wallet_with_time_lock_except_remove_authorized_address.ts | ||||
| multi_sig_wallet_with_time_lock.ts | ||||
| multi_sig_wallet.ts | ||||
| token_registry.ts | ||||
| token_transfer_proxy.ts | ||||
| zrx_token.ts | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user