Compare commits
	
		
			1746 Commits
		
	
	
		
			@0xproject
			...
			@0xproject
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 512dbb448b | ||
|  | b793c1cc73 | ||
|  | aea048ecc7 | ||
|  | d0e6413fcf | ||
|  | 3b7ad1688b | ||
|  | e907b99314 | ||
|  | 973bcb0483 | ||
|  | 87fb9a76ce | ||
|  | 0187e0c47d | ||
|  | 8732d8ece8 | ||
|  | 2e7c130f62 | ||
|  | a90f434df5 | ||
|  | 3b005ad47c | ||
|  | 735bc2f178 | ||
|  | e3cfa6363d | ||
|  | 331b1cb9a0 | ||
|  | 55dbb0ece0 | ||
|  | af4071e119 | ||
|  | 9947e643d0 | ||
|  | d3be4f2852 | ||
|  | e320f343f8 | ||
|  | f6cc7d9c3c | ||
|  | b756f76b0e | ||
|  | 034948065d | ||
|  | 0c2df7e589 | ||
|  | 2ae6a71ca3 | ||
|  | 206fd0f78e | ||
|  | b84225ac70 | ||
|  | 5ebcea53d6 | ||
|  | a491e01144 | ||
|  | 1236efc008 | ||
|  | e63bbdeb87 | ||
|  | 084ccb62a6 | ||
|  | 015469885d | ||
|  | 061f223269 | ||
|  | 88ee35d5f9 | ||
|  | 6c5b33ec71 | ||
|  | 31b8dd1bfc | ||
|  | 35113487f1 | ||
|  | 9ce8e10115 | ||
|  | d07d059eda | ||
|  | d836b0f815 | ||
|  | 1b1733ce7c | ||
|  | 5fd64a969b | ||
|  | 9a762e584c | ||
|  | 7fc0fd9fb6 | ||
|  | da4b70fcae | ||
|  | a0db69ee05 | ||
|  | 2c62504b79 | ||
|  | 67303106dc | ||
|  | 600d574042 | ||
|  | 07d4f21807 | ||
|  | 4da12067b9 | ||
|  | 24ab24879c | ||
|  | dc51741b83 | ||
|  | dd979dbf6d | ||
|  | 0cfea5613a | ||
|  | 98dd3ecab7 | ||
|  | fe05e0bac3 | ||
|  | d3f9b72c84 | ||
|  | 05b35c0fdc | ||
|  | 36b61650b3 | ||
|  | c37b6f0eeb | ||
|  | 28114c3b5a | ||
|  | 2617df4ec7 | ||
|  | 0d28c48eb9 | ||
|  | c6a6a54cce | ||
|  | e5aa03da64 | ||
|  | 47c0195b07 | ||
|  | f13d43dbf5 | ||
|  | f9e99a27d3 | ||
|  | 854b8fad22 | ||
|  | 91c7105d43 | ||
|  | c1e3533287 | ||
|  | bb7c308081 | ||
|  | fcbaf2f4e3 | ||
|  | 109c5df973 | ||
|  | b0fab3ea4a | ||
|  | c40b3dea6c | ||
|  | dbc798596b | ||
|  | fac90c446c | ||
|  | c5859b65a3 | ||
|  | 14bb697924 | ||
|  | dbd815c1e0 | ||
|  | 9592a9a821 | ||
|  | dd9f020c9b | ||
|  | 56f21f4bab | ||
|  | 91bc1b468b | ||
|  | 97268d2253 | ||
|  | 14b3c50b69 | ||
|  | 333bf9de05 | ||
|  | 16a38c687e | ||
|  | 24aa5cd1bf | ||
|  | f699da90ba | ||
|  | d1e33a3dff | ||
|  | f50ac932d6 | ||
|  | cab32d7593 | ||
|  | 2073aa9abc | ||
|  | 0386025395 | ||
|  | 0772403ea9 | ||
|  | 8acfc9a2f9 | ||
|  | de087abc8d | ||
|  | 98b2875512 | ||
|  | e9e73aa0a3 | ||
|  | d280311734 | ||
|  | 789762617f | ||
|  | 6f38d1bee5 | ||
|  | 73d75bc405 | ||
|  | 91dcfd5ee8 | ||
|  | 5fe0e9f2e7 | ||
|  | 51fb6e6a23 | ||
|  | 9392d5c84f | ||
|  | e49d136b99 | ||
|  | d50174b89e | ||
|  | 1d9a77027e | ||
|  | b4cd8897b2 | ||
|  | df341717f7 | ||
|  | 68974313e1 | ||
|  | 39a06e1d3b | ||
|  | bfe57b84d6 | ||
|  | dae975b08c | ||
|  | 27d44e3021 | ||
|  | df00d93b9c | ||
|  | 15bbbb3762 | ||
|  | c9ee526d8b | ||
|  | b110d95de1 | ||
|  | 76eab5d3ec | ||
|  | 4a2715e61f | ||
|  | 7fbcc3999f | ||
|  | e873b8948f | ||
|  | c8108a1db2 | ||
|  | 195c3af84e | ||
|  | 39724292e3 | ||
|  | 24b5aa0e82 | ||
|  | 3af2ef8439 | ||
|  | e2d027e252 | ||
|  | bddcebfbb1 | ||
|  | a05b14e4d9 | ||
|  | 9a36e73f4e | ||
|  | a66ccaa1da | ||
|  | f05a563802 | ||
|  | 06396b8874 | ||
|  | e5e68de2d7 | ||
|  | dcc0908617 | ||
|  | 45d68285f1 | ||
|  | e20f3a0f97 | ||
|  | c5029e61e3 | ||
|  | e90ed01105 | ||
|  | d8099d53fe | ||
|  | 0a976a3fb8 | ||
|  | 4636d5fbc2 | ||
|  | 3506ec1caa | ||
|  | 1f0e819756 | ||
|  | 799ff2a5c3 | ||
|  | ec5f768f9b | ||
|  | 66ab010055 | ||
|  | 6fb157488c | ||
|  | 814518dd80 | ||
|  | 554b18a466 | ||
|  | 855b6b1dc5 | ||
|  | c2ae9f62a4 | ||
|  | 4159a8fe6e | ||
|  | d8b44283a2 | ||
|  | 2c1daf9c9a | ||
|  | c7962216e9 | ||
|  | ffdaf88fd0 | ||
|  | f84f879950 | ||
|  | eb6027fba7 | ||
|  | 9a1f0ac8e2 | ||
|  | 51b6f8bc71 | ||
|  | 4f73b81b9c | ||
|  | 195d11f9d0 | ||
|  | b325ad1735 | ||
|  | 74483631d0 | ||
|  | 89b24a21a0 | ||
|  | f0f13aa1dd | ||
|  | 06f61949f9 | ||
|  | 0e72b67865 | ||
|  | b987eebf21 | ||
|  | c808d12b74 | ||
|  | b466431ede | ||
|  | bf69ca6e53 | ||
|  | 6ffa907f0e | ||
|  | e54501522d | ||
|  | f2baeddc30 | ||
|  | fd349b618a | ||
|  | 6ca2a02766 | ||
|  | d9a282bd92 | ||
|  | dc151f7290 | ||
|  | cce2127f72 | ||
|  | ad4c2b95e4 | ||
|  | 8e7c395f59 | ||
|  | 02d50a513a | ||
|  | d61759f6dd | ||
|  | 5790ed7ba9 | ||
|  | 067adbfb62 | ||
|  | 7fadba59e7 | ||
|  | bcde0731db | ||
|  | 052afb67a4 | ||
|  | 6e15d7bb0f | ||
|  | 5bb68974ec | ||
|  | 0a3ba4d27d | ||
|  | 482a226dc5 | ||
|  | 9e69458ba8 | ||
|  | 71e386d5fa | ||
|  | 60b501b137 | ||
|  | 36f8e9f1d5 | ||
|  | 78707bd3ca | ||
|  | 56137d0605 | ||
|  | 681a582630 | ||
|  | 846a447c4d | ||
|  | f76be4f016 | ||
|  | ed19067096 | ||
|  | eb9f7c2c9d | ||
|  | 52693f7d0a | ||
|  | 5e015872ef | ||
|  | 08c291bd3f | ||
|  | 48c5d69c9d | ||
|  | 0f9c262bb0 | ||
|  | dff0fc65bf | ||
|  | 161f96c07d | ||
|  | 67ad21b368 | ||
|  | d5e633c38f | ||
|  | 617ef5b6ce | ||
|  | 8bd4e38d02 | ||
|  | f364b5c5ab | ||
|  | 6486fced34 | ||
|  | bc9f2a51a2 | ||
|  | 9c03b54d75 | ||
|  | eae08ea1e4 | ||
|  | 6f276223c6 | ||
|  | 21effcaa8b | ||
|  | 114b31a813 | ||
|  | 1a1b7a2bc4 | ||
|  | c9b213839a | ||
|  | 4043fa76cc | ||
|  | 9c8e3bc4c9 | ||
|  | 18b1f01641 | ||
|  | 9085c674e4 | ||
|  | b5d19d3fb1 | ||
|  | cc0477153b | ||
|  | 76008b41c5 | ||
|  | 8193fdc304 | ||
|  | 9d06c81078 | ||
|  | cdf85e5eee | ||
|  | d774dbc432 | ||
|  | 0369f5ebc4 | ||
|  | 1e6b11b27e | ||
|  | 7a8231435b | ||
|  | b1aa7725df | ||
|  | bfe0ba3e9a | ||
|  | 2d39329ee7 | ||
|  | 761b0063a0 | ||
|  | 0f27ce3424 | ||
|  | 2b0c0a6ff7 | ||
|  | 5bd96f6fe9 | ||
|  | 37ac6749ba | ||
|  | bf955bd87f | ||
|  | 6bd921d0bc | ||
|  | 534decea95 | ||
|  | 267830d463 | ||
|  | e82d0c21ec | ||
|  | ece6417699 | ||
|  | 74d5449719 | ||
|  | 4af7ff9cc3 | ||
|  | 46dedfcb67 | ||
|  | a9fa1a0df6 | ||
|  | a8572b4944 | ||
|  | 91c0d47ad4 | ||
|  | fd2611794a | ||
|  | 1fe1c5321b | ||
|  | f063a5db0f | ||
|  | 3883315447 | ||
|  | 7679e07957 | ||
|  | c39ba37ad8 | ||
|  | f1c3840c3b | ||
|  | e5c5b36a73 | ||
|  | c51f7a8375 | ||
|  | e53e2ac31b | ||
|  | b72857cd8b | ||
|  | cc223b9eab | ||
|  | f2c49e8b37 | ||
|  | 9b6476a6b7 | ||
|  | d8898cf9a3 | ||
|  | 34df5af295 | ||
|  | 3de88d5345 | ||
|  | 9ab6ab1bf9 | ||
|  | b6de0bdd43 | ||
|  | a2b62fd808 | ||
|  | fc166dea26 | ||
|  | f9c4d0925e | ||
|  | 1df9370bc2 | ||
|  | 7d840c7a18 | ||
|  | ff12aafc0f | ||
|  | c08b4aa6a1 | ||
|  | 52a6e6357b | ||
|  | 74c0fd419b | ||
|  | 6f540e3e58 | ||
|  | dead04dce8 | ||
|  | 886a03fdcd | ||
|  | 81007c453c | ||
|  | 6529e06057 | ||
|  | 55336f96d7 | ||
|  | 938aabde3d | ||
|  | c7f196b579 | ||
|  | b28a88dbb2 | ||
|  | e6558b7135 | ||
|  | 2c8fb9aa31 | ||
|  | f48c6b6285 | ||
|  | 4f42f60bde | ||
|  | 3942647910 | ||
|  | e0fbc78925 | ||
|  | f3e43d7d94 | ||
|  | f36547241c | ||
|  | 7ad29950a8 | ||
|  | cbf91ad45c | ||
|  | a039b66533 | ||
|  | 3a18c249f5 | ||
|  | 7c0775aa1b | ||
|  | 6514c34ed8 | ||
|  | ba92754669 | ||
|  | 30afd39129 | ||
|  | 41699406cf | ||
|  | 9aa49e59d0 | ||
|  | 29d5034260 | ||
|  | 00d1622b3f | ||
|  | a1acf19ff3 | ||
|  | 86328af6b7 | ||
|  | 36c27bdbf8 | ||
|  | c839965c05 | ||
|  | e1a9f3435f | ||
|  | 9f74feb347 | ||
|  | f99232095b | ||
|  | 5044fe4fe4 | ||
|  | 8e49169e6b | ||
|  | c71781d9ab | ||
|  | 8a2a4052f3 | ||
|  | dad557164e | ||
|  | e2fb49a8f8 | ||
|  | f3241ff86a | ||
|  | b9e7973a0f | ||
|  | 004b1f5288 | ||
|  | 857bd24c6d | ||
|  | 904968cf4a | ||
|  | 83747934ad | ||
|  | 7f90f5ecd4 | ||
|  | 12f02b9814 | ||
|  | 8931388309 | ||
|  | 25160d7344 | ||
|  | ab6bf6edc7 | ||
|  | 56a4a374cd | ||
|  | caa5b4e342 | ||
|  | b6172c3965 | ||
|  | 02ddfa07a7 | ||
|  | 5022878680 | ||
|  | 2bfacbb8ba | ||
|  | b18d2b0274 | ||
|  | f20b496dca | ||
|  | cca17f70b8 | ||
|  | b8e69718a1 | ||
|  | 50ed7d2af2 | ||
|  | 698de932ed | ||
|  | a3d8858bb1 | ||
|  | 83f3ba21b8 | ||
|  | 2aa729b212 | ||
|  | 1de70e4474 | ||
|  | f2393de59b | ||
|  | 94ea7cc451 | ||
|  | f8dbf57582 | ||
|  | c59cd36da6 | ||
|  | 15e92958d6 | ||
|  | 96c648c4b4 | ||
|  | f56a7d0cb2 | ||
|  | 01e617bb83 | ||
|  | 59fd5c69c0 | ||
|  | 28a9a8c380 | ||
|  | 6c2796b433 | ||
|  | 82ad5f7897 | ||
|  | bf8ac3b9e6 | ||
|  | edcdc9b1b9 | ||
|  | 4227aaa68a | ||
|  | b750ce8be6 | ||
|  | 03a6a088c5 | ||
|  | 1e787a7646 | ||
|  | 766ac3f1fe | ||
|  | a9038f2afc | ||
|  | 9828fa335e | ||
|  | 0c04d490bb | ||
|  | bffffffc95 | ||
|  | e9589ff786 | ||
|  | c3bd3437f5 | ||
|  | 01789e6750 | ||
|  | c3f7ba1b91 | ||
|  | 90d72a3683 | ||
|  | f9bcf936ed | ||
|  | acff177c54 | ||
|  | 658214a2e2 | ||
|  | 55f6f02c9b | ||
|  | c5ba52910a | ||
|  | 994ccd6694 | ||
|  | 4921a83813 | ||
|  | a97ba41b86 | ||
|  | 67e2623d2c | ||
|  | 4111095da3 | ||
|  | 6c21ddcedb | ||
|  | d86349658f | ||
|  | 151ce6e3c7 | ||
|  | 6bdee26c30 | ||
|  | 5e4b1eed30 | ||
|  | ab5cd95ccc | ||
|  | a3dc398da5 | ||
|  | b70f5d1a1e | ||
|  | 26363931ed | ||
|  | e2438330f5 | ||
|  | c5fcdd0657 | ||
|  | 345f3c07a5 | ||
|  | f3477ff28c | ||
|  | 7ac4fa50b5 | ||
|  | 2f0a914838 | ||
|  | 5fc7d9a603 | ||
|  | ced68e4e02 | ||
|  | 80071beaac | ||
|  | de1029d5ef | ||
|  | ffeb3194a8 | ||
|  | 95e9f33f6a | ||
|  | c599a20b34 | ||
|  | ca59528a32 | ||
|  | 6f4fd06d38 | ||
|  | 4715c2d006 | ||
|  | fcfa43b6f1 | ||
|  | 56b4c55654 | ||
|  | 830790eeac | ||
|  | 39de9c7879 | ||
|  | 7b6cc14b71 | ||
|  | ec749a4033 | ||
|  | fe32214613 | ||
|  | f6fcb775b7 | ||
|  | d209108a95 | ||
|  | efc64cf17f | ||
|  | 2f41ed50c1 | ||
|  | fcc8cdd36a | ||
|  | 248632ce76 | ||
|  | 25681754bd | ||
|  | 179c487da9 | ||
|  | 350989bbec | ||
|  | f5293e6c38 | ||
|  | 70c3515c94 | ||
|  | 4c7fd5a4e8 | ||
|  | 9d24341d94 | ||
|  | 512502ca08 | ||
|  | 6ce662c7a4 | ||
|  | 701ea5c46b | ||
|  | 2e5ff53d72 | ||
|  | 1229c61ba4 | ||
|  | ee54438e92 | ||
|  | 65af78c85d | ||
|  | b4747c3f85 | ||
|  | 1df074b73e | ||
|  | 254d30b8df | ||
|  | ac5588c7c4 | ||
|  | ddb70a89ad | ||
|  | f4b2a9625d | ||
|  | c2a1317c38 | ||
|  | 49f1a6933c | ||
|  | 9b387b8ec3 | ||
|  | a45a29432e | ||
|  | 819d069edc | ||
|  | b0a57a5091 | ||
|  | d8678d562d | ||
|  | 34a9035164 | ||
|  | 0941e0a929 | ||
|  | 1ee78062d7 | ||
|  | 09f5609618 | ||
|  | 098322c564 | ||
|  | 365e24c1cd | ||
|  | b82fdd59e7 | ||
|  | 6190ac7791 | ||
|  | ed3aeb7997 | ||
|  | 33f92b6bcf | ||
|  | 9131a72a47 | ||
|  | e5617dfe61 | ||
|  | e67d67419f | ||
|  | 17c34716f9 | ||
|  | e12f7c3026 | ||
|  | af395eccda | ||
|  | c403dcdabf | ||
|  | c500cc095f | ||
|  | 6ecda647ad | ||
|  | 3e7ee1f090 | ||
|  | 0c120cb7a3 | ||
|  | cab6829df9 | ||
|  | 0efe6df416 | ||
|  | a4b6112a31 | ||
|  | 47debf0134 | ||
|  | 16ddd1edfc | ||
|  | 0f1fd0e90d | ||
|  | ef76d83d2a | ||
|  | df9f6004f2 | ||
|  | 9a87f99dcd | ||
|  | 30011db6d7 | ||
|  | b6ac132c78 | ||
|  | abf87a643d | ||
|  | 3824ea9079 | ||
|  | 5e22ce05c5 | ||
|  | 8fcc7aefa7 | ||
|  | 0b6ea1d046 | ||
|  | 22d3981a74 | ||
|  | 81b4f4928d | ||
|  | dd77a38535 | ||
|  | d319b53e23 | ||
|  | b9627e14d0 | ||
|  | 56a96d36a1 | ||
|  | e60630fa73 | ||
|  | 5ef6613024 | ||
|  | af7e02de27 | ||
|  | 51d5b9d35d | ||
|  | 092ca6bcf5 | ||
|  | 2625cbbfed | ||
|  | cedd1d5596 | ||
|  | fb9e14a229 | ||
|  | 4e1bd7b5f0 | ||
|  | 5dfed8cd00 | ||
|  | a2672a0d78 | ||
|  | ee5ac6b800 | ||
|  | a481d2ab46 | ||
|  | c8bb21d12d | ||
|  | e817cd7d43 | ||
|  | bd6085fffd | ||
|  | 7efe9a9385 | ||
|  | 50da40a727 | ||
|  | 48390a1875 | ||
|  | a3d27cd128 | ||
|  | 589c814ee6 | ||
|  | 4b60a3cbab | ||
|  | 1aaf633df8 | ||
|  | 82771ec64a | ||
|  | ada8a402da | ||
|  | 17956efe35 | ||
|  | 8378c9f85e | ||
|  | 324b1079e7 | ||
|  | c6da829713 | ||
|  | 844b0687a6 | ||
|  | 2ed2dd2fb7 | ||
|  | d2f7dd3d5a | ||
|  | 9f08916cf1 | ||
|  | a0e3676e3a | ||
|  | 2276793629 | ||
|  | a9b320e636 | ||
|  | ecdc0636d8 | ||
|  | ea12e34809 | ||
|  | 9fb7865292 | ||
|  | 12f30c78ff | ||
|  | e3bed5cc71 | ||
|  | 0f8f5ca5ff | ||
|  | 0fe0433b9a | ||
|  | ab1e38701d | ||
|  | 258fe8ea50 | ||
|  | 813824868e | ||
|  | 028184947f | ||
|  | 14c96e0b97 | ||
|  | ef03d1ae13 | ||
|  | f1613d36ac | ||
|  | 8314bbbbac | ||
|  | 462f1f00d8 | ||
|  | 1c80bba4dd | ||
|  | d22cff0976 | ||
|  | 269b56b907 | ||
|  | 60ebfcf36d | ||
|  | 824c331ea0 | ||
|  | b9e51d2fad | ||
|  | 9669a4d121 | ||
|  | e929fb4337 | ||
|  | 80da9cd31f | ||
|  | 5ed7a1baba | ||
|  | 07c111d1f5 | ||
|  | a2024da955 | ||
|  | 7418926ebb | ||
|  | 4cc33d270e | ||
|  | f767f5c12c | ||
|  | 0ea3b10efd | ||
|  | d634775d40 | ||
|  | c4ab5bc653 | ||
|  | 1d3bdfc374 | ||
|  | 72fb1ee36f | ||
|  | afbc4989d5 | ||
|  | d2e422cd5e | ||
|  | 49c7365d93 | ||
|  | c753e24f0a | ||
|  | acfbba5476 | ||
|  | e796734659 | ||
|  | f172908bde | ||
|  | 16dc4e9f66 | ||
|  | 8eefc89d55 | ||
|  | 20d349cea7 | ||
|  | 22f408f713 | ||
|  | 1e0fa776c1 | ||
|  | faf5c84082 | ||
|  | b21f6e4d86 | ||
|  | bc52303402 | ||
|  | 2da705e81c | ||
|  | a0601cd052 | ||
|  | ed2c06508b | ||
|  | 03b3d74748 | ||
|  | 0557d6a9bf | ||
|  | d975c0cef3 | ||
|  | 188bf000b7 | ||
|  | 608442b2e8 | ||
|  | aefc122caf | ||
|  | a72eae7ea8 | ||
|  | 30e3afc0fb | ||
|  | 97809a03eb | ||
|  | f894ffc0cc | ||
|  | 127fbc6e94 | ||
|  | 9f870b3d4e | ||
|  | 51b86742d1 | ||
|  | 3a85b3212b | ||
|  | fd6445439e | ||
|  | 51fa8d3e24 | ||
|  | 7b8db1156d | ||
|  | 32ad34d224 | ||
|  | cfbb1c440e | ||
|  | ade2f96ca3 | ||
|  | abb38e1bc0 | ||
|  | 0df36471b7 | ||
|  | 97312c2656 | ||
|  | e9e4df4891 | ||
|  | e0f80c5e6a | ||
|  | f21b042ed1 | ||
|  | d8c7c9803c | ||
|  | 302b9deef3 | ||
|  | 0c8264801a | ||
|  | 54d1a0359f | ||
|  | b87e48c113 | ||
|  | a874cd2424 | ||
|  | d9e308e53a | ||
|  | efc3536283 | ||
|  | 4b7e669d29 | ||
|  | 01c6efeaf1 | ||
|  | 22cf7bee5b | ||
|  | ef890aeac4 | ||
|  | 91e8c00076 | ||
|  | 20bf4d8ef9 | ||
|  | 795da130a2 | ||
|  | 51a625d4af | ||
|  | ab8544b0ff | ||
|  | b68d16820f | ||
|  | 61d9cdced0 | ||
|  | 714f9ed207 | ||
|  | ccccaf8e12 | ||
|  | c3ce9d6104 | ||
|  | d3f602f063 | ||
|  | 6b379a8a0f | ||
|  | d1d636f1ca | ||
|  | ba9d3cbdb8 | ||
|  | bcf8d51806 | ||
|  | 66c0d6724a | ||
|  | 0f477607f9 | ||
|  | c1635f2656 | ||
|  | 029d91bd7a | ||
|  | 03dbad6813 | ||
|  | c65b2573c4 | ||
|  | 7fbee77875 | ||
|  | 3cc1a952ca | ||
|  | 9c8de3e933 | ||
|  | cbdce6b67e | ||
|  | a6746ae5cd | ||
|  | 7111f3ffc6 | ||
|  | 87a7a4ad2d | ||
|  | 1ee2d6ed54 | ||
|  | 1eba78e20a | ||
|  | a1fb438a8c | ||
|  | 40d1b0a23c | ||
|  | 1c9a657693 | ||
|  | 11747c6cf4 | ||
|  | 2a7b3aecc3 | ||
|  | 75babed693 | ||
|  | 0a32ae6cb5 | ||
|  | 3d67f122a5 | ||
|  | b0daec8384 | ||
|  | f5b1fe0e6b | ||
|  | 139d289b01 | ||
|  | fd242a9cba | ||
|  | 7efa17ef7d | ||
|  | a0b9c7777b | ||
|  | 5204e4c08d | ||
|  | 1050ecdf3c | ||
|  | 5176d929fa | ||
|  | d712dc47d9 | ||
|  | 8adc6f0faa | ||
|  | 4e783fba57 | ||
|  | ade620f4f7 | ||
|  | 5915f8430c | ||
|  | 9e0f06d060 | ||
|  | ce86ae0191 | ||
|  | 2bec5cb7fd | ||
|  | cd766ea2a1 | ||
|  | aeea3817a4 | ||
|  | 0f11ae1875 | ||
|  | 6e87e3e1ac | ||
|  | 4ba108d12f | ||
|  | 8ff17ff960 | ||
|  | 0d56daf7ab | ||
|  | 9db0bc262b | ||
|  | f410903465 | ||
|  | 5f2c303bd8 | ||
|  | 6aa4984fed | ||
|  | f5cd1ac82e | ||
|  | 54c0b7b261 | ||
|  | a7902eca1f | ||
|  | 2b4bb579d4 | ||
|  | 52c956222e | ||
|  | 0900e0c85e | ||
|  | a5653337c1 | ||
|  | d097113639 | ||
|  | 9389d64392 | ||
|  | 931e7e7d71 | ||
|  | cce2fb40a1 | ||
|  | 547cf4bef3 | ||
|  | d528ce757c | ||
|  | 3b78188fec | ||
|  | d91b30faef | ||
|  | dc956020ef | ||
|  | a52eb81380 | ||
|  | ab0055d5c6 | ||
|  | 32c25a2034 | ||
|  | c30b42434a | ||
|  | 3c797a6e11 | ||
|  | 9b864517e2 | ||
|  | a858e2870b | ||
|  | ce1542da4f | ||
|  | d2ebf4a777 | ||
|  | c5fcea1dbd | ||
|  | 5e8ef070e2 | ||
|  | 2d30c290e9 | ||
|  | 688b34710e | ||
|  | afbfc8ba1c | ||
|  | 671f29774b | ||
|  | 4c99ac0ca2 | ||
|  | 0e690608d3 | ||
|  | 92f6391df5 | ||
|  | f2af6e4b3a | ||
|  | 27c03cffe2 | ||
|  | 499915042e | ||
|  | 1a901554cc | ||
|  | 5b64b3ea93 | ||
|  | 6fc5c0cd46 | ||
|  | 328da21420 | ||
|  | 81062d20eb | ||
|  | 835d06dcdc | ||
|  | 8929543b55 | ||
|  | f62044c1e3 | ||
|  | a31f7a5112 | ||
|  | fe68114f39 | ||
|  | a5231df6d9 | ||
|  | fd545ec00f | ||
|  | 73d8a2adf7 | ||
|  | 04d11d6fac | ||
|  | 2eede4a09e | ||
|  | bc7e8ff471 | ||
|  | 73e81c62fb | ||
|  | 8c5dc7cecd | ||
|  | 300c9f09b9 | ||
|  | 06f4427939 | ||
|  | b1dc20bbb3 | ||
|  | 4887d1d42f | ||
|  | d247d72e3e | ||
|  | 50957e1d29 | ||
|  | 6aad12a52f | ||
|  | db0944acde | ||
|  | e553ef83de | ||
|  | a619949a56 | ||
|  | 1346fa792a | ||
|  | b763cdbd4c | ||
|  | e4eac14dc9 | ||
|  | bdda1f2992 | ||
|  | 9c7289d7a3 | ||
|  | d861caca23 | ||
|  | 590033bcb2 | ||
|  | af1e4574a8 | ||
|  | 7b806fe84d | ||
|  | e54e2ac67b | ||
|  | de9f0732a0 | ||
|  | 20acdbf6c3 | ||
|  | 6a6d2f73a8 | ||
|  | f5a8f00af8 | ||
|  | 018a437d62 | ||
|  | 32d75b6483 | ||
|  | cb6cace910 | ||
|  | 0326ddd79d | ||
|  | d6f40a9281 | ||
|  | 687802394a | ||
|  | ad570b8ae1 | ||
|  | b9165c03af | ||
|  | cfe57f52f4 | ||
|  | 86d4ffe7e5 | ||
|  | 2dea179333 | ||
|  | 5a7908984e | ||
|  | 955fdf5d13 | ||
|  | a6f40d4187 | ||
|  | 6daf754f5b | ||
|  | da8cf9981e | ||
|  | be64184cfa | ||
|  | 3031598843 | ||
|  | b9b00e10d3 | ||
|  | 6c34255a3e | ||
|  | 41064adc66 | ||
|  | 2fcc36bbad | ||
|  | 762c0143eb | ||
|  | 6c6f34ee72 | ||
|  | 42b7b0dab9 | ||
|  | e58e35e098 | ||
|  | 654b048602 | ||
|  | 3ece72af49 | ||
|  | 2ef31991c7 | ||
|  | d3293a5571 | ||
|  | 854752acdf | ||
|  | 0c889385f1 | ||
|  | 6e1a549fcb | ||
|  | 5f0a2953c6 | ||
|  | 78b513c52a | ||
|  | 8ffce78827 | ||
|  | d4852092b8 | ||
|  | 622ce0bf2e | ||
|  | 6a197a64e6 | ||
|  | 1e4c3ed22b | ||
|  | e3521c6388 | ||
|  | 9d81e069dc | ||
|  | 8623a30763 | ||
|  | 6cf39896f1 | ||
|  | 44b6adaa29 | ||
|  | 762a6199b2 | ||
|  | 8da42b12f4 | ||
|  | c473a0444c | ||
|  | e693629bbd | ||
|  | 0dbe883c3b | ||
|  | cc12bc9247 | ||
|  | ddec01e6c1 | ||
|  | 03bc7bb935 | ||
|  | 5207dfdc0e | ||
|  | fc40efb761 | ||
|  | 50556e2609 | ||
|  | 7a22298597 | ||
|  | 36cadaae46 | ||
|  | 09e921a562 | ||
|  | 13cbaf56b2 | ||
|  | 62910c8e89 | ||
|  | f20e1acad9 | ||
|  | 5dea432ebf | ||
|  | 016d82d766 | ||
|  | 260c72cc20 | ||
|  | 3d7bcd7ecb | ||
|  | ac9175bf88 | ||
|  | 294d3bbdc1 | ||
|  | 6db614251e | ||
|  | bcc588efe7 | ||
|  | f7b3fc58bc | ||
|  | de40497330 | ||
|  | d84bb7ed7e | ||
|  | f02ada2d11 | ||
|  | 48970d3424 | ||
|  | 8940b1759d | ||
|  | 91a50d0f53 | ||
|  | ed4f8c5b66 | ||
|  | 2f07ee0a8f | ||
|  | 8dd00a8eef | ||
|  | d7845a177e | ||
|  | 7a3be0a320 | ||
|  | 14cebce304 | ||
|  | 9fcf9f2504 | ||
|  | c466ab6cf2 | ||
|  | 01bf789ad4 | ||
|  | 1a1ab5af54 | ||
|  | 4089ad7b4b | ||
|  | 2adc299c78 | ||
|  | 3aef323c13 | ||
|  | a655cd046c | ||
|  | 9c8701f5f6 | ||
|  | 7ac84aff0a | ||
|  | fd13c8f68c | ||
|  | 532964af42 | ||
|  | 52d1407215 | ||
|  | ecb7356345 | ||
|  | edda7dae94 | ||
|  | 32da0a376a | ||
|  | 073e76ee90 | ||
|  | ceba82260f | ||
|  | a5a61c87fc | ||
|  | d34feb1e0a | ||
|  | 6cc5e45183 | ||
|  | 618c7ef48a | ||
|  | 14047f9c7b | ||
|  | f439f162d2 | ||
|  | 5b685b32bd | ||
|  | 6ce151c676 | ||
|  | eb79b5d651 | ||
|  | 608e1c8960 | ||
|  | f8772d8850 | ||
|  | ce2f408864 | ||
|  | c2a362e3ea | ||
|  | eafdd4d42d | ||
|  | 1a2c58494f | ||
|  | 68c00976f1 | ||
|  | aa2616b307 | ||
|  | 3062c18ebd | ||
|  | a83f5241dc | ||
|  | f89acb49be | ||
|  | 2b5f45676f | ||
|  | aedd51a61b | ||
|  | 0b5a49c17d | ||
|  | 08f7666d21 | ||
|  | 81ff99276b | ||
|  | e71862676c | ||
|  | 67777c586d | ||
|  | 9ada8e4ddf | ||
|  | 0142e7fa8f | ||
|  | 467e9abf5f | ||
|  | 512980d9bd | ||
|  | e235a63119 | ||
|  | 4c28b66539 | ||
|  | 46d79e5115 | ||
|  | d79994fbb2 | ||
|  | 518a2da027 | ||
|  | 71fa92dbeb | ||
|  | 172d2353dd | ||
|  | 3315006c45 | ||
|  | 6700745585 | ||
|  | 0ff18058ab | ||
|  | 1a11283086 | ||
|  | ed559be47c | ||
|  | a60dd1cbaf | ||
|  | 7ee37fb62a | ||
|  | 2970e103db | ||
|  | 78333b3026 | ||
|  | 1ca182e741 | ||
|  | 8419db53bb | ||
|  | f76c9bc226 | ||
|  | 6a39a69afe | ||
|  | 2474d1d2f4 | ||
|  | e4188f5d4c | ||
|  | 0fcbd02d50 | ||
|  | 4969797c23 | ||
|  | 0e932286d2 | ||
|  | 366a9502dd | ||
|  | 988a334758 | ||
|  | 4fe6269043 | ||
|  | 646927962a | ||
|  | b56baefaa6 | ||
|  | f49a507297 | ||
|  | c20549e88d | ||
|  | cd16986942 | ||
|  | e481404a14 | ||
|  | 3dfde15133 | ||
|  | 4454cfa65d | ||
|  | 382839464f | ||
|  | cce5585795 | ||
|  | 26a9fe9127 | ||
|  | 47a267c3fa | ||
|  | 36836eb942 | ||
|  | aad0804a1e | ||
|  | 3c68d9c297 | ||
|  | ffdc7d13a9 | ||
|  | c5085d8364 | ||
|  | 00ad7bc470 | ||
|  | 360927ec77 | ||
|  | b6f546ebe0 | ||
|  | 2a092143dc | ||
|  | de50407953 | ||
|  | 57d5fbfbd8 | ||
|  | 92322c0e07 | ||
|  | 97ed453eb4 | ||
|  | 654b782810 | ||
|  | 51211a21ba | ||
|  | 133b6fe240 | ||
|  | c824fe8718 | ||
|  | 26d3a487a5 | ||
|  | e0a2afc068 | ||
|  | f6e97bb284 | ||
|  | 6c8b998505 | ||
|  | f9fab216e9 | ||
|  | c308359f59 | ||
|  | 375d667144 | ||
|  | 84bd54ba40 | ||
|  | 73c36fe2d2 | ||
|  | ec3e9efdaa | ||
|  | d5c389b7dc | ||
|  | 7f233dcb15 | ||
|  | 6a2421c683 | ||
|  | d66ca7b5cb | ||
|  | 5e38cbd69c | ||
|  | b6d8dcb6e1 | ||
|  | 08ee1ab2e6 | ||
|  | 26edec5773 | ||
|  | d72e06842f | ||
|  | 0a0da63ac7 | ||
|  | 873ec898d8 | ||
|  | 97a70d14a3 | ||
|  | 394fbebfa8 | ||
|  | b79588c4a0 | ||
|  | 3b46e82625 | ||
|  | dbaf1fcd43 | ||
|  | 4caf1271e4 | ||
|  | 6921943aff | ||
|  | 3ce90b8257 | ||
|  | 3866154b50 | ||
|  | 64ed2464cf | ||
|  | e27780aee9 | ||
|  | 744e6e60c5 | ||
|  | f70c1ff009 | ||
|  | 3a808fe7fd | ||
|  | 2ca169b3c4 | ||
|  | 098d486291 | ||
|  | ec4fb70b80 | ||
|  | 2a82807be4 | ||
|  | 43ae868c69 | ||
|  | 1bc742aed1 | ||
|  | 6dc852774e | ||
|  | 7967ebed57 | ||
|  | 105b927397 | ||
|  | 9219f9d8ae | ||
|  | f780e6f235 | ||
|  | 27670f4da6 | ||
|  | e051743a3d | ||
|  | fb03003b3a | ||
|  | e52d0a3512 | ||
|  | cba92a01b6 | ||
|  | 0a87364101 | ||
|  | a89908540f | ||
|  | c4e2dcafa4 | ||
|  | 0163984ea4 | ||
|  | db3ce08cab | ||
|  | 1076959006 | ||
|  | 5127cbb22c | ||
|  | 9175b43542 | ||
|  | 562fec01d8 | ||
|  | b8051c8fed | ||
|  | 4df66a4802 | ||
|  | a2ff63daa5 | ||
|  | 7ce0f9682f | ||
|  | 3c6d0dc3e0 | ||
|  | 64a6fb2344 | ||
|  | 07734a5184 | ||
|  | 32d4994219 | ||
|  | 08d22d2f3c | ||
|  | b7b0185baf | ||
|  | 7b0c13c121 | ||
|  | a98ecc05af | ||
|  | f7337c1a05 | ||
|  | 53e2cda4c8 | ||
|  | 8064914bb7 | ||
|  | 6bb2203f79 | ||
|  | 3d56817da1 | ||
|  | 31e3b9ff8b | ||
|  | b2e32aaf58 | ||
|  | 699de9174e | ||
|  | 1dd9ec4d5a | ||
|  | 87d66ccf6c | ||
|  | 1134ff1075 | ||
|  | 178676ef8c | ||
|  | 94740155e5 | ||
|  | 9341afe764 | ||
|  | 7ce1e9b18d | ||
|  | 1821f60fb5 | ||
|  | 235d78565e | ||
|  | db5880539b | ||
|  | 76f4d67f33 | ||
|  | e59c57106c | ||
|  | bb4c748bf1 | ||
|  | 92cb9c3807 | ||
|  | 1a4e99431b | ||
|  | ec9d1ca57e | ||
|  | 71c9b98896 | ||
|  | 71bac8c60b | ||
|  | 7b0f7c2e5c | ||
|  | ad67a6add5 | ||
|  | 1353723b58 | ||
|  | f811c07454 | ||
|  | bb85382824 | ||
|  | 3ed4a1ba20 | ||
|  | c50da5d034 | ||
|  | 9b196ba68c | ||
|  | df79fb19af | ||
|  | f8bde5ab9b | ||
|  | 0cd37cbf7e | ||
|  | d621e4201d | ||
|  | 82af1df3c3 | ||
|  | ea8c2b8d69 | ||
|  | 8ddcb6c841 | ||
|  | 1681361aed | ||
|  | 6a6f98299d | ||
|  | 19ba272d62 | ||
|  | 2f8ceca2ef | ||
|  | ba1baafca5 | ||
|  | 20a07494f6 | ||
|  | c66477c690 | ||
|  | 5c612a186f | ||
|  | 943e556f43 | ||
|  | 4bf4f96f47 | ||
|  | 384cd2f605 | ||
|  | 425af46f98 | ||
|  | c83ee04662 | ||
|  | 2054cd78da | ||
|  | 88982f98ff | ||
|  | 2ea0b839d3 | ||
|  | afd83e59b8 | ||
|  | 7f84049538 | ||
|  | 98840c9c5f | ||
|  | 26cacfa247 | ||
|  | 4b2d27b5e5 | ||
|  | 69625946b1 | ||
|  | f7fe9b0961 | ||
|  | 7fcd34eb36 | ||
|  | 1f5848ba82 | ||
|  | bbd414bdcd | ||
|  | a1737a28d0 | ||
|  | 66be42d1f8 | ||
|  | c984c0f2c0 | ||
|  | 89d2bb7ecd | ||
|  | 9f8cad93f7 | ||
|  | a207260fe0 | ||
|  | 1ef4a47255 | ||
|  | b8aa68b4d1 | ||
|  | 61edbac6e5 | ||
|  | d315133d34 | ||
|  | 82d59dbea8 | ||
|  | 42884e0871 | ||
|  | 7fb8b546f9 | ||
|  | 80fe1938b8 | ||
|  | 2409afae95 | ||
|  | 06705f9e88 | ||
|  | 2b408e71ac | ||
|  | b097193486 | ||
|  | 543f2c91fe | ||
|  | 05c0088445 | ||
|  | 2f6f815d81 | ||
|  | 1e03fbe1a8 | ||
|  | 4409f11b24 | ||
|  | 7a216901be | ||
|  | 0e7c254b93 | ||
|  | ba14850c9a | ||
|  | 59d3a21993 | ||
|  | d2faa49bf4 | ||
|  | 438c0e27ea | ||
|  | 4c14372b4a | ||
|  | 8b4077d7de | ||
|  | 914b009361 | ||
|  | b2a4b7eb88 | ||
|  | daa50442c9 | ||
|  | 76fd7f47eb | ||
|  | fbf840cb68 | ||
|  | 798a647b71 | ||
|  | 26a0b09064 | ||
|  | 98570b5da1 | ||
|  | e923d7dafb | ||
|  | 64b6861880 | ||
|  | c46e11cae2 | ||
|  | 82ccfa21e1 | ||
|  | 13f7fc1fd2 | ||
|  | 018cc14a87 | ||
|  | 3ce295a2af | ||
|  | a30107ab86 | ||
|  | d8df6968d3 | ||
|  | 0515c6acde | ||
|  | 607b44e01d | ||
|  | 5c0bae2070 | ||
|  | 4012e31115 | ||
|  | 2d8e9eda56 | ||
|  | 4375a0e07e | ||
|  | a07cfb7abc | ||
|  | c131d82699 | ||
|  | de2dcbae5a | ||
|  | b0000bb276 | ||
|  | 82789d5315 | ||
|  | 3df5882711 | ||
|  | b6765b849c | ||
|  | df94e5f164 | ||
|  | 79edc12c76 | ||
|  | bd03151c2a | ||
|  | 7c0fdc7ecf | ||
|  | b333ed91de | ||
|  | 6a073d5f86 | ||
|  | c7159b2be4 | ||
|  | 2d98193c83 | ||
|  | 685756f9d5 | ||
|  | 535bb364b6 | ||
|  | c740539f48 | ||
|  | 4cf331067b | ||
|  | a3ba7683f4 | ||
|  | 5edfec68cf | ||
|  | eb494f78fa | ||
|  | d963941be0 | ||
|  | 8ab65fdde4 | ||
|  | 8e2c0bb977 | ||
|  | f1f1064f70 | ||
|  | 88500e3714 | ||
|  | eae2a4df8b | ||
|  | ade8e95d2e | ||
|  | a0b225b8b1 | ||
|  | 323e8756ba | ||
|  | ada5428df7 | ||
|  | 7869c19245 | ||
|  | 5706b29c8c | ||
|  | 8ff7b2405f | ||
|  | eaabe15863 | ||
|  | 63b2ae743b | ||
|  | c5ea985a70 | ||
|  | 11b35b89f5 | ||
|  | 6d5b16725d | ||
|  | c34897036e | ||
|  | 1e51af1d4b | ||
|  | 8ee6e26608 | ||
|  | 4d36f38f96 | ||
|  | d31ca444e1 | ||
|  | 090b3014c0 | ||
|  | 491a322ceb | ||
|  | 12e16d532b | ||
|  | 7814a391d8 | ||
|  | 322151b0d5 | ||
|  | 4a136cafda | ||
|  | d0df25d9e2 | ||
|  | 8d003dbc30 | ||
|  | 2c7358d64f | ||
|  | 94e260cec6 | ||
|  | 783ac3c105 | ||
|  | d46e3f6778 | ||
|  | 6fe3158778 | ||
|  | bbd12e33ec | ||
|  | e4d55242d8 | ||
|  | dedddcfcf5 | ||
|  | 613a78bcf6 | ||
|  | f5decb1d7e | ||
|  | 47b4c236c3 | ||
|  | 39ccb2df0b | ||
|  | 5bfdffda11 | ||
|  | 247f8c8557 | ||
|  | 3ce449e167 | ||
|  | 663f9657ea | ||
|  | 457f951aaf | ||
|  | feafd57027 | ||
|  | 5c0183c71e | ||
|  | fb7d425244 | ||
|  | 3fab40efe5 | ||
|  | 0bbdbc9e63 | ||
|  | 9bc481ff62 | ||
|  | 32dea43d2e | ||
|  | 632da71a8d | ||
|  | 2ffab22185 | ||
|  | 5541327968 | ||
|  | 096eaa20d7 | ||
|  | e5fe6b915e | ||
|  | 512bd84cc2 | ||
|  | ebbcbeedd2 | ||
|  | be17308e50 | ||
|  | 25fa29e6e1 | ||
|  | bddc47f9b2 | ||
|  | 51948d7760 | ||
|  | 5817a30031 | ||
|  | e216eb1e7b | ||
|  | 549c6afa0a | ||
|  | 6b08e6b809 | ||
|  | 0438fdde49 | ||
|  | be4ea18119 | ||
|  | a75d6531f2 | ||
|  | da69ddc19b | ||
|  | e92926e881 | ||
|  | 7dd208fb49 | ||
|  | 5305db689d | ||
|  | 2338c7a3b3 | ||
|  | 829bc96209 | ||
|  | 7454e16aae | ||
|  | e4acad60e9 | ||
|  | f35af1fb6d | ||
|  | c0e008c601 | ||
|  | 9acf4458c0 | ||
|  | 70de264d4d | ||
|  | 1a0b9e4612 | ||
|  | 66dc70c057 | ||
|  | 6641f34d76 | ||
|  | f3ae5d8160 | ||
|  | d937541aa0 | ||
|  | 21707d7ff6 | ||
|  | 3002bc0eee | ||
|  | df50232ed9 | ||
|  | 17d49067e9 | ||
|  | 9a2e023a51 | ||
|  | 9c747f3160 | ||
|  | 08ea71cb24 | ||
|  | a96abe2422 | ||
|  | 84a4a888e6 | ||
|  | e3299b546e | ||
|  | f2e0f1b2f1 | ||
|  | 2a4456b9ca | ||
|  | 560a55bfd1 | ||
|  | d32f0fad12 | ||
|  | 031e7d270d | ||
|  | 3b73a0e269 | ||
|  | 0bfcf79e79 | ||
|  | bdd299dd9e | ||
|  | f97e605bf6 | ||
|  | db9ff76754 | ||
|  | 49f5495c45 | ||
|  | 9e431df848 | ||
|  | 12476c52a4 | ||
|  | 8fd9aebcb9 | ||
|  | 8c83f4ba3b | ||
|  | 25b6d1a232 | ||
|  | 880cbd88c2 | ||
|  | dcd53c3c5b | ||
|  | 3e64b3da39 | ||
|  | 9a748c8bf1 | ||
|  | 53eae14763 | ||
|  | 074c42e8b6 | ||
|  | 8633fa7024 | ||
|  | 19668b9b48 | ||
|  | 3f02631b98 | ||
|  | da46eefe2e | ||
|  | a3ca3ed33f | ||
|  | efaa33c4d5 | ||
|  | 0cdfe7f458 | ||
|  | 190eafc30e | ||
|  | d4ee0e8622 | ||
|  | 96c90e6295 | ||
|  | ff95da411b | ||
|  | 2ad411ea29 | ||
|  | 55cbcd728d | ||
|  | 8880860105 | ||
|  | 0c238448fd | ||
|  | 8a76fdc126 | ||
|  | 433f830cf3 | ||
|  | 8893bc102c | ||
|  | 0cf9927132 | ||
|  | 5993125cc7 | ||
|  | 0c34309133 | ||
|  | 3d6ce0fb76 | ||
|  | 54f79c2798 | ||
|  | 8bac1706a1 | ||
|  | d0a3779091 | ||
|  | ff0960b174 | ||
|  | 7032825e35 | ||
|  | d118533d87 | ||
|  | 35f4f75733 | ||
|  | ef61c3543f | ||
|  | 897560745a | ||
|  | 5a8539a122 | ||
|  | d9292a70bf | ||
|  | a9c23b7c28 | ||
|  | 2cc7289b7b | ||
|  | 81d6df925e | ||
|  | 263bfb1bda | ||
|  | 677e77d0ae | ||
|  | 0d0c1af7f7 | ||
|  | fb55def54f | ||
|  | eea86757d5 | ||
|  | e7eb220c50 | ||
|  | 7d67005820 | ||
|  | fadd91b6a2 | ||
|  | 5fa6a2848f | ||
|  | 7ab921669b | ||
|  | 4811dfa663 | ||
|  | 7a41a5249f | ||
|  | f9e05d0cad | ||
|  | 15a63c4bc5 | ||
|  | 4a2e4d2b55 | ||
|  | 12033abe09 | ||
|  | f9410d5d00 | ||
|  | c232a32991 | ||
|  | 57f37939d5 | ||
|  | 432ff58107 | ||
|  | 2c7d6a7711 | ||
|  | d31b051fc5 | ||
|  | 98405a39db | ||
|  | 0e354e5ea1 | ||
|  | d172a97247 | ||
|  | 8a3df7e434 | ||
|  | eafcbabaa2 | ||
|  | 14071ea119 | ||
|  | 6239686afa | ||
|  | 45186b70ec | ||
|  | b4fead9606 | ||
|  | 61243b418e | ||
|  | fe75660e88 | ||
|  | 946e6c1644 | ||
|  | 3eb232b3fc | ||
|  | 38de1c9a31 | ||
|  | 78dcb87a75 | ||
|  | 421e568232 | ||
|  | 4efd28c092 | ||
|  | d0bbee7e8c | ||
|  | 7640563991 | ||
|  | 90cf85c3f0 | ||
|  | f1a98693d0 | ||
|  | 2794d64d3e | ||
|  | 82743cca92 | ||
|  | d0c348e595 | ||
|  | f50d3088dc | ||
|  | 0917fa0d75 | ||
|  | cfb73dd534 | ||
|  | ef497b7989 | ||
|  | 9d9341901f | ||
|  | 155e3d225d | ||
|  | ca41f100ab | ||
|  | 084285a760 | ||
|  | 982391cd7c | ||
|  | d206d0a3ae | ||
|  | 627ea6c860 | ||
|  | bcc76b3764 | ||
|  | 39692a8b3f | ||
|  | eba8b4bf00 | ||
|  | f149665660 | ||
|  | e3bb64cf35 | ||
|  | 33f0669100 | ||
|  | 3a5f3e8b55 | ||
|  | a0a90afbc0 | ||
|  | 2f96cb257c | ||
|  | 5910bec52e | ||
|  | 764b1c35cb | ||
|  | ee8c9b764d | ||
|  | 7080f0c35a | ||
|  | 679d60cd5a | ||
|  | bc36c0faed | ||
|  | 3c073bc360 | ||
|  | c52d5e1084 | ||
|  | b7bb27fa21 | ||
|  | 087aaa2f94 | ||
|  | 474b93a22f | ||
|  | 0c2f002a7d | ||
|  | 3d76d83a39 | ||
|  | 787015f537 | ||
|  | fb624fddc4 | ||
|  | 605ddacb71 | ||
|  | 71934f05a8 | ||
|  | 534a0d6836 | ||
|  | 746b1d0c4d | ||
|  | 387c80e00a | ||
|  | 05c914691f | ||
|  | 94398d70f4 | ||
|  | 915ddb2b2b | ||
|  | b916e7f7ef | ||
|  | 3cc30f91a9 | ||
|  | f4a61b4c70 | ||
|  | 6eebd693ce | ||
|  | 7e78f5941a | ||
|  | bc0ae6be31 | ||
|  | c03119d10a | ||
|  | e1879ef4d9 | ||
|  | b6df727efb | ||
|  | fe58b44916 | ||
|  | 0a2694811d | ||
|  | 31fe232bac | ||
|  | 682f6d273c | ||
|  | 83ddaccf4a | ||
|  | e0c0584c59 | ||
|  | 60f5a52964 | ||
|  | 7e5866ce3f | ||
|  | 89b7b56a2c | ||
|  | ae54b13d4b | ||
|  | 927ccc489c | ||
|  | 21f7722f10 | ||
|  | e4afe603f9 | ||
|  | 30d15a1438 | ||
|  | c84586dd66 | ||
|  | e9f87c2026 | ||
|  | afa27a3c2a | ||
|  | ce6078ed94 | ||
|  | 82d1412d45 | ||
|  | 6d5949ba9c | ||
|  | cdb165af7f | ||
|  | 88a3f8e4aa | ||
|  | 1c3dc757c3 | ||
|  | 25866095db | ||
|  | b6c8d8e971 | ||
|  | ab94b0b231 | ||
|  | 760bab8f86 | ||
|  | 817c332d11 | ||
|  | 05fbc8e6b0 | ||
|  | c39301b6da | ||
|  | add9a9db9b | ||
|  | 05123ea6f4 | ||
|  | a8d328bfc9 | ||
|  | d62ff34a5a | ||
|  | a8b8d53d9d | ||
|  | 0d4ff5a916 | ||
|  | 8ace41d144 | ||
|  | 5bb7219f4b | ||
|  | f0200ab697 | ||
|  | f457a56d4a | ||
|  | db086de84a | ||
|  | 37684c6af0 | ||
|  | 3c75d4f1dd | ||
|  | b19276bb0f | ||
|  | 774d831fae | ||
|  | a1b49d8389 | ||
|  | 12e2bfc794 | ||
|  | 6e5abade3c | ||
|  | e4e3676095 | ||
|  | 3ed13150e1 | ||
|  | f03e5c6bd1 | ||
|  | 8496c1cdd3 | ||
|  | 3c3851c221 | ||
|  | 05f1e9e3b8 | ||
|  | 249a1e6d8d | ||
|  | e042e0ad32 | ||
|  | 5db15ca54c | ||
|  | 069b89b208 | ||
|  | 63014aeb6b | ||
|  | 31e21db5b5 | ||
|  | 7f21872510 | ||
|  | 27351c9a90 | ||
|  | 76b918d40e | ||
|  | f5bc0b205c | ||
|  | b3c253ea2a | ||
|  | d17e031259 | ||
|  | 842363200b | ||
|  | d9f9895b2b | ||
|  | bc0edd4042 | ||
|  | 9b82e2df58 | ||
|  | 3d65341080 | ||
|  | 80215ea181 | ||
|  | 78d8526e41 | ||
|  | 0ddaabe377 | ||
|  | 20f9318597 | ||
|  | 9bc6ebde4e | ||
|  | 011f14d115 | ||
|  | 62a5cbb5ce | ||
|  | 5aaf87d612 | ||
|  | 96b31f3974 | ||
|  | 09e387bf09 | ||
|  | 05fe8792ea | ||
|  | 18ed45597a | ||
|  | b646c84414 | ||
|  | a200eaacaa | ||
|  | f5ad553be3 | ||
|  | 7b7664bd66 | ||
|  | 4f4acc04fe | ||
|  | dee0fec9e9 | ||
|  | 73cc2a140c | ||
|  | 6058a74da5 | ||
|  | ab5e021bda | ||
|  | bd3b652cfc | ||
|  | 73429fc720 | ||
|  | 10478a6b2f | ||
|  | 0fc9814004 | ||
|  | e0bc01eea1 | ||
|  | 2af6d3f6bc | ||
|  | cbe5438a31 | ||
|  | 67c4ad128c | ||
|  | 870eca0d9f | ||
|  | d299458084 | ||
|  | e0cf68f1d5 | ||
|  | 64906a1ba5 | ||
|  | e75721016e | ||
|  | e0d5b9daf8 | ||
|  | 5989844f1c | ||
|  | 14e3f413a2 | ||
|  | a97d77064a | ||
|  | 3342dd4001 | ||
|  | 785b9811f3 | ||
|  | 643c77ded0 | ||
|  | e617da3bbf | ||
|  | 76f01511a3 | ||
|  | dd8727d3ae | ||
|  | b933946f33 | ||
|  | 5d2f9d7a33 | ||
|  | 3baf14b793 | ||
|  | c57e4ba508 | ||
|  | 98656289ea | ||
|  | 167a38e27d | ||
|  | ba6806df5d | ||
|  | fe12101278 | ||
|  | d6d7f4e875 | ||
|  | 63caddea62 | ||
|  | 36b01fbdcf | ||
|  | 45a3d8b75a | ||
|  | bca62c813d | ||
|  | ae1cf74dcd | ||
|  | 577a8dd005 | ||
|  | 5900899c01 | ||
|  | 2dfc468094 | ||
|  | 98ffe9931d | ||
|  | 2004c0d739 | ||
|  | cd7cb025ad | ||
|  | 96da267778 | ||
|  | 5816e410e9 | ||
|  | 31c98fc0db | ||
|  | 00bf957b53 | ||
|  | 5b999c2f7d | ||
|  | 1cc9d9c071 | ||
|  | 72fb8460e9 | ||
|  | 577156fe5f | ||
|  | 612cc96e41 | ||
|  | da3f783a9f | ||
|  | b1e8545981 | ||
|  | 6a2da6dc06 | ||
|  | 58603e2a5a | ||
|  | d97184880c | ||
|  | 625f40cfa6 | ||
|  | 49049b8c12 | ||
|  | 037912ccab | ||
|  | 8b05b864fb | ||
|  | 319135c8fe | ||
|  | 61d9e418e8 | ||
|  | 475bb2845d | ||
|  | 42f39de0f9 | ||
|  | 3898b8e8ab | ||
|  | b1fd005c95 | ||
|  | cf8fdd3a70 | ||
|  | cb754ee125 | ||
|  | cea81df969 | ||
|  | af1d5fce6e | ||
|  | 54b86b6131 | ||
|  | ec2b83515b | ||
|  | 2f2724dff5 | ||
|  | 271fa26890 | ||
|  | fe437da751 | ||
|  | 129876d1be | ||
|  | f2ced67a8d | ||
|  | 787eec8be4 | ||
|  | cc39eea999 | ||
|  | cbfed99bc6 | ||
|  | 2b4cd8b2ec | ||
|  | b5dc72b126 | ||
|  | ab4d2faea3 | ||
|  | 1677817d9f | ||
|  | 03854baf53 | ||
|  | 61dc253de1 | ||
|  | a0e8f410d1 | ||
|  | 2865f63c5d | ||
|  | 3f19ab1a87 | ||
|  | d75fec0cee | ||
|  | 39570a9663 | ||
|  | 479c18e21f | ||
|  | fd4453d85e | ||
|  | 7ee7f99780 | ||
|  | 4c0b8e3113 | ||
|  | e0af60d8a7 | ||
|  | afcb7f00da | ||
|  | a59e9f024e | ||
|  | e1b06bfce2 | ||
|  | 8de3f03b49 | ||
|  | db8f018b42 | ||
|  | 59cb2132f2 | ||
|  | 25f62daf14 | ||
|  | 05b9dfbe30 | ||
|  | 3db4e2ee2f | ||
|  | 86a6a5b826 | ||
|  | cc6338d048 | ||
|  | 57b65726d6 | ||
|  | 44a736c53b | ||
|  | 38cbd42d81 | ||
|  | 28d019f824 | ||
|  | 54b8e1be89 | ||
|  | 9778695b4a | ||
|  | 44b6285268 | ||
|  | 6c6fb2e287 | ||
|  | ecdfde8c38 | ||
|  | ea2d5b9d4a | ||
|  | 4670cc1a5f | ||
|  | 1e0522fe8f | ||
|  | 70858603ed | ||
|  | 3c508c1d27 | ||
|  | 5c44db341f | ||
|  | cf73363016 | ||
|  | 351173e554 | ||
|  | 342432dc76 | ||
|  | c4538cada7 | ||
|  | de532bb2fc | ||
|  | f525afa5de | ||
|  | 9fba470364 | ||
|  | 6cd5bf31c9 | ||
|  | 321c0a8537 | ||
|  | b9bc58ef10 | ||
|  | 7bcf05fd19 | ||
|  | f816bdf541 | ||
|  | 79472552aa | ||
|  | c5e5c8288e | ||
|  | fd1c7f7169 | ||
|  | 9212d67e2f | ||
|  | f5c74d123a | ||
|  | c8421efcd3 | ||
|  | f382609d01 | ||
|  | f9615c18a1 | ||
|  | a74597c7cd | ||
|  | d50fbac5f9 | ||
|  | 95086a75e6 | ||
|  | 073a96cf63 | ||
|  | d3c64bd5b4 | ||
|  | 7024a7468a | ||
|  | 62e60e2ba6 | ||
|  | fb3860757c | ||
|  | e4a8b17522 | ||
|  | 448df1bb9c | ||
|  | bf6900fb2a | ||
|  | 50552546f3 | ||
|  | 324fab8186 | ||
|  | 7ab80f01b5 | ||
|  | 9ce4a5c7b1 | ||
|  | c9a0525a10 | ||
|  | 83465bb7f5 | ||
|  | e8771fb36a | ||
|  | d4d03f3d7f | ||
|  | d567d667e8 | ||
|  | 3d55bbbc29 | ||
|  | 2f8e52f905 | ||
|  | a5896ac6b6 | ||
|  | 94b9d5644c | ||
|  | 06e5fc233c | ||
|  | aefb922a05 | ||
|  | a22434fd73 | ||
|  | c41846805d | ||
|  | b7b45b69a6 | ||
|  | ed5528664c | ||
|  | fe88d3c225 | ||
|  | aed4ee8694 | ||
|  | 817d9b0d3e | ||
|  | df9cfe7840 | ||
|  | 8cd4578d83 | ||
|  | 9ca41b9536 | ||
|  | 559743c911 | ||
|  | 3a7f26f620 | ||
|  | 04a0eae241 | ||
|  | 0500d2fb6e | ||
|  | 31f1a9e5aa | ||
|  | 6387aae471 | ||
|  | 152082e182 | ||
|  | 08eb2b3df7 | ||
|  | 846ec87249 | ||
|  | 62690b5159 | ||
|  | 719c432ca8 | ||
|  | e654616b6d | ||
|  | f0473b0320 | ||
|  | fcc627e6e1 | ||
|  | fe17802cd2 | ||
|  | 368d59c3ca | ||
|  | 94ee82e076 | ||
|  | 0beab9eec4 | ||
|  | aa997f1be5 | ||
|  | 4eb58a70bb | ||
|  | 9200ed2216 | ||
|  | e1f7dd1372 | ||
|  | 32833b7301 | ||
|  | 3302c89284 | ||
|  | 4874d55d03 | ||
|  | 10faa47495 | ||
|  | dea322e2c5 | ||
|  | 790af0fd72 | ||
|  | 4e5bfae332 | ||
|  | 662dc12877 | 
| @@ -25,31 +25,17 @@ jobs: | ||||
|           key: yarn-packages-{{ .Branch }}-{{ checksum "yarn.lock" }} | ||||
|           paths: | ||||
|             - node_modules/ | ||||
|       - run: node ./node_modules/lerna/bin/lerna.js bootstrap | ||||
|       - run: yarn build | ||||
|       - run: > | ||||
|             if [ -z "$(git diff --name-only v2-prototype packages/website)" ]; then | ||||
|                 yarn build --exclude website | ||||
|             else | ||||
|                 yarn build | ||||
|             fi | ||||
|       - save_cache: | ||||
|           key: repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo | ||||
|   test-1: | ||||
|     docker: | ||||
|       - image: circleci/node:9 | ||||
|     working_directory: ~/repo | ||||
|     steps: | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn wsrun test:circleci @0xproject/contract-wrappers | ||||
|       - run: yarn wsrun test:circleci @0xproject/sol-compiler | ||||
|       - save_cache: | ||||
|           key: coverage-contract-wrappers-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/contract-wrappers/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-sol-compiler-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/sol-compiler/coverage/lcov.info | ||||
|   test-contracts: | ||||
|   test-contracts-ganache: | ||||
|     docker: | ||||
|       - image: circleci/node:9 | ||||
|     working_directory: ~/repo | ||||
| @@ -58,7 +44,19 @@ jobs: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn wsrun test:circleci contracts | ||||
|   test-2: | ||||
|   test-contracts-geth: | ||||
|     docker: | ||||
|       - image: circleci/node:9 | ||||
|       - image: albrow/0x-devnet | ||||
|     working_directory: ~/repo | ||||
|     steps: | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       # HACK(albrow): we need to sleep 10 seconds to ensure the devnet is | ||||
|       # initialized | ||||
|       - run: sleep 10 && TEST_PROVIDER=geth yarn wsrun test contracts | ||||
|   test-rest: | ||||
|     docker: | ||||
|       - image: circleci/node:9 | ||||
|     working_directory: ~/repo | ||||
| @@ -66,21 +64,46 @@ jobs: | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn wsrun test:circleci 0x.js | ||||
|       - run: yarn wsrun test:circleci @0xproject/abi-gen | ||||
|       - run: yarn wsrun test:circleci @0xproject/assert | ||||
|       - run: yarn wsrun test:circleci @0xproject/base-contract | ||||
|       - run: yarn wsrun test:circleci @0xproject/connect | ||||
|       - run: yarn wsrun test:circleci @0xproject/contract-wrappers | ||||
|       - run: yarn wsrun test:circleci @0xproject/dev-utils | ||||
|       - run: yarn wsrun test:circleci @0xproject/json-schemas | ||||
|       - run: yarn wsrun test:circleci @0xproject/subproviders | ||||
|       - run: yarn wsrun test:circleci @0xproject/sol-cov | ||||
|       - run: yarn wsrun test:circleci @0xproject/metacoin | ||||
|       - run: yarn wsrun test:circleci @0xproject/order-utils | ||||
|       - run: yarn wsrun test:circleci @0xproject/order-watcher | ||||
|       - run: yarn wsrun test:circleci @0xproject/sol-compiler | ||||
|       - run: yarn wsrun test:circleci @0xproject/sol-cov | ||||
|       - run: yarn wsrun test:circleci @0xproject/sra-report | ||||
|       - run: yarn wsrun test:circleci @0xproject/subproviders | ||||
|       - run: yarn wsrun test:circleci @0xproject/web3-wrapper | ||||
|       - save_cache: | ||||
|           key: coverage-0xjs-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/0x.js/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-abi-gen-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/abi-gen/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-assert-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/assert/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-base-contract-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/base-contract/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-connect-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/connect/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-contract-wrappers-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/contract-wrappers/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-dev-utils-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
| @@ -90,17 +113,37 @@ jobs: | ||||
|           paths: | ||||
|             - ~/repo/packages/json-schemas/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-subproviders-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           key: coverage-metacoin-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/subproviders/coverage/lcov.info | ||||
|             - ~/repo/packages/metacoin/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-order-utils-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/order-utils/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-order-watcher-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/order-watcher/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-sol-compiler-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/sol-compiler/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-sol-cov-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/sol-cov/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-metacoin-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           key: coverage-sra-report-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/metacoin/coverage/lcov.info | ||||
|             - ~/repo/packages/sra-report/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-subproviders-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/subproviders/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-web3-wrapper-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/web3-wrapper/coverage/lcov.info | ||||
|   static-tests: | ||||
|     working_directory: ~/repo | ||||
|     docker: | ||||
| @@ -110,7 +153,7 @@ jobs: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn prettier:ci | ||||
|       - run: yarn lerna:run lint | ||||
|       - run: yarn lerna run lint | ||||
|   submit-coverage: | ||||
|     docker: | ||||
|       - image: circleci/node:9 | ||||
| @@ -119,9 +162,18 @@ jobs: | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-0xjs-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-abi-gen-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-assert-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-base-contract-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-connect-{{ .Environment.CIRCLE_SHA1 }} | ||||
| @@ -136,35 +188,44 @@ jobs: | ||||
|             - coverage-json-schemas-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-subproviders-{{ .Environment.CIRCLE_SHA1 }} | ||||
|             - coverage-metacoin-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-sol-cov-{{ .Environment.CIRCLE_SHA1 }} | ||||
|             - coverage-order-utils-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-contracts-{{ .Environment.CIRCLE_SHA1 }} | ||||
|             - coverage-order-watcher-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-sol-compiler-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-0xjs-{{ .Environment.CIRCLE_SHA1 }} | ||||
|             - coverage-sol-cov-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-metacoin-{{ .Environment.CIRCLE_SHA1 }} | ||||
|             - coverage-sra-report-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-subproviders-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-web3-wrapper-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-contracts-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn report_coverage | ||||
| workflows: | ||||
|   version: 2 | ||||
|   main: | ||||
|     jobs: | ||||
|       - build | ||||
|       - test-1: | ||||
|       - test-contracts-ganache: | ||||
|           requires: | ||||
|             - build | ||||
|       - test-2: | ||||
|       - test-contracts-geth: | ||||
|           requires: | ||||
|             - build | ||||
|       - test-contracts: | ||||
|       - test-rest: | ||||
|           requires: | ||||
|             - build | ||||
|       - static-tests: | ||||
| @@ -172,5 +233,4 @@ workflows: | ||||
|             - build | ||||
|       - submit-coverage: | ||||
|           requires: | ||||
|             - test-1 | ||||
|             - test-2 | ||||
|             - test-rest | ||||
|   | ||||
							
								
								
									
										18
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -41,6 +41,7 @@ typings/ | ||||
|  | ||||
| # Optional npm cache directory | ||||
| .npm | ||||
| .npmrc | ||||
|  | ||||
| # Optional eslint cache | ||||
| .eslintcache | ||||
| @@ -67,6 +68,9 @@ generated_docs/ | ||||
|  | ||||
| TODO.md | ||||
|  | ||||
| # VSCode file | ||||
| .vscode | ||||
|  | ||||
| packages/website/public/bundle* | ||||
| packages/react-docs/example/public/bundle* | ||||
|  | ||||
| @@ -78,16 +82,20 @@ packages/sol-cov/test/fixtures/artifacts/ | ||||
| packages/metacoin/artifacts/ | ||||
| packages/order-watcher/test/artifacts/ | ||||
| packages/contract-wrappers/test/artifacts/ | ||||
| packages/contract-wrappers/src/artifacts/ | ||||
| packages/order-watcher/src/artifacts/ | ||||
|  | ||||
| # generated contract wrappers | ||||
| packages/0x.js/src/contract_wrappers/generated/ | ||||
| packages/contracts/src/contract_wrappers/generated/ | ||||
| # generated contract watcher | ||||
| packages/0x.js/src/generated_contract_wrappers/ | ||||
| packages/contracts/generated_contract_wrappers/ | ||||
| packages/contract-wrappers/src/contract_wrappers/generated/ | ||||
| packages/metacoin/src/contract_wrappers | ||||
| packages/fill-scenarios/src/generated_contract_wrappers/ | ||||
| packages/order-watcher/src/generated_contract_wrappers/ | ||||
| packages/migrations/src/v1/contract_wrappers | ||||
| packages/migrations/src/v2/contract_wrappers | ||||
| packages/order-utils/src/generated_contract_wrappers/ | ||||
| packages/migrations/src/1.0.0/contract_wrappers | ||||
| packages/migrations/src/2.0.0/contract_wrappers | ||||
| packages/migrations/src/2.0.0-beta-testnet/contract_wrappers | ||||
|  | ||||
| # solc-bin in sol-compiler | ||||
| packages/sol-compiler/solc_bin/ | ||||
|   | ||||
| @@ -1,11 +1,24 @@ | ||||
| lib | ||||
| .nyc_output | ||||
| /packages/0x.js/test/artifacts | ||||
| /packages/contract-wrappers/src/contract_wrappers/generated/ | ||||
| /packages/metacoin/src/contract_wrappers | ||||
| /packages/0x.js/src/generated_contract_wrappers/ | ||||
| /packages/contracts/generated_contract_wrappers/ | ||||
| /packages/fill-scenarios/src/generated_contract_wrappers/ | ||||
| /packages/order-watcher/src/generated_contract_wrappers/ | ||||
| /packages/order-utils/src/generated_contract_wrappers/ | ||||
| /packages/migrations/src/1.0.0/contract_wrappers | ||||
| /packages/migrations/src/2.0.0/contract_wrappers | ||||
| /packages/migrations/src/2.0.0-beta-testnet/contract_wrappers | ||||
| /packages/0x.js/src/artifacts | ||||
| /packages/contracts/src/artifacts | ||||
| /packages/contract-wrappers/src/artifacts | ||||
| /packages/order-watcher/src/artifacts | ||||
| /packages/metacoin/artifacts | ||||
| /packages/contract-wrappers/test/artifacts | ||||
| /packages/order-watcher/test/artifacts | ||||
| /packages/migrations/artifacts/1.0.0 | ||||
| /packages/migrations/artifacts/2.0.0 | ||||
| /packages/migrations/artifacts/2.0.0-beta-testnet | ||||
| package.json | ||||
| scripts/postpublish_utils.js | ||||
|   | ||||
| @@ -21,6 +21,18 @@ If you're adding a new public function/member, make sure you document it with Ja | ||||
|  | ||||
| If the sub-package you are modifying has a `CHANGELOG.md` file, make sure to add an entry in it for the change made to the package. For published packages, only changes that modify the public interface or behavior of the package need a CHANGELOG entry. | ||||
|  | ||||
| #### Enabling code coverage checks on your fork | ||||
|  | ||||
| If you simply fork the repo and then create a PR sourced from it, your PR will fail its test coverage check. This is because the 0x CircleCI configuration sets the `COVERALLS_REPO_TOKEN` environment variable to the token for 0xProject/0x-monorepo, but when running the check against your fork the token needs to match the repo that is your fork, rather than the 0x repo. | ||||
|  | ||||
| To facilitate this check, after creating your fork, but before creating the branch for your PR, do the following: | ||||
|  | ||||
| 1.  Log in to [coveralls.io](https://coveralls.io/), go to Add Repos, and enable your fork. Then go to the settings for that repo, and copy the Repo Token identifier. | ||||
| 2.  Log in to [CircleCI](https://circleci.com/login), go to Add Projects, click the Set Up Project button corresponding to your fork, and then click Start Building. (Aside from step 3 below, no actual set up is needed, since it will use the `.circleci/config.yml` file in 0x-monorepo, so you can ignore all of the instruction/explanation given on the page with the Start Building button.) | ||||
| 3.  In CircleCI, configure your project to add an Environment Variable, with name `COVERALLS_REPO_TOKEN`, and for the value paste in the Repo Token you copied in step 1. | ||||
|  | ||||
| Now, when you push to your branch, CircleCI will automatically run all of the checks in your own instance, and the coverage check will work since it has the proper Repo Token, and the PR will magically refer to your own checks rather than running them in the 0x CircleCI instance. | ||||
|  | ||||
| ### Styleguide | ||||
|  | ||||
| We use [TSLint](https://palantir.github.io/tslint/) with [custom configs](https://github.com/0xProject/0x-monorepo/tree/development/packages/tslint-config) to keep our code style consistent. | ||||
|   | ||||
| @@ -1,41 +1,27 @@ | ||||
| <!--- Thank you for taking the time to submit a Pull Request --> | ||||
|  | ||||
| <!--- Provide a general summary of the issue in the Title above --> | ||||
|  | ||||
| ## Description | ||||
|  | ||||
| <!--- Describe your changes in detail --> | ||||
|  | ||||
| ## Motivation and Context | ||||
| ## Testing instructions | ||||
|  | ||||
| <!--- Why is this change required? What problem does it solve? --> | ||||
|  | ||||
| <!--- If it fixes an open issue, please link to the issue here. --> | ||||
|  | ||||
| ## How Has This Been Tested? | ||||
|  | ||||
| <!--- Please describe in detail how you tested your changes. --> | ||||
|  | ||||
| <!--- Include details of your testing environment, and the tests you ran to --> | ||||
|  | ||||
| <!--- see how your change affects other areas of the code, etc. --> | ||||
| <!--- Please describe how reviewers can test your changes --> | ||||
|  | ||||
| ## Types of changes | ||||
|  | ||||
| <!--- What types of changes does your code introduce? Put an `x` in all the boxes that apply: --> | ||||
| <!--- What types of changes does your code introduce? Uncomment all the bullets 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) | ||||
| <!-- * 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. --> | ||||
| <!--- The following points should be used to indicate the progress of your PR.  Put an `x` in all the boxes that apply right now, and come back over time and check them off as you make progress.  If you're unsure about any of these, don't hesitate to ask. We're here to help! --> | ||||
|  | ||||
| <!--- 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. | ||||
| *   [ ] Prefixed the title of this PR with `[WIP]` if it is a work in progress. | ||||
| *   [ ] Prefixed the title of this PR with bracketed package name(s) corresponding to the changed package(s). For example: `[sol-cov] Fixed bug`. | ||||
| *   [ ] Added tests to cover my changes, or decided that tests would be too impractical. | ||||
| *   [ ] Updated documentation, or decided that no doc change is needed. | ||||
| *   [ ] Added new entries to the relevant CHANGELOG.jsons. | ||||
| *   [ ] 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. | ||||
|   | ||||
| @@ -6,8 +6,11 @@ | ||||
|  | ||||
| This repository is a monorepo including the 0x protocol smart contracts and numerous developer tools. Each public sub-package is independently published to NPM. | ||||
|  | ||||
| If you're developing on 0x now or are interested in using 0x infrastructure in the future, please join our [developer mailing list][dev-mailing-list-url] for updates. | ||||
|  | ||||
| [website-url]: https://0xproject.com/ | ||||
| [whitepaper-url]: https://0xproject.com/pdfs/0x_white_paper.pdf | ||||
| [dev-mailing-list-url]: http://eepurl.com/dx4cPf | ||||
|  | ||||
| [](https://circleci.com/gh/0xProject/0x-monorepo) | ||||
| [](https://coveralls.io/github/0xProject/0x-monorepo?branch=development) | ||||
|   | ||||
							
								
								
									
										11
									
								
								lerna.json
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								lerna.json
									
									
									
									
									
								
							| @@ -1,15 +1,10 @@ | ||||
| { | ||||
|     "lerna": "2.5.1", | ||||
|     "lerna": "3.0.0-beta.23", | ||||
|     "packages": ["packages/*"], | ||||
|     "commands": { | ||||
|         "publish": { | ||||
|             "allowBranch": "development" | ||||
|         } | ||||
|     }, | ||||
|     "version": "independent", | ||||
|     "commands": { | ||||
|     "command": { | ||||
|         "publish": { | ||||
|             "ignore": ["test/**/*", "*.md", "scripts", "lib", "tslint.json", "tsconfig.json"] | ||||
|             "ignoreChanges": ["test/**/*", "*.md", "scripts", "lib", "tslint.json", "tsconfig.json"] | ||||
|         } | ||||
|     }, | ||||
|     "npmClient": "yarn", | ||||
|   | ||||
							
								
								
									
										27
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								package.json
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | ||||
|     "private": true, | ||||
|     "name": "0x-monorepo", | ||||
|     "engines": { | ||||
|         "node" : ">=6.12" | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
|     "workspaces": [ | ||||
|         "packages/*" | ||||
| @@ -13,20 +13,26 @@ | ||||
|         "prettier:ci": "prettier --list-different '**/*.{ts,tsx,json,md}' --config .prettierrc", | ||||
|         "report_coverage": "lcov-result-merger 'packages/*/coverage/lcov.info' | coveralls", | ||||
|         "test:installation": "node ./packages/monorepo-scripts/lib/test_installation.js", | ||||
|         "run:publish": "run-s install:all rebuild script:publish", | ||||
|         "run:publish:dry": "run-s install:all rebuild script:publish:dry", | ||||
|         "test:installation:local": "IS_LOCAL_PUBLISH=true node ./packages/monorepo-scripts/lib/test_installation.js", | ||||
|         "run:publish": "run-s install:all build:monorepo_scripts script:prepublish_checks rebuild:no_website script:publish", | ||||
|         "run:publish:local": "IS_LOCAL_PUBLISH=true yarn run:publish", | ||||
|         "script:prepublish_checks": "node ./packages/monorepo-scripts/lib/prepublish_checks.js", | ||||
|         "script:publish": "node ./packages/monorepo-scripts/lib/publish.js", | ||||
|         "script:publish:dry": "IS_DRY_RUN=true yarn script:publish", | ||||
|         "install:all": "yarn install", | ||||
|         "wsrun": "wsrun", | ||||
|         "lerna:run": "lerna run", | ||||
|         "watch": "wsrun watch $PKG --fast-exit -r --stages --done-criteria='complete|successfully'", | ||||
|         "lerna": "lerna", | ||||
|         "watch": "wsrun watch_without_deps $PKG --fast-exit -r --stages --done-criteria='complete|successfully'", | ||||
|         "build": "wsrun build $PKG --fast-exit -r --stages", | ||||
|         "build:no_website": "wsrun build $PKG --fast-exit -r --stages --exclude @0xproject/website", | ||||
|         "build:monorepo_scripts": "PKG=@0xproject/monorepo-scripts yarn build", | ||||
|         "clean": "wsrun clean $PKG --fast-exit -r --parallel", | ||||
|         "remove_node_modules": "lerna clean --yes; rm -rf node_modules", | ||||
|         "rebuild": "run-s clean build", | ||||
|         "rebuild:no_website": "run-s clean build:no_website", | ||||
|         "test": "wsrun test $PKG --fast-exit --serial --exclude-missing", | ||||
|         "stage_docs": "wsrun docs:stage $PKG --fast-exit --parallel --exclude-missing", | ||||
|         "lint": "wsrun lint $PKG --fast-exit --parallel --exclude-missing" | ||||
|         "lint": "wsrun lint $PKG --fast-exit --parallel --exclude-missing", | ||||
|         "comment:postinstall": "HACK: For some reason `yarn` is not setting up symlinks properly for order-utils. We temporarily set them manually. Remove this after V2 refactor is complete." | ||||
|     }, | ||||
|     "config": { | ||||
|         "mnemonic": "concert load couple harbor equip island argue ramp clarify fence smart topic" | ||||
| @@ -34,14 +40,15 @@ | ||||
|     "devDependencies": { | ||||
|         "async-child-process": "^1.1.1", | ||||
|         "coveralls": "^3.0.0", | ||||
|         "ganache-cli": "^6.1.0", | ||||
|         "ganache-cli": "6.1.3", | ||||
|         "lcov-result-merger": "^3.0.0", | ||||
|         "lerna": "^2.5.1", | ||||
|         "@0x-lerna-fork/lerna": "3.0.0-beta.23", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "prettier": "^1.11.1", | ||||
|         "source-map-support": "^0.5.6", | ||||
|         "wsrun": "^2.2.0" | ||||
|     }, | ||||
|     "resolutions": { | ||||
|         "ethereumjs-tx": "0xProject/ethereumjs-tx#fake-tx-include-signature-by-default" | ||||
|         "ethers": "0xproject/ethers.js#eip-838-reasons" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,128 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1527809861, | ||||
|         "version": "1.0.1-rc.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed bug caused by importing non-existent dep" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1532619515 | ||||
|     }, | ||||
|     { | ||||
|         "version": "1.0.1-rc.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1532605697 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532357734, | ||||
|         "version": "1.0.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532043100, | ||||
|         "version": "1.0.0-rc.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Remove `zeroEx.assetData`  and instead re-export it's static functions directly off `ZeroEx`" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532043000, | ||||
|         "version": "1.0.0-rc.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Remove tokenRegistry wrapper", | ||||
|                 "pr": 863 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Rename `zeroEx.token` to `zeroEx.erc20Token`, and add `zeroEx.erc721Token`", | ||||
|                 "pr": 863 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Rename `zeroEx.proxy` to `zeroEx.erc20Proxy` and add `zeroEx.erc721Proxy`", | ||||
|                 "pr": 863 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Refactored `ZeroEx.isValidSignature` to `zeroEx.isValidSignatureAsync`. It is now async so that it can verify contract-dependent signature types", | ||||
|                 "pr": 863 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Refactored `signOrderHashAsync` to `ecSignOrderHashAsync`. There are now many non-ECSignature ways to sign orders too.", | ||||
|                 "pr": 863 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Removed `createOrderWatcherAsync` method. Will be added back once OrderWatcher is refactored for V2", | ||||
|                 "pr": 863 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "0x.js exports renamed contract events and event arg types", | ||||
|                 "pr": 863 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Export `ZeroEx.assetData` with methods to decode/encode assetData fields found in 0x orders", | ||||
|                 "pr": 884 | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531919263, | ||||
|         "version": "0.38.6", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531149657, | ||||
|         "version": "0.38.5", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1529397769, | ||||
|         "version": "0.38.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527617805, | ||||
|         "version": "0.38.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527617227, | ||||
|         "version": "0.38.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527616612, | ||||
|         "version": "0.38.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|   | ||||
| @@ -1,11 +1,58 @@ | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| changelogUtils.file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.38.1 - _May 31, 2018_ | ||||
| ## v1.0.1-rc.2 - _July 26, 2018_ | ||||
|  | ||||
|     * Fixed bug caused by importing non-existent dep | ||||
|  | ||||
| ## v1.0.1-rc.1 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.0 - _July 23, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.0-rc.2 - _July 20, 2018_ | ||||
|  | ||||
|     * Remove `zeroEx.assetData`  and instead re-export it's static functions directly off `ZeroEx` | ||||
|  | ||||
| ## v1.0.0-rc.1 - _July 20, 2018_ | ||||
|  | ||||
|     * Remove tokenRegistry wrapper (#863) | ||||
|     * Rename `zeroEx.token` to `zeroEx.erc20Token`, and add `zeroEx.erc721Token` (#863) | ||||
|     * Rename `zeroEx.proxy` to `zeroEx.erc20Proxy` and add `zeroEx.erc721Proxy` (#863) | ||||
|     * Refactored `ZeroEx.isValidSignature` to `zeroEx.isValidSignatureAsync`. It is now async so that it can verify contract-dependent signature types (#863) | ||||
|     * Refactored `signOrderHashAsync` to `ecSignOrderHashAsync`. There are now many non-ECSignature ways to sign orders too. (#863) | ||||
|     * Removed `createOrderWatcherAsync` method. Will be added back once OrderWatcher is refactored for V2 (#863) | ||||
|     * 0x.js exports renamed contract events and event arg types (#863) | ||||
|     * Export `ZeroEx.assetData` with methods to decode/encode assetData fields found in 0x orders (#884) | ||||
|  | ||||
| ## v0.38.6 - _July 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.38.5 - _July 9, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.38.4 - _June 19, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.38.3 - _May 29, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.38.2 - _May 29, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.38.1 - _May 29, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| @@ -14,7 +61,7 @@ CHANGELOG | ||||
|     * Renamed createOrderStateWatcher to createOrderWatcherAsync since it is now async (#579) | ||||
|     * Renamed ZeroExError to ContractWrappersErrors since they now lives in the @0xproject/contract-wrappers subpackage (#579) | ||||
|  | ||||
| ## v0.37.2 - _May 4, 2018_ | ||||
| ## v0.37.2 - _May 5, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "0x.js", | ||||
|     "version": "0.38.0", | ||||
|     "version": "1.0.1-rc.1", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -15,27 +15,30 @@ | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "watch": "tsc -w", | ||||
|         "prebuild": "run-s clean generate_contract_wrappers", | ||||
|         "build": "run-p build:umd:prod build:commonjs; exit 0;", | ||||
|         "generate_contract_wrappers": "abi-gen --abis 'src/compact_artifacts/@(Exchange|Token|TokenTransferProxy|EtherToken|TokenRegistry|DummyToken).json' --template ../contract_templates/contract.handlebars --partials '../contract_templates/partials/**/*.handlebars' --output src/contract_wrappers/generated --backend ethers && prettier --write 'src/contract_wrappers/generated/**.ts'", | ||||
|         "lint": "tslint --project .", | ||||
|         "watch_without_deps": "yarn pre_build && tsc -w", | ||||
|         "build": "yarn pre_build && yarn build:all && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "build:all": "run-p build:umd:prod build:commonjs; exit 0;", | ||||
|         "pre_build": "run-s update_artifacts generate_contract_wrappers", | ||||
|         "copy_artifacts": "copyfiles -u 2 './src/artifacts/**/*.json' ./lib/src/artifacts", | ||||
|         "update_artifacts": "for i in ${npm_package_config_contracts}; do copyfiles -u 4 ../migrations/artifacts/2.0.0/$i.json src/artifacts; done;", | ||||
|         "generate_contract_wrappers": "abi-gen --abis 'src/artifacts/@(ZRXToken).json' --template ../contract_templates/contract.handlebars --partials '../contract_templates/partials/**/*.handlebars' --output src/generated_contract_wrappers --backend ethers", | ||||
|         "lint": "tslint --project . --exclude **/src/generated_contract_wrappers/**/*", | ||||
|         "test:circleci": "run-s test:coverage", | ||||
|         "test": "run-s clean test:commonjs", | ||||
|         "test": "yarn run_mocha", | ||||
|         "rebuild_and_test": "run-s build test", | ||||
|         "test:coverage": "nyc npm run test --all && yarn coverage:report:lcov", | ||||
|         "coverage:report:lcov": "nyc report --reporter=text-lcov > coverage/lcov.info", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp scripts src/contract_wrappers/generated", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp scripts src/generated_contract_wrappers", | ||||
|         "build:umd:prod": "NODE_ENV=production webpack", | ||||
|         "build:commonjs": "tsc && copyfiles -u 2 './src/compact_artifacts/**/*.json' ./lib/src/compact_artifacts && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "test:commonjs": "run-s build:commonjs run_mocha", | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js lib/test/global_hooks.js --timeout 10000 --bail --exit", | ||||
|         "build:commonjs": "tsc && yarn copy_artifacts && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "run_mocha": "mocha --require source-map-support/register --require make-promises-safe lib/test/**/*_test.js lib/test/global_hooks.js --timeout 10000 --bail --exit", | ||||
|         "manual:postpublish": "yarn build; node ./scripts/postpublish.js", | ||||
|         "docs:stage": "node scripts/stage_docs.js", | ||||
|         "docs:json": "typedoc --excludePrivate --excludeExternals --target ES5 --json $JSON_FILE_PATH $PROJECT_FILES", | ||||
|         "upload_docs_json": "aws s3 cp generated_docs/index.json $S3_URL --profile 0xproject --grants read=uri=http://acs.amazonaws.com/groups/global/AllUsers --content-type application/json" | ||||
|     }, | ||||
|     "config": { | ||||
|         "compact_artifacts": "Exchange DummyToken ZRXToken Token EtherToken TokenTransferProxy TokenRegistry", | ||||
|         "contracts": "ZRXToken", | ||||
|         "postpublish": { | ||||
|             "assets": [ | ||||
|                 "packages/0x.js/_bundles/index.js", | ||||
| @@ -48,13 +51,11 @@ | ||||
|                     "../contract-wrappers/src/types.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/ether_token_wrapper.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/exchange_wrapper.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/token_registry_wrapper.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/token_transfer_proxy_wrapper.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/token_wrapper.ts", | ||||
|                     "../order-watcher/src/order_watcher/order_watcher.ts", | ||||
|                     "./src/contract_wrappers/generated/ether_token.ts", | ||||
|                     "./src/contract_wrappers/generated/token.ts", | ||||
|                     "./src/contract_wrappers/generated/exchange.ts" | ||||
|                     "../contract-wrappers/src/contract_wrappers/erc20_proxy_wrapper.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/erc721_proxy_wrapper.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/erc20_token_wrapper.ts", | ||||
|                     "../contract-wrappers/src/contract_wrappers/erc721_token_wrapper.ts", | ||||
|                     "../order-watcher/src/order_watcher/order_watcher.ts" | ||||
|                 ], | ||||
|                 "s3BucketPath": "s3://doc-jsons/0x.js/", | ||||
|                 "s3StagingBucketPath": "s3://staging-doc-jsons/0x.js/" | ||||
| @@ -67,12 +68,11 @@ | ||||
|     }, | ||||
|     "license": "Apache-2.0", | ||||
|     "devDependencies": { | ||||
|         "@0xproject/abi-gen": "^0.3.0", | ||||
|         "@0xproject/dev-utils": "^0.4.2", | ||||
|         "@0xproject/migrations": "^0.0.6", | ||||
|         "@0xproject/monorepo-scripts": "^0.1.20", | ||||
|         "@0xproject/sol-compiler": "^0.5.0", | ||||
|         "@0xproject/tslint-config": "^0.4.18", | ||||
|         "@0xproject/abi-gen": "^1.0.3", | ||||
|         "@0xproject/dev-utils": "^1.0.3", | ||||
|         "@0xproject/migrations": "^1.0.3", | ||||
|         "@0xproject/monorepo-scripts": "^1.0.4", | ||||
|         "@0xproject/tslint-config": "^1.0.4", | ||||
|         "@types/lodash": "4.14.104", | ||||
|         "@types/mocha": "^2.2.42", | ||||
|         "@types/node": "^8.0.53", | ||||
| @@ -89,28 +89,27 @@ | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "nyc": "^11.0.1", | ||||
|         "opn-cli": "^3.1.0", | ||||
|         "prettier": "^1.11.1", | ||||
|         "shx": "^0.2.2", | ||||
|         "sinon": "^4.0.0", | ||||
|         "source-map-support": "^0.5.0", | ||||
|         "tslint": "5.8.0", | ||||
|         "tslint": "5.11.0", | ||||
|         "typedoc": "0xProject/typedoc", | ||||
|         "typescript": "2.7.1", | ||||
|         "webpack": "^3.1.0" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0xproject/assert": "^0.2.10", | ||||
|         "@0xproject/base-contract": "^0.3.2", | ||||
|         "@0xproject/contract-wrappers": "^0.0.2", | ||||
|         "@0xproject/order-utils": "^0.0.5", | ||||
|         "@0xproject/order-watcher": "^0.0.2", | ||||
|         "@0xproject/sol-compiler": "^0.5.0", | ||||
|         "@0xproject/types": "0.7.0", | ||||
|         "@0xproject/typescript-typings": "^0.3.2", | ||||
|         "@0xproject/utils": "^0.6.2", | ||||
|         "@0xproject/web3-wrapper": "^0.6.4", | ||||
|         "ethereum-types": "^0.0.1", | ||||
|         "ethers": "^3.0.15", | ||||
|         "@0xproject/assert": "^1.0.3", | ||||
|         "@0xproject/base-contract": "^1.0.3", | ||||
|         "@0xproject/contract-wrappers": "^1.0.1-rc.2", | ||||
|         "@0xproject/order-utils": "^1.0.1-rc.2", | ||||
|         "@0xproject/sol-compiler": "^1.0.3", | ||||
|         "@0xproject/subproviders": "^1.0.3", | ||||
|         "@0xproject/types": "^1.0.1-rc.2", | ||||
|         "@0xproject/typescript-typings": "^1.0.3", | ||||
|         "@0xproject/utils": "^1.0.3", | ||||
|         "@0xproject/web3-wrapper": "^1.1.1", | ||||
|         "ethereum-types": "^1.0.3", | ||||
|         "ethers": "3.0.22", | ||||
|         "lodash": "^4.17.4" | ||||
|     }, | ||||
|     "publishConfig": { | ||||
|   | ||||
| @@ -2,24 +2,28 @@ import { assert } from '@0xproject/assert'; | ||||
| import { | ||||
|     ContractWrappers, | ||||
|     ContractWrappersConfig, | ||||
|     ERC20ProxyWrapper, | ||||
|     ERC20TokenWrapper, | ||||
|     ERC721ProxyWrapper, | ||||
|     ERC721TokenWrapper, | ||||
|     EtherTokenWrapper, | ||||
|     ExchangeWrapper, | ||||
|     TokenRegistryWrapper, | ||||
|     TokenTransferProxyWrapper, | ||||
|     TokenWrapper, | ||||
| } from '@0xproject/contract-wrappers'; | ||||
| import { | ||||
|     assetDataUtils, | ||||
|     ecSignOrderHashAsync, | ||||
|     generatePseudoRandomSalt, | ||||
|     getOrderHashHex, | ||||
|     isValidOrderHash, | ||||
|     isValidSignature, | ||||
|     signOrderHashAsync, | ||||
|     isValidSignatureAsync, | ||||
|     MessagePrefixOpts, | ||||
|     orderHashUtils, | ||||
| } from '@0xproject/order-utils'; | ||||
| import { OrderWatcher, OrderWatcherConfig } from '@0xproject/order-watcher'; | ||||
| import { ECSignature, Order, Provider, SignedOrder, TransactionReceiptWithDecodedLogs } from '@0xproject/types'; | ||||
| // HACK: Since we export assetDataUtils from ZeroEx and it has AssetProxyId, ERC20AssetData and ERC721AssetData | ||||
| // in it's public interface, we need to import these types here. | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { AssetProxyId, ECSignature, ERC20AssetData, ERC721AssetData, Order, SignedOrder } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
| import { Provider, TransactionReceiptWithDecodedLogs } from 'ethereum-types'; | ||||
|  | ||||
| import { constants } from './utils/constants'; | ||||
|  | ||||
| @@ -39,25 +43,29 @@ export class ZeroEx { | ||||
|      */ | ||||
|     public exchange: ExchangeWrapper; | ||||
|     /** | ||||
|      * An instance of the TokenRegistryWrapper class containing methods for interacting with the 0x | ||||
|      * TokenRegistry smart contract. | ||||
|      * An instance of the ERC20TokenWrapper class containing methods for interacting with any ERC20 token smart contract. | ||||
|      */ | ||||
|     public tokenRegistry: TokenRegistryWrapper; | ||||
|     public erc20Token: ERC20TokenWrapper; | ||||
|     /** | ||||
|      * An instance of the TokenWrapper class containing methods for interacting with any ERC20 token smart contract. | ||||
|      * An instance of the ERC721TokenWrapper class containing methods for interacting with any ERC721 token smart contract. | ||||
|      */ | ||||
|     public token: TokenWrapper; | ||||
|     public erc721Token: ERC721TokenWrapper; | ||||
|     /** | ||||
|      * An instance of the EtherTokenWrapper class containing methods for interacting with the | ||||
|      * wrapped ETH ERC20 token smart contract. | ||||
|      */ | ||||
|     public etherToken: EtherTokenWrapper; | ||||
|     /** | ||||
|      * An instance of the TokenTransferProxyWrapper class containing methods for interacting with the | ||||
|      * tokenTransferProxy smart contract. | ||||
|      * An instance of the ERC20ProxyWrapper class containing methods for interacting with the | ||||
|      * ERC20 proxy smart contract. | ||||
|      */ | ||||
|     public proxy: TokenTransferProxyWrapper; | ||||
|     private _contractWrappers: ContractWrappers; | ||||
|     public erc20Proxy: ERC20ProxyWrapper; | ||||
|     /** | ||||
|      * An instance of the ERC721ProxyWrapper class containing methods for interacting with the | ||||
|      * ERC721 proxy smart contract. | ||||
|      */ | ||||
|     public erc721Proxy: ERC721ProxyWrapper; | ||||
|     private readonly _contractWrappers: ContractWrappers; | ||||
|     /** | ||||
|      * Generates a pseudo-random 256-bit salt. | ||||
|      * The salt can be included in a 0x order, ensuring that the order generates a unique orderHash | ||||
| @@ -67,24 +75,13 @@ export class ZeroEx { | ||||
|     public static generatePseudoRandomSalt(): BigNumber { | ||||
|         return generatePseudoRandomSalt(); | ||||
|     } | ||||
|     /** | ||||
|      * Verifies that the elliptic curve signature `signature` was generated | ||||
|      * by signing `data` with the private key corresponding to the `signerAddress` address. | ||||
|      * @param   data          The hex encoded data signed by the supplied signature. | ||||
|      * @param   signature     An object containing the elliptic curve signature parameters. | ||||
|      * @param   signerAddress The hex encoded address that signed the data, producing the supplied signature. | ||||
|      * @return  Whether the signature is valid for the supplied signerAddress and data. | ||||
|      */ | ||||
|     public static isValidSignature(data: string, signature: ECSignature, signerAddress: string): boolean { | ||||
|         return isValidSignature(data, signature, signerAddress); | ||||
|     } | ||||
|     /** | ||||
|      * Computes the orderHash for a supplied order. | ||||
|      * @param   order   An object that conforms to the Order or SignedOrder interface definitions. | ||||
|      * @return  The resulting orderHash from hashing the supplied order. | ||||
|      */ | ||||
|     public static getOrderHashHex(order: Order | SignedOrder): string { | ||||
|         return getOrderHashHex(order); | ||||
|         return orderHashUtils.getOrderHashHex(order); | ||||
|     } | ||||
|     /** | ||||
|      * Checks if the supplied hex encoded order hash is valid. | ||||
| @@ -94,7 +91,7 @@ export class ZeroEx { | ||||
|      * @return  Whether the supplied orderHash has the expected format. | ||||
|      */ | ||||
|     public static isValidOrderHash(orderHash: string): boolean { | ||||
|         return isValidOrderHash(orderHash); | ||||
|         return orderHashUtils.isValidOrderHash(orderHash); | ||||
|     } | ||||
|     /** | ||||
|      * A unit amount is defined as the amount of a token above the specified decimal places (integer part). | ||||
| @@ -124,6 +121,57 @@ export class ZeroEx { | ||||
|         const baseUnitAmount = Web3Wrapper.toBaseUnitAmount(amount, decimals); | ||||
|         return baseUnitAmount; | ||||
|     } | ||||
|     /** | ||||
|      * Encodes an ERC20 token address into a hex encoded assetData string, usable in the makerAssetData or | ||||
|      * takerAssetData fields in a 0x order. | ||||
|      * @param tokenAddress  The ERC20 token address to encode | ||||
|      * @return The hex encoded assetData string | ||||
|      */ | ||||
|     public static encodeERC20AssetData(tokenAddress: string): string { | ||||
|         return assetDataUtils.encodeERC20AssetData(tokenAddress); | ||||
|     } | ||||
|     /** | ||||
|      * Decodes an ERC20 assetData hex string into it's corresponding ERC20 tokenAddress & assetProxyId | ||||
|      * @param assetData Hex encoded assetData string to decode | ||||
|      * @return An object containing the decoded tokenAddress & assetProxyId | ||||
|      */ | ||||
|     public static decodeERC20AssetData(assetData: string): ERC20AssetData { | ||||
|         return assetDataUtils.decodeERC20AssetData(assetData); | ||||
|     } | ||||
|     /** | ||||
|      * Encodes an ERC721 token address into a hex encoded assetData string, usable in the makerAssetData or | ||||
|      * takerAssetData fields in a 0x order. | ||||
|      * @param tokenAddress  The ERC721 token address to encode | ||||
|      * @param tokenId  The ERC721 tokenId to encode | ||||
|      * @return The hex encoded assetData string | ||||
|      */ | ||||
|     public static encodeERC721AssetData(tokenAddress: string, tokenId: BigNumber): string { | ||||
|         return assetDataUtils.encodeERC721AssetData(tokenAddress, tokenId); | ||||
|     } | ||||
|     /** | ||||
|      * Decodes an ERC721 assetData hex string into it's corresponding ERC721 tokenAddress, tokenId & assetProxyId | ||||
|      * @param assetData Hex encoded assetData string to decode | ||||
|      * @return An object containing the decoded tokenAddress, tokenId & assetProxyId | ||||
|      */ | ||||
|     public static decodeERC721AssetData(assetData: string): ERC721AssetData { | ||||
|         return assetDataUtils.decodeERC721AssetData(assetData); | ||||
|     } | ||||
|     /** | ||||
|      * Decode and return the assetProxyId from the assetData | ||||
|      * @param assetData Hex encoded assetData string to decode | ||||
|      * @return The assetProxyId | ||||
|      */ | ||||
|     public static decodeAssetProxyId(assetData: string): AssetProxyId { | ||||
|         return assetDataUtils.decodeAssetProxyId(assetData); | ||||
|     } | ||||
|     /** | ||||
|      * Decode any assetData into it's corresponding assetData object | ||||
|      * @param assetData Hex encoded assetData string to decode | ||||
|      * @return Either a ERC20 or ERC721 assetData object | ||||
|      */ | ||||
|     public static decodeAssetDataOrThrow(assetData: string): ERC20AssetData | ERC721AssetData { | ||||
|         return assetDataUtils.decodeAssetDataOrThrow(assetData); | ||||
|     } | ||||
|     /** | ||||
|      * Instantiates a new ZeroEx instance that provides the public interface to the 0x.js library. | ||||
|      * @param   provider    The Provider instance you would like the 0x.js library to use for interacting with | ||||
| @@ -135,12 +183,29 @@ export class ZeroEx { | ||||
|         assert.isWeb3Provider('provider', provider); | ||||
|         this._contractWrappers = new ContractWrappers(provider, config); | ||||
|  | ||||
|         this.proxy = this._contractWrappers.proxy; | ||||
|         this.token = this._contractWrappers.token; | ||||
|         this.erc20Proxy = this._contractWrappers.erc20Proxy; | ||||
|         this.erc721Proxy = this._contractWrappers.erc721Proxy; | ||||
|         this.erc20Token = this._contractWrappers.erc20Token; | ||||
|         this.erc721Token = this._contractWrappers.erc721Token; | ||||
|         this.exchange = this._contractWrappers.exchange; | ||||
|         this.tokenRegistry = this._contractWrappers.tokenRegistry; | ||||
|         this.etherToken = this._contractWrappers.etherToken; | ||||
|     } | ||||
|     /** | ||||
|      * Verifies that the provided signature is valid according to the 0x Protocol smart contracts | ||||
|      * @param   data          The hex encoded data signed by the supplied signature. | ||||
|      * @param   signature     The hex encoded signature. | ||||
|      * @param   signerAddress The hex encoded address that signed the data, producing the supplied signature. | ||||
|      * @return  Whether the signature is valid for the supplied signerAddress and data. | ||||
|      */ | ||||
|     public async isValidSignatureAsync(data: string, signature: string, signerAddress: string): Promise<boolean> { | ||||
|         const isValid = await isValidSignatureAsync( | ||||
|             this._contractWrappers.getProvider(), | ||||
|             data, | ||||
|             signature, | ||||
|             signerAddress, | ||||
|         ); | ||||
|         return isValid; | ||||
|     } | ||||
|     /** | ||||
|      * Sets a new web3 provider for 0x.js. Updating the provider will stop all | ||||
|      * subscriptions so you will need to re-subscribe to all events relevant to your app after this call. | ||||
| @@ -173,23 +238,21 @@ export class ZeroEx { | ||||
|      * @param   orderHash       Hex encoded orderHash to sign. | ||||
|      * @param   signerAddress   The hex encoded Ethereum address you wish to sign it with. This address | ||||
|      *          must be available via the Provider supplied to 0x.js. | ||||
|      * @param   shouldAddPersonalMessagePrefix  Some signers add the personal message prefix `\x19Ethereum Signed Message` | ||||
|      *          themselves (e.g Parity Signer, Ledger, TestRPC) and others expect it to already be done by the client | ||||
|      *          (e.g Metamask). Depending on which signer this request is going to, decide on whether to add the prefix | ||||
|      *          before sending the request. | ||||
|      * @param   MessagePrefixOpts  Options regarding the desired prefix and whether to add it before calling `eth_sign` | ||||
|      * @return  An object containing the Elliptic curve signature parameters generated by signing the orderHash. | ||||
|      */ | ||||
|     public async signOrderHashAsync( | ||||
|     public async ecSignOrderHashAsync( | ||||
|         orderHash: string, | ||||
|         signerAddress: string, | ||||
|         shouldAddPersonalMessagePrefix: boolean, | ||||
|         messagePrefixOpts: MessagePrefixOpts, | ||||
|     ): Promise<ECSignature> { | ||||
|         return signOrderHashAsync( | ||||
|         const signature = await ecSignOrderHashAsync( | ||||
|             this._contractWrappers.getProvider(), | ||||
|             orderHash, | ||||
|             signerAddress, | ||||
|             shouldAddPersonalMessagePrefix, | ||||
|             messagePrefixOpts, | ||||
|         ); | ||||
|         return signature; | ||||
|     } | ||||
|     /** | ||||
|      * Waits for a transaction to be mined and returns the transaction receipt. | ||||
| @@ -212,18 +275,4 @@ export class ZeroEx { | ||||
|         ); | ||||
|         return transactionReceiptWithDecodedLogs; | ||||
|     } | ||||
|     /** | ||||
|      * Instantiates and returns a new OrderWatcher instance. | ||||
|      * Defaults to watching the pending state. | ||||
|      * @param   config      The configuration object. Look up the type for the description. | ||||
|      * @return  An instance of the 0x.js OrderWatcher class. | ||||
|      */ | ||||
|     public async createOrderWatcherAsync(config?: OrderWatcherConfig): Promise<OrderWatcher> { | ||||
|         // Hack: Get Web3Wrapper from ContractWrappers | ||||
|         const web3Wrapper: Web3Wrapper = (this._contractWrappers as any)._web3Wrapper; | ||||
|         const networkId = await web3Wrapper.getNetworkIdAsync(); | ||||
|         const provider = this._contractWrappers.getProvider(); | ||||
|         const orderWatcher = new OrderWatcher(provider, networkId, config); | ||||
|         return orderWatcher; | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										7
									
								
								packages/0x.js/src/artifacts.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								packages/0x.js/src/artifacts.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| import { ContractArtifact } from '@0xproject/sol-compiler'; | ||||
|  | ||||
| import * as ZRXToken from './artifacts/ZRXToken.json'; | ||||
|  | ||||
| export const artifacts = { | ||||
|     ZRXToken: (ZRXToken as any) as ContractArtifact, | ||||
| }; | ||||
							
								
								
									
										10031
									
								
								packages/0x.js/src/artifacts/ZRXToken.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10031
									
								
								packages/0x.js/src/artifacts/ZRXToken.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|     "contract_name": "DummyToken", | ||||
|     "abi": [ | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_target", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_value", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setBalance", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         } | ||||
|     ] | ||||
| } | ||||
| @@ -1,287 +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" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "_owner", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "_value", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "Deposit", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "_owner", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "_value", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "Withdrawal", | ||||
|             "type": "event" | ||||
|         } | ||||
|     ], | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0xc00fd9820cd2898cc4c054b7bf142de637ad129a" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0xc778417e063141139fce010982780140aa0cd5ab" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0x653e49e301e508a13237c0ddc98ae7d4cd2667a1" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x871dd7c2b4b25e1aa18728e9d5f2af4c4e431f5c" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,172 +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" | ||||
|         } | ||||
|     ] | ||||
| } | ||||
| @@ -1,547 +0,0 @@ | ||||
| { | ||||
|     "contract_name": "TokenRegistry", | ||||
|     "abi": [ | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_index", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "removeToken", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenAddressByName", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenAddressBySymbol", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenSwarmHash", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenMetaData", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "owner", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "addToken", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenName", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "tokens", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "tokenAddresses", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenByName", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "getTokenAddresses", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address[]" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenIpfsHash", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenBySymbol", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenSymbol", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "newOwner", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "transferOwnership", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogAddToken", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogRemoveToken", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldName", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newName", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenNameChange", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldSymbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newSymbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenSymbolChange", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldIpfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newIpfsHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenIpfsHashChange", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldSwarmHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newSwarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenSwarmHashChange", | ||||
|             "type": "event" | ||||
|         } | ||||
|     ], | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0x926a74c5c36adf004c87399e65f75628b0f98d2c" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0x6b1a50f0bb5a7995444bd3877b22dc89c62843ed" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0x4e9aad8184de8833365fea970cd9149372fdf1e6" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0xf18e504561f4347bea557f3d4558f559dddbae7f" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x0b1ba0af832d7c05fd64161e0db78e85978e8082" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,187 +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" | ||||
|         } | ||||
|     ], | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0x8da0d80f5007ef1e431dd2127178d224e32c2ef4" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0x4e9aad8184de8833365fea970cd9149372fdf1e6" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0xa8e9fa8f91e5ae138c74648c9c304f1c75003a8d" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0x087eed4bc1ee3de49befbd66c662b434b15d49d4" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x1dc4c1cefef38a777b15aa20260a54e584b16c48" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,20 +0,0 @@ | ||||
| { | ||||
|     "contract_name": "ZRX", | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0xe41d2489571d322189246dafa5ebde1f4699f498" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0xa8e9fa8f91e5ae138c74648c9c304f1c75003a8d" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0x00f58d6d585f84b2d7267940cede30ce2fe6eae8" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0x6ff6c0ff1d68b964901f986d4c9fa3ac68346570" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x1d7022f5b17d2f8b695918fb48fa1089c9f85401" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,30 +1,38 @@ | ||||
| export { ZeroEx } from './0x'; | ||||
|  | ||||
| export { MessagePrefixType, MessagePrefixOpts } from '@0xproject/order-utils'; | ||||
| export { Web3ProviderEngine, RPCSubprovider } from '@0xproject/subproviders'; | ||||
|  | ||||
| export { | ||||
|     BlockParamLiteral, | ||||
|     FilterObject, | ||||
|     BlockParam, | ||||
|     ContractEventArg, | ||||
|     ExchangeContractErrs, | ||||
|     LogWithDecodedArgs, | ||||
|     Order, | ||||
|     Provider, | ||||
|     SignedOrder, | ||||
|     ECSignature, | ||||
|     OrderStateValid, | ||||
|     OrderStateInvalid, | ||||
|     OrderState, | ||||
|     Token, | ||||
|     ERC20AssetData, | ||||
|     ERC721AssetData, | ||||
|     AssetProxyId, | ||||
| } from '@0xproject/types'; | ||||
|  | ||||
| export { | ||||
|     BlockParamLiteral, | ||||
|     FilterObject, | ||||
|     BlockParam, | ||||
|     LogWithDecodedArgs, | ||||
|     ContractEventArg, | ||||
|     Provider, | ||||
|     TransactionReceipt, | ||||
|     TransactionReceiptWithDecodedLogs, | ||||
| } from '@0xproject/types'; | ||||
| } from 'ethereum-types'; | ||||
|  | ||||
| export { | ||||
|     EventCallback, | ||||
|     ContractEvent, | ||||
|     IndexedFilterValues, | ||||
|     BlockRange, | ||||
|     OrderCancellationRequest, | ||||
|     OrderFillRequest, | ||||
|     ContractEventArgs, | ||||
|     MethodOpts, | ||||
| @@ -34,18 +42,25 @@ export { | ||||
|     DecodedLogEvent, | ||||
|     OnOrderStateChangeCallback, | ||||
|     ContractWrappersError, | ||||
|     EtherTokenContractEventArgs, | ||||
|     WithdrawalContractEventArgs, | ||||
|     DepositContractEventArgs, | ||||
|     EtherTokenEvents, | ||||
|     TransferContractEventArgs, | ||||
|     ApprovalContractEventArgs, | ||||
|     TokenContractEventArgs, | ||||
|     TokenEvents, | ||||
|     LogErrorContractEventArgs, | ||||
|     LogCancelContractEventArgs, | ||||
|     LogFillContractEventArgs, | ||||
|     ExchangeContractEventArgs, | ||||
|     ExchangeEvents, | ||||
|     WETH9Events, | ||||
|     WETH9WithdrawalEventArgs, | ||||
|     WETH9ApprovalEventArgs, | ||||
|     WETH9EventArgs, | ||||
|     WETH9DepositEventArgs, | ||||
|     WETH9TransferEventArgs, | ||||
|     ERC20TokenTransferEventArgs, | ||||
|     ERC20TokenApprovalEventArgs, | ||||
|     ERC20TokenEvents, | ||||
|     ERC20TokenEventArgs, | ||||
|     ERC721TokenApprovalEventArgs, | ||||
|     ERC721TokenApprovalForAllEventArgs, | ||||
|     ERC721TokenTransferEventArgs, | ||||
|     ERC721TokenEvents, | ||||
|     ExchangeCancelUpToEventArgs, | ||||
|     ExchangeAssetProxyRegisteredEventArgs, | ||||
|     ExchangeFillEventArgs, | ||||
|     ExchangeCancelEventArgs, | ||||
|     ExchangeEventArgs, | ||||
|     ContractWrappersConfig, | ||||
|     OrderInfo, | ||||
| } from '@0xproject/contract-wrappers'; | ||||
|   | ||||
| @@ -8,8 +8,8 @@ export const zeroExPrivateNetworkConfigSchema = { | ||||
|         gasPrice: { $ref: '/Number' }, | ||||
|         zrxContractAddress: { $ref: '/Address' }, | ||||
|         exchangeContractAddress: { $ref: '/Address' }, | ||||
|         tokenRegistryContractAddress: { $ref: '/Address' }, | ||||
|         tokenTransferProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc20ProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc721ProxyContractAddress: { $ref: '/Address' }, | ||||
|         orderWatcherConfig: { | ||||
|             type: 'object', | ||||
|             properties: { | ||||
| @@ -29,7 +29,7 @@ export const zeroExPrivateNetworkConfigSchema = { | ||||
|         'networkId', | ||||
|         'zrxContractAddress', | ||||
|         'exchangeContractAddress', | ||||
|         'tokenRegistryContractAddress', | ||||
|         'tokenTransferProxyContractAddress', | ||||
|         'erc20ProxyContractAddress', | ||||
|         'erc721ProxyContractAddress', | ||||
|     ], | ||||
| }; | ||||
|   | ||||
| @@ -22,8 +22,8 @@ export const zeroExPublicNetworkConfigSchema = { | ||||
|         gasPrice: { $ref: '/Number' }, | ||||
|         zrxContractAddress: { $ref: '/Address' }, | ||||
|         exchangeContractAddress: { $ref: '/Address' }, | ||||
|         tokenRegistryContractAddress: { $ref: '/Address' }, | ||||
|         tokenTransferProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc20ProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc721ProxyContractAddress: { $ref: '/Address' }, | ||||
|         orderWatcherConfig: { | ||||
|             type: 'object', | ||||
|             properties: { | ||||
|   | ||||
| @@ -1,16 +1,3 @@ | ||||
| import { | ||||
|     BlockParam, | ||||
|     BlockParamLiteral, | ||||
|     ContractAbi, | ||||
|     ContractEventArg, | ||||
|     ExchangeContractErrs, | ||||
|     FilterObject, | ||||
|     LogWithDecodedArgs, | ||||
|     Order, | ||||
|     OrderState, | ||||
|     SignedOrder, | ||||
| } from '@0xproject/types'; | ||||
|  | ||||
| export enum InternalZeroExError { | ||||
|     NoAbiDecoder = 'NO_ABI_DECODER', | ||||
|     ZrxNotInTokenRegistry = 'ZRX_NOT_IN_TOKEN_REGISTRY', | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| export const constants = { | ||||
|     NULL_ADDRESS: '0x0000000000000000000000000000000000000000', | ||||
|     TESTRPC_NETWORK_ID: 50, | ||||
|   | ||||
| @@ -1,18 +1,14 @@ | ||||
| import { ContractWrappers } from '@0xproject/contract-wrappers'; | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle } from '@0xproject/dev-utils'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'make-promises-safe'; | ||||
| import 'mocha'; | ||||
| import * as path from 'path'; | ||||
| import * as Sinon from 'sinon'; | ||||
|  | ||||
| import { ApprovalContractEventArgs, LogWithDecodedArgs, Order, TokenEvents, ZeroEx } from '../src'; | ||||
| import { ERC20TokenApprovalEventArgs, ERC20TokenEvents, LogWithDecodedArgs, ZeroEx } from '../src'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { tokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
| @@ -31,9 +27,7 @@ describe('ZeroEx library', () => { | ||||
|         it('overrides provider in nested web3s and invalidates contractInstances', async () => { | ||||
|             // Instantiate the contract instances with the current provider | ||||
|             await (zeroEx.exchange as any)._getExchangeContractAsync(); | ||||
|             await (zeroEx.tokenRegistry as any)._getTokenRegistryContractAsync(); | ||||
|             expect((zeroEx.exchange as any)._exchangeContractIfExists).to.not.be.undefined(); | ||||
|             expect((zeroEx.tokenRegistry as any)._tokenRegistryContractIfExists).to.not.be.undefined(); | ||||
|  | ||||
|             // Add property to newProvider so that we can differentiate it from old provider | ||||
|             (provider as any).zeroExTestId = 1; | ||||
| @@ -41,52 +35,43 @@ describe('ZeroEx library', () => { | ||||
|  | ||||
|             // Check that contractInstances with old provider are removed after provider update | ||||
|             expect((zeroEx.exchange as any)._exchangeContractIfExists).to.be.undefined(); | ||||
|             expect((zeroEx.tokenRegistry as any)._tokenRegistryContractIfExists).to.be.undefined(); | ||||
|  | ||||
|             // Check that all nested zeroExContract/web3Wrapper instances return the updated provider | ||||
|             const nestedWeb3WrapperProvider = ((zeroEx as any)._contractWrappers as ContractWrappers).getProvider(); | ||||
|             expect((nestedWeb3WrapperProvider as any).zeroExTestId).to.be.a('number'); | ||||
|             const exchangeWeb3WrapperProvider = (zeroEx.exchange as any)._web3Wrapper.getProvider(); | ||||
|             expect(exchangeWeb3WrapperProvider.zeroExTestId).to.be.a('number'); | ||||
|             const tokenRegistryWeb3WrapperProvider = (zeroEx.tokenRegistry as any)._web3Wrapper.getProvider(); | ||||
|             expect(tokenRegistryWeb3WrapperProvider.zeroExTestId).to.be.a('number'); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#isValidSignature', () => { | ||||
|         // The Exchange smart contract `isValidSignature` method only validates orderHashes and assumes | ||||
|         // the length of the data is exactly 32 bytes. Thus for these tests, we use data of this size. | ||||
|         const dataHex = '0x6927e990021d23b1eb7b8789f6a6feaf98fe104bb0cf8259421b79f9a34222b0'; | ||||
|         const signature = { | ||||
|             v: 27, | ||||
|             r: '0x61a3ed31b43c8780e905a260a35faefcc527be7516aa11c0256729b5b351bc33', | ||||
|             s: '0x40349190569279751135161d22529dc25add4f6069af05be04cacbda2ace2254', | ||||
|         }; | ||||
|         const ethSignSignature = | ||||
|             '0x1B61a3ed31b43c8780e905a260a35faefcc527be7516aa11c0256729b5b351bc3340349190569279751135161d22529dc25add4f6069af05be04cacbda2ace225403'; | ||||
|         const address = '0x5409ed021d9299bf6814279a6a1411a7e866a631'; | ||||
|         it("should return false if the data doesn't pertain to the signature & address", async () => { | ||||
|             return expect( | ||||
|                 (zeroEx.exchange as any)._isValidSignatureUsingContractCallAsync('0x0', signature, address), | ||||
|             ).to.become(false); | ||||
|             return expect((zeroEx.exchange as any).isValidSignatureAsync('0x0', address, ethSignSignature)).to.become( | ||||
|                 false, | ||||
|             ); | ||||
|         }); | ||||
|         it("should return false if the address doesn't pertain to the signature & data", async () => { | ||||
|             const validUnrelatedAddress = '0x8b0292b11a196601ed2ce54b665cafeca0347d42'; | ||||
|             return expect( | ||||
|                 (zeroEx.exchange as any)._isValidSignatureUsingContractCallAsync( | ||||
|                     dataHex, | ||||
|                     signature, | ||||
|                     validUnrelatedAddress, | ||||
|                 ), | ||||
|                 (zeroEx.exchange as any).isValidSignatureAsync(dataHex, validUnrelatedAddress, ethSignSignature), | ||||
|             ).to.become(false); | ||||
|         }); | ||||
|         it("should return false if the signature doesn't pertain to the dataHex & address", async () => { | ||||
|             const wrongSignature = _.assign({}, signature, { v: 28 }); | ||||
|             return expect( | ||||
|                 (zeroEx.exchange as any)._isValidSignatureUsingContractCallAsync(dataHex, wrongSignature, address), | ||||
|             ).to.become(false); | ||||
|             const signatureArray = ethSignSignature.split(''); | ||||
|             // tslint:disable-next-line:custom-no-magic-numbers | ||||
|             signatureArray[5] = 'C'; // V = 28, instead of 27 | ||||
|             const wrongSignature = signatureArray.join(''); | ||||
|             return expect((zeroEx.exchange as any).isValidSignatureAsync(dataHex, address, wrongSignature)).to.become( | ||||
|                 false, | ||||
|             ); | ||||
|         }); | ||||
|         it('should return true if the signature does pertain to the dataHex & address', async () => { | ||||
|             return expect( | ||||
|                 (zeroEx.exchange as any)._isValidSignatureUsingContractCallAsync(dataHex, signature, address), | ||||
|             ).to.become(true); | ||||
|             return expect((zeroEx.exchange as any).isValidSignatureAsync(dataHex, address, ethSignSignature)).to.become( | ||||
|                 true, | ||||
|             ); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#toUnitAmount', () => { | ||||
| @@ -131,17 +116,16 @@ describe('ZeroEx library', () => { | ||||
|         it('returns transaction receipt with decoded logs', async () => { | ||||
|             const availableAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|             const coinbase = availableAddresses[0]; | ||||
|             const tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|             const tokenUtils = new TokenUtils(tokens); | ||||
|             const zrxTokenAddress = tokenUtils.getProtocolTokenOrThrow().address; | ||||
|             const proxyAddress = zeroEx.proxy.getContractAddress(); | ||||
|             const txHash = await zeroEx.token.setUnlimitedProxyAllowanceAsync(zrxTokenAddress, coinbase); | ||||
|             const zrxTokenAddress = tokenUtils.getProtocolTokenAddress(); | ||||
|             const erc20ProxyAddress = zeroEx.erc20Proxy.getContractAddress(); | ||||
|             const txHash = await zeroEx.erc20Token.setUnlimitedProxyAllowanceAsync(zrxTokenAddress, coinbase); | ||||
|             const txReceiptWithDecodedLogs = await zeroEx.awaitTransactionMinedAsync(txHash); | ||||
|             const log = txReceiptWithDecodedLogs.logs[0] as LogWithDecodedArgs<ApprovalContractEventArgs>; | ||||
|             expect(log.event).to.be.equal(TokenEvents.Approval); | ||||
|             // tslint:disable-next-line:no-unnecessary-type-assertion | ||||
|             const log = txReceiptWithDecodedLogs.logs[0] as LogWithDecodedArgs<ERC20TokenApprovalEventArgs>; | ||||
|             expect(log.event).to.be.equal(ERC20TokenEvents.Approval); | ||||
|             expect(log.args._owner).to.be.equal(coinbase); | ||||
|             expect(log.args._spender).to.be.equal(proxyAddress); | ||||
|             expect(log.args._value).to.be.bignumber.equal(zeroEx.token.UNLIMITED_ALLOWANCE_IN_BASE_UNITS); | ||||
|             expect(log.args._spender).to.be.equal(erc20ProxyAddress); | ||||
|             expect(log.args._value).to.be.bignumber.equal(zeroEx.erc20Token.UNLIMITED_ALLOWANCE_IN_BASE_UNITS); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#config', () => { | ||||
| @@ -153,15 +137,13 @@ describe('ZeroEx library', () => { | ||||
|             const zeroExWithWrongExchangeAddress = new ZeroEx(provider, zeroExConfig); | ||||
|             expect(zeroExWithWrongExchangeAddress.exchange.getContractAddress()).to.be.equal(ZeroEx.NULL_ADDRESS); | ||||
|         }); | ||||
|         it('allows to specify token registry token contract address', async () => { | ||||
|         it('allows to specify erc20Proxy contract address', async () => { | ||||
|             const zeroExConfig = { | ||||
|                 tokenRegistryContractAddress: ZeroEx.NULL_ADDRESS, | ||||
|                 erc20ProxyContractAddress: ZeroEx.NULL_ADDRESS, | ||||
|                 networkId: constants.TESTRPC_NETWORK_ID, | ||||
|             }; | ||||
|             const zeroExWithWrongTokenRegistryAddress = new ZeroEx(provider, zeroExConfig); | ||||
|             expect(zeroExWithWrongTokenRegistryAddress.tokenRegistry.getContractAddress()).to.be.equal( | ||||
|                 ZeroEx.NULL_ADDRESS, | ||||
|             ); | ||||
|             const zeroExWithWrongERC20ProxyAddress = new ZeroEx(provider, zeroExConfig); | ||||
|             expect(zeroExWithWrongERC20ProxyAddress.erc20Proxy.getContractAddress()).to.be.equal(ZeroEx.NULL_ADDRESS); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
|   | ||||
| @@ -1,50 +0,0 @@ | ||||
| import { web3Factory } from '@0xproject/dev-utils'; | ||||
| import * as fs from 'fs'; | ||||
| import 'make-promises-safe'; | ||||
|  | ||||
| import { ZeroEx } from '../src'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
|  | ||||
| // Those tests are slower cause they're talking to a remote node | ||||
| const TIMEOUT = 10000; | ||||
|  | ||||
| describe('Artifacts', () => { | ||||
|     describe('contracts are deployed on kovan', () => { | ||||
|         const kovanRpcUrl = constants.KOVAN_RPC_URL; | ||||
|         const provider = web3Factory.getRpcProvider({ rpcUrl: kovanRpcUrl }); | ||||
|         const config = { | ||||
|             networkId: constants.KOVAN_NETWORK_ID, | ||||
|         }; | ||||
|         const zeroEx = new ZeroEx(provider, config); | ||||
|         it('token registry contract is deployed', async () => { | ||||
|             await (zeroEx.tokenRegistry as any)._getTokenRegistryContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
|         it('proxy contract is deployed', async () => { | ||||
|             await (zeroEx.proxy as any)._getTokenTransferProxyContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
|         it('exchange contract is deployed', async () => { | ||||
|             await (zeroEx.exchange as any)._getExchangeContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
|     }); | ||||
|     describe('contracts are deployed on ropsten', () => { | ||||
|         const ropstenRpcUrl = constants.ROPSTEN_RPC_URL; | ||||
|         const provider = web3Factory.getRpcProvider({ rpcUrl: ropstenRpcUrl }); | ||||
|         const config = { | ||||
|             networkId: constants.ROPSTEN_NETWORK_ID, | ||||
|         }; | ||||
|         const zeroEx = new ZeroEx(provider, config); | ||||
|         it('token registry contract is deployed', async () => { | ||||
|             await (zeroEx.tokenRegistry as any)._getTokenRegistryContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
|         it('proxy contract is deployed', async () => { | ||||
|             await (zeroEx.proxy as any)._getTokenTransferProxyContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
|         it('exchange contract is deployed', async () => { | ||||
|             await (zeroEx.exchange as any)._getExchangeContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
|     }); | ||||
| }); | ||||
| @@ -1,19 +1,17 @@ | ||||
| import { devConstants } from '@0xproject/dev-utils'; | ||||
| import { runV1MigrationsAsync } from '@0xproject/migrations'; | ||||
| import * as path from 'path'; | ||||
| import { runV2MigrationsAsync } from '@0xproject/migrations'; | ||||
|  | ||||
| import { constants } from './utils/constants'; | ||||
| import { provider } from './utils/web3_wrapper'; | ||||
|  | ||||
| before('migrate contracts', async function(): Promise<void> { | ||||
|     // HACK: Since the migrations take longer then our global mocha timeout limit | ||||
|     // we manually increase it for this before hook. | ||||
|     const mochaTestTimeoutMs = 20000; | ||||
|     this.timeout(mochaTestTimeoutMs); | ||||
|     this.timeout(mochaTestTimeoutMs); // tslint:disable-line:no-invalid-this | ||||
|     const txDefaults = { | ||||
|         gas: devConstants.GAS_LIMIT, | ||||
|         from: devConstants.TESTRPC_FIRST_ADDRESS, | ||||
|     }; | ||||
|     const artifactsDir = `../migrations/artifacts/1.0.0`; | ||||
|     await runV1MigrationsAsync(provider, artifactsDir, txDefaults); | ||||
|     const artifactsDir = `../migrations/artifacts/2.0.0`; | ||||
|     await runV2MigrationsAsync(provider, artifactsDir, txDefaults); | ||||
| }); | ||||
|   | ||||
| @@ -1,34 +1,9 @@ | ||||
| import { Token } from '@0xproject/types'; | ||||
| import * as _ from 'lodash'; | ||||
| import { artifacts } from '../../src/artifacts'; | ||||
|  | ||||
| import { InternalZeroExError } from '../../src/types'; | ||||
| import { constants } from './constants'; | ||||
|  | ||||
| const PROTOCOL_TOKEN_SYMBOL = 'ZRX'; | ||||
| const WETH_TOKEN_SYMBOL = 'WETH'; | ||||
|  | ||||
| export class TokenUtils { | ||||
|     private _tokens: Token[]; | ||||
|     constructor(tokens: Token[]) { | ||||
|         this._tokens = tokens; | ||||
|     } | ||||
|     public getProtocolTokenOrThrow(): Token { | ||||
|         const zrxToken = _.find(this._tokens, { symbol: PROTOCOL_TOKEN_SYMBOL }); | ||||
|         if (_.isUndefined(zrxToken)) { | ||||
|             throw new Error(InternalZeroExError.ZrxNotInTokenRegistry); | ||||
|         } | ||||
|         return zrxToken; | ||||
|     } | ||||
|     public getWethTokenOrThrow(): Token { | ||||
|         const wethToken = _.find(this._tokens, { symbol: WETH_TOKEN_SYMBOL }); | ||||
|         if (_.isUndefined(wethToken)) { | ||||
|             throw new Error(InternalZeroExError.WethNotInTokenRegistry); | ||||
|         } | ||||
|         return wethToken; | ||||
|     } | ||||
|     public getDummyTokens(): Token[] { | ||||
|         const dummyTokens = _.filter(this._tokens, token => { | ||||
|             return !_.includes([PROTOCOL_TOKEN_SYMBOL, WETH_TOKEN_SYMBOL], token.symbol); | ||||
|         }); | ||||
|         return dummyTokens; | ||||
|     } | ||||
| } | ||||
| export const tokenUtils = { | ||||
|     getProtocolTokenAddress(): string { | ||||
|         return artifacts.ZRXToken.networks[constants.TESTRPC_NETWORK_ID].address; | ||||
|     }, | ||||
| }; | ||||
|   | ||||
| @@ -1,8 +1,12 @@ | ||||
| import { devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { Provider } from '@0xproject/types'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { Provider } from 'ethereum-types'; | ||||
|  | ||||
| const txDefaults = { | ||||
|     from: devConstants.TESTRPC_FIRST_ADDRESS, | ||||
|     gas: devConstants.GAS_LIMIT, | ||||
| }; | ||||
| const provider: Provider = web3Factory.getRpcProvider({ shouldUseInProcessGanache: true }); | ||||
| const web3Wrapper = new Web3Wrapper(provider); | ||||
|  | ||||
| export { provider, web3Wrapper }; | ||||
| export { provider, web3Wrapper, txDefaults }; | ||||
|   | ||||
| @@ -1,13 +1,95 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1527809861, | ||||
|         "version": "0.3.1", | ||||
|         "timestamp": 1532619515, | ||||
|         "version": "1.0.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532614997, | ||||
|         "version": "1.0.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532605697, | ||||
|         "version": "1.0.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "1.0.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix the abi-gen entry point in package.json", | ||||
|                 "pr": 901 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1532357734 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532043000, | ||||
|         "version": "1.0.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Convert e_r_c to erc in generated file names", | ||||
|                 "pr": 822 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Remove the output directory before writing to it", | ||||
|                 "pr": 822 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "skip generation of wrappers that are already up to date", | ||||
|                 "pr": 788 | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531919263, | ||||
|         "version": "0.3.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531149657, | ||||
|         "version": "0.3.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1529397769, | ||||
|         "version": "0.3.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.3.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Incorrect publish that was unpublished" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1527810075 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.3.0", | ||||
|         "changes": [ | ||||
|   | ||||
| @@ -1,19 +1,53 @@ | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| changelogUtils.file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.3.1 - _May 31, 2018_ | ||||
| ## v1.0.4 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.3 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.2 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.1 - _July 23, 2018_ | ||||
|  | ||||
|     * Fix the abi-gen entry point in package.json (#901) | ||||
|  | ||||
| ## v1.0.0 - _July 20, 2018_ | ||||
|  | ||||
|     * Convert e_r_c to erc in generated file names (#822) | ||||
|     * Remove the output directory before writing to it (#822) | ||||
|     * skip generation of wrappers that are already up to date (#788) | ||||
|  | ||||
| ## v0.3.4 - _July 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.3.3 - _July 9, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.3.2 - _June 19, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.3.1 - _June 1, 2018_ | ||||
|  | ||||
|     * Incorrect publish that was unpublished | ||||
|  | ||||
| ## v0.3.0 - _May 22, 2018_ | ||||
|  | ||||
|     * Properly export the executable binary (#588) | ||||
|  | ||||
| ## v0.2.13 - _May 4, 2018_ | ||||
| ## v0.2.13 - _May 5, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
|   | ||||
| @@ -4,8 +4,7 @@ This package allows you to generate TypeScript contract wrappers from ABI files. | ||||
| It's heavily inspired by [Geth abigen](https://github.com/ethereum/go-ethereum/wiki/Native-DApps:-Go-bindings-to-Ethereum-contracts) but takes a different approach. | ||||
| You can write your custom handlebars templates which will allow you to seamlessly integrate the generated code into your existing codebase with existing conventions. | ||||
|  | ||||
| For an example of the generated [wrapper files](https://github.com/0xProject/0x-monorepo/tree/development/packages/0x.js/src/contract_wrappers/generated) check out 0x.js. | ||||
| [Here](https://github.com/0xProject/0x-monorepo/tree/development/packages/0x.js/contract_templates) are the templates used to generate those files. | ||||
| [Here](https://github.com/0xProject/0x-monorepo/tree/development/packages/0x.js/contract_templates) are the templates used to generate the contract wrappers used by 0x.js.e | ||||
|  | ||||
| ## Installation | ||||
|  | ||||
| @@ -45,7 +44,7 @@ You need to also specify the location of your main template used for every contr | ||||
|  | ||||
| ## How to write custom templates? | ||||
|  | ||||
| The best way to get started is to copy [0x.js templates](https://github.com/0xProject/0x-monorepo/tree/development/packages/0x.js/contract_templates) and start adjusting them for your needs. | ||||
| The best way to get started is to copy [0x.js templates](https://github.com/0xProject/0x-monorepo/tree/development/packages/contract_templates) and start adjusting them for your needs. | ||||
| We use [handlebars](http://handlebarsjs.com/) template engine under the hood. | ||||
| You need to have a master template called `contract.mustache`. it will be used to generate each contract wrapper. Although - you don't need and probably shouldn't write all your logic in a single template file. You can write [partial templates](http://handlebarsjs.com/partials.html) and as long as they are within a partials folder - they will be registered and available. | ||||
|  | ||||
|   | ||||
| @@ -1,2 +1,2 @@ | ||||
| #!/usr/bin/env node | ||||
| require('../lib/index.js') | ||||
| require('../lib/src/index.js'); | ||||
|   | ||||
| @@ -1,17 +1,22 @@ | ||||
| { | ||||
|     "name": "@0xproject/abi-gen", | ||||
|     "version": "0.3.0", | ||||
|     "version": "1.0.3", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
|     "description": "Generate contract wrappers from ABI and handlebars templates", | ||||
|     "main": "lib/index.js", | ||||
|     "types": "lib/index.d.ts", | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "watch": "tsc -w", | ||||
|         "watch_without_deps": "tsc -w", | ||||
|         "lint": "tslint --project .", | ||||
|         "clean": "shx rm -rf lib scripts", | ||||
|         "build": "tsc && copyfiles -u 2 './lib/monorepo_scripts/**/*' ./scripts", | ||||
|         "test": "yarn run_mocha", | ||||
|         "run_mocha": "mocha --require source-map-support/register --require make-promises-safe lib/test/**/*_test.js --bail --exit", | ||||
|         "test:circleci": "yarn test:coverage", | ||||
|         "test:coverage": "nyc npm run test --all && yarn coverage:report:lcov", | ||||
|         "coverage:report:lcov": "nyc report --reporter=text-lcov > coverage/lcov.info", | ||||
|         "manual:postpublish": "yarn build; node ./scripts/postpublish.js" | ||||
|     }, | ||||
|     "bin": { | ||||
| @@ -27,30 +32,37 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x-monorepo/packages/abi-gen/README.md", | ||||
|     "dependencies": { | ||||
|         "@0xproject/typescript-typings": "^0.3.2", | ||||
|         "@0xproject/utils": "^0.6.2", | ||||
|         "ethereum-types": "^0.0.1", | ||||
|         "@0xproject/typescript-typings": "^1.0.3", | ||||
|         "@0xproject/utils": "^1.0.3", | ||||
|         "chalk": "^2.3.0", | ||||
|         "ethereum-types": "^1.0.3", | ||||
|         "glob": "^7.1.2", | ||||
|         "handlebars": "^4.0.11", | ||||
|         "lodash": "^4.17.4", | ||||
|         "mkdirp": "^0.5.1", | ||||
|         "sleep": "^5.1.1", | ||||
|         "tmp": "^0.0.33", | ||||
|         "to-snake-case": "^1.0.0", | ||||
|         "yargs": "^10.0.3" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/monorepo-scripts": "^0.1.20", | ||||
|         "@0xproject/tslint-config": "^0.4.18", | ||||
|         "@types/glob": "^5.0.33", | ||||
|         "@0xproject/monorepo-scripts": "^1.0.4", | ||||
|         "@0xproject/tslint-config": "^1.0.4", | ||||
|         "@types/glob": "5.0.35", | ||||
|         "@types/handlebars": "^4.0.36", | ||||
|         "@types/mkdirp": "^0.5.1", | ||||
|         "@types/node": "^8.0.53", | ||||
|         "@types/sleep": "^0.0.7", | ||||
|         "@types/tmp": "^0.0.33", | ||||
|         "@types/yargs": "^10.0.0", | ||||
|         "chai": "^4.1.2", | ||||
|         "copyfiles": "^1.2.0", | ||||
|         "dirty-chai": "^2.0.1", | ||||
|         "make-promises-safe": "^1.1.0", | ||||
|         "mocha": "^5.2.0", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "tslint": "5.11.0", | ||||
|         "typescript": "2.7.1" | ||||
|     }, | ||||
|     "publishConfig": { | ||||
|   | ||||
| @@ -3,16 +3,13 @@ | ||||
| import { abiUtils, logUtils } from '@0xproject/utils'; | ||||
| import chalk from 'chalk'; | ||||
| import { AbiDefinition, ConstructorAbi, EventAbi, MethodAbi } from 'ethereum-types'; | ||||
| import * as fs from 'fs'; | ||||
| import { sync as globSync } from 'glob'; | ||||
| import * as Handlebars from 'handlebars'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as mkdirp from 'mkdirp'; | ||||
| import * as yargs from 'yargs'; | ||||
|  | ||||
| import toSnakeCase = require('to-snake-case'); | ||||
|  | ||||
| import { ContextData, ContractsBackend, Method, ParamKind } from './types'; | ||||
| import { ContextData, ContractsBackend, ParamKind } from './types'; | ||||
| import { utils } from './utils'; | ||||
|  | ||||
| const ABI_TYPE_CONSTRUCTOR = 'constructor'; | ||||
| @@ -70,16 +67,6 @@ function registerPartials(partialsGlob: string): void { | ||||
|     } | ||||
| } | ||||
|  | ||||
| function writeOutputFile(name: string, renderedTsCode: string): void { | ||||
|     let fileName = toSnakeCase(name); | ||||
|     if (fileName === 'z_r_x_token') { | ||||
|         fileName = 'zrx_token'; | ||||
|     } | ||||
|     const filePath = `${args.output}/${fileName}.ts`; | ||||
|     fs.writeFileSync(filePath, renderedTsCode); | ||||
|     logUtils.log(`Created: ${chalk.bold(filePath)}`); | ||||
| } | ||||
|  | ||||
| Handlebars.registerHelper('parameterType', utils.solTypeToTsType.bind(utils, ParamKind.Input, args.backend)); | ||||
| Handlebars.registerHelper('returnType', utils.solTypeToTsType.bind(utils, ParamKind.Output, args.backend)); | ||||
| if (args.partials) { | ||||
| @@ -118,6 +105,14 @@ for (const abiFileName of abiFileNames) { | ||||
|         process.exit(1); | ||||
|     } | ||||
|  | ||||
|     const outFileName = utils.makeOutputFileName(namedContent.name); | ||||
|     const outFilePath = `${args.output}/${outFileName}.ts`; | ||||
|  | ||||
|     if (utils.isOutputFileUpToDate(abiFileName, outFilePath)) { | ||||
|         logUtils.log(`Already up to date: ${chalk.bold(outFilePath)}`); | ||||
|         continue; | ||||
|     } | ||||
|  | ||||
|     let ctor = ABI.find((abi: AbiDefinition) => abi.type === ABI_TYPE_CONSTRUCTOR) as ConstructorAbi; | ||||
|     if (_.isUndefined(ctor)) { | ||||
|         ctor = utils.getEmptyConstructor(); // The constructor exists, but it's implicit in JSON's ABI definition | ||||
| @@ -152,5 +147,6 @@ for (const abiFileName of abiFileNames) { | ||||
|         events: eventAbis, | ||||
|     }; | ||||
|     const renderedTsCode = template(contextData); | ||||
|     writeOutputFile(namedContent.name, renderedTsCode); | ||||
|     utils.writeOutputFile(outFilePath, renderedTsCode); | ||||
|     logUtils.log(`Created: ${chalk.bold(outFilePath)}`); | ||||
| } | ||||
|   | ||||
| @@ -2,6 +2,7 @@ import { AbiType, ConstructorAbi, DataItem } from 'ethereum-types'; | ||||
| import * as fs from 'fs'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as path from 'path'; | ||||
| import toSnakeCase = require('to-snake-case'); | ||||
|  | ||||
| import { ContractsBackend, ParamKind } from './types'; | ||||
|  | ||||
| @@ -56,7 +57,7 @@ export const utils = { | ||||
|                     const componentType = `${component.name}: ${componentValueType}`; | ||||
|                     return componentType; | ||||
|                 }); | ||||
|                 const tsType = `{${componentsType}}`; | ||||
|                 const tsType = `{${componentsType.join(';')}}`; | ||||
|                 return tsType; | ||||
|             } | ||||
|             throw new Error(`Unknown Solidity type found: ${solType}`); | ||||
| @@ -92,4 +93,27 @@ export const utils = { | ||||
|             inputs: [], | ||||
|         }; | ||||
|     }, | ||||
|     makeOutputFileName(name: string): string { | ||||
|         let fileName = toSnakeCase(name); | ||||
|         // HACK: Snake case doesn't make a lot of sense for abbreviated names but we can't reliably detect abbreviations | ||||
|         // so we special-case the abbreviations we use. | ||||
|         fileName = fileName.replace('z_r_x', 'zrx').replace('e_r_c', 'erc'); | ||||
|         return fileName; | ||||
|     }, | ||||
|     writeOutputFile(filePath: string, renderedTsCode: string): void { | ||||
|         fs.writeFileSync(filePath, renderedTsCode); | ||||
|     }, | ||||
|     isOutputFileUpToDate(abiFile: string, outputFile: string): boolean { | ||||
|         const abiFileModTimeMs = fs.statSync(abiFile).mtimeMs; | ||||
|         try { | ||||
|             const outFileModTimeMs = fs.statSync(outputFile).mtimeMs; | ||||
|             return outFileModTimeMs > abiFileModTimeMs; | ||||
|         } catch (err) { | ||||
|             if (err.code === 'ENOENT') { | ||||
|                 return false; | ||||
|             } else { | ||||
|                 throw err; | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
| }; | ||||
|   | ||||
							
								
								
									
										86
									
								
								packages/abi-gen/test/utils_test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								packages/abi-gen/test/utils_test.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | ||||
| import * as chai from 'chai'; | ||||
| import * as dirtyChai from 'dirty-chai'; | ||||
| import * as fs from 'fs'; | ||||
| import 'mocha'; | ||||
| import * as tmp from 'tmp'; | ||||
|  | ||||
| import { utils } from '../src/utils'; | ||||
|  | ||||
| tmp.setGracefulCleanup(); // remove tmp files even if there are failures | ||||
|  | ||||
| chai.use(dirtyChai); | ||||
|  | ||||
| const expect = chai.expect; | ||||
|  | ||||
| describe('makeOutputFileName()', () => { | ||||
|     it('should handle Metacoin usage', () => { | ||||
|         expect(utils.makeOutputFileName('Metacoin')).to.equal('metacoin'); | ||||
|     }); | ||||
|     it('should handle special zrx_token case', () => { | ||||
|         expect(utils.makeOutputFileName('ZRXToken')).to.equal('zrx_token'); | ||||
|     }); | ||||
|     it('should handle special erc_token case', () => { | ||||
|         expect(utils.makeOutputFileName('ERC20Token')).to.equal('erc20_token'); | ||||
|     }); | ||||
| }); | ||||
|  | ||||
| describe('writeOutputFile()', () => { | ||||
|     let tempFilePath: string; | ||||
|     before(() => { | ||||
|         tempFilePath = tmp.fileSync( | ||||
|             { discardDescriptor: true }, // close file (so we can update it) | ||||
|         ).name; | ||||
|     }); | ||||
|     it('should write content to output file', () => { | ||||
|         const content = 'hello world'; | ||||
|  | ||||
|         utils.writeOutputFile(tempFilePath, content); | ||||
|  | ||||
|         expect(fs.readFileSync(tempFilePath).toString()).to.equal(content); | ||||
|     }); | ||||
| }); | ||||
|  | ||||
| describe('isOutputFileUpToDate()', () => { | ||||
|     it('should throw ENOENT when there is no abi file', () => { | ||||
|         expect(utils.isOutputFileUpToDate.bind('nonexistant1', 'nonexistant2')).to.throw('ENOENT'); | ||||
|     }); | ||||
|  | ||||
|     describe('when the abi input file exists', () => { | ||||
|         let abiFile: string; | ||||
|         before(() => { | ||||
|             abiFile = tmp.fileSync( | ||||
|                 { discardDescriptor: true }, // close file (set timestamp) | ||||
|             ).name; | ||||
|         }); | ||||
|  | ||||
|         describe('without an existing output file', () => { | ||||
|             it('should return false', () => { | ||||
|                 expect(utils.isOutputFileUpToDate(abiFile, 'nonexistant_file')).to.be.false(); | ||||
|             }); | ||||
|         }); | ||||
|  | ||||
|         describe('with an existing output file', () => { | ||||
|             let outputFile: string; | ||||
|             before(() => { | ||||
|                 outputFile = tmp.fileSync( | ||||
|                     { discardDescriptor: true }, // close file (set timestamp) | ||||
|                 ).name; | ||||
|                 const abiFileModTimeMs = fs.statSync(abiFile).mtimeMs; | ||||
|                 const outfileModTimeMs = abiFileModTimeMs + 1; | ||||
|                 fs.utimesSync(outputFile, outfileModTimeMs, outfileModTimeMs); | ||||
|             }); | ||||
|  | ||||
|             it('should return true when output file is newer than abi file', async () => { | ||||
|                 expect(utils.isOutputFileUpToDate(abiFile, outputFile)).to.be.true(); | ||||
|             }); | ||||
|  | ||||
|             it('should return false when output file exists but is older than abi file', () => { | ||||
|                 const outFileModTimeMs = fs.statSync(outputFile).mtimeMs; | ||||
|                 const abiFileModTimeMs = outFileModTimeMs + 1; | ||||
|                 fs.utimesSync(abiFile, abiFileModTimeMs, abiFileModTimeMs); | ||||
|  | ||||
|                 expect(utils.isOutputFileUpToDate(abiFile, outputFile)).to.be.false(); | ||||
|             }); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
| @@ -1,13 +1,87 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1527809861, | ||||
|         "version": "0.2.11", | ||||
|         "timestamp": 1532619515, | ||||
|         "version": "1.0.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532614997, | ||||
|         "version": "1.0.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532605697, | ||||
|         "version": "1.0.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532357734, | ||||
|         "version": "1.0.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532043000, | ||||
|         "version": "1.0.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Fix bug in string enum assertion. We erroneously were checking against the enum keys, not values", | ||||
|                 "pr": 821 | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531919263, | ||||
|         "version": "0.2.14", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531149657, | ||||
|         "version": "0.2.13", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1529397769, | ||||
|         "version": "0.2.12", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.2.11", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Incorrect publish that was unpublished" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1527810075 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527008270, | ||||
|         "version": "0.2.10", | ||||
|   | ||||
| @@ -1,19 +1,51 @@ | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| changelogUtils.file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.2.11 - _May 31, 2018_ | ||||
| ## v1.0.4 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.3 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.2 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.1 - _July 23, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.0 - _July 20, 2018_ | ||||
|  | ||||
|     * Fix bug in string enum assertion. We erroneously were checking against the enum keys, not values (#821) | ||||
|  | ||||
| ## v0.2.14 - _July 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.13 - _July 9, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.12 - _June 19, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.11 - _June 1, 2018_ | ||||
|  | ||||
|     * Incorrect publish that was unpublished | ||||
|  | ||||
| ## v0.2.10 - _May 22, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.9 - _May 4, 2018_ | ||||
| ## v0.2.9 - _May 5, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0xproject/assert", | ||||
|     "version": "0.2.10", | ||||
|     "version": "1.0.3", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -8,13 +8,13 @@ | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "watch": "tsc -w", | ||||
|         "watch_without_deps": "tsc -w", | ||||
|         "build": "tsc && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "clean": "shx rm -rf lib test_temp scripts", | ||||
|         "lint": "tslint --project .", | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js --exit", | ||||
|         "prepublishOnly": "run-p build", | ||||
|         "test": "run-s clean build run_mocha", | ||||
|         "run_mocha": "mocha --require source-map-support/register --require make-promises-safe lib/test/**/*_test.js --exit", | ||||
|         "test": "yarn run_mocha", | ||||
|         "rebuild_and_test": "run-s clean build test", | ||||
|         "test:coverage": "nyc npm run test --all && yarn coverage:report:lcov", | ||||
|         "coverage:report:lcov": "nyc report --reporter=text-lcov > coverage/lcov.info", | ||||
|         "test:circleci": "yarn test:coverage", | ||||
| @@ -30,8 +30,8 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x-monorepo/packages/assert/README.md", | ||||
|     "devDependencies": { | ||||
|         "@0xproject/monorepo-scripts": "^0.1.20", | ||||
|         "@0xproject/tslint-config": "^0.4.18", | ||||
|         "@0xproject/monorepo-scripts": "^1.0.4", | ||||
|         "@0xproject/tslint-config": "^1.0.4", | ||||
|         "@types/lodash": "4.14.104", | ||||
|         "@types/mocha": "^2.2.42", | ||||
|         "@types/valid-url": "^1.0.2", | ||||
| @@ -43,13 +43,13 @@ | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "nyc": "^11.0.1", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "tslint": "5.11.0", | ||||
|         "typescript": "2.7.1" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0xproject/json-schemas": "0.7.22", | ||||
|         "@0xproject/typescript-typings": "^0.3.2", | ||||
|         "@0xproject/utils": "^0.6.2", | ||||
|         "@0xproject/json-schemas": "^1.0.1-rc.2", | ||||
|         "@0xproject/typescript-typings": "^1.0.3", | ||||
|         "@0xproject/utils": "^1.0.3", | ||||
|         "lodash": "^4.17.4", | ||||
|         "valid-url": "^1.0.9" | ||||
|     }, | ||||
|   | ||||
| @@ -8,41 +8,41 @@ const HEX_REGEX = /^0x[0-9A-F]*$/i; | ||||
| export const assert = { | ||||
|     isBigNumber(variableName: string, value: BigNumber): void { | ||||
|         const isBigNumber = _.isObject(value) && (value as any).isBigNumber; | ||||
|         this.assert(isBigNumber, this.typeAssertionMessage(variableName, 'BigNumber', value)); | ||||
|         assert.assert(isBigNumber, assert.typeAssertionMessage(variableName, 'BigNumber', value)); | ||||
|     }, | ||||
|     isValidBaseUnitAmount(variableName: string, value: BigNumber): void { | ||||
|         assert.isBigNumber(variableName, value); | ||||
|         const isNegative = value.lessThan(0); | ||||
|         this.assert(!isNegative, `${variableName} cannot be a negative number, found value: ${value.toNumber()}`); | ||||
|         assert.assert(!isNegative, `${variableName} cannot be a negative number, found value: ${value.toNumber()}`); | ||||
|         const hasDecimals = value.decimalPlaces() !== 0; | ||||
|         this.assert( | ||||
|         assert.assert( | ||||
|             !hasDecimals, | ||||
|             `${variableName} should be in baseUnits (no decimals), found value: ${value.toNumber()}`, | ||||
|         ); | ||||
|     }, | ||||
|     isString(variableName: string, value: string): void { | ||||
|         this.assert(_.isString(value), this.typeAssertionMessage(variableName, 'string', value)); | ||||
|         assert.assert(_.isString(value), assert.typeAssertionMessage(variableName, 'string', value)); | ||||
|     }, | ||||
|     isFunction(variableName: string, value: any): void { | ||||
|         this.assert(_.isFunction(value), this.typeAssertionMessage(variableName, 'function', value)); | ||||
|         assert.assert(_.isFunction(value), assert.typeAssertionMessage(variableName, 'function', value)); | ||||
|     }, | ||||
|     isHexString(variableName: string, value: string): void { | ||||
|         this.assert( | ||||
|         assert.assert( | ||||
|             _.isString(value) && HEX_REGEX.test(value), | ||||
|             this.typeAssertionMessage(variableName, 'HexString', value), | ||||
|             assert.typeAssertionMessage(variableName, 'HexString', value), | ||||
|         ); | ||||
|     }, | ||||
|     isETHAddressHex(variableName: string, value: string): void { | ||||
|         this.assert(_.isString(value), this.typeAssertionMessage(variableName, 'string', value)); | ||||
|         this.assert(addressUtils.isAddress(value), this.typeAssertionMessage(variableName, 'ETHAddressHex', value)); | ||||
|         assert.assert(_.isString(value), assert.typeAssertionMessage(variableName, 'string', value)); | ||||
|         assert.assert(addressUtils.isAddress(value), assert.typeAssertionMessage(variableName, 'ETHAddressHex', value)); | ||||
|     }, | ||||
|     doesBelongToStringEnum( | ||||
|         variableName: string, | ||||
|         value: string, | ||||
|         stringEnum: any /* There is no base type for every string enum */, | ||||
|     ): void { | ||||
|         const doesBelongToStringEnum = !_.isUndefined(stringEnum[value]); | ||||
|         const enumValues = _.keys(stringEnum); | ||||
|         const enumValues = _.values(stringEnum); | ||||
|         const doesBelongToStringEnum = _.includes(enumValues, value); | ||||
|         const enumValuesAsStrings = _.map(enumValues, enumValue => `'${enumValue}'`); | ||||
|         const enumValuesAsString = enumValuesAsStrings.join(', '); | ||||
|         assert.assert( | ||||
| @@ -51,17 +51,17 @@ export const assert = { | ||||
|         ); | ||||
|     }, | ||||
|     hasAtMostOneUniqueValue(value: any[], errMsg: string): void { | ||||
|         this.assert(_.uniq(value).length <= 1, errMsg); | ||||
|         assert.assert(_.uniq(value).length <= 1, errMsg); | ||||
|     }, | ||||
|     isNumber(variableName: string, value: number): void { | ||||
|         this.assert(_.isFinite(value), this.typeAssertionMessage(variableName, 'number', value)); | ||||
|         assert.assert(_.isFinite(value), assert.typeAssertionMessage(variableName, 'number', value)); | ||||
|     }, | ||||
|     isBoolean(variableName: string, value: boolean): void { | ||||
|         this.assert(_.isBoolean(value), this.typeAssertionMessage(variableName, 'boolean', value)); | ||||
|         assert.assert(_.isBoolean(value), assert.typeAssertionMessage(variableName, 'boolean', value)); | ||||
|     }, | ||||
|     isWeb3Provider(variableName: string, value: any): void { | ||||
|         const isWeb3Provider = _.isFunction(value.send) || _.isFunction(value.sendAsync); | ||||
|         this.assert(isWeb3Provider, this.typeAssertionMessage(variableName, 'Provider', value)); | ||||
|         assert.assert(isWeb3Provider, assert.typeAssertionMessage(variableName, 'Provider', value)); | ||||
|     }, | ||||
|     doesConformToSchema(variableName: string, value: any, schema: Schema, subSchemas?: Schema[]): void { | ||||
|         if (_.isUndefined(value)) { | ||||
| @@ -76,15 +76,15 @@ export const assert = { | ||||
|         const msg = `Expected ${variableName} to conform to schema ${schema.id} | ||||
| Encountered: ${JSON.stringify(value, null, '\t')} | ||||
| Validation errors: ${validationResult.errors.join(', ')}`; | ||||
|         this.assert(!hasValidationErrors, msg); | ||||
|         assert.assert(!hasValidationErrors, msg); | ||||
|     }, | ||||
|     isWebUri(variableName: string, value: any): void { | ||||
|         const isValidUrl = !_.isUndefined(validUrl.isWebUri(value)); | ||||
|         this.assert(isValidUrl, this.typeAssertionMessage(variableName, 'web uri', value)); | ||||
|         assert.assert(isValidUrl, assert.typeAssertionMessage(variableName, 'web uri', value)); | ||||
|     }, | ||||
|     isUri(variableName: string, value: any): void { | ||||
|         const isValidUri = !_.isUndefined(validUrl.isUri(value)); | ||||
|         this.assert(isValidUri, this.typeAssertionMessage(variableName, 'uri', value)); | ||||
|         assert.assert(isValidUri, assert.typeAssertionMessage(variableName, 'uri', value)); | ||||
|     }, | ||||
|     assert(condition: boolean, message: string): void { | ||||
|         if (!condition) { | ||||
|   | ||||
| @@ -2,7 +2,6 @@ import { schemas } from '@0xproject/json-schemas'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as dirtyChai from 'dirty-chai'; | ||||
| import 'make-promises-safe'; | ||||
| import 'mocha'; | ||||
|  | ||||
| import { assert } from '../src/index'; | ||||
| @@ -50,7 +49,7 @@ describe('Assertions', () => { | ||||
|     }); | ||||
|     describe('#isFunction', () => { | ||||
|         it('should not throw for valid input', () => { | ||||
|             const validInputs = [BigNumber, assert.isString]; | ||||
|             const validInputs = [BigNumber, assert.isString.bind(assert)]; | ||||
|             validInputs.forEach(input => expect(assert.isFunction.bind(assert, variableName, input)).to.not.throw()); | ||||
|         }); | ||||
|         it('should throw for invalid input', () => { | ||||
|   | ||||
| @@ -1,13 +1,86 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1527809861, | ||||
|         "version": "0.3.3", | ||||
|         "timestamp": 1532619515, | ||||
|         "version": "1.0.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532614997, | ||||
|         "version": "1.0.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532605697, | ||||
|         "version": "1.0.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532357734, | ||||
|         "version": "1.0.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532043000, | ||||
|         "version": "1.0.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531919263, | ||||
|         "version": "0.3.6", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531149657, | ||||
|         "version": "0.3.5", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.3.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Update EthersJs to fix the `value.toLowerCase()` is not a function bug caused by `ethers.js` breaking patch version https://github.com/ethers-io/ethers.js/issues/201" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1529397769 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527810075, | ||||
|         "version": "0.3.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Incorrect publish that was unpublished" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527008270, | ||||
|         "version": "0.3.2", | ||||
|   | ||||
| @@ -1,19 +1,51 @@ | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| changelogUtils.file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.3.3 - _May 31, 2018_ | ||||
| ## v1.0.4 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.3 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.2 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.1 - _July 23, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.0 - _July 20, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.3.6 - _July 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.3.5 - _July 9, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.3.4 - _June 19, 2018_ | ||||
|  | ||||
|     * Update EthersJs to fix the `value.toLowerCase()` is not a function bug caused by `ethers.js` breaking patch version https://github.com/ethers-io/ethers.js/issues/201 | ||||
|  | ||||
| ## v0.3.3 - _June 1, 2018_ | ||||
|  | ||||
|     * Incorrect publish that was unpublished | ||||
|  | ||||
| ## v0.3.2 - _May 22, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.3.1 - _May 4, 2018_ | ||||
| ## v0.3.1 - _May 5, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0xproject/base-contract", | ||||
|     "version": "0.3.2", | ||||
|     "version": "1.0.3", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -8,15 +8,16 @@ | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "watch": "tsc -w", | ||||
|         "build": "tsc && copyfiles -u 2 './lib/monorepo_scripts/**/*' ./scripts", | ||||
|         "watch_without_deps": "tsc -w", | ||||
|         "build": "tsc && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "clean": "shx rm -rf lib scripts", | ||||
|         "test": "run-s clean build run_mocha", | ||||
|         "test": "yarn run_mocha", | ||||
|         "rebuild_and_test": "run-s clean build test", | ||||
|         "test:circleci": "yarn test:coverage", | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js --bail --exit", | ||||
|         "run_mocha": "mocha --require source-map-support/register --require make-promises-safe lib/test/**/*_test.js --bail --exit", | ||||
|         "test:coverage": "nyc npm run test --all && yarn coverage:report:lcov", | ||||
|         "coverage:report:lcov": "nyc report --reporter=text-lcov > coverage/lcov.info", | ||||
|         "lint": "tslint --project .", | ||||
|         "lint": "tslint --project . --exclude **/src/contract_wrappers/**/*", | ||||
|         "manual:postpublish": "yarn build; node ./scripts/postpublish.js" | ||||
|     }, | ||||
|     "license": "Apache-2.0", | ||||
| @@ -29,8 +30,8 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x-monorepo/packages/base-contract/README.md", | ||||
|     "devDependencies": { | ||||
|         "@0xproject/monorepo-scripts": "^0.1.20", | ||||
|         "@0xproject/tslint-config": "^0.4.18", | ||||
|         "@0xproject/monorepo-scripts": "^1.0.4", | ||||
|         "@0xproject/tslint-config": "^1.0.4", | ||||
|         "@types/lodash": "4.14.104", | ||||
|         "chai": "^4.0.1", | ||||
|         "copyfiles": "^1.2.0", | ||||
| @@ -38,15 +39,15 @@ | ||||
|         "mocha": "^4.0.1", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "tslint": "5.11.0", | ||||
|         "typescript": "2.7.1" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "ethereum-types": "^0.0.1", | ||||
|         "@0xproject/typescript-typings": "^0.3.2", | ||||
|         "@0xproject/utils": "^0.6.2", | ||||
|         "@0xproject/web3-wrapper": "^0.6.4", | ||||
|         "ethers": "^3.0.15", | ||||
|         "@0xproject/typescript-typings": "^1.0.3", | ||||
|         "@0xproject/utils": "^1.0.3", | ||||
|         "@0xproject/web3-wrapper": "^1.1.1", | ||||
|         "ethereum-types": "^1.0.3", | ||||
|         "ethers": "3.0.22", | ||||
|         "lodash": "^4.17.4" | ||||
|     }, | ||||
|     "publishConfig": { | ||||
|   | ||||
| @@ -37,13 +37,14 @@ export class BaseContract { | ||||
|     protected static _lowercaseAddress(type: string, value: string): string { | ||||
|         return type === 'address' ? value.toLowerCase() : value; | ||||
|     } | ||||
|     protected static _bigNumberToString(type: string, value: any): any { | ||||
|     protected static _bigNumberToString(_type: string, value: any): any { | ||||
|         return _.isObject(value) && value.isBigNumber ? value.toString() : value; | ||||
|     } | ||||
|     protected static _lookupConstructorAbi(abi: ContractAbi): ConstructorAbi { | ||||
|         const constructorAbiIfExists = _.find( | ||||
|             abi, | ||||
|             (abiDefinition: AbiDefinition) => abiDefinition.type === AbiType.Constructor, | ||||
|             // tslint:disable-next-line:no-unnecessary-type-assertion | ||||
|         ) as ConstructorAbi | undefined; | ||||
|         if (!_.isUndefined(constructorAbiIfExists)) { | ||||
|             return constructorAbiIfExists; | ||||
| @@ -59,7 +60,7 @@ export class BaseContract { | ||||
|             return defaultConstructorAbi; | ||||
|         } | ||||
|     } | ||||
|     protected static _bnToBigNumber(type: string, value: any): any { | ||||
|     protected static _bnToBigNumber(_type: string, value: any): any { | ||||
|         return _.isObject(value) && value._bn ? new BigNumber(value.toString()) : value; | ||||
|     } | ||||
|     protected static async _applyDefaultsToTxDataAsync<T extends Partial<TxData | TxDataPayable>>( | ||||
| @@ -71,16 +72,13 @@ export class BaseContract { | ||||
|         // 1. Optional param passed in to public method call | ||||
|         // 2. Global config passed in at library instantiation | ||||
|         // 3. Gas estimate calculation + safety margin | ||||
|         const removeUndefinedProperties = _.pickBy; | ||||
|         const txDataWithDefaults: TxData = { | ||||
|         const removeUndefinedProperties = _.pickBy.bind(_); | ||||
|         const txDataWithDefaults = { | ||||
|             ...removeUndefinedProperties(txDefaults), | ||||
|             ...removeUndefinedProperties(txData as any), | ||||
|             // HACK: TS can't prove that T is spreadable. | ||||
|             // Awaiting https://github.com/Microsoft/TypeScript/pull/13288 to be merged | ||||
|         } as any; | ||||
|             ...removeUndefinedProperties(txData), | ||||
|         }; | ||||
|         if (_.isUndefined(txDataWithDefaults.gas) && !_.isUndefined(estimateGasAsync)) { | ||||
|             const estimatedGas = await estimateGasAsync(txData); | ||||
|             txDataWithDefaults.gas = estimatedGas; | ||||
|             txDataWithDefaults.gas = await estimateGasAsync(txDataWithDefaults); | ||||
|         } | ||||
|         return txDataWithDefaults; | ||||
|     } | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import 'make-promises-safe'; | ||||
| import 'mocha'; | ||||
|  | ||||
| import { formatABIDataItem } from '../src/utils'; | ||||
|   | ||||
| @@ -1,6 +1,79 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1527809861, | ||||
|         "timestamp": 1532619515, | ||||
|         "version": "1.0.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532614997, | ||||
|         "version": "1.0.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532605697, | ||||
|         "version": "1.0.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532357734, | ||||
|         "version": "1.0.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532043000, | ||||
|         "version": "1.0.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Remove `WebSocketOrderbookChannel` from the public interface and replace with `orderbookChannelFactory`" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531919263, | ||||
|         "version": "0.6.17", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531149657, | ||||
|         "version": "0.6.16", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1529397769, | ||||
|         "version": "0.6.15", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527616612, | ||||
|         "version": "0.6.14", | ||||
|         "changes": [ | ||||
|             { | ||||
|   | ||||
| @@ -1,11 +1,43 @@ | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| changelogUtils.file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.6.14 - _May 31, 2018_ | ||||
| ## v1.0.4 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.3 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.2 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.1 - _July 23, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.0 - _July 20, 2018_ | ||||
|  | ||||
|     * Remove `WebSocketOrderbookChannel` from the public interface and replace with `orderbookChannelFactory` | ||||
|  | ||||
| ## v0.6.17 - _July 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.6.16 - _July 9, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.6.15 - _June 19, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.6.14 - _May 29, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| @@ -13,7 +45,7 @@ CHANGELOG | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.6.12 - _May 4, 2018_ | ||||
| ## v0.6.12 - _May 5, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0xproject/connect", | ||||
|     "version": "0.6.13", | ||||
|     "version": "1.0.3", | ||||
|     "engines": { | ||||
|         "node": ">=6.12" | ||||
|     }, | ||||
| @@ -15,13 +15,14 @@ | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "watch": "tsc -w", | ||||
|         "watch_without_deps": "tsc -w", | ||||
|         "build": "tsc && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "clean": "shx rm -rf lib test_temp scripts", | ||||
|         "copy_test_fixtures": "copyfiles -u 2 './test/fixtures/**/*.json' ./lib/test/fixtures", | ||||
|         "lint": "tslint --project .", | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js --exit", | ||||
|         "test": "run-s clean build copy_test_fixtures run_mocha", | ||||
|         "run_mocha": "mocha --require source-map-support/register --require make-promises-safe lib/test/**/*_test.js --exit", | ||||
|         "test": "run-s copy_test_fixtures run_mocha", | ||||
|         "rebuild_and_test": "run-s clean build test", | ||||
|         "test:coverage": "nyc npm run test --all && yarn coverage:report:lcov", | ||||
|         "coverage:report:lcov": "nyc report --reporter=text-lcov > coverage/lcov.info", | ||||
|         "test:circleci": "yarn test:coverage", | ||||
| @@ -50,24 +51,25 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x-monorepo/packages/connect/README.md", | ||||
|     "dependencies": { | ||||
|         "@0xproject/assert": "^0.2.10", | ||||
|         "@0xproject/json-schemas": "0.7.22", | ||||
|         "@0xproject/types": "^0.7.0", | ||||
|         "@0xproject/typescript-typings": "^0.3.2", | ||||
|         "@0xproject/utils": "^0.6.2", | ||||
|         "isomorphic-fetch": "^2.2.1", | ||||
|         "@0xproject/assert": "^0.2.14", | ||||
|         "@0xproject/json-schemas": "^0.8.3", | ||||
|         "@0xproject/types": "^0.8.2", | ||||
|         "@0xproject/typescript-typings": "^1.0.3", | ||||
|         "@0xproject/utils": "^1.0.3", | ||||
|         "lodash": "^4.17.4", | ||||
|         "query-string": "^5.0.1", | ||||
|         "sinon": "^4.0.0", | ||||
|         "websocket": "^1.0.25" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/monorepo-scripts": "^0.1.20", | ||||
|         "@0xproject/tslint-config": "^0.4.18", | ||||
|         "@types/fetch-mock": "^5.12.1", | ||||
|         "@0xproject/monorepo-scripts": "^1.0.4", | ||||
|         "@0xproject/tslint-config": "^1.0.4", | ||||
|         "@types/fetch-mock": "^5.12.2", | ||||
|         "@types/lodash": "4.14.104", | ||||
|         "@types/mocha": "^2.2.42", | ||||
|         "@types/query-string": "^5.0.1", | ||||
|         "@types/websocket": "^0.0.34", | ||||
|         "@types/sinon": "^2.2.2", | ||||
|         "@types/websocket": "^0.0.39", | ||||
|         "async-child-process": "^1.1.1", | ||||
|         "chai": "^4.0.1", | ||||
|         "chai-as-promised": "^7.1.0", | ||||
| @@ -79,7 +81,7 @@ | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "nyc": "^11.0.1", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "tslint": "5.11.0", | ||||
|         "typedoc": "~0.8.0", | ||||
|         "typescript": "2.7.1" | ||||
|     }, | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import { assert } from '@0xproject/assert'; | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { SignedOrder } from '@0xproject/types'; | ||||
| import 'isomorphic-fetch'; | ||||
| import { fetchAsync } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as queryString from 'query-string'; | ||||
|  | ||||
| @@ -38,7 +38,7 @@ const OPTS_TO_QUERY_FIELD_MAP = { | ||||
|  * that implement the standard relayer API v0 | ||||
|  */ | ||||
| export class HttpClient implements Client { | ||||
|     private _apiEndpointUrl: string; | ||||
|     private readonly _apiEndpointUrl: string; | ||||
|     /** | ||||
|      * Format parameters to be appended to http requests into query string form | ||||
|      */ | ||||
| @@ -48,7 +48,7 @@ export class HttpClient implements Client { | ||||
|             return ''; | ||||
|         } | ||||
|         // format params into a form the api expects | ||||
|         const formattedParams = _.mapKeys(params, (value: any, key: string) => { | ||||
|         const formattedParams = _.mapKeys(params, (_value: any, key: string) => { | ||||
|             return _.get(OPTS_TO_QUERY_FIELD_MAP, key, key); | ||||
|         }); | ||||
|         // stringify the formatted object | ||||
| @@ -167,7 +167,7 @@ export class HttpClient implements Client { | ||||
|         const headers = new Headers({ | ||||
|             'content-type': 'application/json', | ||||
|         }); | ||||
|         const response = await fetch(url, { | ||||
|         const response = await fetchAsync(url, { | ||||
|             method: requestType, | ||||
|             body: JSON.stringify(payload), | ||||
|             headers, | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| export { HttpClient } from './http_client'; | ||||
| export { WebSocketOrderbookChannel } from './ws_orderbook_channel'; | ||||
| export { orderbookChannelFactory } from './orderbook_channel_factory'; | ||||
| export { | ||||
|     Client, | ||||
|     FeesRequest, | ||||
| @@ -14,7 +14,6 @@ export { | ||||
|     TokenPairsItem, | ||||
|     TokenPairsRequestOpts, | ||||
|     TokenTradeInfo, | ||||
|     WebSocketOrderbookChannelConfig, | ||||
| } from './types'; | ||||
|  | ||||
| export { Order, SignedOrder } from '@0xproject/types'; | ||||
|   | ||||
							
								
								
									
										32
									
								
								packages/connect/src/orderbook_channel_factory.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								packages/connect/src/orderbook_channel_factory.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| import * as WebSocket from 'websocket'; | ||||
|  | ||||
| import { OrderbookChannel, OrderbookChannelHandler } from './types'; | ||||
| import { assert } from './utils/assert'; | ||||
| import { WebSocketOrderbookChannel } from './ws_orderbook_channel'; | ||||
|  | ||||
| export const orderbookChannelFactory = { | ||||
|     /** | ||||
|      * Instantiates a new WebSocketOrderbookChannel instance | ||||
|      * @param   url                  The relayer API base WS url you would like to interact with | ||||
|      * @param   handler              An OrderbookChannelHandler instance that responds to various | ||||
|      *                               channel updates | ||||
|      * @return  An OrderbookChannel Promise | ||||
|      */ | ||||
|     async createWebSocketOrderbookChannelAsync( | ||||
|         url: string, | ||||
|         handler: OrderbookChannelHandler, | ||||
|     ): Promise<OrderbookChannel> { | ||||
|         assert.isUri('url', url); | ||||
|         assert.isOrderbookChannelHandler('handler', handler); | ||||
|         return new Promise<OrderbookChannel>((resolve, reject) => { | ||||
|             const client = new WebSocket.w3cwebsocket(url); | ||||
|             client.onopen = () => { | ||||
|                 const orderbookChannel = new WebSocketOrderbookChannel(client, handler); | ||||
|                 resolve(orderbookChannel); | ||||
|             }; | ||||
|             client.onerror = err => { | ||||
|                 reject(err); | ||||
|             }; | ||||
|         }); | ||||
|     }, | ||||
| }; | ||||
| @@ -3,7 +3,6 @@ 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 = { | ||||
|     feesRequestSchema, | ||||
| @@ -11,5 +10,4 @@ export const schemas = { | ||||
|     ordersRequestOptsSchema, | ||||
|     pagedRequestOptsSchema, | ||||
|     tokenPairsRequestOptsSchema, | ||||
|     webSocketOrderbookChannelConfigSchema, | ||||
| }; | ||||
|   | ||||
| @@ -1,10 +0,0 @@ | ||||
| export const webSocketOrderbookChannelConfigSchema = { | ||||
|     id: '/WebSocketOrderbookChannelConfig', | ||||
|     type: 'object', | ||||
|     properties: { | ||||
|         heartbeatIntervalMs: { | ||||
|             type: 'number', | ||||
|             minimum: 10, | ||||
|         }, | ||||
|     }, | ||||
| }; | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { Order, SignedOrder } from '@0xproject/types'; | ||||
| import { SignedOrder } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| export interface Client { | ||||
| @@ -11,17 +11,10 @@ export interface Client { | ||||
| } | ||||
|  | ||||
| export interface OrderbookChannel { | ||||
|     subscribe: (subscriptionOpts: OrderbookChannelSubscriptionOpts, handler: OrderbookChannelHandler) => void; | ||||
|     subscribe: (subscriptionOpts: OrderbookChannelSubscriptionOpts) => void; | ||||
|     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 | ||||
| @@ -46,8 +39,8 @@ export interface OrderbookChannelHandler { | ||||
|         subscriptionOpts: OrderbookChannelSubscriptionOpts, | ||||
|         order: SignedOrder, | ||||
|     ) => void; | ||||
|     onError: (channel: OrderbookChannel, subscriptionOpts: OrderbookChannelSubscriptionOpts, err: Error) => void; | ||||
|     onClose: (channel: OrderbookChannel, subscriptionOpts: OrderbookChannelSubscriptionOpts) => void; | ||||
|     onError: (channel: OrderbookChannel, err: Error, subscriptionOpts?: OrderbookChannelSubscriptionOpts) => void; | ||||
|     onClose: (channel: OrderbookChannel) => void; | ||||
| } | ||||
|  | ||||
| export type OrderbookChannelMessage = | ||||
|   | ||||
							
								
								
									
										26
									
								
								packages/connect/src/utils/assert.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								packages/connect/src/utils/assert.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| import { assert as sharedAssert } from '@0xproject/assert'; | ||||
| // HACK: We need those two unused imports because they're actually used by sharedAssert which gets injected here | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { Schema, schemas } from '@0xproject/json-schemas'; | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { ECSignature } from '@0xproject/types'; | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| export const assert = { | ||||
|     ...sharedAssert, | ||||
|     isOrderbookChannelSubscriptionOpts(variableName: string, subscriptionOpts: any): void { | ||||
|         sharedAssert.doesConformToSchema( | ||||
|             variableName, | ||||
|             subscriptionOpts, | ||||
|             schemas.relayerApiOrderbookChannelSubscribePayload, | ||||
|         ); | ||||
|     }, | ||||
|     isOrderbookChannelHandler(variableName: string, handler: any): void { | ||||
|         sharedAssert.isFunction(`${variableName}.onSnapshot`, _.get(handler, 'onSnapshot')); | ||||
|         sharedAssert.isFunction(`${variableName}.onUpdate`, _.get(handler, 'onUpdate')); | ||||
|         sharedAssert.isFunction(`${variableName}.onError`, _.get(handler, 'onError')); | ||||
|         sharedAssert.isFunction(`${variableName}.onClose`, _.get(handler, 'onClose')); | ||||
|     }, | ||||
| }; | ||||
| @@ -8,10 +8,16 @@ import { relayerResponseJsonParsers } from './relayer_response_json_parsers'; | ||||
|  | ||||
| export const orderbookChannelMessageParser = { | ||||
|     parse(utf8Data: string): OrderbookChannelMessage { | ||||
|         // parse the message | ||||
|         const messageObj = JSON.parse(utf8Data); | ||||
|         // ensure we have a type parameter to switch on | ||||
|         const type: string = _.get(messageObj, 'type'); | ||||
|         assert.assert(!_.isUndefined(type), `Message is missing a type parameter: ${utf8Data}`); | ||||
|         assert.isString('type', type); | ||||
|         // ensure we have a request id for the resulting message | ||||
|         const requestId: number = _.get(messageObj, 'requestId'); | ||||
|         assert.assert(!_.isUndefined(requestId), `Message is missing a requestId parameter: ${utf8Data}`); | ||||
|         assert.isNumber('requestId', requestId); | ||||
|         switch (type) { | ||||
|             case OrderbookChannelMessageTypes.Snapshot: { | ||||
|                 assert.doesConformToSchema('message', messageObj, schemas.relayerApiOrderbookChannelSnapshotSchema); | ||||
| @@ -28,7 +34,7 @@ export const orderbookChannelMessageParser = { | ||||
|             default: { | ||||
|                 return { | ||||
|                     type: OrderbookChannelMessageTypes.Unknown, | ||||
|                     requestId: 0, | ||||
|                     requestId, | ||||
|                     payload: undefined, | ||||
|                 }; | ||||
|             } | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| import { assert } from '@0xproject/assert'; | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { SignedOrder } from '@0xproject/types'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { FeesResponse, OrderbookResponse, TokenPairsItem } from '../types'; | ||||
|  | ||||
|   | ||||
| @@ -6,12 +6,12 @@ export const typeConverters = { | ||||
|         const bids = _.get(orderbook, 'bids', []); | ||||
|         const asks = _.get(orderbook, 'asks', []); | ||||
|         return { | ||||
|             bids: bids.map((order: any) => this.convertOrderStringFieldsToBigNumber(order)), | ||||
|             asks: asks.map((order: any) => this.convertOrderStringFieldsToBigNumber(order)), | ||||
|             bids: bids.map((order: any) => typeConverters.convertOrderStringFieldsToBigNumber(order)), | ||||
|             asks: asks.map((order: any) => typeConverters.convertOrderStringFieldsToBigNumber(order)), | ||||
|         }; | ||||
|     }, | ||||
|     convertOrderStringFieldsToBigNumber(order: any): any { | ||||
|         return this.convertStringsFieldsToBigNumbers(order, [ | ||||
|         return typeConverters.convertStringsFieldsToBigNumbers(order, [ | ||||
|             'makerTokenAmount', | ||||
|             'takerTokenAmount', | ||||
|             'makerFee', | ||||
|   | ||||
| @@ -1,166 +1,105 @@ | ||||
| import { assert } from '@0xproject/assert'; | ||||
| 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, | ||||
|     OrderbookChannelMessageTypes, | ||||
|     OrderbookChannelSubscriptionOpts, | ||||
|     WebsocketClientEventType, | ||||
|     WebsocketConnectionEventType, | ||||
|     WebSocketOrderbookChannelConfig, | ||||
| } from './types'; | ||||
| import { assert } from './utils/assert'; | ||||
| 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 | ||||
|  */ | ||||
| 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; | ||||
|     private readonly _client: WebSocket.w3cwebsocket; | ||||
|     private readonly _handler: OrderbookChannelHandler; | ||||
|     private readonly _subscriptionOptsList: OrderbookChannelSubscriptionOpts[] = []; | ||||
|     /** | ||||
|      * Instantiates a new WebSocketOrderbookChannel instance | ||||
|      * @param   url                 The relayer API base WS url you would like to interact with | ||||
|      * @param   config              The configuration object. Look up the type for the description. | ||||
|      * @param   client               A WebSocket client | ||||
|      * @param   handler              An OrderbookChannelHandler instance that responds to various | ||||
|      *                               channel updates | ||||
|      * @return  An instance of WebSocketOrderbookChannel | ||||
|      */ | ||||
|     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(); | ||||
|     constructor(client: WebSocket.w3cwebsocket, handler: OrderbookChannelHandler) { | ||||
|         assert.isOrderbookChannelHandler('handler', handler); | ||||
|         // set private members | ||||
|         this._client = client; | ||||
|         this._handler = handler; | ||||
|         // attach client callbacks | ||||
|         this._client.onerror = err => { | ||||
|             this._handler.onError(this, err); | ||||
|         }; | ||||
|         this._client.onclose = () => { | ||||
|             this._handler.onClose(this); | ||||
|         }; | ||||
|         this._client.onmessage = message => { | ||||
|             this._handleWebSocketMessage(message); | ||||
|         }; | ||||
|     } | ||||
|     /** | ||||
|      * Subscribe to orderbook snapshots and updates from the websocket | ||||
|      * @param   subscriptionOpts     An OrderbookChannelSubscriptionOpts instance describing which | ||||
|      *                               token pair to subscribe to | ||||
|      * @param   handler              An OrderbookChannelHandler instance that responds to various | ||||
|      *                               channel updates | ||||
|      */ | ||||
|     public subscribe(subscriptionOpts: OrderbookChannelSubscriptionOpts, handler: OrderbookChannelHandler): void { | ||||
|         assert.doesConformToSchema( | ||||
|             'subscriptionOpts', | ||||
|             subscriptionOpts, | ||||
|             schemas.relayerApiOrderbookChannelSubscribePayload, | ||||
|         ); | ||||
|         assert.isFunction('handler.onSnapshot', _.get(handler, 'onSnapshot')); | ||||
|         assert.isFunction('handler.onUpdate', _.get(handler, 'onUpdate')); | ||||
|         assert.isFunction('handler.onError', _.get(handler, 'onError')); | ||||
|         assert.isFunction('handler.onClose', _.get(handler, 'onClose')); | ||||
|         this._subscriptionCounter += 1; | ||||
|     public subscribe(subscriptionOpts: OrderbookChannelSubscriptionOpts): void { | ||||
|         assert.isOrderbookChannelSubscriptionOpts('subscriptionOpts', subscriptionOpts); | ||||
|         assert.assert(this._client.readyState === WebSocket.w3cwebsocket.OPEN, 'WebSocket connection is closed'); | ||||
|         this._subscriptionOptsList.push(subscriptionOpts); | ||||
|         // TODO: update requestId management to use UUIDs for v2 | ||||
|         const subscribeMessage = { | ||||
|             type: 'subscribe', | ||||
|             channel: 'orderbook', | ||||
|             requestId: this._subscriptionCounter, | ||||
|             requestId: this._subscriptionOptsList.length - 1, | ||||
|             payload: subscriptionOpts, | ||||
|         }; | ||||
|         this._getConnection((error, connection) => { | ||||
|             if (!_.isUndefined(error)) { | ||||
|                 handler.onError(this, subscriptionOpts, error); | ||||
|             } else if (!_.isUndefined(connection) && connection.connected) { | ||||
|                 connection.on(WebsocketConnectionEventType.Error, wsError => { | ||||
|                     handler.onError(this, subscriptionOpts, wsError); | ||||
|                 }); | ||||
|                 connection.on(WebsocketConnectionEventType.Close, (code: number, desc: string) => { | ||||
|                     handler.onClose(this, subscriptionOpts); | ||||
|                 }); | ||||
|                 connection.on(WebsocketConnectionEventType.Message, message => { | ||||
|                     this._handleWebSocketMessage(subscribeMessage.requestId, subscriptionOpts, message, handler); | ||||
|                 }); | ||||
|                 connection.sendUTF(JSON.stringify(subscribeMessage)); | ||||
|             } | ||||
|         }); | ||||
|         this._client.send(JSON.stringify(subscribeMessage)); | ||||
|     } | ||||
|     /** | ||||
|      * Close the websocket and stop receiving updates | ||||
|      */ | ||||
|     public close(): void { | ||||
|         if (!_.isUndefined(this._connectionIfExists)) { | ||||
|             this._connectionIfExists.close(); | ||||
|         } | ||||
|         if (!_.isUndefined(this._heartbeatTimerIfExists)) { | ||||
|             clearInterval(this._heartbeatTimerIfExists); | ||||
|         } | ||||
|         this._client.close(); | ||||
|     } | ||||
|     private _getConnection(callback: (error?: Error, connection?: WebSocket.connection) => void): void { | ||||
|         if (!_.isUndefined(this._connectionIfExists) && this._connectionIfExists.connected) { | ||||
|             callback(undefined, this._connectionIfExists); | ||||
|         } 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, | ||||
|     private _handleWebSocketMessage(message: any): void { | ||||
|         if (_.isUndefined(message.data)) { | ||||
|             this._handler.onError(this, new Error(`Message does not contain data. Url: ${this._client.url}`)); | ||||
|             return; | ||||
|         } | ||||
|         try { | ||||
|             const data = message.data; | ||||
|             const parserResult = orderbookChannelMessageParser.parse(data); | ||||
|             const subscriptionOpts = this._subscriptionOptsList[parserResult.requestId]; | ||||
|             if (_.isUndefined(subscriptionOpts)) { | ||||
|                 this._handler.onError( | ||||
|                     this, | ||||
|                     new Error(`Message has unknown requestId. Url: ${this._client.url} Message: ${data}`), | ||||
|                 ); | ||||
|                 return; | ||||
|             } | ||||
|             switch (parserResult.type) { | ||||
|                 case OrderbookChannelMessageTypes.Snapshot: { | ||||
|                     this._handler.onSnapshot(this, subscriptionOpts, parserResult.payload); | ||||
|                     break; | ||||
|                 } | ||||
|                 case OrderbookChannelMessageTypes.Update: { | ||||
|                     this._handler.onUpdate(this, subscriptionOpts, parserResult.payload); | ||||
|                     break; | ||||
|                 } | ||||
|                 default: { | ||||
|                     this._handler.onError( | ||||
|                         this, | ||||
|                         new Error(`Message has unknown type parameter. Url: ${this._client.url} Message: ${data}`), | ||||
|                         subscriptionOpts, | ||||
|                     ); | ||||
|                 } | ||||
|                 callback(undefined, this._connectionIfExists); | ||||
|             }); | ||||
|             this._client.on(WebsocketClientEventType.ConnectFailed, error => { | ||||
|                 callback(error, undefined); | ||||
|             }); | ||||
|             this._client.connect(this._apiEndpointUrl); | ||||
|         } | ||||
|     } | ||||
|     private _handleWebSocketMessage( | ||||
|         requestId: number, | ||||
|         subscriptionOpts: OrderbookChannelSubscriptionOpts, | ||||
|         message: WebSocket.IMessage, | ||||
|         handler: OrderbookChannelHandler, | ||||
|     ): void { | ||||
|         if (!_.isUndefined(message.utf8Data)) { | ||||
|             try { | ||||
|                 const utf8Data = message.utf8Data; | ||||
|                 const parserResult = orderbookChannelMessageParser.parse(utf8Data); | ||||
|                 if (parserResult.requestId === requestId) { | ||||
|                     switch (parserResult.type) { | ||||
|                         case OrderbookChannelMessageTypes.Snapshot: { | ||||
|                             handler.onSnapshot(this, subscriptionOpts, parserResult.payload); | ||||
|                             break; | ||||
|                         } | ||||
|                         case OrderbookChannelMessageTypes.Update: { | ||||
|                             handler.onUpdate(this, subscriptionOpts, parserResult.payload); | ||||
|                             break; | ||||
|                         } | ||||
|                         default: { | ||||
|                             handler.onError( | ||||
|                                 this, | ||||
|                                 subscriptionOpts, | ||||
|                                 new Error(`Message has missing a type parameter: ${utf8Data}`), | ||||
|                             ); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } catch (error) { | ||||
|                 handler.onError(this, subscriptionOpts, error); | ||||
|             } | ||||
|         } else { | ||||
|             handler.onError(this, subscriptionOpts, new Error(`Message does not contain utf8Data`)); | ||||
|         } catch (error) { | ||||
|             this._handler.onError(this, error); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -3,7 +3,6 @@ import * as chai from 'chai'; | ||||
| import * as chaiAsPromised from 'chai-as-promised'; | ||||
| import * as dirtyChai from 'dirty-chai'; | ||||
| import * as fetchMock from 'fetch-mock'; | ||||
| import 'make-promises-safe'; | ||||
| import 'mocha'; | ||||
|  | ||||
| import { HttpClient } from '../src/index'; | ||||
|   | ||||
							
								
								
									
										45
									
								
								packages/connect/test/orderbook_channel_factory_test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								packages/connect/test/orderbook_channel_factory_test.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| import * as chai from 'chai'; | ||||
| import * as dirtyChai from 'dirty-chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'mocha'; | ||||
|  | ||||
| import { orderbookChannelFactory } from '../src/orderbook_channel_factory'; | ||||
|  | ||||
| chai.config.includeStack = true; | ||||
| chai.use(dirtyChai); | ||||
| const expect = chai.expect; | ||||
| const emptyOrderbookChannelHandler = { | ||||
|     onSnapshot: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
|     onUpdate: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
|     onError: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
|     onClose: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
| }; | ||||
|  | ||||
| describe('orderbookChannelFactory', () => { | ||||
|     const websocketUrl = 'ws://localhost:8080'; | ||||
|     describe('#createWebSocketOrderbookChannelAsync', () => { | ||||
|         it('throws when input is not a url', () => { | ||||
|             const badUrlInput = 54; | ||||
|             expect( | ||||
|                 orderbookChannelFactory.createWebSocketOrderbookChannelAsync( | ||||
|                     badUrlInput as any, | ||||
|                     emptyOrderbookChannelHandler, | ||||
|                 ), | ||||
|             ).to.be.rejected(); | ||||
|         }); | ||||
|         it('throws when handler has the incorrect members', () => { | ||||
|             const badHandlerInput = {}; | ||||
|             expect( | ||||
|                 orderbookChannelFactory.createWebSocketOrderbookChannelAsync(websocketUrl, badHandlerInput as any), | ||||
|             ).to.be.rejected(); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
| @@ -1,6 +1,5 @@ | ||||
| import * as chai from 'chai'; | ||||
| import * as dirtyChai from 'dirty-chai'; | ||||
| import 'make-promises-safe'; | ||||
| import 'mocha'; | ||||
|  | ||||
| import { orderbookChannelMessageParser } from '../src/utils/orderbook_channel_message_parser'; | ||||
|   | ||||
| @@ -1,62 +1,59 @@ | ||||
| import * as chai from 'chai'; | ||||
| import * as dirtyChai from 'dirty-chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'make-promises-safe'; | ||||
| import 'mocha'; | ||||
| import * as Sinon from 'sinon'; | ||||
| import * as WebSocket from 'websocket'; | ||||
|  | ||||
| import { WebSocketOrderbookChannel } from '../src/ws_orderbook_channel'; | ||||
|  | ||||
| chai.config.includeStack = true; | ||||
| chai.use(dirtyChai); | ||||
| const expect = chai.expect; | ||||
| const emptyOrderbookChannelHandler = { | ||||
|     onSnapshot: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
|     onUpdate: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
|     onError: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
|     onClose: () => { | ||||
|         _.noop(); | ||||
|     }, | ||||
| }; | ||||
|  | ||||
| describe('WebSocketOrderbookChannel', () => { | ||||
|     const websocketUrl = 'ws://localhost:8080'; | ||||
|     const orderbookChannel = new WebSocketOrderbookChannel(websocketUrl); | ||||
|     const openClient = new WebSocket.w3cwebsocket(websocketUrl); | ||||
|     Sinon.stub(openClient, 'readyState').get(() => WebSocket.w3cwebsocket.OPEN); | ||||
|     Sinon.stub(openClient, 'send').callsFake(_.noop.bind(_)); | ||||
|     const openOrderbookChannel = new WebSocketOrderbookChannel(openClient, emptyOrderbookChannelHandler); | ||||
|     const subscriptionOpts = { | ||||
|         baseTokenAddress: '0x323b5d4c32345ced77393b3530b1eed0f346429d', | ||||
|         quoteTokenAddress: '0xef7fff64389b814a946f3e92105513705ca6b990', | ||||
|         snapshot: true, | ||||
|         limit: 100, | ||||
|     }; | ||||
|     const emptyOrderbookChannelHandler = { | ||||
|         onSnapshot: () => { | ||||
|             _.noop(); | ||||
|         }, | ||||
|         onUpdate: () => { | ||||
|             _.noop(); | ||||
|         }, | ||||
|         onError: () => { | ||||
|             _.noop(); | ||||
|         }, | ||||
|         onClose: () => { | ||||
|             _.noop(); | ||||
|         }, | ||||
|     }; | ||||
|     describe('#subscribe', () => { | ||||
|         it('throws when subscriptionOpts does not conform to schema', () => { | ||||
|             const badSubscribeCall = orderbookChannel.subscribe.bind( | ||||
|                 orderbookChannel, | ||||
|                 {}, | ||||
|                 emptyOrderbookChannelHandler, | ||||
|             ); | ||||
|             const badSubscribeCall = openOrderbookChannel.subscribe.bind(openOrderbookChannel, {}); | ||||
|             expect(badSubscribeCall).throws( | ||||
|                 'Expected subscriptionOpts to conform to schema /RelayerApiOrderbookChannelSubscribePayload\nEncountered: {}\nValidation errors: instance requires property "baseTokenAddress", instance requires property "quoteTokenAddress"', | ||||
|             ); | ||||
|         }); | ||||
|         it('throws when handler has the incorrect members', () => { | ||||
|             const badSubscribeCall = orderbookChannel.subscribe.bind(orderbookChannel, subscriptionOpts, {}); | ||||
|             expect(badSubscribeCall).throws( | ||||
|                 'Expected handler.onSnapshot to be of type function, encountered: undefined', | ||||
|             ); | ||||
|         }); | ||||
|         it('does not throw when inputs are of correct types', () => { | ||||
|             const goodSubscribeCall = orderbookChannel.subscribe.bind( | ||||
|                 orderbookChannel, | ||||
|                 subscriptionOpts, | ||||
|                 emptyOrderbookChannelHandler, | ||||
|             ); | ||||
|             const goodSubscribeCall = openOrderbookChannel.subscribe.bind(openOrderbookChannel, subscriptionOpts); | ||||
|             expect(goodSubscribeCall).to.not.throw(); | ||||
|         }); | ||||
|         it('throws when client is closed', () => { | ||||
|             const closedClient = new WebSocket.w3cwebsocket(websocketUrl); | ||||
|             Sinon.stub(closedClient, 'readyState').get(() => WebSocket.w3cwebsocket.CLOSED); | ||||
|             const closedOrderbookChannel = new WebSocketOrderbookChannel(closedClient, emptyOrderbookChannelHandler); | ||||
|             const badSubscribeCall = closedOrderbookChannel.subscribe.bind(closedOrderbookChannel, subscriptionOpts); | ||||
|             expect(badSubscribeCall).throws('WebSocket connection is closed'); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
|   | ||||
| @@ -1,11 +1,70 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1527809861, | ||||
|         "version": "0.0.3", | ||||
|         "version": "1.0.1-rc.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed bug caused by importing non-existent dep" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1532619515 | ||||
|     }, | ||||
|     { | ||||
|         "version": "1.0.1-rc.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1532605697 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532357734, | ||||
|         "version": "1.0.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1532043000, | ||||
|         "version": "1.0.0-rc.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Update blockstream to v5.0 and propogate up caught errors to active subscriptions", | ||||
|                 "pr": 815 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Update to v2 of 0x rpotocol", | ||||
|                 "pr": 822 | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1531919263, | ||||
|         "version": "0.1.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1529397769, | ||||
|         "version": "0.0.5", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1527617227, | ||||
|         "version": "0.0.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Expose 'abi' ContractAbi property on all contract wrappers" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|   | ||||
| @@ -1,14 +1,39 @@ | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| changelogUtils.file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.0.3 - _May 31, 2018_ | ||||
| ## v1.0.1-rc.2 - _July 26, 2018_ | ||||
|  | ||||
|     * Fixed bug caused by importing non-existent dep | ||||
|  | ||||
| ## v1.0.1-rc.1 - _July 26, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.0 - _July 23, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v1.0.0-rc.1 - _July 20, 2018_ | ||||
|  | ||||
|     * Update blockstream to v5.0 and propogate up caught errors to active subscriptions (#815) | ||||
|     * Update to v2 of 0x rpotocol (#822) | ||||
|  | ||||
| ## v0.1.1 - _July 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.0.5 - _June 19, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.0.4 - _May 29, 2018_ | ||||
|  | ||||
|     * Expose 'abi' ContractAbi property on all contract wrappers | ||||
|  | ||||
| ## v0.0.2 - _May 22, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "@0xproject/contract-wrappers", | ||||
|     "version": "0.0.2", | ||||
|     "version": "1.0.1-rc.1", | ||||
|     "description": "Smart TS wrappers for 0x smart contracts", | ||||
|     "keywords": [ | ||||
|         "0xproject", | ||||
| @@ -11,29 +11,26 @@ | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "watch": "tsc -w", | ||||
|         "prebuild": "run-s clean generate_contract_wrappers", | ||||
|         "generate_contract_wrappers": "abi-gen --abis 'src/compact_artifacts/@(Exchange|Token|TokenTransferProxy|EtherToken|TokenRegistry|DummyToken).json' --template ../contract_templates/contract.handlebars --partials '../contract_templates/partials/**/*.handlebars' --output src/contract_wrappers/generated --backend ethers && prettier --write 'src/contract_wrappers/generated/**.ts'", | ||||
|         "lint": "tslint --project .", | ||||
|         "watch_without_deps": "yarn pre_build && tsc -w", | ||||
|         "build": "yarn pre_build && tsc && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "pre_build": "run-s update_artifacts_v2_beta update_artifacts_v2 generate_contract_wrappers copy_artifacts", | ||||
|         "generate_contract_wrappers": "abi-gen --abis 'src/artifacts/@(Exchange|DummyERC20Token|DummyERC721Token|ZRXToken|ERC20Token|ERC721Token|WETH9|ERC20Proxy|ERC721Proxy).json' --template ../contract_templates/contract.handlebars --partials '../contract_templates/partials/**/*.handlebars' --output src/contract_wrappers/generated --backend ethers", | ||||
|         "lint": "tslint --project . --exclude **/src/contract_wrappers/**/* --exclude **/lib/**/*", | ||||
|         "test:circleci": "run-s test:coverage", | ||||
|         "test": "run-s clean build run_mocha", | ||||
|         "test": "yarn run_mocha", | ||||
|         "rebuild_and_test": "run-s build test", | ||||
|         "test:coverage": "nyc npm run test --all && yarn coverage:report:lcov", | ||||
|         "coverage:report:lcov": "nyc report --reporter=text-lcov > coverage/lcov.info", | ||||
|         "update_artifacts": "for i in ${npm_package_config_contracts}; do copyfiles -u 4 ../migrations/artifacts/1.0.0/$i.json test/artifacts; done;", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp scripts test/artifacts src/contract_wrappers/generated", | ||||
|         "build": "tsc && yarn update_artifacts && copyfiles -u 2 './src/compact_artifacts/**/*.json' ./lib/src/compact_artifacts && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js lib/test/global_hooks.js --timeout 10000 --bail --exit", | ||||
|         "update_artifacts_v2_beta": "for i in ${npm_package_config_contracts_v2_beta}; do copyfiles -u 4 ../migrations/artifacts/2.0.0-beta-testnet/$i.json src/artifacts; done;", | ||||
|         "update_artifacts_v2": "for i in ${npm_package_config_contracts_v2}; do copyfiles -u 4 ../migrations/artifacts/2.0.0/$i.json src/artifacts; done;", | ||||
|         "copy_artifacts": "copyfiles -u 2 './src/artifacts/**/*.json' ./lib/src/artifacts", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp scripts test/artifacts src/contract_wrappers/generated src/artifacts", | ||||
|         "run_mocha": "mocha --require source-map-support/register --require make-promises-safe lib/test/**/*_test.js lib/test/global_hooks.js --timeout 10000 --bail --exit", | ||||
|         "manual:postpublish": "yarn build; node ./scripts/postpublish.js" | ||||
|     }, | ||||
|     "config": { | ||||
|         "compact_artifacts": "Exchange DummyToken ZRXToken Token EtherToken TokenTransferProxy TokenRegistry", | ||||
|         "contracts": "Exchange DummyToken ZRXToken Token WETH9 TokenTransferProxy_v1 MultiSigWallet MultiSigWalletWithTimeLock MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress MaliciousToken TokenRegistry Arbitrage EtherDelta AccountLevels", | ||||
|         "postpublish": { | ||||
|             "assets": [ | ||||
|                 "packages/contract-wrappers/_bundles/index.js", | ||||
|                 "packages/contract-wrappers/_bundles/index.min.js" | ||||
|             ] | ||||
|         } | ||||
|         "contracts_v2_beta": "Exchange ERC20Proxy ERC20Token ERC721Proxy ERC721Token WETH9 ZRXToken", | ||||
|         "contracts_v2": "DummyERC20Token DummyERC721Token" | ||||
|     }, | ||||
|     "repository": { | ||||
|         "type": "git", | ||||
| @@ -44,13 +41,13 @@ | ||||
|         "node": ">=6.0.0" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/abi-gen": "^0.3.0", | ||||
|         "@0xproject/dev-utils": "^0.4.2", | ||||
|         "@0xproject/migrations": "^0.0.6", | ||||
|         "@0xproject/monorepo-scripts": "^0.1.20", | ||||
|         "@0xproject/sol-compiler": "^0.5.0", | ||||
|         "@0xproject/subproviders": "^0.10.2", | ||||
|         "@0xproject/tslint-config": "^0.4.18", | ||||
|         "@0xproject/abi-gen": "^1.0.3", | ||||
|         "@0xproject/dev-utils": "^1.0.2", | ||||
|         "@0xproject/migrations": "^1.0.2", | ||||
|         "@0xproject/monorepo-scripts": "^1.0.4", | ||||
|         "@0xproject/sol-compiler": "^1.0.3", | ||||
|         "@0xproject/subproviders": "^1.0.3", | ||||
|         "@0xproject/tslint-config": "^1.0.4", | ||||
|         "@types/lodash": "4.14.104", | ||||
|         "@types/mocha": "^2.2.42", | ||||
|         "@types/node": "^8.0.53", | ||||
| @@ -67,28 +64,27 @@ | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "nyc": "^11.0.1", | ||||
|         "opn-cli": "^3.1.0", | ||||
|         "prettier": "^1.11.1", | ||||
|         "shx": "^0.2.2", | ||||
|         "sinon": "^4.0.0", | ||||
|         "source-map-support": "^0.5.0", | ||||
|         "tslint": "5.8.0", | ||||
|         "tslint": "5.11.0", | ||||
|         "typescript": "2.7.1", | ||||
|         "web3-provider-engine": "^14.0.4" | ||||
|         "web3-provider-engine": "14.0.6" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0xproject/assert": "^0.2.10", | ||||
|         "@0xproject/base-contract": "^0.3.2", | ||||
|         "@0xproject/fill-scenarios": "^0.0.2", | ||||
|         "@0xproject/json-schemas": "0.7.22", | ||||
|         "@0xproject/order-utils": "^0.0.5", | ||||
|         "@0xproject/types": "0.7.0", | ||||
|         "@0xproject/typescript-typings": "^0.3.2", | ||||
|         "@0xproject/utils": "^0.6.2", | ||||
|         "@0xproject/web3-wrapper": "^0.6.4", | ||||
|         "ethereum-types": "^0.0.1", | ||||
|         "ethereumjs-blockstream": "^2.0.6", | ||||
|         "@0xproject/assert": "^1.0.3", | ||||
|         "@0xproject/base-contract": "^1.0.3", | ||||
|         "@0xproject/fill-scenarios": "^1.0.1-rc.1", | ||||
|         "@0xproject/json-schemas": "^1.0.1-rc.2", | ||||
|         "@0xproject/order-utils": "^1.0.1-rc.1", | ||||
|         "@0xproject/types": "^1.0.1-rc.2", | ||||
|         "@0xproject/typescript-typings": "^1.0.3", | ||||
|         "@0xproject/utils": "^1.0.3", | ||||
|         "@0xproject/web3-wrapper": "^1.1.1", | ||||
|         "ethereum-types": "^1.0.3", | ||||
|         "ethereumjs-blockstream": "5.0.0", | ||||
|         "ethereumjs-util": "^5.1.1", | ||||
|         "ethers": "^3.0.15", | ||||
|         "ethers": "3.0.22", | ||||
|         "js-sha3": "^0.7.0", | ||||
|         "lodash": "^4.17.4", | ||||
|         "uuid": "^3.1.0" | ||||
|   | ||||
| @@ -0,0 +1,11 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| export abstract class AbstractBalanceAndProxyAllowanceLazyStore { | ||||
|     public abstract async getBalanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber>; | ||||
|     public abstract async getProxyAllowanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber>; | ||||
|     public abstract setBalance(tokenAddress: string, userAddress: string, balance: BigNumber): void; | ||||
|     public abstract deleteBalance(tokenAddress: string, userAddress: string): void; | ||||
|     public abstract setProxyAllowance(tokenAddress: string, userAddress: string, proxyAllowance: BigNumber): void; | ||||
|     public abstract deleteProxyAllowance(tokenAddress: string, userAddress: string): void; | ||||
|     public abstract deleteAll(): void; | ||||
| } | ||||
| @@ -1,18 +1,23 @@ | ||||
| import { Artifact } from '@0xproject/types'; | ||||
| import { ContractArtifact } from '@0xproject/sol-compiler'; | ||||
|  | ||||
| import * as DummyERC20Token from './artifacts/DummyERC20Token.json'; | ||||
| import * as DummyERC721Token from './artifacts/DummyERC721Token.json'; | ||||
| import * as ERC20Proxy from './artifacts/ERC20Proxy.json'; | ||||
| import * as ERC20Token from './artifacts/ERC20Token.json'; | ||||
| import * as ERC721Proxy from './artifacts/ERC721Proxy.json'; | ||||
| import * as ERC721Token from './artifacts/ERC721Token.json'; | ||||
| import * as Exchange from './artifacts/Exchange.json'; | ||||
| import * as EtherToken from './artifacts/WETH9.json'; | ||||
| import * as ZRXToken from './artifacts/ZRXToken.json'; | ||||
|  | ||||
| import * as DummyToken from './compact_artifacts/DummyToken.json'; | ||||
| import * as EtherToken from './compact_artifacts/EtherToken.json'; | ||||
| import * as Exchange from './compact_artifacts/Exchange.json'; | ||||
| import * as Token from './compact_artifacts/Token.json'; | ||||
| import * as TokenRegistry from './compact_artifacts/TokenRegistry.json'; | ||||
| import * as TokenTransferProxy from './compact_artifacts/TokenTransferProxy.json'; | ||||
| import * as ZRX from './compact_artifacts/ZRX.json'; | ||||
| export const artifacts = { | ||||
|     ZRX: (ZRX as any) as Artifact, | ||||
|     DummyToken: (DummyToken as any) as Artifact, | ||||
|     Token: (Token as any) as Artifact, | ||||
|     Exchange: (Exchange as any) as Artifact, | ||||
|     EtherToken: (EtherToken as any) as Artifact, | ||||
|     TokenRegistry: (TokenRegistry as any) as Artifact, | ||||
|     TokenTransferProxy: (TokenTransferProxy as any) as Artifact, | ||||
|     ZRXToken: (ZRXToken as any) as ContractArtifact, | ||||
|     DummyERC20Token: (DummyERC20Token as any) as ContractArtifact, | ||||
|     DummyERC721Token: (DummyERC721Token as any) as ContractArtifact, | ||||
|     ERC20Token: (ERC20Token as any) as ContractArtifact, | ||||
|     ERC721Token: (ERC721Token as any) as ContractArtifact, | ||||
|     Exchange: (Exchange as any) as ContractArtifact, | ||||
|     EtherToken: (EtherToken as any) as ContractArtifact, | ||||
|     ERC20Proxy: (ERC20Proxy as any) as ContractArtifact, | ||||
|     ERC721Proxy: (ERC721Proxy as any) as ContractArtifact, | ||||
| }; | ||||
|   | ||||
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|     "contract_name": "DummyToken", | ||||
|     "abi": [ | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_target", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_value", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setBalance", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         } | ||||
|     ] | ||||
| } | ||||
| @@ -1,287 +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" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "_owner", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "_value", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "Deposit", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "_owner", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "_value", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "Withdrawal", | ||||
|             "type": "event" | ||||
|         } | ||||
|     ], | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0xc00fd9820cd2898cc4c054b7bf142de637ad129a" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0xc778417e063141139fce010982780140aa0cd5ab" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0x653e49e301e508a13237c0ddc98ae7d4cd2667a1" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x871dd7c2b4b25e1aa18728e9d5f2af4c4e431f5c" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,610 +0,0 @@ | ||||
| { | ||||
|     "contract_name": "Exchange", | ||||
|     "abi": [ | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "numerator", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "denominator", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "target", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "isRoundingError", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bool" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "filled", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "cancelled", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "fillTakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "shouldThrowOnInsufficientBalanceOrAllowance", | ||||
|                     "type": "bool" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "v", | ||||
|                     "type": "uint8[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "r", | ||||
|                     "type": "bytes32[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "s", | ||||
|                     "type": "bytes32[]" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "fillOrdersUpTo", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "cancelTakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "cancelOrder", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "ZRX_TOKEN_CONTRACT", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "fillTakerTokenAmounts", | ||||
|                     "type": "uint256[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "v", | ||||
|                     "type": "uint8[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "r", | ||||
|                     "type": "bytes32[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "s", | ||||
|                     "type": "bytes32[]" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "batchFillOrKillOrders", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "fillTakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "v", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "r", | ||||
|                     "type": "bytes32" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "s", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "fillOrKillOrder", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderHash", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getUnavailableTakerTokenAmount", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "signer", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "hash", | ||||
|                     "type": "bytes32" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "v", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "r", | ||||
|                     "type": "bytes32" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "s", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "isValidSignature", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bool" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "numerator", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "denominator", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "target", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getPartialAmount", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "TOKEN_TRANSFER_PROXY_CONTRACT", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "fillTakerTokenAmounts", | ||||
|                     "type": "uint256[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "shouldThrowOnInsufficientBalanceOrAllowance", | ||||
|                     "type": "bool" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "v", | ||||
|                     "type": "uint8[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "r", | ||||
|                     "type": "bytes32[]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "s", | ||||
|                     "type": "bytes32[]" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "batchFillOrders", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6][]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "cancelTakerTokenAmounts", | ||||
|                     "type": "uint256[]" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "batchCancelOrders", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "fillTakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "shouldThrowOnInsufficientBalanceOrAllowance", | ||||
|                     "type": "bool" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "v", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "r", | ||||
|                     "type": "bytes32" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "s", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "fillOrder", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "filledTakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "orderAddresses", | ||||
|                     "type": "address[5]" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "orderValues", | ||||
|                     "type": "uint256[6]" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getOrderHash", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "EXTERNAL_QUERY_GAS_LIMIT", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint16" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "VERSION", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_zrxToken", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_tokenTransferProxy", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "constructor" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "maker", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "taker", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "feeRecipient", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "makerToken", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "takerToken", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "filledMakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "filledTakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "paidMakerFee", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "paidTakerFee", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "tokens", | ||||
|                     "type": "bytes32" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "orderHash", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogFill", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "maker", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "feeRecipient", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "makerToken", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "takerToken", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "cancelledMakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "cancelledTakerTokenAmount", | ||||
|                     "type": "uint256" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "tokens", | ||||
|                     "type": "bytes32" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "orderHash", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogCancel", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "errorId", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "orderHash", | ||||
|                     "type": "bytes32" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogError", | ||||
|             "type": "event" | ||||
|         } | ||||
|     ], | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0x12459c951127e0c374ff9105dda097662a027093" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0x479cc461fecd078f766ecc58533d6f69580cf3ac" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0x1d16ef40fac01cec8adac2ac49427b9384192c05" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0x90fe2af704b34e0224bf2299c838e04d4dcf1364" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x48bacb9266a570d521063ef5dd96e61686dbe788" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,172 +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" | ||||
|         } | ||||
|     ] | ||||
| } | ||||
| @@ -1,547 +0,0 @@ | ||||
| { | ||||
|     "contract_name": "TokenRegistry", | ||||
|     "abi": [ | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_index", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "removeToken", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenAddressByName", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenAddressBySymbol", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenSwarmHash", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenMetaData", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "owner", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "addToken", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenName", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "tokens", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint256" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "tokenAddresses", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_name", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenByName", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [], | ||||
|             "name": "getTokenAddresses", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address[]" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenIpfsHash", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": true, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "getTokenBySymbol", | ||||
|             "outputs": [ | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "_token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "name": "_symbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "setTokenSymbol", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "constant": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "name": "newOwner", | ||||
|                     "type": "address" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "transferOwnership", | ||||
|             "outputs": [], | ||||
|             "payable": false, | ||||
|             "type": "function" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogAddToken", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "name", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "symbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "decimals", | ||||
|                     "type": "uint8" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "ipfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "swarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogRemoveToken", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldName", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newName", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenNameChange", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldSymbol", | ||||
|                     "type": "string" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newSymbol", | ||||
|                     "type": "string" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenSymbolChange", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldIpfsHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newIpfsHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenIpfsHashChange", | ||||
|             "type": "event" | ||||
|         }, | ||||
|         { | ||||
|             "anonymous": false, | ||||
|             "inputs": [ | ||||
|                 { | ||||
|                     "indexed": true, | ||||
|                     "name": "token", | ||||
|                     "type": "address" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "oldSwarmHash", | ||||
|                     "type": "bytes" | ||||
|                 }, | ||||
|                 { | ||||
|                     "indexed": false, | ||||
|                     "name": "newSwarmHash", | ||||
|                     "type": "bytes" | ||||
|                 } | ||||
|             ], | ||||
|             "name": "LogTokenSwarmHashChange", | ||||
|             "type": "event" | ||||
|         } | ||||
|     ], | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0x926a74c5c36adf004c87399e65f75628b0f98d2c" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0x6b1a50f0bb5a7995444bd3877b22dc89c62843ed" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0x4e9aad8184de8833365fea970cd9149372fdf1e6" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0xf18e504561f4347bea557f3d4558f559dddbae7f" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x0b1ba0af832d7c05fd64161e0db78e85978e8082" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,187 +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" | ||||
|         } | ||||
|     ], | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0x8da0d80f5007ef1e431dd2127178d224e32c2ef4" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0x4e9aad8184de8833365fea970cd9149372fdf1e6" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0xa8e9fa8f91e5ae138c74648c9c304f1c75003a8d" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0x087eed4bc1ee3de49befbd66c662b434b15d49d4" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x1dc4c1cefef38a777b15aa20260a54e584b16c48" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,20 +0,0 @@ | ||||
| { | ||||
|     "contract_name": "ZRX", | ||||
|     "networks": { | ||||
|         "1": { | ||||
|             "address": "0xe41d2489571d322189246dafa5ebde1f4699f498" | ||||
|         }, | ||||
|         "3": { | ||||
|             "address": "0xa8e9fa8f91e5ae138c74648c9c304f1c75003a8d" | ||||
|         }, | ||||
|         "4": { | ||||
|             "address": "0x00f58d6d585f84b2d7267940cede30ce2fe6eae8" | ||||
|         }, | ||||
|         "42": { | ||||
|             "address": "0x6ff6c0ff1d68b964901f986d4c9fa3ac68346570" | ||||
|         }, | ||||
|         "50": { | ||||
|             "address": "0x1d7022f5b17d2f8b695918fb48fa1089c9f85401" | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,13 +1,16 @@ | ||||
| import { Provider } from '@0xproject/types'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { Provider } from 'ethereum-types'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { constants } from './utils/constants'; | ||||
|  | ||||
| import { artifacts } from './artifacts'; | ||||
| import { ERC20ProxyWrapper } from './contract_wrappers/erc20_proxy_wrapper'; | ||||
| import { ERC20TokenWrapper } from './contract_wrappers/erc20_token_wrapper'; | ||||
| import { ERC721ProxyWrapper } from './contract_wrappers/erc721_proxy_wrapper'; | ||||
| import { ERC721TokenWrapper } from './contract_wrappers/erc721_token_wrapper'; | ||||
| import { EtherTokenWrapper } from './contract_wrappers/ether_token_wrapper'; | ||||
| import { ExchangeWrapper } from './contract_wrappers/exchange_wrapper'; | ||||
| import { TokenRegistryWrapper } from './contract_wrappers/token_registry_wrapper'; | ||||
| import { TokenTransferProxyWrapper } from './contract_wrappers/token_transfer_proxy_wrapper'; | ||||
| import { TokenWrapper } from './contract_wrappers/token_wrapper'; | ||||
| import { ContractWrappersConfigSchema } from './schemas/contract_wrappers_config_schema'; | ||||
| import { contractWrappersPrivateNetworkConfigSchema } from './schemas/contract_wrappers_private_network_config_schema'; | ||||
| import { contractWrappersPublicNetworkConfigSchema } from './schemas/contract_wrappers_public_network_config_schema'; | ||||
| @@ -22,24 +25,28 @@ export class ContractWrappers { | ||||
|      */ | ||||
|     public exchange: ExchangeWrapper; | ||||
|     /** | ||||
|      * An instance of the TokenRegistryWrapper class containing methods for interacting with the 0x | ||||
|      * TokenRegistry smart contract. | ||||
|      * An instance of the ERC20TokenWrapper class containing methods for interacting with any ERC20 token smart contract. | ||||
|      */ | ||||
|     public tokenRegistry: TokenRegistryWrapper; | ||||
|     public erc20Token: ERC20TokenWrapper; | ||||
|     /** | ||||
|      * An instance of the TokenWrapper class containing methods for interacting with any ERC20 token smart contract. | ||||
|      * An instance of the ERC721TokenWrapper class containing methods for interacting with any ERC721 token smart contract. | ||||
|      */ | ||||
|     public token: TokenWrapper; | ||||
|     public erc721Token: ERC721TokenWrapper; | ||||
|     /** | ||||
|      * An instance of the EtherTokenWrapper class containing methods for interacting with the | ||||
|      * wrapped ETH ERC20 token smart contract. | ||||
|      */ | ||||
|     public etherToken: EtherTokenWrapper; | ||||
|     /** | ||||
|      * An instance of the TokenTransferProxyWrapper class containing methods for interacting with the | ||||
|      * tokenTransferProxy smart contract. | ||||
|      * An instance of the ERC20ProxyWrapper class containing methods for interacting with the | ||||
|      * erc20Proxy smart contract. | ||||
|      */ | ||||
|     public proxy: TokenTransferProxyWrapper; | ||||
|     public erc20Proxy: ERC20ProxyWrapper; | ||||
|     /** | ||||
|      * An instance of the ERC721ProxyWrapper class containing methods for interacting with the | ||||
|      * erc721Proxy smart contract. | ||||
|      */ | ||||
|     public erc721Proxy: ERC721ProxyWrapper; | ||||
|     private _web3Wrapper: Web3Wrapper; | ||||
|     /** | ||||
|      * Instantiates a new ContractWrappers instance. | ||||
| @@ -55,7 +62,7 @@ export class ContractWrappers { | ||||
|             contractWrappersPublicNetworkConfigSchema, | ||||
|         ]); | ||||
|         const artifactJSONs = _.values(artifacts); | ||||
|         const abiArrays = _.map(artifactJSONs, artifact => artifact.abi); | ||||
|         const abiArrays = _.map(artifactJSONs, artifact => artifact.compilerOutput.abi); | ||||
|         const txDefaults = { | ||||
|             gasPrice: config.gasPrice, | ||||
|         }; | ||||
| @@ -63,25 +70,40 @@ export class ContractWrappers { | ||||
|         _.forEach(abiArrays, abi => { | ||||
|             this._web3Wrapper.abiDecoder.addABI(abi); | ||||
|         }); | ||||
|         this.proxy = new TokenTransferProxyWrapper( | ||||
|         const blockPollingIntervalMs = _.isUndefined(config.blockPollingIntervalMs) | ||||
|             ? constants.DEFAULT_BLOCK_POLLING_INTERVAL | ||||
|             : config.blockPollingIntervalMs; | ||||
|         this.erc20Proxy = new ERC20ProxyWrapper(this._web3Wrapper, config.networkId, config.erc20ProxyContractAddress); | ||||
|         this.erc721Proxy = new ERC721ProxyWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             config.tokenTransferProxyContractAddress, | ||||
|             config.erc721ProxyContractAddress, | ||||
|         ); | ||||
|         this.erc20Token = new ERC20TokenWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             this.erc20Proxy, | ||||
|             blockPollingIntervalMs, | ||||
|         ); | ||||
|         this.erc721Token = new ERC721TokenWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             this.erc721Proxy, | ||||
|             blockPollingIntervalMs, | ||||
|         ); | ||||
|         this.etherToken = new EtherTokenWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             this.erc20Token, | ||||
|             blockPollingIntervalMs, | ||||
|         ); | ||||
|         this.token = new TokenWrapper(this._web3Wrapper, config.networkId, this.proxy); | ||||
|         this.exchange = new ExchangeWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             this.token, | ||||
|             config.exchangeContractAddress, | ||||
|             config.zrxContractAddress, | ||||
|             blockPollingIntervalMs, | ||||
|         ); | ||||
|         this.tokenRegistry = new TokenRegistryWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             config.tokenRegistryContractAddress, | ||||
|         ); | ||||
|         this.etherToken = new EtherTokenWrapper(this._web3Wrapper, config.networkId, this.token); | ||||
|     } | ||||
|     /** | ||||
|      * Sets a new web3 provider for 0x.js. Updating the provider will stop all | ||||
| @@ -93,12 +115,10 @@ export class ContractWrappers { | ||||
|         this._web3Wrapper.setProvider(provider); | ||||
|         (this.exchange as any)._invalidateContractInstances(); | ||||
|         (this.exchange as any)._setNetworkId(networkId); | ||||
|         (this.tokenRegistry as any)._invalidateContractInstance(); | ||||
|         (this.tokenRegistry as any)._setNetworkId(networkId); | ||||
|         (this.token as any)._invalidateContractInstances(); | ||||
|         (this.token as any)._setNetworkId(networkId); | ||||
|         (this.proxy as any)._invalidateContractInstance(); | ||||
|         (this.proxy as any)._setNetworkId(networkId); | ||||
|         (this.erc20Token as any)._invalidateContractInstances(); | ||||
|         (this.erc20Token as any)._setNetworkId(networkId); | ||||
|         (this.erc20Proxy as any)._invalidateContractInstance(); | ||||
|         (this.erc20Proxy as any)._setNetworkId(networkId); | ||||
|         (this.etherToken as any)._invalidateContractInstance(); | ||||
|         (this.etherToken as any)._setNetworkId(networkId); | ||||
|     } | ||||
|   | ||||
| @@ -1,15 +1,8 @@ | ||||
| import { | ||||
|     Artifact, | ||||
|     BlockParamLiteral, | ||||
|     ContractAbi, | ||||
|     FilterObject, | ||||
|     LogEntry, | ||||
|     LogWithDecodedArgs, | ||||
|     RawLog, | ||||
| } from '@0xproject/types'; | ||||
| import { AbiDecoder, intervalUtils } from '@0xproject/utils'; | ||||
| import { ContractArtifact } from '@0xproject/sol-compiler'; | ||||
| import { AbiDecoder, intervalUtils, logUtils } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { Block, BlockAndLogStreamer } from 'ethereumjs-blockstream'; | ||||
| import { BlockParamLiteral, ContractAbi, FilterObject, LogEntry, LogWithDecodedArgs, RawLog } from 'ethereum-types'; | ||||
| import { Block, BlockAndLogStreamer, Log } from 'ethereumjs-blockstream'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { | ||||
| @@ -19,7 +12,6 @@ import { | ||||
|     ContractWrappersError, | ||||
|     EventCallback, | ||||
|     IndexedFilterValues, | ||||
|     InternalContractWrappersError, | ||||
| } from '../types'; | ||||
| import { constants } from '../utils/constants'; | ||||
| import { filterUtils } from '../utils/filter_utils'; | ||||
| @@ -29,16 +21,19 @@ const CONTRACT_NAME_TO_NOT_FOUND_ERROR: { | ||||
| } = { | ||||
|     ZRX: ContractWrappersError.ZRXContractDoesNotExist, | ||||
|     EtherToken: ContractWrappersError.EtherTokenContractDoesNotExist, | ||||
|     Token: ContractWrappersError.TokenContractDoesNotExist, | ||||
|     TokenRegistry: ContractWrappersError.TokenRegistryContractDoesNotExist, | ||||
|     TokenTransferProxy: ContractWrappersError.TokenTransferProxyContractDoesNotExist, | ||||
|     ERC20Token: ContractWrappersError.ERC20TokenContractDoesNotExist, | ||||
|     ERC20Proxy: ContractWrappersError.ERC20ProxyContractDoesNotExist, | ||||
|     ERC721Token: ContractWrappersError.ERC721TokenContractDoesNotExist, | ||||
|     ERC721Proxy: ContractWrappersError.ERC721ProxyContractDoesNotExist, | ||||
|     Exchange: ContractWrappersError.ExchangeContractDoesNotExist, | ||||
| }; | ||||
|  | ||||
| export class ContractWrapper { | ||||
| export abstract class ContractWrapper { | ||||
|     public abstract abi: ContractAbi; | ||||
|     protected _web3Wrapper: Web3Wrapper; | ||||
|     protected _networkId: number; | ||||
|     private _blockAndLogStreamerIfExists?: BlockAndLogStreamer; | ||||
|     private _blockAndLogStreamerIfExists: BlockAndLogStreamer<Block, Log> | undefined; | ||||
|     private _blockPollingIntervalMs: number; | ||||
|     private _blockAndLogStreamIntervalIfExists?: NodeJS.Timer; | ||||
|     private _filters: { [filterToken: string]: FilterObject }; | ||||
|     private _filterCallbacks: { | ||||
| @@ -46,9 +41,19 @@ export class ContractWrapper { | ||||
|     }; | ||||
|     private _onLogAddedSubscriptionToken: string | undefined; | ||||
|     private _onLogRemovedSubscriptionToken: string | undefined; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number) { | ||||
|     private static _onBlockAndLogStreamerError(isVerbose: boolean, err: Error): void { | ||||
|         // Since Blockstream errors are all recoverable, we simply log them if the verbose | ||||
|         // config is passed in. | ||||
|         if (isVerbose) { | ||||
|             logUtils.warn(err); | ||||
|         } | ||||
|     } | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, blockPollingIntervalMs?: number) { | ||||
|         this._web3Wrapper = web3Wrapper; | ||||
|         this._networkId = networkId; | ||||
|         this._blockPollingIntervalMs = _.isUndefined(blockPollingIntervalMs) | ||||
|             ? constants.DEFAULT_BLOCK_POLLING_INTERVAL | ||||
|             : blockPollingIntervalMs; | ||||
|         this._filters = {}; | ||||
|         this._filterCallbacks = {}; | ||||
|         this._blockAndLogStreamerIfExists = undefined; | ||||
| @@ -81,10 +86,11 @@ export class ContractWrapper { | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|         abi: ContractAbi, | ||||
|         callback: EventCallback<ArgsType>, | ||||
|         isVerbose: boolean = false, | ||||
|     ): string { | ||||
|         const filter = filterUtils.getFilter(address, eventName, indexFilterValues, abi); | ||||
|         if (_.isUndefined(this._blockAndLogStreamerIfExists)) { | ||||
|             this._startBlockAndLogStream(); | ||||
|             this._startBlockAndLogStream(isVerbose); | ||||
|         } | ||||
|         const filterToken = filterUtils.generateUUID(); | ||||
|         this._filters[filterToken] = filter; | ||||
| @@ -106,14 +112,12 @@ export class ContractWrapper { | ||||
|     protected _tryToDecodeLogOrNoop<ArgsType extends ContractEventArgs>( | ||||
|         log: LogEntry, | ||||
|     ): LogWithDecodedArgs<ArgsType> | RawLog { | ||||
|         if (_.isUndefined(this._web3Wrapper.abiDecoder)) { | ||||
|             throw new Error(InternalContractWrappersError.NoAbiDecoder); | ||||
|         } | ||||
|         const logWithDecodedArgs = this._web3Wrapper.abiDecoder.tryToDecodeLogOrNoop(log); | ||||
|         const abiDecoder = new AbiDecoder([this.abi]); | ||||
|         const logWithDecodedArgs = abiDecoder.tryToDecodeLogOrNoop(log); | ||||
|         return logWithDecodedArgs; | ||||
|     } | ||||
|     protected async _getContractAbiAndAddressFromArtifactsAsync( | ||||
|         artifact: Artifact, | ||||
|         artifact: ContractArtifact, | ||||
|         addressIfExists?: string, | ||||
|     ): Promise<[ContractAbi, string]> { | ||||
|         let contractAddress: string; | ||||
| @@ -127,12 +131,12 @@ export class ContractWrapper { | ||||
|         } | ||||
|         const doesContractExist = await this._web3Wrapper.doesContractExistAtAddressAsync(contractAddress); | ||||
|         if (!doesContractExist) { | ||||
|             throw new Error(CONTRACT_NAME_TO_NOT_FOUND_ERROR[artifact.contract_name]); | ||||
|             throw new Error(CONTRACT_NAME_TO_NOT_FOUND_ERROR[artifact.contractName]); | ||||
|         } | ||||
|         const abiAndAddress: [ContractAbi, string] = [artifact.abi, contractAddress]; | ||||
|         const abiAndAddress: [ContractAbi, string] = [artifact.compilerOutput.abi, contractAddress]; | ||||
|         return abiAndAddress; | ||||
|     } | ||||
|     protected _getContractAddress(artifact: Artifact, addressIfExists?: string): string { | ||||
|     protected _getContractAddress(artifact: ContractArtifact, addressIfExists?: string): string { | ||||
|         if (_.isUndefined(addressIfExists)) { | ||||
|             const contractAddress = artifact.networks[this._networkId].address; | ||||
|             if (_.isUndefined(contractAddress)) { | ||||
| @@ -155,20 +159,21 @@ export class ContractWrapper { | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
|     private _startBlockAndLogStream(): void { | ||||
|     private _startBlockAndLogStream(isVerbose: boolean): void { | ||||
|         if (!_.isUndefined(this._blockAndLogStreamerIfExists)) { | ||||
|             throw new Error(ContractWrappersError.SubscriptionAlreadyPresent); | ||||
|         } | ||||
|         this._blockAndLogStreamerIfExists = new BlockAndLogStreamer( | ||||
|             this._web3Wrapper.getBlockAsync.bind(this._web3Wrapper), | ||||
|             this._web3Wrapper.getLogsAsync.bind(this._web3Wrapper), | ||||
|             ContractWrapper._onBlockAndLogStreamerError.bind(this, isVerbose), | ||||
|         ); | ||||
|         const catchAllLogFilter = {}; | ||||
|         this._blockAndLogStreamerIfExists.addLogFilter(catchAllLogFilter); | ||||
|         this._blockAndLogStreamIntervalIfExists = intervalUtils.setAsyncExcludingInterval( | ||||
|             this._reconcileBlockAsync.bind(this), | ||||
|             constants.DEFAULT_BLOCK_POLLING_INTERVAL, | ||||
|             this._onReconcileBlockError.bind(this), | ||||
|             this._blockPollingIntervalMs, | ||||
|             ContractWrapper._onBlockAndLogStreamerError.bind(this, isVerbose), | ||||
|         ); | ||||
|         let isRemoved = false; | ||||
|         this._onLogAddedSubscriptionToken = this._blockAndLogStreamerIfExists.subscribeToOnLogAdded( | ||||
| @@ -179,12 +184,11 @@ export class ContractWrapper { | ||||
|             this._onLogStateChanged.bind(this, isRemoved), | ||||
|         ); | ||||
|     } | ||||
|     private _onReconcileBlockError(err: Error): void { | ||||
|         const filterTokens = _.keys(this._filterCallbacks); | ||||
|         _.each(filterTokens, filterToken => { | ||||
|             this._unsubscribe(filterToken, err); | ||||
|         }); | ||||
|     } | ||||
|     // HACK: This should be a package-scoped method (which doesn't exist in TS) | ||||
|     // We don't want this method available in the public interface for all classes | ||||
|     // who inherit from ContractWrapper, and it is only used by the internal implementation | ||||
|     // of those higher classes. | ||||
|     // tslint:disable-next-line:no-unused-variable | ||||
|     private _setNetworkId(networkId: number): void { | ||||
|         this._networkId = networkId; | ||||
|     } | ||||
|   | ||||
| @@ -0,0 +1,85 @@ | ||||
| import { AssetProxyId } from '@0xproject/types'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { ContractAbi } from 'ethereum-types'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { assert } from '../utils/assert'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { ERC20ProxyContract } from './generated/erc20_proxy'; | ||||
|  | ||||
| /** | ||||
|  * This class includes the functionality related to interacting with the ERC20Proxy contract. | ||||
|  */ | ||||
| export class ERC20ProxyWrapper extends ContractWrapper { | ||||
|     public abi: ContractAbi = artifacts.ERC20Proxy.compilerOutput.abi; | ||||
|     private _erc20ProxyContractIfExists?: ERC20ProxyContract; | ||||
|     private _contractAddressIfExists?: string; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, contractAddressIfExists?: string) { | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._contractAddressIfExists = contractAddressIfExists; | ||||
|     } | ||||
|     /** | ||||
|      * Get the 4 bytes ID of this asset proxy | ||||
|      * @return  Proxy id | ||||
|      */ | ||||
|     public async getProxyIdAsync(): Promise<AssetProxyId> { | ||||
|         const ERC20ProxyContractInstance = await this._getERC20ProxyContractAsync(); | ||||
|         const proxyId = (await ERC20ProxyContractInstance.getProxyId.callAsync()) as AssetProxyId; | ||||
|         return proxyId; | ||||
|     } | ||||
|     /** | ||||
|      * Check if the Exchange contract address is authorized by the ERC20Proxy contract. | ||||
|      * @param   exchangeContractAddress     The hex encoded address of the Exchange contract to call. | ||||
|      * @return  Whether the exchangeContractAddress is authorized. | ||||
|      */ | ||||
|     public async isAuthorizedAsync(exchangeContractAddress: string): Promise<boolean> { | ||||
|         assert.isETHAddressHex('exchangeContractAddress', exchangeContractAddress); | ||||
|         const normalizedExchangeContractAddress = exchangeContractAddress.toLowerCase(); | ||||
|         const ERC20ProxyContractInstance = await this._getERC20ProxyContractAsync(); | ||||
|         const isAuthorized = await ERC20ProxyContractInstance.authorized.callAsync(normalizedExchangeContractAddress); | ||||
|         return isAuthorized; | ||||
|     } | ||||
|     /** | ||||
|      * Get the list of all Exchange contract addresses authorized by the ERC20Proxy contract. | ||||
|      * @return  The list of authorized addresses. | ||||
|      */ | ||||
|     public async getAuthorizedAddressesAsync(): Promise<string[]> { | ||||
|         const ERC20ProxyContractInstance = await this._getERC20ProxyContractAsync(); | ||||
|         const authorizedAddresses = await ERC20ProxyContractInstance.getAuthorizedAddresses.callAsync(); | ||||
|         return authorizedAddresses; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves the Ethereum address of the ERC20Proxy contract deployed on the network | ||||
|      * that the user-passed web3 provider is connected to. | ||||
|      * @returns The Ethereum address of the ERC20Proxy contract being used. | ||||
|      */ | ||||
|     public getContractAddress(): string { | ||||
|         const contractAddress = this._getContractAddress(artifacts.ERC20Proxy, this._contractAddressIfExists); | ||||
|         return contractAddress; | ||||
|     } | ||||
|     // HACK: We don't want this method to be visible to the other units within that package but not to the end user. | ||||
|     // TS doesn't give that possibility and therefore we make it private and access it over an any cast. Because of that tslint sees it as unused. | ||||
|     // tslint:disable-next-line:no-unused-variable | ||||
|     private _invalidateContractInstance(): void { | ||||
|         delete this._erc20ProxyContractIfExists; | ||||
|     } | ||||
|     private async _getERC20ProxyContractAsync(): Promise<ERC20ProxyContract> { | ||||
|         if (!_.isUndefined(this._erc20ProxyContractIfExists)) { | ||||
|             return this._erc20ProxyContractIfExists; | ||||
|         } | ||||
|         const [abi, address] = await this._getContractAbiAndAddressFromArtifactsAsync( | ||||
|             artifacts.ERC20Proxy, | ||||
|             this._contractAddressIfExists, | ||||
|         ); | ||||
|         const contractInstance = new ERC20ProxyContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         this._erc20ProxyContractIfExists = contractInstance; | ||||
|         return this._erc20ProxyContractIfExists; | ||||
|     } | ||||
| } | ||||
| @@ -1,10 +1,12 @@ | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { AbiDecoder, BigNumber } from '@0xproject/utils'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { ContractAbi, LogWithDecodedArgs } from 'ethereum-types'; | ||||
| import * as _ from 'lodash'; | ||||
| 
 | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { methodOptsSchema } from '../schemas/method_opts_schema'; | ||||
| import { txOptsSchema } from '../schemas/tx_opts_schema'; | ||||
| import { | ||||
|     BlockRange, | ||||
|     ContractWrappersError, | ||||
| @@ -17,22 +19,30 @@ import { assert } from '../utils/assert'; | ||||
| import { constants } from '../utils/constants'; | ||||
| 
 | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { TokenContract, TokenContractEventArgs, TokenEvents } from './generated/token'; | ||||
| import { TokenTransferProxyWrapper } from './token_transfer_proxy_wrapper'; | ||||
| import { ERC20ProxyWrapper } from './erc20_proxy_wrapper'; | ||||
| import { ERC20TokenContract, ERC20TokenEventArgs, ERC20TokenEvents } from './generated/erc20_token'; | ||||
| 
 | ||||
| const removeUndefinedProperties = _.pickBy; | ||||
| 
 | ||||
| /** | ||||
|  * This class includes all the functionality related to interacting with ERC20 token contracts. | ||||
|  * All ERC20 method calls are supported, along with some convenience methods for getting/setting allowances | ||||
|  * to the 0x Proxy smart contract. | ||||
|  * to the 0x ERC20 Proxy smart contract. | ||||
|  */ | ||||
| export class TokenWrapper extends ContractWrapper { | ||||
| export class ERC20TokenWrapper extends ContractWrapper { | ||||
|     public abi: ContractAbi = artifacts.ERC20Token.compilerOutput.abi; | ||||
|     public UNLIMITED_ALLOWANCE_IN_BASE_UNITS = constants.UNLIMITED_ALLOWANCE_IN_BASE_UNITS; | ||||
|     private _tokenContractsByAddress: { [address: string]: TokenContract }; | ||||
|     private _tokenTransferProxyWrapper: TokenTransferProxyWrapper; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, tokenTransferProxyWrapper: TokenTransferProxyWrapper) { | ||||
|         super(web3Wrapper, networkId); | ||||
|     private _tokenContractsByAddress: { [address: string]: ERC20TokenContract }; | ||||
|     private _erc20ProxyWrapper: ERC20ProxyWrapper; | ||||
|     constructor( | ||||
|         web3Wrapper: Web3Wrapper, | ||||
|         networkId: number, | ||||
|         erc20ProxyWrapper: ERC20ProxyWrapper, | ||||
|         blockPollingIntervalMs?: number, | ||||
|     ) { | ||||
|         super(web3Wrapper, networkId, blockPollingIntervalMs); | ||||
|         this._tokenContractsByAddress = {}; | ||||
|         this._tokenTransferProxyWrapper = tokenTransferProxyWrapper; | ||||
|         this._erc20ProxyWrapper = erc20ProxyWrapper; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves an owner's ERC20 token balance. | ||||
| @@ -44,17 +54,18 @@ export class TokenWrapper extends ContractWrapper { | ||||
|     public async getBalanceAsync( | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         methodOpts?: MethodOpts, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<BigNumber> { | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.doesConformToSchema('methodOpts', methodOpts, methodOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
| 
 | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|         const defaultBlock = _.isUndefined(methodOpts) ? undefined : methodOpts.defaultBlock; | ||||
| 
 | ||||
|         const txData = {}; | ||||
|         let balance = await tokenContract.balanceOf.callAsync(normalizedOwnerAddress, txData, defaultBlock); | ||||
|         let balance = await tokenContract.balanceOf.callAsync(normalizedOwnerAddress, txData, methodOpts.defaultBlock); | ||||
|         // Wrap BigNumbers returned from web3 with our own (later) version of BigNumber
 | ||||
|         balance = new BigNumber(balance); | ||||
|         return balance; | ||||
| @@ -77,20 +88,25 @@ export class TokenWrapper extends ContractWrapper { | ||||
|         amountInBaseUnits: BigNumber, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('spenderAddress', spenderAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         await assert.isSenderAddressAsync('ownerAddress', ownerAddress, this._web3Wrapper); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedSpenderAddress = spenderAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         assert.isETHAddressHex('spenderAddress', spenderAddress); | ||||
|         assert.isValidBaseUnitAmount('amountInBaseUnits', amountInBaseUnits); | ||||
|         assert.doesConformToSchema('txOpts', txOpts, txOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         const normalizedSpenderAddress = spenderAddress.toLowerCase(); | ||||
| 
 | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|         const txHash = await tokenContract.approve.sendTransactionAsync(normalizedSpenderAddress, amountInBaseUnits, { | ||||
|             from: normalizedOwnerAddress, | ||||
|             gas: txOpts.gasLimit, | ||||
|             gasPrice: txOpts.gasPrice, | ||||
|         }); | ||||
|         const txHash = await tokenContract.approve.sendTransactionAsync( | ||||
|             normalizedSpenderAddress, | ||||
|             amountInBaseUnits, | ||||
|             removeUndefinedProperties({ | ||||
|                 from: normalizedOwnerAddress, | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
| @@ -111,16 +127,10 @@ export class TokenWrapper extends ContractWrapper { | ||||
|         spenderAddress: string, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('spenderAddress', spenderAddress); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         const normalizedSpenderAddress = spenderAddress.toLowerCase(); | ||||
|         const txHash = await this.setAllowanceAsync( | ||||
|             normalizedTokenAddress, | ||||
|             normalizedOwnerAddress, | ||||
|             normalizedSpenderAddress, | ||||
|             tokenAddress, | ||||
|             ownerAddress, | ||||
|             spenderAddress, | ||||
|             this.UNLIMITED_ALLOWANCE_IN_BASE_UNITS, | ||||
|             txOpts, | ||||
|         ); | ||||
| @@ -138,23 +148,24 @@ export class TokenWrapper extends ContractWrapper { | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         spenderAddress: string, | ||||
|         methodOpts?: MethodOpts, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<BigNumber> { | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('spenderAddress', spenderAddress); | ||||
|         assert.doesConformToSchema('methodOpts', methodOpts, methodOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         const normalizedSpenderAddress = spenderAddress.toLowerCase(); | ||||
| 
 | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|         const defaultBlock = _.isUndefined(methodOpts) ? undefined : methodOpts.defaultBlock; | ||||
| 
 | ||||
|         const txData = {}; | ||||
|         let allowanceInBaseUnits = await tokenContract.allowance.callAsync( | ||||
|             normalizedOwnerAddress, | ||||
|             normalizedSpenderAddress, | ||||
|             txData, | ||||
|             defaultBlock, | ||||
|             methodOpts.defaultBlock, | ||||
|         ); | ||||
|         // Wrap BigNumbers returned from web3 with our own (later) version of BigNumber
 | ||||
|         allowanceInBaseUnits = new BigNumber(allowanceInBaseUnits); | ||||
| @@ -169,20 +180,10 @@ export class TokenWrapper extends ContractWrapper { | ||||
|     public async getProxyAllowanceAsync( | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         methodOpts?: MethodOpts, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<BigNumber> { | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
| 
 | ||||
|         const proxyAddress = this._tokenTransferProxyWrapper.getContractAddress(); | ||||
|         const allowanceInBaseUnits = await this.getAllowanceAsync( | ||||
|             normalizedTokenAddress, | ||||
|             normalizedOwnerAddress, | ||||
|             proxyAddress, | ||||
|             methodOpts, | ||||
|         ); | ||||
|         const proxyAddress = this._erc20ProxyWrapper.getContractAddress(); | ||||
|         const allowanceInBaseUnits = await this.getAllowanceAsync(tokenAddress, ownerAddress, proxyAddress, methodOpts); | ||||
|         return allowanceInBaseUnits; | ||||
|     } | ||||
|     /** | ||||
| @@ -201,16 +202,10 @@ export class TokenWrapper extends ContractWrapper { | ||||
|         amountInBaseUnits: BigNumber, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         assert.isValidBaseUnitAmount('amountInBaseUnits', amountInBaseUnits); | ||||
| 
 | ||||
|         const proxyAddress = this._tokenTransferProxyWrapper.getContractAddress(); | ||||
|         const proxyAddress = this._erc20ProxyWrapper.getContractAddress(); | ||||
|         const txHash = await this.setAllowanceAsync( | ||||
|             normalizedTokenAddress, | ||||
|             normalizedOwnerAddress, | ||||
|             tokenAddress, | ||||
|             ownerAddress, | ||||
|             proxyAddress, | ||||
|             amountInBaseUnits, | ||||
|             txOpts, | ||||
| @@ -233,13 +228,9 @@ export class TokenWrapper extends ContractWrapper { | ||||
|         ownerAddress: string, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         const txHash = await this.setProxyAllowanceAsync( | ||||
|             normalizedTokenAddress, | ||||
|             normalizedOwnerAddress, | ||||
|             tokenAddress, | ||||
|             ownerAddress, | ||||
|             this.UNLIMITED_ALLOWANCE_IN_BASE_UNITS, | ||||
|             txOpts, | ||||
|         ); | ||||
| @@ -262,12 +253,13 @@ export class TokenWrapper extends ContractWrapper { | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('toAddress', toAddress); | ||||
|         await assert.isSenderAddressAsync('fromAddress', fromAddress, this._web3Wrapper); | ||||
|         assert.isETHAddressHex('toAddress', toAddress); | ||||
|         assert.isValidBaseUnitAmount('amountInBaseUnits', amountInBaseUnits); | ||||
|         assert.doesConformToSchema('txOpts', txOpts, txOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedFromAddress = fromAddress.toLowerCase(); | ||||
|         const normalizedToAddress = toAddress.toLowerCase(); | ||||
|         assert.isValidBaseUnitAmount('amountInBaseUnits', amountInBaseUnits); | ||||
| 
 | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
| 
 | ||||
| @@ -276,11 +268,15 @@ export class TokenWrapper extends ContractWrapper { | ||||
|             throw new Error(ContractWrappersError.InsufficientBalanceForTransfer); | ||||
|         } | ||||
| 
 | ||||
|         const txHash = await tokenContract.transfer.sendTransactionAsync(normalizedToAddress, amountInBaseUnits, { | ||||
|             from: normalizedFromAddress, | ||||
|             gas: txOpts.gasLimit, | ||||
|             gasPrice: txOpts.gasPrice, | ||||
|         }); | ||||
|         const txHash = await tokenContract.transfer.sendTransactionAsync( | ||||
|             normalizedToAddress, | ||||
|             amountInBaseUnits, | ||||
|             removeUndefinedProperties({ | ||||
|                 from: normalizedFromAddress, | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
| @@ -305,15 +301,16 @@ export class TokenWrapper extends ContractWrapper { | ||||
|         amountInBaseUnits: BigNumber, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('toAddress', toAddress); | ||||
|         assert.isETHAddressHex('fromAddress', fromAddress); | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('fromAddress', fromAddress); | ||||
|         assert.isETHAddressHex('toAddress', toAddress); | ||||
|         await assert.isSenderAddressAsync('senderAddress', senderAddress, this._web3Wrapper); | ||||
|         assert.isValidBaseUnitAmount('amountInBaseUnits', amountInBaseUnits); | ||||
|         assert.doesConformToSchema('txOpts', txOpts, txOptsSchema); | ||||
|         const normalizedToAddress = toAddress.toLowerCase(); | ||||
|         const normalizedFromAddress = fromAddress.toLowerCase(); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedSenderAddress = senderAddress.toLowerCase(); | ||||
|         assert.isValidBaseUnitAmount('amountInBaseUnits', amountInBaseUnits); | ||||
| 
 | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
| 
 | ||||
| @@ -335,11 +332,11 @@ export class TokenWrapper extends ContractWrapper { | ||||
|             normalizedFromAddress, | ||||
|             normalizedToAddress, | ||||
|             amountInBaseUnits, | ||||
|             { | ||||
|             removeUndefinedProperties({ | ||||
|                 from: normalizedSenderAddress, | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|             }, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
| @@ -350,25 +347,28 @@ export class TokenWrapper extends ContractWrapper { | ||||
|      * @param   indexFilterValues   An object where the keys are indexed args returned by the event and | ||||
|      *                              the value is the value you are interested in. E.g `{maker: aUserAddressHex}` | ||||
|      * @param   callback            Callback that gets called when a log is added/removed | ||||
|      * @param   isVerbose           Enable verbose subscription warnings (e.g recoverable network issues encountered) | ||||
|      * @return Subscription token used later to unsubscribe | ||||
|      */ | ||||
|     public subscribe<ArgsType extends TokenContractEventArgs>( | ||||
|     public subscribe<ArgsType extends ERC20TokenEventArgs>( | ||||
|         tokenAddress: string, | ||||
|         eventName: TokenEvents, | ||||
|         eventName: ERC20TokenEvents, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|         callback: EventCallback<ArgsType>, | ||||
|         isVerbose: boolean = false, | ||||
|     ): string { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, TokenEvents); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, ERC20TokenEvents); | ||||
|         assert.doesConformToSchema('indexFilterValues', indexFilterValues, schemas.indexFilterValuesSchema); | ||||
|         assert.isFunction('callback', callback); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const subscriptionToken = this._subscribe<ArgsType>( | ||||
|             normalizedTokenAddress, | ||||
|             eventName, | ||||
|             indexFilterValues, | ||||
|             artifacts.Token.abi, | ||||
|             artifacts.ERC20Token.compilerOutput.abi, | ||||
|             callback, | ||||
|             isVerbose, | ||||
|         ); | ||||
|         return subscriptionToken; | ||||
|     } | ||||
| @@ -377,6 +377,7 @@ export class TokenWrapper extends ContractWrapper { | ||||
|      * @param   subscriptionToken Subscription token returned by `subscribe()` | ||||
|      */ | ||||
|     public unsubscribe(subscriptionToken: string): void { | ||||
|         assert.isValidSubscriptionToken('subscriptionToken', subscriptionToken); | ||||
|         this._unsubscribe(subscriptionToken); | ||||
|     } | ||||
|     /** | ||||
| @@ -394,41 +395,44 @@ export class TokenWrapper extends ContractWrapper { | ||||
|      *                              the value is the value you are interested in. E.g `{_from: aUserAddressHex}` | ||||
|      * @return  Array of logs that match the parameters | ||||
|      */ | ||||
|     public async getLogsAsync<ArgsType extends TokenContractEventArgs>( | ||||
|     public async getLogsAsync<ArgsType extends ERC20TokenEventArgs>( | ||||
|         tokenAddress: string, | ||||
|         eventName: TokenEvents, | ||||
|         eventName: ERC20TokenEvents, | ||||
|         blockRange: BlockRange, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|     ): Promise<Array<LogWithDecodedArgs<ArgsType>>> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, TokenEvents); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, ERC20TokenEvents); | ||||
|         assert.doesConformToSchema('blockRange', blockRange, schemas.blockRangeSchema); | ||||
|         assert.doesConformToSchema('indexFilterValues', indexFilterValues, schemas.indexFilterValuesSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const logs = await this._getLogsAsync<ArgsType>( | ||||
|             normalizedTokenAddress, | ||||
|             eventName, | ||||
|             blockRange, | ||||
|             indexFilterValues, | ||||
|             artifacts.Token.abi, | ||||
|             artifacts.ERC20Token.compilerOutput.abi, | ||||
|         ); | ||||
|         return logs; | ||||
|     } | ||||
|     // HACK: We don't want this method to be visible to the other units within that package but not to the end user.
 | ||||
|     // TS doesn't give that possibility and therefore we make it private and access it over an any cast. Because of that tslint sees it as unused.
 | ||||
|     // tslint:disable-next-line:no-unused-variable
 | ||||
|     private _invalidateContractInstances(): void { | ||||
|         this.unsubscribeAll(); | ||||
|         this._tokenContractsByAddress = {}; | ||||
|     } | ||||
|     private async _getTokenContractAsync(tokenAddress: string): Promise<TokenContract> { | ||||
|     private async _getTokenContractAsync(tokenAddress: string): Promise<ERC20TokenContract> { | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         let tokenContract = this._tokenContractsByAddress[normalizedTokenAddress]; | ||||
|         if (!_.isUndefined(tokenContract)) { | ||||
|             return tokenContract; | ||||
|         } | ||||
|         const [abi, address] = await this._getContractAbiAndAddressFromArtifactsAsync( | ||||
|             artifacts.Token, | ||||
|             artifacts.ERC20Token, | ||||
|             normalizedTokenAddress, | ||||
|         ); | ||||
|         const contractInstance = new TokenContract( | ||||
|         const contractInstance = new ERC20TokenContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
| @@ -0,0 +1,85 @@ | ||||
| import { AssetProxyId } from '@0xproject/types'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { ContractAbi } from 'ethereum-types'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { assert } from '../utils/assert'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { ERC721ProxyContract } from './generated/erc721_proxy'; | ||||
|  | ||||
| /** | ||||
|  * This class includes the functionality related to interacting with the ERC721Proxy contract. | ||||
|  */ | ||||
| export class ERC721ProxyWrapper extends ContractWrapper { | ||||
|     public abi: ContractAbi = artifacts.ERC20Proxy.compilerOutput.abi; | ||||
|     private _erc721ProxyContractIfExists?: ERC721ProxyContract; | ||||
|     private _contractAddressIfExists?: string; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, contractAddressIfExists?: string) { | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._contractAddressIfExists = contractAddressIfExists; | ||||
|     } | ||||
|     /** | ||||
|      * Get the 4 bytes ID of this asset proxy | ||||
|      * @return  Proxy id | ||||
|      */ | ||||
|     public async getProxyIdAsync(): Promise<AssetProxyId> { | ||||
|         const ERC721ProxyContractInstance = await this._getERC721ProxyContractAsync(); | ||||
|         const proxyId = (await ERC721ProxyContractInstance.getProxyId.callAsync()) as AssetProxyId; | ||||
|         return proxyId; | ||||
|     } | ||||
|     /** | ||||
|      * Check if the Exchange contract address is authorized by the ERC721Proxy contract. | ||||
|      * @param   exchangeContractAddress     The hex encoded address of the Exchange contract to call. | ||||
|      * @return  Whether the exchangeContractAddress is authorized. | ||||
|      */ | ||||
|     public async isAuthorizedAsync(exchangeContractAddress: string): Promise<boolean> { | ||||
|         assert.isETHAddressHex('exchangeContractAddress', exchangeContractAddress); | ||||
|         const normalizedExchangeContractAddress = exchangeContractAddress.toLowerCase(); | ||||
|         const ERC721ProxyContractInstance = await this._getERC721ProxyContractAsync(); | ||||
|         const isAuthorized = await ERC721ProxyContractInstance.authorized.callAsync(normalizedExchangeContractAddress); | ||||
|         return isAuthorized; | ||||
|     } | ||||
|     /** | ||||
|      * Get the list of all Exchange contract addresses authorized by the ERC721Proxy contract. | ||||
|      * @return  The list of authorized addresses. | ||||
|      */ | ||||
|     public async getAuthorizedAddressesAsync(): Promise<string[]> { | ||||
|         const ERC721ProxyContractInstance = await this._getERC721ProxyContractAsync(); | ||||
|         const authorizedAddresses = await ERC721ProxyContractInstance.getAuthorizedAddresses.callAsync(); | ||||
|         return authorizedAddresses; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves the Ethereum address of the ERC721Proxy contract deployed on the network | ||||
|      * that the user-passed web3 provider is connected to. | ||||
|      * @returns The Ethereum address of the ERC721Proxy contract being used. | ||||
|      */ | ||||
|     public getContractAddress(): string { | ||||
|         const contractAddress = this._getContractAddress(artifacts.ERC721Proxy, this._contractAddressIfExists); | ||||
|         return contractAddress; | ||||
|     } | ||||
|     // HACK: We don't want this method to be visible to the other units within that package but not to the end user. | ||||
|     // TS doesn't give that possibility and therefore we make it private and access it over an any cast. Because of that tslint sees it as unused. | ||||
|     // tslint:disable-next-line:no-unused-variable | ||||
|     private _invalidateContractInstance(): void { | ||||
|         delete this._erc721ProxyContractIfExists; | ||||
|     } | ||||
|     private async _getERC721ProxyContractAsync(): Promise<ERC721ProxyContract> { | ||||
|         if (!_.isUndefined(this._erc721ProxyContractIfExists)) { | ||||
|             return this._erc721ProxyContractIfExists; | ||||
|         } | ||||
|         const [abi, address] = await this._getContractAbiAndAddressFromArtifactsAsync( | ||||
|             artifacts.ERC721Proxy, | ||||
|             this._contractAddressIfExists, | ||||
|         ); | ||||
|         const contractInstance = new ERC721ProxyContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         this._erc721ProxyContractIfExists = contractInstance; | ||||
|         return this._erc721ProxyContractIfExists; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,472 @@ | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { ContractAbi, LogWithDecodedArgs } from 'ethereum-types'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { methodOptsSchema } from '../schemas/method_opts_schema'; | ||||
| import { txOptsSchema } from '../schemas/tx_opts_schema'; | ||||
| import { | ||||
|     BlockRange, | ||||
|     ContractWrappersError, | ||||
|     EventCallback, | ||||
|     IndexedFilterValues, | ||||
|     MethodOpts, | ||||
|     TransactionOpts, | ||||
| } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
| import { constants } from '../utils/constants'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { ERC721ProxyWrapper } from './erc721_proxy_wrapper'; | ||||
| import { ERC721TokenContract, ERC721TokenEventArgs, ERC721TokenEvents } from './generated/erc721_token'; | ||||
|  | ||||
| const removeUndefinedProperties = _.pickBy; | ||||
|  | ||||
| /** | ||||
|  * This class includes all the functionality related to interacting with ERC721 token contracts. | ||||
|  * All ERC721 method calls are supported, along with some convenience methods for getting/setting allowances | ||||
|  * to the 0x ERC721 Proxy smart contract. | ||||
|  */ | ||||
| export class ERC721TokenWrapper extends ContractWrapper { | ||||
|     public abi: ContractAbi = artifacts.ERC721Token.compilerOutput.abi; | ||||
|     private _tokenContractsByAddress: { [address: string]: ERC721TokenContract }; | ||||
|     private _erc721ProxyWrapper: ERC721ProxyWrapper; | ||||
|     constructor( | ||||
|         web3Wrapper: Web3Wrapper, | ||||
|         networkId: number, | ||||
|         erc721ProxyWrapper: ERC721ProxyWrapper, | ||||
|         blockPollingIntervalMs?: number, | ||||
|     ) { | ||||
|         super(web3Wrapper, networkId, blockPollingIntervalMs); | ||||
|         this._tokenContractsByAddress = {}; | ||||
|         this._erc721ProxyWrapper = erc721ProxyWrapper; | ||||
|     } | ||||
|     /** | ||||
|      * Count all NFTs assigned to an owner | ||||
|      * NFTs assigned to the zero address are considered invalid, and this function throws for queries about the zero address. | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   ownerAddress    The hex encoded user Ethereum address whose balance you would like to check. | ||||
|      * @param   methodOpts      Optional arguments this method accepts. | ||||
|      * @return  The number of NFTs owned by `ownerAddress`, possibly zero | ||||
|      */ | ||||
|     public async getTokenCountAsync( | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<BigNumber> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.doesConformToSchema('methodOpts', methodOpts, methodOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|  | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|  | ||||
|         const txData = {}; | ||||
|         let balance = await tokenContract.balanceOf.callAsync(normalizedOwnerAddress, txData, methodOpts.defaultBlock); | ||||
|         // Wrap BigNumbers returned from web3 with our own (later) version of BigNumber | ||||
|         balance = new BigNumber(balance); | ||||
|         return balance; | ||||
|     } | ||||
|     /** | ||||
|      * Find the owner of an NFT | ||||
|      * NFTs assigned to zero address are considered invalid, and queries about them do throw. | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   tokenId         The identifier for an NFT | ||||
|      * @param   methodOpts      Optional arguments this method accepts. | ||||
|      * @return  The address of the owner of the NFT | ||||
|      */ | ||||
|     public async getOwnerOfAsync( | ||||
|         tokenAddress: string, | ||||
|         tokenId: BigNumber, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isBigNumber('tokenId', tokenId); | ||||
|         assert.doesConformToSchema('methodOpts', methodOpts, methodOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|  | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|  | ||||
|         const txData = {}; | ||||
|         try { | ||||
|             const tokenOwner = await tokenContract.ownerOf.callAsync(tokenId, txData, methodOpts.defaultBlock); | ||||
|             return tokenOwner; | ||||
|         } catch (err) { | ||||
|             throw new Error(ContractWrappersError.ERC721OwnerNotFound); | ||||
|         } | ||||
|     } | ||||
|     /** | ||||
|      * Query if an address is an authorized operator for all NFT's of `ownerAddress` | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   ownerAddress    The hex encoded user Ethereum address of the token owner. | ||||
|      * @param   operatorAddress The hex encoded user Ethereum address of the operator you'd like to check if approved. | ||||
|      * @param   methodOpts      Optional arguments this method accepts. | ||||
|      * @return  True if `operatorAddress` is an approved operator for `ownerAddress`, false otherwise | ||||
|      */ | ||||
|     public async isApprovedForAllAsync( | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         operatorAddress: string, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<boolean> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('ownerAddress', ownerAddress); | ||||
|         assert.isETHAddressHex('operatorAddress', operatorAddress); | ||||
|         assert.doesConformToSchema('methodOpts', methodOpts, methodOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         const normalizedOperatorAddress = operatorAddress.toLowerCase(); | ||||
|  | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|  | ||||
|         const txData = {}; | ||||
|         const isApprovedForAll = await tokenContract.isApprovedForAll.callAsync( | ||||
|             normalizedOwnerAddress, | ||||
|             normalizedOperatorAddress, | ||||
|             txData, | ||||
|             methodOpts.defaultBlock, | ||||
|         ); | ||||
|         return isApprovedForAll; | ||||
|     } | ||||
|     /** | ||||
|      * Query if 0x proxy is an authorized operator for all NFT's of `ownerAddress` | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   ownerAddress    The hex encoded user Ethereum address of the token owner. | ||||
|      * @param   methodOpts      Optional arguments this method accepts. | ||||
|      * @return  True if `operatorAddress` is an approved operator for `ownerAddress`, false otherwise | ||||
|      */ | ||||
|     public async isProxyApprovedForAllAsync( | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<boolean> { | ||||
|         const proxyAddress = this._erc721ProxyWrapper.getContractAddress(); | ||||
|         const isProxyApprovedForAll = await this.isApprovedForAllAsync( | ||||
|             tokenAddress, | ||||
|             ownerAddress, | ||||
|             proxyAddress, | ||||
|             methodOpts, | ||||
|         ); | ||||
|         return isProxyApprovedForAll; | ||||
|     } | ||||
|     /** | ||||
|      * Get the approved address for a single NFT. Returns undefined if no approval was set | ||||
|      * Throws if `_tokenId` is not a valid NFT | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   tokenId         The identifier for an NFT | ||||
|      * @param   methodOpts      Optional arguments this method accepts. | ||||
|      * @return  The approved address for this NFT, or the undefined if there is none | ||||
|      */ | ||||
|     public async getApprovedIfExistsAsync( | ||||
|         tokenAddress: string, | ||||
|         tokenId: BigNumber, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<string | undefined> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isBigNumber('tokenId', tokenId); | ||||
|         assert.doesConformToSchema('methodOpts', methodOpts, methodOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|  | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|  | ||||
|         const txData = {}; | ||||
|         const approvedAddress = await tokenContract.getApproved.callAsync(tokenId, txData, methodOpts.defaultBlock); | ||||
|         if (approvedAddress === constants.NULL_ADDRESS) { | ||||
|             return undefined; | ||||
|         } | ||||
|         return approvedAddress; | ||||
|     } | ||||
|     /** | ||||
|      * Checks if 0x proxy is approved for a single NFT | ||||
|      * Throws if `_tokenId` is not a valid NFT | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   tokenId         The identifier for an NFT | ||||
|      * @param   methodOpts      Optional arguments this method accepts. | ||||
|      * @return  True if 0x proxy is approved | ||||
|      */ | ||||
|     public async isProxyApprovedAsync( | ||||
|         tokenAddress: string, | ||||
|         tokenId: BigNumber, | ||||
|         methodOpts: MethodOpts = {}, | ||||
|     ): Promise<boolean> { | ||||
|         const proxyAddress = this._erc721ProxyWrapper.getContractAddress(); | ||||
|         const approvedAddress = await this.getApprovedIfExistsAsync(tokenAddress, tokenId, methodOpts); | ||||
|         const isProxyApproved = approvedAddress === proxyAddress; | ||||
|         return isProxyApproved; | ||||
|     } | ||||
|     /** | ||||
|      * Enable or disable approval for a third party ("operator") to manage all of `ownerAddress`'s assets. | ||||
|      * Throws if `_tokenId` is not a valid NFT | ||||
|      * Emits the ApprovalForAll event. | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   ownerAddress    The hex encoded user Ethereum address of the token owner. | ||||
|      * @param   operatorAddress The hex encoded user Ethereum address of the operator you'd like to set approval for. | ||||
|      * @param   isApproved      The boolean variable to set the approval to. | ||||
|      * @param   txOpts          Transaction parameters. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
|     public async setApprovalForAllAsync( | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         operatorAddress: string, | ||||
|         isApproved: boolean, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         await assert.isSenderAddressAsync('ownerAddress', ownerAddress, this._web3Wrapper); | ||||
|         assert.isETHAddressHex('operatorAddress', operatorAddress); | ||||
|         assert.isBoolean('isApproved', isApproved); | ||||
|         assert.doesConformToSchema('txOpts', txOpts, txOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedOwnerAddress = ownerAddress.toLowerCase(); | ||||
|         const normalizedOperatorAddress = operatorAddress.toLowerCase(); | ||||
|  | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|         const txHash = await tokenContract.setApprovalForAll.sendTransactionAsync( | ||||
|             normalizedOperatorAddress, | ||||
|             isApproved, | ||||
|             removeUndefinedProperties({ | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|                 from: normalizedOwnerAddress, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
|      * Enable or disable approval for a third party ("operator") to manage all of `ownerAddress`'s assets. | ||||
|      * Throws if `_tokenId` is not a valid NFT | ||||
|      * Emits the ApprovalForAll event. | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   ownerAddress    The hex encoded user Ethereum address of the token owner. | ||||
|      * @param   operatorAddress The hex encoded user Ethereum address of the operator you'd like to set approval for. | ||||
|      * @param   isApproved      The boolean variable to set the approval to. | ||||
|      * @param   txOpts          Transaction parameters. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
|     public async setProxyApprovalForAllAsync( | ||||
|         tokenAddress: string, | ||||
|         ownerAddress: string, | ||||
|         isApproved: boolean, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         const proxyAddress = this._erc721ProxyWrapper.getContractAddress(); | ||||
|         const txHash = await this.setApprovalForAllAsync(tokenAddress, ownerAddress, proxyAddress, isApproved, txOpts); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
|      * Set or reaffirm the approved address for an NFT | ||||
|      * The zero address indicates there is no approved address. Throws unless `msg.sender` is the current NFT owner, | ||||
|      * or an authorized operator of the current owner. | ||||
|      * Throws if `_tokenId` is not a valid NFT | ||||
|      * Emits the Approval event. | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   approvedAddress The hex encoded user Ethereum address you'd like to set approval for. | ||||
|      * @param   tokenId         The identifier for an NFT | ||||
|      * @param   txOpts          Transaction parameters. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
|     public async setApprovalAsync( | ||||
|         tokenAddress: string, | ||||
|         approvedAddress: string, | ||||
|         tokenId: BigNumber, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('approvedAddress', approvedAddress); | ||||
|         assert.isBigNumber('tokenId', tokenId); | ||||
|         assert.doesConformToSchema('txOpts', txOpts, txOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedApprovedAddress = approvedAddress.toLowerCase(); | ||||
|  | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|         const tokenOwnerAddress = await tokenContract.ownerOf.callAsync(tokenId); | ||||
|         await assert.isSenderAddressAsync('tokenOwnerAddress', tokenOwnerAddress, this._web3Wrapper); | ||||
|         const txHash = await tokenContract.approve.sendTransactionAsync( | ||||
|             normalizedApprovedAddress, | ||||
|             tokenId, | ||||
|             removeUndefinedProperties({ | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|                 from: tokenOwnerAddress, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
|      * Set or reaffirm 0x proxy as an approved address for an NFT | ||||
|      * Throws unless `msg.sender` is the current NFT owner, or an authorized operator of the current owner. | ||||
|      * Throws if `_tokenId` is not a valid NFT | ||||
|      * Emits the Approval event. | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   tokenId         The identifier for an NFT | ||||
|      * @param   txOpts          Transaction parameters. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
|     public async setProxyApprovalAsync( | ||||
|         tokenAddress: string, | ||||
|         tokenId: BigNumber, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         const proxyAddress = this._erc721ProxyWrapper.getContractAddress(); | ||||
|         const txHash = await this.setApprovalAsync(tokenAddress, proxyAddress, tokenId, txOpts); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
|      * Enable or disable approval for a third party ("operator") to manage all of `ownerAddress`'s assets. | ||||
|      * Throws if `_tokenId` is not a valid NFT | ||||
|      * Emits the ApprovalForAll event. | ||||
|      * @param   tokenAddress    The hex encoded contract Ethereum address where the ERC721 token is deployed. | ||||
|      * @param   receiverAddress The hex encoded Ethereum address of the user to send the NFT to. | ||||
|      * @param   senderAddress The hex encoded Ethereum address of the user to send the NFT to. | ||||
|      * @param   tokenId         The identifier for an NFT | ||||
|      * @param   txOpts          Transaction parameters. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
|     public async transferFromAsync( | ||||
|         tokenAddress: string, | ||||
|         receiverAddress: string, | ||||
|         senderAddress: string, | ||||
|         tokenId: BigNumber, | ||||
|         txOpts: TransactionOpts = {}, | ||||
|     ): Promise<string> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.isETHAddressHex('receiverAddress', receiverAddress); | ||||
|         await assert.isSenderAddressAsync('senderAddress', senderAddress, this._web3Wrapper); | ||||
|         assert.doesConformToSchema('txOpts', txOpts, txOptsSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const normalizedReceiverAddress = receiverAddress.toLowerCase(); | ||||
|         const normalizedSenderAddress = senderAddress.toLowerCase(); | ||||
|         const tokenContract = await this._getTokenContractAsync(normalizedTokenAddress); | ||||
|         const ownerAddress = await this.getOwnerOfAsync(tokenAddress, tokenId); | ||||
|         if (normalizedSenderAddress !== ownerAddress) { | ||||
|             const isApprovedForAll = await this.isApprovedForAllAsync( | ||||
|                 normalizedTokenAddress, | ||||
|                 ownerAddress, | ||||
|                 normalizedSenderAddress, | ||||
|             ); | ||||
|             if (!isApprovedForAll) { | ||||
|                 const approvedAddress = await this.getApprovedIfExistsAsync(normalizedTokenAddress, tokenId); | ||||
|                 if (approvedAddress !== normalizedSenderAddress) { | ||||
|                     throw new Error(ContractWrappersError.ERC721NoApproval); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         const txHash = await tokenContract.transferFrom.sendTransactionAsync( | ||||
|             ownerAddress, | ||||
|             normalizedReceiverAddress, | ||||
|             tokenId, | ||||
|             removeUndefinedProperties({ | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|                 from: normalizedSenderAddress, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
|      * Subscribe to an event type emitted by the Token contract. | ||||
|      * @param   tokenAddress        The hex encoded address where the ERC721 token is deployed. | ||||
|      * @param   eventName           The token contract event you would like to subscribe to. | ||||
|      * @param   indexFilterValues   An object where the keys are indexed args returned by the event and | ||||
|      *                              the value is the value you are interested in. E.g `{maker: aUserAddressHex}` | ||||
|      * @param   callback            Callback that gets called when a log is added/removed | ||||
|      * @param   isVerbose           Enable verbose subscription warnings (e.g recoverable network issues encountered) | ||||
|      * @return Subscription token used later to unsubscribe | ||||
|      */ | ||||
|     public subscribe<ArgsType extends ERC721TokenEventArgs>( | ||||
|         tokenAddress: string, | ||||
|         eventName: ERC721TokenEvents, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|         callback: EventCallback<ArgsType>, | ||||
|         isVerbose: boolean = false, | ||||
|     ): string { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, ERC721TokenEvents); | ||||
|         assert.doesConformToSchema('indexFilterValues', indexFilterValues, schemas.indexFilterValuesSchema); | ||||
|         assert.isFunction('callback', callback); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const subscriptionToken = this._subscribe<ArgsType>( | ||||
|             normalizedTokenAddress, | ||||
|             eventName, | ||||
|             indexFilterValues, | ||||
|             artifacts.ERC721Token.compilerOutput.abi, | ||||
|             callback, | ||||
|             isVerbose, | ||||
|         ); | ||||
|         return subscriptionToken; | ||||
|     } | ||||
|     /** | ||||
|      * Cancel a subscription | ||||
|      * @param   subscriptionToken Subscription token returned by `subscribe()` | ||||
|      */ | ||||
|     public unsubscribe(subscriptionToken: string): void { | ||||
|         assert.isValidSubscriptionToken('subscriptionToken', subscriptionToken); | ||||
|         this._unsubscribe(subscriptionToken); | ||||
|     } | ||||
|     /** | ||||
|      * Cancels all existing subscriptions | ||||
|      */ | ||||
|     public unsubscribeAll(): void { | ||||
|         super._unsubscribeAll(); | ||||
|     } | ||||
|     /** | ||||
|      * Gets historical logs without creating a subscription | ||||
|      * @param   tokenAddress        An address of the token that emitted the logs. | ||||
|      * @param   eventName           The token contract event you would like to subscribe to. | ||||
|      * @param   blockRange          Block range to get logs from. | ||||
|      * @param   indexFilterValues   An object where the keys are indexed args returned by the event and | ||||
|      *                              the value is the value you are interested in. E.g `{_from: aUserAddressHex}` | ||||
|      * @return  Array of logs that match the parameters | ||||
|      */ | ||||
|     public async getLogsAsync<ArgsType extends ERC721TokenEventArgs>( | ||||
|         tokenAddress: string, | ||||
|         eventName: ERC721TokenEvents, | ||||
|         blockRange: BlockRange, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|     ): Promise<Array<LogWithDecodedArgs<ArgsType>>> { | ||||
|         assert.isETHAddressHex('tokenAddress', tokenAddress); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, ERC721TokenEvents); | ||||
|         assert.doesConformToSchema('blockRange', blockRange, schemas.blockRangeSchema); | ||||
|         assert.doesConformToSchema('indexFilterValues', indexFilterValues, schemas.indexFilterValuesSchema); | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         const logs = await this._getLogsAsync<ArgsType>( | ||||
|             normalizedTokenAddress, | ||||
|             eventName, | ||||
|             blockRange, | ||||
|             indexFilterValues, | ||||
|             artifacts.ERC721Token.compilerOutput.abi, | ||||
|         ); | ||||
|         return logs; | ||||
|     } | ||||
|     // HACK: We don't want this method to be visible to the other units within that package but not to the end user. | ||||
|     // TS doesn't give that possibility and therefore we make it private and access it over an any cast. Because of that tslint sees it as unused. | ||||
|     // tslint:disable-next-line:no-unused-variable | ||||
|     private _invalidateContractInstances(): void { | ||||
|         this.unsubscribeAll(); | ||||
|         this._tokenContractsByAddress = {}; | ||||
|     } | ||||
|     private async _getTokenContractAsync(tokenAddress: string): Promise<ERC721TokenContract> { | ||||
|         const normalizedTokenAddress = tokenAddress.toLowerCase(); | ||||
|         let tokenContract = this._tokenContractsByAddress[normalizedTokenAddress]; | ||||
|         if (!_.isUndefined(tokenContract)) { | ||||
|             return tokenContract; | ||||
|         } | ||||
|         const [abi, address] = await this._getContractAbiAndAddressFromArtifactsAsync( | ||||
|             artifacts.ERC721Token, | ||||
|             normalizedTokenAddress, | ||||
|         ); | ||||
|         const contractInstance = new ERC721TokenContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         tokenContract = contractInstance; | ||||
|         this._tokenContractsByAddress[normalizedTokenAddress] = tokenContract; | ||||
|         return tokenContract; | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,7 @@ | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { AbiDecoder, BigNumber } from '@0xproject/utils'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { ContractAbi, LogWithDecodedArgs } from 'ethereum-types'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| @@ -9,21 +9,29 @@ import { BlockRange, ContractWrappersError, EventCallback, IndexedFilterValues, | ||||
| import { assert } from '../utils/assert'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { EtherTokenContract, EtherTokenContractEventArgs, EtherTokenEvents } from './generated/ether_token'; | ||||
| import { TokenWrapper } from './token_wrapper'; | ||||
| import { ERC20TokenWrapper } from './erc20_token_wrapper'; | ||||
| import { WETH9Contract, WETH9EventArgs, WETH9Events } from './generated/weth9'; | ||||
|  | ||||
| const removeUndefinedProperties = _.pickBy; | ||||
|  | ||||
| /** | ||||
|  * This class includes all the functionality related to interacting with a wrapped Ether ERC20 token contract. | ||||
|  * The caller can convert ETH into the equivalent number of wrapped ETH ERC20 tokens and back. | ||||
|  */ | ||||
| export class EtherTokenWrapper extends ContractWrapper { | ||||
|     public abi: ContractAbi = artifacts.EtherToken.compilerOutput.abi; | ||||
|     private _etherTokenContractsByAddress: { | ||||
|         [address: string]: EtherTokenContract; | ||||
|         [address: string]: WETH9Contract; | ||||
|     } = {}; | ||||
|     private _tokenWrapper: TokenWrapper; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, tokenWrapper: TokenWrapper) { | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._tokenWrapper = tokenWrapper; | ||||
|     private _erc20TokenWrapper: ERC20TokenWrapper; | ||||
|     constructor( | ||||
|         web3Wrapper: Web3Wrapper, | ||||
|         networkId: number, | ||||
|         erc20TokenWrapper: ERC20TokenWrapper, | ||||
|         blockPollingIntervalMs?: number, | ||||
|     ) { | ||||
|         super(web3Wrapper, networkId, blockPollingIntervalMs); | ||||
|         this._erc20TokenWrapper = erc20TokenWrapper; | ||||
|     } | ||||
|     /** | ||||
|      * Deposit ETH into the Wrapped ETH smart contract and issues the equivalent number of wrapped ETH tokens | ||||
| @@ -51,12 +59,14 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|         assert.assert(ethBalanceInWei.gte(amountInWei), ContractWrappersError.InsufficientEthBalanceForDeposit); | ||||
|  | ||||
|         const wethContract = await this._getEtherTokenContractAsync(normalizedEtherTokenAddress); | ||||
|         const txHash = await wethContract.deposit.sendTransactionAsync({ | ||||
|             from: normalizedDepositorAddress, | ||||
|             value: amountInWei, | ||||
|             gas: txOpts.gasLimit, | ||||
|             gasPrice: txOpts.gasPrice, | ||||
|         }); | ||||
|         const txHash = await wethContract.deposit.sendTransactionAsync( | ||||
|             removeUndefinedProperties({ | ||||
|                 from: normalizedDepositorAddress, | ||||
|                 value: amountInWei, | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
| @@ -80,7 +90,7 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|         const normalizedEtherTokenAddress = etherTokenAddress.toLowerCase(); | ||||
|         const normalizedWithdrawerAddress = withdrawer.toLowerCase(); | ||||
|  | ||||
|         const WETHBalanceInBaseUnits = await this._tokenWrapper.getBalanceAsync( | ||||
|         const WETHBalanceInBaseUnits = await this._erc20TokenWrapper.getBalanceAsync( | ||||
|             normalizedEtherTokenAddress, | ||||
|             normalizedWithdrawerAddress, | ||||
|         ); | ||||
| @@ -90,11 +100,14 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|         ); | ||||
|  | ||||
|         const wethContract = await this._getEtherTokenContractAsync(normalizedEtherTokenAddress); | ||||
|         const txHash = await wethContract.withdraw.sendTransactionAsync(amountInWei, { | ||||
|             from: normalizedWithdrawerAddress, | ||||
|             gas: txOpts.gasLimit, | ||||
|             gasPrice: txOpts.gasPrice, | ||||
|         }); | ||||
|         const txHash = await wethContract.withdraw.sendTransactionAsync( | ||||
|             amountInWei, | ||||
|             removeUndefinedProperties({ | ||||
|                 from: normalizedWithdrawerAddress, | ||||
|                 gas: txOpts.gasLimit, | ||||
|                 gasPrice: txOpts.gasPrice, | ||||
|             }), | ||||
|         ); | ||||
|         return txHash; | ||||
|     } | ||||
|     /** | ||||
| @@ -106,15 +119,15 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|      *                              the value is the value you are interested in. E.g `{_owner: aUserAddressHex}` | ||||
|      * @return  Array of logs that match the parameters | ||||
|      */ | ||||
|     public async getLogsAsync<ArgsType extends EtherTokenContractEventArgs>( | ||||
|     public async getLogsAsync<ArgsType extends WETH9EventArgs>( | ||||
|         etherTokenAddress: string, | ||||
|         eventName: EtherTokenEvents, | ||||
|         eventName: WETH9Events, | ||||
|         blockRange: BlockRange, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|     ): Promise<Array<LogWithDecodedArgs<ArgsType>>> { | ||||
|         assert.isETHAddressHex('etherTokenAddress', etherTokenAddress); | ||||
|         const normalizedEtherTokenAddress = etherTokenAddress.toLowerCase(); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, EtherTokenEvents); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, WETH9Events); | ||||
|         assert.doesConformToSchema('blockRange', blockRange, schemas.blockRangeSchema); | ||||
|         assert.doesConformToSchema('indexFilterValues', indexFilterValues, schemas.indexFilterValuesSchema); | ||||
|         const logs = await this._getLogsAsync<ArgsType>( | ||||
| @@ -122,7 +135,7 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|             eventName, | ||||
|             blockRange, | ||||
|             indexFilterValues, | ||||
|             artifacts.EtherToken.abi, | ||||
|             artifacts.EtherToken.compilerOutput.abi, | ||||
|         ); | ||||
|         return logs; | ||||
|     } | ||||
| @@ -133,25 +146,28 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|      * @param   indexFilterValues   An object where the keys are indexed args returned by the event and | ||||
|      *                              the value is the value you are interested in. E.g `{_owner: aUserAddressHex}` | ||||
|      * @param   callback            Callback that gets called when a log is added/removed | ||||
|      * @param   isVerbose           Enable verbose subscription warnings (e.g recoverable network issues encountered) | ||||
|      * @return Subscription token used later to unsubscribe | ||||
|      */ | ||||
|     public subscribe<ArgsType extends EtherTokenContractEventArgs>( | ||||
|     public subscribe<ArgsType extends WETH9EventArgs>( | ||||
|         etherTokenAddress: string, | ||||
|         eventName: EtherTokenEvents, | ||||
|         eventName: WETH9Events, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|         callback: EventCallback<ArgsType>, | ||||
|         isVerbose: boolean = false, | ||||
|     ): string { | ||||
|         assert.isETHAddressHex('etherTokenAddress', etherTokenAddress); | ||||
|         const normalizedEtherTokenAddress = etherTokenAddress.toLowerCase(); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, EtherTokenEvents); | ||||
|         assert.doesBelongToStringEnum('eventName', eventName, WETH9Events); | ||||
|         assert.doesConformToSchema('indexFilterValues', indexFilterValues, schemas.indexFilterValuesSchema); | ||||
|         assert.isFunction('callback', callback); | ||||
|         const subscriptionToken = this._subscribe<ArgsType>( | ||||
|             normalizedEtherTokenAddress, | ||||
|             eventName, | ||||
|             indexFilterValues, | ||||
|             artifacts.EtherToken.abi, | ||||
|             artifacts.EtherToken.compilerOutput.abi, | ||||
|             callback, | ||||
|             isVerbose, | ||||
|         ); | ||||
|         return subscriptionToken; | ||||
|     } | ||||
| @@ -160,6 +176,7 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|      * @param   subscriptionToken Subscription token returned by `subscribe()` | ||||
|      */ | ||||
|     public unsubscribe(subscriptionToken: string): void { | ||||
|         assert.isValidSubscriptionToken('subscriptionToken', subscriptionToken); | ||||
|         this._unsubscribe(subscriptionToken); | ||||
|     } | ||||
|     /** | ||||
| @@ -181,11 +198,12 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|             : networkSpecificArtifact.address; | ||||
|         return contractAddressIfExists; | ||||
|     } | ||||
|     // tslint:disable-next-line:no-unused-variable | ||||
|     private _invalidateContractInstance(): void { | ||||
|         this.unsubscribeAll(); | ||||
|         this._etherTokenContractsByAddress = {}; | ||||
|     } | ||||
|     private async _getEtherTokenContractAsync(etherTokenAddress: string): Promise<EtherTokenContract> { | ||||
|     private async _getEtherTokenContractAsync(etherTokenAddress: string): Promise<WETH9Contract> { | ||||
|         let etherTokenContract = this._etherTokenContractsByAddress[etherTokenAddress]; | ||||
|         if (!_.isUndefined(etherTokenContract)) { | ||||
|             return etherTokenContract; | ||||
| @@ -194,7 +212,7 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|             artifacts.EtherToken, | ||||
|             etherTokenAddress, | ||||
|         ); | ||||
|         const contractInstance = new EtherTokenContract( | ||||
|         const contractInstance = new WETH9Contract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,131 +0,0 @@ | ||||
| import { Token } from '@0xproject/types'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { TokenMetadata } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
| import { constants } from '../utils/constants'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { TokenRegistryContract } from './generated/token_registry'; | ||||
|  | ||||
| /** | ||||
|  * This class includes all the functionality related to interacting with the 0x Token Registry smart contract. | ||||
|  */ | ||||
| export class TokenRegistryWrapper extends ContractWrapper { | ||||
|     private _tokenRegistryContractIfExists?: TokenRegistryContract; | ||||
|     private _contractAddressIfExists?: string; | ||||
|     private static _createTokenFromMetadata(metadata: TokenMetadata): Token | undefined { | ||||
|         if (metadata[0] === constants.NULL_ADDRESS) { | ||||
|             return undefined; | ||||
|         } | ||||
|         const token = { | ||||
|             address: metadata[0], | ||||
|             name: metadata[1], | ||||
|             symbol: metadata[2], | ||||
|             decimals: metadata[3], | ||||
|         }; | ||||
|         return token; | ||||
|     } | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, contractAddressIfExists?: string) { | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._contractAddressIfExists = contractAddressIfExists; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves all the tokens currently listed in the Token Registry smart contract | ||||
|      * @return  An array of objects that conform to the Token interface. | ||||
|      */ | ||||
|     public async getTokensAsync(): Promise<Token[]> { | ||||
|         const addresses = await this.getTokenAddressesAsync(); | ||||
|         const tokenPromises: Array<Promise<Token | undefined>> = _.map(addresses, async (address: string) => | ||||
|             this.getTokenIfExistsAsync(address), | ||||
|         ); | ||||
|         const tokens = await Promise.all(tokenPromises); | ||||
|         return tokens as Token[]; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves all the addresses of the tokens currently listed in the Token Registry smart contract | ||||
|      * @return  An array of token addresses. | ||||
|      */ | ||||
|     public async getTokenAddressesAsync(): Promise<string[]> { | ||||
|         const tokenRegistryContract = await this._getTokenRegistryContractAsync(); | ||||
|         const addresses = await tokenRegistryContract.getTokenAddresses.callAsync(); | ||||
|         const lowerCaseAddresses = _.map(addresses, address => address.toLowerCase()); | ||||
|         return lowerCaseAddresses; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves a token by address currently listed in the Token Registry smart contract | ||||
|      * @return  An object that conforms to the Token interface or undefined if token not found. | ||||
|      */ | ||||
|     public async getTokenIfExistsAsync(address: string): Promise<Token | undefined> { | ||||
|         assert.isETHAddressHex('address', address); | ||||
|         const normalizedAddress = address.toLowerCase(); | ||||
|  | ||||
|         const tokenRegistryContract = await this._getTokenRegistryContractAsync(); | ||||
|         const metadata = await tokenRegistryContract.getTokenMetaData.callAsync(normalizedAddress); | ||||
|         const token = TokenRegistryWrapper._createTokenFromMetadata(metadata); | ||||
|         return token; | ||||
|     } | ||||
|     public async getTokenAddressBySymbolIfExistsAsync(symbol: string): Promise<string | undefined> { | ||||
|         assert.isString('symbol', symbol); | ||||
|         const tokenRegistryContract = await this._getTokenRegistryContractAsync(); | ||||
|         const addressIfExists = await tokenRegistryContract.getTokenAddressBySymbol.callAsync(symbol); | ||||
|         if (addressIfExists === constants.NULL_ADDRESS) { | ||||
|             return undefined; | ||||
|         } | ||||
|         return addressIfExists; | ||||
|     } | ||||
|     public async getTokenAddressByNameIfExistsAsync(name: string): Promise<string | undefined> { | ||||
|         assert.isString('name', name); | ||||
|         const tokenRegistryContract = await this._getTokenRegistryContractAsync(); | ||||
|         const addressIfExists = await tokenRegistryContract.getTokenAddressByName.callAsync(name); | ||||
|         if (addressIfExists === constants.NULL_ADDRESS) { | ||||
|             return undefined; | ||||
|         } | ||||
|         return addressIfExists; | ||||
|     } | ||||
|     public async getTokenBySymbolIfExistsAsync(symbol: string): Promise<Token | undefined> { | ||||
|         assert.isString('symbol', symbol); | ||||
|         const tokenRegistryContract = await this._getTokenRegistryContractAsync(); | ||||
|         const metadata = await tokenRegistryContract.getTokenBySymbol.callAsync(symbol); | ||||
|         const token = TokenRegistryWrapper._createTokenFromMetadata(metadata); | ||||
|         return token; | ||||
|     } | ||||
|     public async getTokenByNameIfExistsAsync(name: string): Promise<Token | undefined> { | ||||
|         assert.isString('name', name); | ||||
|         const tokenRegistryContract = await this._getTokenRegistryContractAsync(); | ||||
|         const metadata = await tokenRegistryContract.getTokenByName.callAsync(name); | ||||
|         const token = TokenRegistryWrapper._createTokenFromMetadata(metadata); | ||||
|         return token; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves the Ethereum address of the TokenRegistry contract deployed on the network | ||||
|      * that the user-passed web3 provider is connected to. | ||||
|      * @returns The Ethereum address of the TokenRegistry contract being used. | ||||
|      */ | ||||
|     public getContractAddress(): string { | ||||
|         const contractAddress = this._getContractAddress(artifacts.TokenRegistry, this._contractAddressIfExists); | ||||
|         return contractAddress; | ||||
|     } | ||||
|     private _invalidateContractInstance(): void { | ||||
|         delete this._tokenRegistryContractIfExists; | ||||
|     } | ||||
|     private async _getTokenRegistryContractAsync(): Promise<TokenRegistryContract> { | ||||
|         if (!_.isUndefined(this._tokenRegistryContractIfExists)) { | ||||
|             return this._tokenRegistryContractIfExists; | ||||
|         } | ||||
|         const [abi, address] = await this._getContractAbiAndAddressFromArtifactsAsync( | ||||
|             artifacts.TokenRegistry, | ||||
|             this._contractAddressIfExists, | ||||
|         ); | ||||
|         const contractInstance = new TokenRegistryContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         this._tokenRegistryContractIfExists = contractInstance; | ||||
|         return this._tokenRegistryContractIfExists; | ||||
|     } | ||||
| } | ||||
| @@ -1,72 +0,0 @@ | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { assert } from '../utils/assert'; | ||||
|  | ||||
| import { ContractWrapper } from './contract_wrapper'; | ||||
| import { TokenTransferProxyContract } from './generated/token_transfer_proxy'; | ||||
|  | ||||
| /** | ||||
|  * This class includes the functionality related to interacting with the TokenTransferProxy contract. | ||||
|  */ | ||||
| export class TokenTransferProxyWrapper extends ContractWrapper { | ||||
|     private _tokenTransferProxyContractIfExists?: TokenTransferProxyContract; | ||||
|     private _contractAddressIfExists?: string; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, contractAddressIfExists?: string) { | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._contractAddressIfExists = contractAddressIfExists; | ||||
|     } | ||||
|     /** | ||||
|      * Check if the Exchange contract address is authorized by the TokenTransferProxy contract. | ||||
|      * @param   exchangeContractAddress     The hex encoded address of the Exchange contract to call. | ||||
|      * @return  Whether the exchangeContractAddress is authorized. | ||||
|      */ | ||||
|     public async isAuthorizedAsync(exchangeContractAddress: string): Promise<boolean> { | ||||
|         assert.isETHAddressHex('exchangeContractAddress', exchangeContractAddress); | ||||
|         const normalizedExchangeContractAddress = exchangeContractAddress.toLowerCase(); | ||||
|         const tokenTransferProxyContractInstance = await this._getTokenTransferProxyContractAsync(); | ||||
|         const isAuthorized = await tokenTransferProxyContractInstance.authorized.callAsync( | ||||
|             normalizedExchangeContractAddress, | ||||
|         ); | ||||
|         return isAuthorized; | ||||
|     } | ||||
|     /** | ||||
|      * Get the list of all Exchange contract addresses authorized by the TokenTransferProxy contract. | ||||
|      * @return  The list of authorized addresses. | ||||
|      */ | ||||
|     public async getAuthorizedAddressesAsync(): Promise<string[]> { | ||||
|         const tokenTransferProxyContractInstance = await this._getTokenTransferProxyContractAsync(); | ||||
|         const authorizedAddresses = await tokenTransferProxyContractInstance.getAuthorizedAddresses.callAsync(); | ||||
|         return authorizedAddresses; | ||||
|     } | ||||
|     /** | ||||
|      * Retrieves the Ethereum address of the TokenTransferProxy contract deployed on the network | ||||
|      * that the user-passed web3 provider is connected to. | ||||
|      * @returns The Ethereum address of the TokenTransferProxy contract being used. | ||||
|      */ | ||||
|     public getContractAddress(): string { | ||||
|         const contractAddress = this._getContractAddress(artifacts.TokenTransferProxy, this._contractAddressIfExists); | ||||
|         return contractAddress; | ||||
|     } | ||||
|     private _invalidateContractInstance(): void { | ||||
|         delete this._tokenTransferProxyContractIfExists; | ||||
|     } | ||||
|     private async _getTokenTransferProxyContractAsync(): Promise<TokenTransferProxyContract> { | ||||
|         if (!_.isUndefined(this._tokenTransferProxyContractIfExists)) { | ||||
|             return this._tokenTransferProxyContractIfExists; | ||||
|         } | ||||
|         const [abi, address] = await this._getContractAbiAndAddressFromArtifactsAsync( | ||||
|             artifacts.TokenTransferProxy, | ||||
|             this._contractAddressIfExists, | ||||
|         ); | ||||
|         const contractInstance = new TokenTransferProxyContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         this._tokenTransferProxyContractIfExists = contractInstance; | ||||
|         return this._tokenTransferProxyContractIfExists; | ||||
|     } | ||||
| } | ||||
| @@ -1,28 +0,0 @@ | ||||
| import { AbstractBalanceAndProxyAllowanceFetcher } from '@0xproject/order-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { TokenWrapper } from '../contract_wrappers/token_wrapper'; | ||||
|  | ||||
| export class SimpleBalanceAndProxyAllowanceFetcher implements AbstractBalanceAndProxyAllowanceFetcher { | ||||
|     private _tokenWrapper: TokenWrapper; | ||||
|     private _defaultBlock: BlockParamLiteral; | ||||
|     constructor(token: TokenWrapper, defaultBlock: BlockParamLiteral) { | ||||
|         this._tokenWrapper = token; | ||||
|         this._defaultBlock = defaultBlock; | ||||
|     } | ||||
|     public async getBalanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber> { | ||||
|         const methodOpts = { | ||||
|             defaultBlock: this._defaultBlock, | ||||
|         }; | ||||
|         const balance = this._tokenWrapper.getBalanceAsync(tokenAddress, userAddress, methodOpts); | ||||
|         return balance; | ||||
|     } | ||||
|     public async getProxyAllowanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber> { | ||||
|         const methodOpts = { | ||||
|             defaultBlock: this._defaultBlock, | ||||
|         }; | ||||
|         const proxyAllowance = this._tokenWrapper.getProxyAllowanceAsync(tokenAddress, userAddress, methodOpts); | ||||
|         return proxyAllowance; | ||||
|     } | ||||
| } | ||||
| @@ -1,36 +0,0 @@ | ||||
| import { AbstractOrderFilledCancelledFetcher } from '@0xproject/order-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
|  | ||||
| export class SimpleOrderFilledCancelledFetcher implements AbstractOrderFilledCancelledFetcher { | ||||
|     private _exchangeWrapper: ExchangeWrapper; | ||||
|     private _defaultBlock: BlockParamLiteral; | ||||
|     constructor(exchange: ExchangeWrapper, defaultBlock: BlockParamLiteral) { | ||||
|         this._exchangeWrapper = exchange; | ||||
|         this._defaultBlock = defaultBlock; | ||||
|     } | ||||
|     public async getFilledTakerAmountAsync(orderHash: string): Promise<BigNumber> { | ||||
|         const methodOpts = { | ||||
|             defaultBlock: this._defaultBlock, | ||||
|         }; | ||||
|         const filledTakerAmount = this._exchangeWrapper.getFilledTakerAmountAsync(orderHash, methodOpts); | ||||
|         return filledTakerAmount; | ||||
|     } | ||||
|     public async getCancelledTakerAmountAsync(orderHash: string): Promise<BigNumber> { | ||||
|         const methodOpts = { | ||||
|             defaultBlock: this._defaultBlock, | ||||
|         }; | ||||
|         const cancelledTakerAmount = this._exchangeWrapper.getCancelledTakerAmountAsync(orderHash, methodOpts); | ||||
|         return cancelledTakerAmount; | ||||
|     } | ||||
|     public async getUnavailableTakerAmountAsync(orderHash: string): Promise<BigNumber> { | ||||
|         const unavailableTakerAmount = await this._exchangeWrapper.getUnavailableTakerAmountAsync(orderHash); | ||||
|         return unavailableTakerAmount; | ||||
|     } | ||||
|     public getZRXTokenAddress(): string { | ||||
|         const zrxToken = this._exchangeWrapper.getZRXTokenAddress(); | ||||
|         return zrxToken; | ||||
|     } | ||||
| } | ||||
| @@ -1,9 +1,10 @@ | ||||
| export { ContractWrappers } from './contract_wrappers'; | ||||
| export { ExchangeWrapper } from './contract_wrappers/exchange_wrapper'; | ||||
| export { TokenWrapper } from './contract_wrappers/token_wrapper'; | ||||
| export { TokenRegistryWrapper } from './contract_wrappers/token_registry_wrapper'; | ||||
| export { ERC20TokenWrapper } from './contract_wrappers/erc20_token_wrapper'; | ||||
| export { ERC721TokenWrapper } from './contract_wrappers/erc721_token_wrapper'; | ||||
| export { EtherTokenWrapper } from './contract_wrappers/ether_token_wrapper'; | ||||
| export { TokenTransferProxyWrapper } from './contract_wrappers/token_transfer_proxy_wrapper'; | ||||
| export { ExchangeWrapper } from './contract_wrappers/exchange_wrapper'; | ||||
| export { ERC20ProxyWrapper } from './contract_wrappers/erc20_proxy_wrapper'; | ||||
| export { ERC721ProxyWrapper } from './contract_wrappers/erc721_proxy_wrapper'; | ||||
|  | ||||
| export { | ||||
|     ContractWrappersError, | ||||
| @@ -12,7 +13,6 @@ export { | ||||
|     Token, | ||||
|     IndexedFilterValues, | ||||
|     BlockRange, | ||||
|     OrderCancellationRequest, | ||||
|     OrderFillRequest, | ||||
|     ContractEventArgs, | ||||
|     ContractWrappersConfig, | ||||
| @@ -22,47 +22,60 @@ export { | ||||
|     LogEvent, | ||||
|     DecodedLogEvent, | ||||
|     OnOrderStateChangeCallback, | ||||
|     OrderStatus, | ||||
|     OrderInfo, | ||||
| } from './types'; | ||||
|  | ||||
| export { | ||||
|     Order, | ||||
|     SignedOrder, | ||||
|     ECSignature, | ||||
|     OrderStateValid, | ||||
|     OrderStateInvalid, | ||||
|     OrderState, | ||||
|     AssetProxyId, | ||||
| } from '@0xproject/types'; | ||||
|  | ||||
| export { | ||||
|     BlockParamLiteral, | ||||
|     FilterObject, | ||||
|     BlockParam, | ||||
|     ContractEventArg, | ||||
|     ExchangeContractErrs, | ||||
|     LogWithDecodedArgs, | ||||
|     Order, | ||||
|     Provider, | ||||
|     SignedOrder, | ||||
|     ECSignature, | ||||
|     OrderStateValid, | ||||
|     OrderStateInvalid, | ||||
|     OrderState, | ||||
|     TransactionReceipt, | ||||
|     TransactionReceiptWithDecodedLogs, | ||||
| } from '@0xproject/types'; | ||||
| } from 'ethereum-types'; | ||||
|  | ||||
| export { | ||||
|     EtherTokenContractEventArgs, | ||||
|     WithdrawalContractEventArgs, | ||||
|     DepositContractEventArgs, | ||||
|     EtherTokenEvents, | ||||
| } from './contract_wrappers/generated/ether_token'; | ||||
|     WETH9Events, | ||||
|     WETH9WithdrawalEventArgs, | ||||
|     WETH9ApprovalEventArgs, | ||||
|     WETH9EventArgs, | ||||
|     WETH9DepositEventArgs, | ||||
|     WETH9TransferEventArgs, | ||||
| } from './contract_wrappers/generated/weth9'; | ||||
|  | ||||
| export { | ||||
|     TransferContractEventArgs, | ||||
|     ApprovalContractEventArgs, | ||||
|     TokenContractEventArgs, | ||||
|     TokenEvents, | ||||
| } from './contract_wrappers/generated/token'; | ||||
|     ERC20TokenTransferEventArgs, | ||||
|     ERC20TokenApprovalEventArgs, | ||||
|     ERC20TokenEvents, | ||||
|     ERC20TokenEventArgs, | ||||
| } from './contract_wrappers/generated/erc20_token'; | ||||
|  | ||||
| export { | ||||
|     LogErrorContractEventArgs, | ||||
|     LogCancelContractEventArgs, | ||||
|     LogFillContractEventArgs, | ||||
|     ExchangeContractEventArgs, | ||||
|     ERC721TokenApprovalEventArgs, | ||||
|     ERC721TokenApprovalForAllEventArgs, | ||||
|     ERC721TokenTransferEventArgs, | ||||
|     ERC721TokenEvents, | ||||
|     ERC721TokenEventArgs, | ||||
| } from './contract_wrappers/generated/erc721_token'; | ||||
|  | ||||
| export { | ||||
|     ExchangeCancelUpToEventArgs, | ||||
|     ExchangeAssetProxyRegisteredEventArgs, | ||||
|     ExchangeFillEventArgs, | ||||
|     ExchangeCancelEventArgs, | ||||
|     ExchangeEventArgs, | ||||
|     ExchangeEvents, | ||||
| } from './contract_wrappers/generated/exchange'; | ||||
|  | ||||
| export { BalanceAndProxyAllowanceLazyStore } from './stores/balance_proxy_allowance_lazy_store'; | ||||
| export { OrderFilledCancelledLazyStore } from './stores/order_filled_cancelled_lazy_store'; | ||||
|   | ||||
| @@ -8,8 +8,9 @@ export const contractWrappersPrivateNetworkConfigSchema = { | ||||
|         gasPrice: { $ref: '/Number' }, | ||||
|         zrxContractAddress: { $ref: '/Address' }, | ||||
|         exchangeContractAddress: { $ref: '/Address' }, | ||||
|         tokenRegistryContractAddress: { $ref: '/Address' }, | ||||
|         tokenTransferProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc20ProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc721ProxyContractAddress: { $ref: '/Address' }, | ||||
|         blockPollingIntervalMs: { type: 'number' }, | ||||
|         orderWatcherConfig: { | ||||
|             type: 'object', | ||||
|             properties: { | ||||
| @@ -29,7 +30,7 @@ export const contractWrappersPrivateNetworkConfigSchema = { | ||||
|         'networkId', | ||||
|         'zrxContractAddress', | ||||
|         'exchangeContractAddress', | ||||
|         'tokenRegistryContractAddress', | ||||
|         'tokenTransferProxyContractAddress', | ||||
|         'erc20ProxyContractAddress', | ||||
|         'erc721ProxyContractAddress', | ||||
|     ], | ||||
| }; | ||||
|   | ||||
| @@ -22,8 +22,9 @@ export const contractWrappersPublicNetworkConfigSchema = { | ||||
|         gasPrice: { $ref: '/Number' }, | ||||
|         zrxContractAddress: { $ref: '/Address' }, | ||||
|         exchangeContractAddress: { $ref: '/Address' }, | ||||
|         tokenRegistryContractAddress: { $ref: '/Address' }, | ||||
|         tokenTransferProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc20ProxyContractAddress: { $ref: '/Address' }, | ||||
|         erc721ProxyContractAddress: { $ref: '/Address' }, | ||||
|         blockPollingIntervalMs: { type: 'number' }, | ||||
|         orderWatcherConfig: { | ||||
|             type: 'object', | ||||
|             properties: { | ||||
|   | ||||
| @@ -0,0 +1,7 @@ | ||||
| export const methodOptsSchema = { | ||||
|     id: '/MethodOpts', | ||||
|     properties: { | ||||
|         defaultBlock: { $ref: '/BlockParam' }, | ||||
|     }, | ||||
|     type: 'object', | ||||
| }; | ||||
| @@ -0,0 +1,8 @@ | ||||
| export const orderTxOptsSchema = { | ||||
|     id: '/OrderTxOpts', | ||||
|     allOf: [{ $ref: '/TxOpts' }], | ||||
|     properties: { | ||||
|         shouldValidate: { type: 'boolean' }, | ||||
|     }, | ||||
|     type: 'object', | ||||
| }; | ||||
							
								
								
									
										8
									
								
								packages/contract-wrappers/src/schemas/tx_opts_schema.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								packages/contract-wrappers/src/schemas/tx_opts_schema.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| export const txOptsSchema = { | ||||
|     id: '/TxOpts', | ||||
|     properties: { | ||||
|         gasPrice: { $ref: '/Number' }, | ||||
|         gasLimit: { type: 'number' }, | ||||
|     }, | ||||
|     type: 'object', | ||||
| }; | ||||
| @@ -1,91 +0,0 @@ | ||||
| import { AbstractBalanceAndProxyAllowanceFetcher } from '@0xproject/order-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { TokenWrapper } from '../contract_wrappers/token_wrapper'; | ||||
|  | ||||
| /** | ||||
|  * Copy on read store for balances/proxyAllowances of tokens/accounts | ||||
|  */ | ||||
| export class BalanceAndProxyAllowanceLazyStore implements AbstractBalanceAndProxyAllowanceFetcher { | ||||
|     private _tokenWrapper: TokenWrapper; | ||||
|     private _defaultBlock: BlockParamLiteral; | ||||
|     private _balance: { | ||||
|         [tokenAddress: string]: { | ||||
|             [userAddress: string]: BigNumber; | ||||
|         }; | ||||
|     }; | ||||
|     private _proxyAllowance: { | ||||
|         [tokenAddress: string]: { | ||||
|             [userAddress: string]: BigNumber; | ||||
|         }; | ||||
|     }; | ||||
|     constructor(token: TokenWrapper, defaultBlock: BlockParamLiteral) { | ||||
|         this._tokenWrapper = token; | ||||
|         this._defaultBlock = defaultBlock; | ||||
|         this._balance = {}; | ||||
|         this._proxyAllowance = {}; | ||||
|     } | ||||
|     public async getBalanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber> { | ||||
|         if (_.isUndefined(this._balance[tokenAddress]) || _.isUndefined(this._balance[tokenAddress][userAddress])) { | ||||
|             const methodOpts = { | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const balance = await this._tokenWrapper.getBalanceAsync(tokenAddress, userAddress, methodOpts); | ||||
|             this.setBalance(tokenAddress, userAddress, balance); | ||||
|         } | ||||
|         const cachedBalance = this._balance[tokenAddress][userAddress]; | ||||
|         return cachedBalance; | ||||
|     } | ||||
|     public setBalance(tokenAddress: string, userAddress: string, balance: BigNumber): void { | ||||
|         if (_.isUndefined(this._balance[tokenAddress])) { | ||||
|             this._balance[tokenAddress] = {}; | ||||
|         } | ||||
|         this._balance[tokenAddress][userAddress] = balance; | ||||
|     } | ||||
|     public deleteBalance(tokenAddress: string, userAddress: string): void { | ||||
|         if (!_.isUndefined(this._balance[tokenAddress])) { | ||||
|             delete this._balance[tokenAddress][userAddress]; | ||||
|             if (_.isEmpty(this._balance[tokenAddress])) { | ||||
|                 delete this._balance[tokenAddress]; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     public async getProxyAllowanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber> { | ||||
|         if ( | ||||
|             _.isUndefined(this._proxyAllowance[tokenAddress]) || | ||||
|             _.isUndefined(this._proxyAllowance[tokenAddress][userAddress]) | ||||
|         ) { | ||||
|             const methodOpts = { | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const proxyAllowance = await this._tokenWrapper.getProxyAllowanceAsync( | ||||
|                 tokenAddress, | ||||
|                 userAddress, | ||||
|                 methodOpts, | ||||
|             ); | ||||
|             this.setProxyAllowance(tokenAddress, userAddress, proxyAllowance); | ||||
|         } | ||||
|         const cachedProxyAllowance = this._proxyAllowance[tokenAddress][userAddress]; | ||||
|         return cachedProxyAllowance; | ||||
|     } | ||||
|     public setProxyAllowance(tokenAddress: string, userAddress: string, proxyAllowance: BigNumber): void { | ||||
|         if (_.isUndefined(this._proxyAllowance[tokenAddress])) { | ||||
|             this._proxyAllowance[tokenAddress] = {}; | ||||
|         } | ||||
|         this._proxyAllowance[tokenAddress][userAddress] = proxyAllowance; | ||||
|     } | ||||
|     public deleteProxyAllowance(tokenAddress: string, userAddress: string): void { | ||||
|         if (!_.isUndefined(this._proxyAllowance[tokenAddress])) { | ||||
|             delete this._proxyAllowance[tokenAddress][userAddress]; | ||||
|             if (_.isEmpty(this._proxyAllowance[tokenAddress])) { | ||||
|                 delete this._proxyAllowance[tokenAddress]; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     public deleteAll(): void { | ||||
|         this._balance = {}; | ||||
|         this._proxyAllowance = {}; | ||||
|     } | ||||
| } | ||||
| @@ -1,75 +0,0 @@ | ||||
| import { AbstractOrderFilledCancelledFetcher } from '@0xproject/order-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
|  | ||||
| /** | ||||
|  * Copy on read store for filled/cancelled taker amounts | ||||
|  */ | ||||
| export class OrderFilledCancelledLazyStore implements AbstractOrderFilledCancelledFetcher { | ||||
|     private _exchangeWrapper: ExchangeWrapper; | ||||
|     private _defaultBlock: BlockParamLiteral; | ||||
|     private _filledTakerAmount: { | ||||
|         [orderHash: string]: BigNumber; | ||||
|     }; | ||||
|     private _cancelledTakerAmount: { | ||||
|         [orderHash: string]: BigNumber; | ||||
|     }; | ||||
|     constructor(exchange: ExchangeWrapper, defaultBlock: BlockParamLiteral) { | ||||
|         this._exchangeWrapper = exchange; | ||||
|         this._defaultBlock = defaultBlock; | ||||
|         this._filledTakerAmount = {}; | ||||
|         this._cancelledTakerAmount = {}; | ||||
|     } | ||||
|     public async getFilledTakerAmountAsync(orderHash: string): Promise<BigNumber> { | ||||
|         if (_.isUndefined(this._filledTakerAmount[orderHash])) { | ||||
|             const methodOpts = { | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const filledTakerAmount = await this._exchangeWrapper.getFilledTakerAmountAsync(orderHash, methodOpts); | ||||
|             this.setFilledTakerAmount(orderHash, filledTakerAmount); | ||||
|         } | ||||
|         const cachedFilled = this._filledTakerAmount[orderHash]; | ||||
|         return cachedFilled; | ||||
|     } | ||||
|     public setFilledTakerAmount(orderHash: string, filledTakerAmount: BigNumber): void { | ||||
|         this._filledTakerAmount[orderHash] = filledTakerAmount; | ||||
|     } | ||||
|     public deleteFilledTakerAmount(orderHash: string): void { | ||||
|         delete this._filledTakerAmount[orderHash]; | ||||
|     } | ||||
|     public async getCancelledTakerAmountAsync(orderHash: string): Promise<BigNumber> { | ||||
|         if (_.isUndefined(this._cancelledTakerAmount[orderHash])) { | ||||
|             const methodOpts = { | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const cancelledTakerAmount = await this._exchangeWrapper.getCancelledTakerAmountAsync( | ||||
|                 orderHash, | ||||
|                 methodOpts, | ||||
|             ); | ||||
|             this.setCancelledTakerAmount(orderHash, cancelledTakerAmount); | ||||
|         } | ||||
|         const cachedCancelled = this._cancelledTakerAmount[orderHash]; | ||||
|         return cachedCancelled; | ||||
|     } | ||||
|     public setCancelledTakerAmount(orderHash: string, cancelledTakerAmount: BigNumber): void { | ||||
|         this._cancelledTakerAmount[orderHash] = cancelledTakerAmount; | ||||
|     } | ||||
|     public deleteCancelledTakerAmount(orderHash: string): void { | ||||
|         delete this._cancelledTakerAmount[orderHash]; | ||||
|     } | ||||
|     public deleteAll(): void { | ||||
|         this._filledTakerAmount = {}; | ||||
|         this._cancelledTakerAmount = {}; | ||||
|     } | ||||
|     public async getUnavailableTakerAmountAsync(orderHash: string): Promise<BigNumber> { | ||||
|         const unavailableTakerAmount = await this._exchangeWrapper.getUnavailableTakerAmountAsync(orderHash); | ||||
|         return unavailableTakerAmount; | ||||
|     } | ||||
|     public getZRXTokenAddress(): string { | ||||
|         const zrxToken = this._exchangeWrapper.getZRXTokenAddress(); | ||||
|         return zrxToken; | ||||
|     } | ||||
| } | ||||
| @@ -1,30 +1,25 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { | ||||
|     BlockParam, | ||||
|     BlockParamLiteral, | ||||
|     ContractAbi, | ||||
|     ContractEventArg, | ||||
|     ExchangeContractErrs, | ||||
|     FilterObject, | ||||
|     LogEntryEvent, | ||||
|     LogWithDecodedArgs, | ||||
|     Order, | ||||
|     OrderState, | ||||
|     SignedOrder, | ||||
| } from '@0xproject/types'; | ||||
| import { OrderState, SignedOrder } from '@0xproject/types'; | ||||
| import { BlockParam, ContractEventArg, DecodedLogArgs, LogEntryEvent, LogWithDecodedArgs } from 'ethereum-types'; | ||||
|  | ||||
| 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'; | ||||
| import { ERC20TokenEventArgs, ERC20TokenEvents } from './contract_wrappers/generated/erc20_token'; | ||||
| import { ERC721TokenEventArgs, ERC721TokenEvents } from './contract_wrappers/generated/erc721_token'; | ||||
| import { ExchangeEventArgs, ExchangeEvents } from './contract_wrappers/generated/exchange'; | ||||
| import { WETH9EventArgs, WETH9Events } from './contract_wrappers/generated/weth9'; | ||||
|  | ||||
| export enum ExchangeWrapperError { | ||||
|     AssetDataMismatch = 'ASSET_DATA_MISMATCH', | ||||
| } | ||||
|  | ||||
| export enum ContractWrappersError { | ||||
|     ExchangeContractDoesNotExist = 'EXCHANGE_CONTRACT_DOES_NOT_EXIST', | ||||
|     ZRXContractDoesNotExist = 'ZRX_CONTRACT_DOES_NOT_EXIST', | ||||
|     EtherTokenContractDoesNotExist = 'ETHER_TOKEN_CONTRACT_DOES_NOT_EXIST', | ||||
|     TokenTransferProxyContractDoesNotExist = 'TOKEN_TRANSFER_PROXY_CONTRACT_DOES_NOT_EXIST', | ||||
|     TokenRegistryContractDoesNotExist = 'TOKEN_REGISTRY_CONTRACT_DOES_NOT_EXIST', | ||||
|     TokenContractDoesNotExist = 'TOKEN_CONTRACT_DOES_NOT_EXIST', | ||||
|     ERC20ProxyContractDoesNotExist = 'ERC20_PROXY_CONTRACT_DOES_NOT_EXIST', | ||||
|     ERC721ProxyContractDoesNotExist = 'ERC721_PROXY_CONTRACT_DOES_NOT_EXIST', | ||||
|     ERC20TokenContractDoesNotExist = 'ERC20_TOKEN_CONTRACT_DOES_NOT_EXIST', | ||||
|     ERC721TokenContractDoesNotExist = 'ERC721_TOKEN_CONTRACT_DOES_NOT_EXIST', | ||||
|     ContractNotDeployedOnNetwork = 'CONTRACT_NOT_DEPLOYED_ON_NETWORK', | ||||
|     InsufficientAllowanceForTransfer = 'INSUFFICIENT_ALLOWANCE_FOR_TRANSFER', | ||||
|     InsufficientBalanceForTransfer = 'INSUFFICIENT_BALANCE_FOR_TRANSFER', | ||||
| @@ -34,30 +29,24 @@ export enum ContractWrappersError { | ||||
|     OutOfGas = 'OUT_OF_GAS', | ||||
|     SubscriptionNotFound = 'SUBSCRIPTION_NOT_FOUND', | ||||
|     SubscriptionAlreadyPresent = 'SUBSCRIPTION_ALREADY_PRESENT', | ||||
|     ERC721OwnerNotFound = 'ERC_721_OWNER_NOT_FOUND', | ||||
|     ERC721NoApproval = 'ERC_721_NO_APPROVAL', | ||||
| } | ||||
|  | ||||
| export enum InternalContractWrappersError { | ||||
|     NoAbiDecoder = 'NO_ABI_DECODER', | ||||
|     ZrxNotInTokenRegistry = 'ZRX_NOT_IN_TOKEN_REGISTRY', | ||||
|     WethNotInTokenRegistry = 'WETH_NOT_IN_TOKEN_REGISTRY', | ||||
| } | ||||
|  | ||||
| export type LogEvent = LogEntryEvent; | ||||
| export interface DecodedLogEvent<ArgsType> { | ||||
| export interface DecodedLogEvent<ArgsType extends DecodedLogArgs> { | ||||
|     isRemoved: boolean; | ||||
|     log: LogWithDecodedArgs<ArgsType>; | ||||
| } | ||||
|  | ||||
| export type EventCallback<ArgsType> = (err: null | Error, log?: DecodedLogEvent<ArgsType>) => void; | ||||
|  | ||||
| export enum ExchangeContractErrCodes { | ||||
|     ERROR_FILL_EXPIRED, // Order has already expired | ||||
|     ERROR_FILL_NO_VALUE, // Order has already been fully filled or cancelled | ||||
|     ERROR_FILL_TRUNCATION, // Rounding error too large | ||||
|     ERROR_FILL_BALANCE_ALLOWANCE, // Insufficient balance or allowance for token transfer | ||||
|     ERROR_CANCEL_EXPIRED, // Order has already expired | ||||
|     ERROR_CANCEL_NO_VALUE, // Order has already been fully filled or cancelled | ||||
| } | ||||
| export type EventCallback<ArgsType extends DecodedLogArgs> = ( | ||||
|     err: null | Error, | ||||
|     log?: DecodedLogEvent<ArgsType>, | ||||
| ) => void; | ||||
|  | ||||
| export interface ContractEvent { | ||||
|     logIndex: number; | ||||
| @@ -71,7 +60,7 @@ export interface ContractEvent { | ||||
|     args: ContractEventArgs; | ||||
| } | ||||
|  | ||||
| export type ContractEventArgs = ExchangeContractEventArgs | TokenContractEventArgs | EtherTokenContractEventArgs; | ||||
| export type ContractEventArgs = ExchangeEventArgs | ERC20TokenEventArgs | ERC721TokenEventArgs | WETH9EventArgs; | ||||
|  | ||||
| //                          [address, name, symbol, decimals, ipfsHash, swarmHash] | ||||
| export type TokenMetadata = [string, string, string, number, string, string]; | ||||
| @@ -94,7 +83,7 @@ export interface TokenAddressBySymbol { | ||||
|     [symbol: string]: string; | ||||
| } | ||||
|  | ||||
| export type ContractEvents = TokenEvents | ExchangeEvents | EtherTokenEvents; | ||||
| export type ContractEvents = ERC20TokenEvents | ERC721TokenEvents | ExchangeEvents | WETH9Events; | ||||
|  | ||||
| export interface IndexedFilterValues { | ||||
|     [index: string]: ContractEventArg; | ||||
| @@ -105,14 +94,9 @@ export interface BlockRange { | ||||
|     toBlock: BlockParam; | ||||
| } | ||||
|  | ||||
| export interface OrderCancellationRequest { | ||||
|     order: Order | SignedOrder; | ||||
|     takerTokenCancelAmount: BigNumber; | ||||
| } | ||||
|  | ||||
| export interface OrderFillRequest { | ||||
|     signedOrder: SignedOrder; | ||||
|     takerTokenFillAmount: BigNumber; | ||||
|     takerAssetFillAmount: BigNumber; | ||||
| } | ||||
|  | ||||
| export type AsyncMethod = (...args: any[]) => Promise<any>; | ||||
| @@ -123,17 +107,19 @@ export type SyncMethod = (...args: any[]) => any; | ||||
|  * gasPrice: Gas price to use with every transaction | ||||
|  * exchangeContractAddress: The address of an exchange contract to use | ||||
|  * zrxContractAddress: The address of the ZRX contract to use | ||||
|  * tokenRegistryContractAddress: The address of a token registry contract to use | ||||
|  * tokenTransferProxyContractAddress: The address of the token transfer proxy contract to use | ||||
|  * erc20ProxyContractAddress: The address of the erc20 token transfer proxy contract to use | ||||
|  * erc721ProxyContractAddress: The address of the erc721 token transfer proxy contract to use | ||||
|  * orderWatcherConfig: All the configs related to the orderWatcher | ||||
|  * blockPollingIntervalMs: The interval to use for block polling in event watching methods (defaults to 1000) | ||||
|  */ | ||||
| export interface ContractWrappersConfig { | ||||
|     networkId: number; | ||||
|     gasPrice?: BigNumber; | ||||
|     exchangeContractAddress?: string; | ||||
|     zrxContractAddress?: string; | ||||
|     tokenRegistryContractAddress?: string; | ||||
|     tokenTransferProxyContractAddress?: string; | ||||
|     erc20ProxyContractAddress?: string; | ||||
|     erc721ProxyContractAddress?: string; | ||||
|     blockPollingIntervalMs?: number; | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -158,7 +144,7 @@ export interface MethodOpts { | ||||
|  | ||||
| /** | ||||
|  * gasPrice: Gas price in Wei to use for a transaction | ||||
|  * gasLimit: The amount of gas to send with a transaction | ||||
|  * gasLimit: The amount of gas to send with a transaction (in Gwei) | ||||
|  */ | ||||
| export interface TransactionOpts { | ||||
|     gasPrice?: BigNumber; | ||||
| @@ -184,3 +170,19 @@ export enum TransferType { | ||||
| } | ||||
|  | ||||
| export type OnOrderStateChangeCallback = (err: Error | null, orderState?: OrderState) => void; | ||||
|  | ||||
| export interface OrderInfo { | ||||
|     orderStatus: number; | ||||
|     orderHash: string; | ||||
|     orderTakerAssetFilledAmount: BigNumber; | ||||
| } | ||||
|  | ||||
| export enum OrderStatus { | ||||
|     INVALID, | ||||
|     INVALID_MAKER_ASSET_AMOUNT, | ||||
|     INVALID_TAKER_ASSET_AMOUNT, | ||||
|     FILLABLE, | ||||
|     EXPIRED, | ||||
|     FULLY_FILLED, | ||||
|     CANCELLED, | ||||
| } | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user