Compare commits
	
		
			733 Commits
		
	
	
		
			chai-as-pr
			...
			@0xproject
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 3ba78553f0 | ||
|  | 4d485fc424 | ||
|  | 85f28ade86 | ||
|  | f6f2991a44 | ||
|  | 4ea222bbff | ||
|  | f9f5e04b41 | ||
|  | ea6706a2af | ||
|  | 64c5c5eb40 | ||
|  | 823f2db09f | ||
|  | a71e511f82 | ||
|  | 12d5c35d14 | ||
|  | 1a161cc02e | ||
|  | 96f19ba8da | ||
|  | a63dfb7995 | ||
|  | 97ea1e300a | ||
|  | d87d93dfac | ||
|  | 3ffcb03d87 | ||
|  | 33b08b90a3 | ||
|  | cbca2061f7 | ||
|  | bf4873e519 | ||
|  | 8fc1b38ff2 | ||
|  | 7d957538b4 | ||
|  | 7a8edb5018 | ||
|  | 2193d9ae6e | ||
|  | 79d01fe2d7 | ||
|  | 0d02037a12 | ||
|  | d263f7783f | ||
|  | d8ef76fd5e | ||
|  | bc3c7a30c4 | ||
|  | 7b318b3cc2 | ||
|  | e5cf41b313 | ||
|  | 74012ad584 | ||
|  | 06b4f007f8 | ||
|  | a9cf425410 | ||
|  | 5355da6cad | ||
|  | 38f7c4a0d2 | ||
|  | 1fcf3c5dc4 | ||
|  | 20b0afacf5 | ||
|  | 6dbe8dbc50 | ||
|  | 73e23996a6 | ||
|  | e40bce253c | ||
|  | 74c279ea3a | ||
|  | 6c13b792f9 | ||
|  | 6be7466c4a | ||
|  | 1dbdd7ee1f | ||
|  | eb89926cee | ||
|  | 7923ff4ac6 | ||
|  | 783314c037 | ||
|  | 15cf64318c | ||
|  | 442017f93a | ||
|  | 4dd9f29769 | ||
|  | f2f9bd2e7a | ||
|  | d95b8ef3e1 | ||
|  | ed0c64fdcf | ||
|  | 9a91e39b3f | ||
|  | ce3f25d48f | ||
|  | b669508c34 | ||
|  | 364d8824af | ||
|  | 749354b1c0 | ||
|  | be73084e04 | ||
|  | 5eb90697c8 | ||
|  | faedd2fa0b | ||
|  | c47fb8f9a8 | ||
|  | 27b915789e | ||
|  | ddc6dca98c | ||
|  | 72aa3d3005 | ||
|  | e8d4f6d532 | ||
|  | 631e7e9c58 | ||
|  | 3c84ce2050 | ||
|  | 9db1ce7ceb | ||
|  | e472f7899f | ||
|  | b053781453 | ||
|  | f892b7dbf6 | ||
|  | b146acc69e | ||
|  | 63b941fbaf | ||
|  | 29dc22e208 | ||
|  | c44f9e56ad | ||
|  | 2fe209d5ff | ||
|  | 41bd0e30d6 | ||
|  | 40f4dd91e9 | ||
|  | 5bf43a3560 | ||
|  | f0afc0ae45 | ||
|  | 916b4d3a26 | ||
|  | 6d1a587c5c | ||
|  | bce97c2543 | ||
|  | 34446cf569 | ||
|  | 1e13e927d0 | ||
|  | 3c0fa0b7e6 | ||
|  | ad894fbdbb | ||
|  | 7d9c6eafbf | ||
|  | de6f757ec8 | ||
|  | 3eeb8f4d6d | ||
|  | f44ef7ce59 | ||
|  | b08c616713 | ||
|  | 3ad693d334 | ||
|  | 7d8badc86e | ||
|  | 854d65b51b | ||
|  | 4aa67e2925 | ||
|  | 260ab2d413 | ||
|  | a824957de7 | ||
|  | 4017c172a2 | ||
|  | 65b2c936ab | ||
|  | eee190826a | ||
|  | 20a1deb187 | ||
|  | 9169913a2c | ||
|  | df773d07f3 | ||
|  | bf0ef055fb | ||
|  | 4e4842a62f | ||
|  | a34c9095c3 | ||
|  | efdbc1ff6c | ||
|  | 84a4b7d1c1 | ||
|  | a9b5faa787 | ||
|  | 49a54c0ff6 | ||
|  | 70d403e6f8 | ||
|  | eecf09f515 | ||
|  | 5b69cd4a22 | ||
|  | 61fc3346c2 | ||
|  | c80b42712a | ||
|  | 8d76d74a17 | ||
|  | b7e98abc43 | ||
|  | 6f72fed8b5 | ||
|  | 27575e9866 | ||
|  | 986ba175ce | ||
|  | 919b327fc5 | ||
|  | e05b55d4a5 | ||
|  | 073bf738dd | ||
|  | 68e8d6f304 | ||
|  | 6f24337a53 | ||
|  | 0e8f5004d6 | ||
|  | 524e4707d2 | ||
|  | 22fa5a57a5 | ||
|  | e30c76b743 | ||
|  | a0fac663f7 | ||
|  | 277e58c2e5 | ||
|  | 75a51af006 | ||
|  | 24454938e5 | ||
|  | 774ab8a8ef | ||
|  | 21dc94b709 | ||
|  | d6176872f7 | ||
|  | c396be42b9 | ||
|  | 89a72ebf0d | ||
|  | 7f7ddee0f9 | ||
|  | b99c797945 | ||
|  | 59edca4166 | ||
|  | fbba5e054a | ||
|  | ea47613d90 | ||
|  | 9d18f751c8 | ||
|  | 9745dfe2f4 | ||
|  | 29d38593d6 | ||
|  | d76bc18bb7 | ||
|  | cbe61ac315 | ||
|  | 250d97a7c4 | ||
|  | 249bf0163d | ||
|  | 20aaab0847 | ||
|  | 3e648cfb7e | ||
|  | 2106d7476d | ||
|  | 43e07e7ce3 | ||
|  | 5e4e27fed5 | ||
|  | 6c02722f56 | ||
|  | 5cfebd2680 | ||
|  | bd20b1747d | ||
|  | 674e56cea6 | ||
|  | 61809130a6 | ||
|  | f5e6e0eaf7 | ||
|  | b2c423dd84 | ||
|  | 4a9752d7cd | ||
|  | 7db9a01639 | ||
|  | e9cb5c069a | ||
|  | 03e4205700 | ||
|  | fd9278ac02 | ||
|  | 1b7c7037b8 | ||
|  | 913264c811 | ||
|  | e70b6630f9 | ||
|  | 6d53947fd8 | ||
|  | 1c0d982398 | ||
|  | a88b4040ff | ||
|  | e8073cd6f2 | ||
|  | 8281be235c | ||
|  | 9ce03e3515 | ||
|  | 667938696d | ||
|  | a165281dcf | ||
|  | 185f70f2dd | ||
|  | cd3e14f45a | ||
|  | dd87588dfe | ||
|  | 29042e1939 | ||
|  | 4dbf6559aa | ||
|  | b987b5988d | ||
|  | 6ba6bec105 | ||
|  | d95b1e2db4 | ||
|  | c1d6c7ff66 | ||
|  | 6e12794765 | ||
|  | 0f4b05e374 | ||
|  | 695b697cdf | ||
|  | 3aea0e3b2f | ||
|  | c0e92d511e | ||
|  | 51f2a20b2a | ||
|  | 333a23f222 | ||
|  | 3bf3f479f5 | ||
|  | 6241d06f27 | ||
|  | 9e81d3c87b | ||
|  | a9b2838c5f | ||
|  | fbc39614c0 | ||
|  | b2d6ac8dba | ||
|  | b090b7b1f2 | ||
|  | ba0696a0d7 | ||
|  | b57850a225 | ||
|  | 4d9029bb0e | ||
|  | bc49dde4d5 | ||
|  | afe07b2926 | ||
|  | 2411bfc20f | ||
|  | 4d4ea8a4d0 | ||
|  | 595517e68b | ||
|  | 40ab2de393 | ||
|  | 723276ae3f | ||
|  | 76c5945017 | ||
|  | 01c6fd92e8 | ||
|  | 3f230a8fdb | ||
|  | 2a6a71ea6c | ||
|  | cd23f220a0 | ||
|  | fab88ea2cc | ||
|  | 688f8615ff | ||
|  | d187a31e38 | ||
|  | c6f85464ce | ||
|  | a220b56736 | ||
|  | 0e33f45f3d | ||
|  | ff7c3012a5 | ||
|  | 20fec2943b | ||
|  | 08b30b0706 | ||
|  | bf52ce7e72 | ||
|  | 1bac5019e8 | ||
|  | 19454a92dc | ||
|  | cdbb3a015f | ||
|  | 644da2b0cb | ||
|  | 57446d78f1 | ||
|  | 3e285c0ef1 | ||
|  | a322148631 | ||
|  | 33ec9fdf47 | ||
|  | 323826111a | ||
|  | ddd3d284d9 | ||
|  | f55a300f43 | ||
|  | 08a69ebd6e | ||
|  | ddb8e26bec | ||
|  | 57ca611e12 | ||
|  | 1eff120f49 | ||
|  | 4bc6096ec0 | ||
|  | 95eb114051 | ||
|  | 9c856de49c | ||
|  | d502f79303 | ||
|  | 5224337323 | ||
|  | ef49192170 | ||
|  | c9df388731 | ||
|  | 870da2ab22 | ||
|  | 6122840241 | ||
|  | 03b00ef8da | ||
|  | 84b820abc6 | ||
|  | cc4ff568a9 | ||
|  | 665011174b | ||
|  | 37f210e9f0 | ||
|  | 9c01e3a8a0 | ||
|  | c4dd9658e7 | ||
|  | 29aa09e448 | ||
|  | 1337b6928a | ||
|  | ac35d8127e | ||
|  | a6ae1efadb | ||
|  | bd7b5c51b2 | ||
|  | 397cd77ef9 | ||
|  | 743c3dbe01 | ||
|  | 9f1c212596 | ||
|  | defd249565 | ||
|  | 8926dac78c | ||
|  | 18cac3f092 | ||
|  | 01e27426d6 | ||
|  | 0b09cc36b0 | ||
|  | f3cb484f82 | ||
|  | 0053762760 | ||
|  | d72b7299c6 | ||
|  | eb89ef79eb | ||
|  | 066d13f5b7 | ||
|  | ec06d8d606 | ||
|  | a2e4aaa9a3 | ||
|  | 26e9696ddb | ||
|  | 343191e936 | ||
|  | 3e3b667366 | ||
|  | 3b45d4727b | ||
|  | b4f3450d4a | ||
|  | 0a8b7cb494 | ||
|  | 125ace3519 | ||
|  | 109fc41474 | ||
|  | f30353087f | ||
|  | d106079d9b | ||
|  | dc3be992a3 | ||
|  | bed7d87b7f | ||
|  | 05daab5dea | ||
|  | 170e5589f9 | ||
|  | 538914aa52 | ||
|  | 81deb68c8e | ||
|  | 36986fe9c9 | ||
|  | 5791632933 | ||
|  | 289359bf0d | ||
|  | 81f6487865 | ||
|  | 21b797c3f9 | ||
|  | de8450d5c9 | ||
|  | bcb9ee4cc2 | ||
|  | 7c87447241 | ||
|  | b39d87f357 | ||
|  | 552b14b1fa | ||
|  | 5779ffd01b | ||
|  | a7c24a17f4 | ||
|  | 8743c40911 | ||
|  | 7ef6bd4b14 | ||
|  | 6af0f08dfc | ||
|  | 54ae94dde0 | ||
|  | c570f3865f | ||
|  | ed9d1da297 | ||
|  | beb483ea85 | ||
|  | 46b7fecafe | ||
|  | e476682922 | ||
|  | 8478dc8d6d | ||
|  | 9f8e41cbfa | ||
|  | 3916383dd0 | ||
|  | a60c8f7d8c | ||
|  | 4e5cd472c2 | ||
|  | e1341bc6d9 | ||
|  | d437a66019 | ||
|  | 542b46a22f | ||
|  | 6fef533fff | ||
|  | ec219fc395 | ||
|  | a555a8a374 | ||
|  | 78e9c48803 | ||
|  | 18d3e5458a | ||
|  | ac25764d12 | ||
|  | c55e7fa91a | ||
|  | e31ba2e12e | ||
|  | 73f8ae9a47 | ||
|  | 32b85625c1 | ||
|  | 629edd3108 | ||
|  | ee77b81551 | ||
|  | 2c7fdac5cd | ||
|  | d118116548 | ||
|  | 8d01956c3e | ||
|  | 1dda8c1468 | ||
|  | 111f7e917e | ||
|  | 477daf4168 | ||
|  | 8b52793f2f | ||
|  | 18b9fe5256 | ||
|  | 439e864085 | ||
|  | f45191d0e8 | ||
|  | 32feadee42 | ||
|  | c4b4bb9e8e | ||
|  | 8fd705d2af | ||
|  | 3c36135d6c | ||
|  | 02ede26893 | ||
|  | af21ad1615 | ||
|  | 07fa01528b | ||
|  | 38f716bd77 | ||
|  | 6a410b03ff | ||
|  | 3cd7bce0a3 | ||
|  | 6693540f43 | ||
|  | 647bc5a63e | ||
|  | 4f76bb2a12 | ||
|  | 9991ddecc2 | ||
|  | 3cf2cb89bb | ||
|  | 2875cfa8c7 | ||
|  | 87cbbdad72 | ||
|  | 07de3a1d94 | ||
|  | 27880a6059 | ||
|  | 0367e4117a | ||
|  | ec582d6e46 | ||
|  | 4ca706d4e6 | ||
|  | 72671c1014 | ||
|  | a3c31f4f4a | ||
|  | db8be4a66e | ||
|  | 2f7c19e80d | ||
|  | 7d9c357409 | ||
|  | abf41b073c | ||
|  | c9b07107f3 | ||
|  | 773be348a3 | ||
|  | b7bb8d9b2a | ||
|  | c7c12371ef | ||
|  | fb40b10501 | ||
|  | d4dce41d3a | ||
|  | 293b55e51f | ||
|  | 11bac66046 | ||
|  | 2a438419ab | ||
|  | 0f0aca7de5 | ||
|  | f699b9a73f | ||
|  | 214096de9e | ||
|  | a0ccb609cd | ||
|  | 4e05554b3e | ||
|  | 04c08b9fc8 | ||
|  | 86c1c8082d | ||
|  | c5afc5feb5 | ||
|  | 8392ee4625 | ||
|  | ac881d149c | ||
|  | cc4e390c91 | ||
|  | 26c726da45 | ||
|  | 358f3d9b42 | ||
|  | 3337625fa0 | ||
|  | ae2daa5a6f | ||
|  | 79f521b555 | ||
|  | fffcb98ac4 | ||
|  | 5468358f21 | ||
|  | 87044313c2 | ||
|  | 794b155827 | ||
|  | 4941ffd354 | ||
|  | aa8a3ee055 | ||
|  | c1d17c83f8 | ||
|  | db030016fa | ||
|  | ae04f55882 | ||
|  | b40fab35f6 | ||
|  | 644deee8b5 | ||
|  | c7302c46e5 | ||
|  | 4948551703 | ||
|  | d4c1b3b0bd | ||
|  | bbdb072634 | ||
|  | d7bf003d51 | ||
|  | 5a827eb3d4 | ||
|  | b37076136b | ||
|  | 3574ab253f | ||
|  | 312a30578b | ||
|  | 8243e73413 | ||
|  | 5175fe8107 | ||
|  | 2acb767640 | ||
|  | a9b1dcb32a | ||
|  | 8f8577b7c6 | ||
|  | 0225d34b74 | ||
|  | 8d1e27a1a5 | ||
|  | e4ea6e1ec3 | ||
|  | 8137d41ce5 | ||
|  | 4b7f0bd374 | ||
|  | f9ad97b978 | ||
|  | b145a17d11 | ||
|  | 3430e2bdac | ||
|  | cdcf925378 | ||
|  | 76029cbf09 | ||
|  | b9c1653c1c | ||
|  | f6c01520ae | ||
|  | 0fb4de85c4 | ||
|  | ffe7363776 | ||
|  | 4a27a7dc58 | ||
|  | 3b3d5b12bc | ||
|  | 380e51ca50 | ||
|  | aea7207b9f | ||
|  | 9593739938 | ||
|  | 40ebb533b3 | ||
|  | 7fe26ee719 | ||
|  | 28d63ad8e1 | ||
|  | 56eeea1e63 | ||
|  | 642a2cf165 | ||
|  | e16feb27f4 | ||
|  | 83ae7ba08d | ||
|  | a86f8a81a2 | ||
|  | 28abcef1ca | ||
|  | 32d15d79f1 | ||
|  | 538ac604a8 | ||
|  | 009b70f5b2 | ||
|  | f7c1e10b5a | ||
|  | 3f3e8be004 | ||
|  | cb612360ca | ||
|  | 6a8c2cb717 | ||
|  | c8a8b851d8 | ||
|  | ba9a734ba7 | ||
|  | b08374f0ba | ||
|  | c2f8858aab | ||
|  | 1f81fa1c6c | ||
|  | db44a5bca7 | ||
|  | 53e1815c1d | ||
|  | 20985d515f | ||
|  | 0334004b11 | ||
|  | 95e2b37d62 | ||
|  | dba1b8a7e9 | ||
|  | ee29ed26ff | ||
|  | a08ae722c1 | ||
|  | b3c1c0ccad | ||
|  | e1fa65f5ef | ||
|  | a2e848a7fa | ||
|  | 67fbffc964 | ||
|  | c3b4359e87 | ||
|  | 11ed5d62ba | ||
|  | 5827170815 | ||
|  | ca25b816fa | ||
|  | a9db0e8ebe | ||
|  | a0791455e1 | ||
|  | efb0ee4c02 | ||
|  | df1968157c | ||
|  | 355aac2a1a | ||
|  | b93b66edfb | ||
|  | 92a4e77288 | ||
|  | 7ac646ff94 | ||
|  | ef6aa9f41b | ||
|  | df9e7385ad | ||
|  | e065ac45dc | ||
|  | 745af5309d | ||
|  | 952f1cf8d0 | ||
|  | 86a55fe55a | ||
|  | 88c6694ffc | ||
|  | 20826e0f08 | ||
|  | e474096119 | ||
|  | 075f286130 | ||
|  | 32e3cab116 | ||
|  | 49ff4299c6 | ||
|  | 4d18a4802d | ||
|  | d613791104 | ||
|  | 44f7f79bd9 | ||
|  | 1cdfbbadaa | ||
|  | 76a31b6fd6 | ||
|  | 0ad3d06ef9 | ||
|  | fb0fd8ddc4 | ||
|  | 2a9913b8fb | ||
|  | 9b8d2ed469 | ||
|  | 17148df06d | ||
|  | d93089fcc0 | ||
|  | 870995933a | ||
|  | d6c2e47bbd | ||
|  | e2b2bf1e0d | ||
|  | c4a18ee64b | ||
|  | 7143996d26 | ||
|  | 22f78a2c52 | ||
|  | bd7517cfd4 | ||
|  | 9bffce9dc5 | ||
|  | 10f6a17857 | ||
|  | 2197c2481a | ||
|  | 8d90e640b0 | ||
|  | 368870a2fc | ||
|  | 945a19bb61 | ||
|  | b0abc384bc | ||
|  | 8f45e9a518 | ||
|  | b06f1d1982 | ||
|  | 4365350430 | ||
|  | 3b158cb726 | ||
|  | 2298a34c37 | ||
|  | 633039c528 | ||
|  | ee31d5e24d | ||
|  | f590aa11f7 | ||
|  | 6b7f48644c | ||
|  | 21aac75533 | ||
|  | 95b02a3197 | ||
|  | be7c444959 | ||
|  | f02d3f689d | ||
|  | 981752059c | ||
|  | 6c87ebac01 | ||
|  | a9479b3c01 | ||
|  | c5afca53a4 | ||
|  | b4cb88ab26 | ||
|  | ad4f607643 | ||
|  | c7d340e822 | ||
|  | 2c501d2380 | ||
|  | 3787e4a83c | ||
|  | 3b77e4ebf1 | ||
|  | 6eebf717d5 | ||
|  | 98f32d6f1f | ||
|  | 62f45f7b41 | ||
|  | a7d8f6599a | ||
|  | 4da6db8418 | ||
|  | d991291f2a | ||
|  | 392fb42973 | ||
|  | 13299158d1 | ||
|  | a6571b09d2 | ||
|  | 870ba445b8 | ||
|  | caaa70f630 | ||
|  | 56a8e0a09a | ||
|  | 4c08667a07 | ||
|  | 4ac6b6828c | ||
|  | c050186014 | ||
|  | 63f2606863 | ||
|  | 5160e0ba18 | ||
|  | 0aad2ee005 | ||
|  | 8a58ffda86 | ||
|  | cea8dcae3d | ||
|  | fc7e7d9331 | ||
|  | 494bff4bc0 | ||
|  | 824ee8a3dc | ||
|  | 47af38ecb8 | ||
|  | 654c790c3d | ||
|  | 7ebebb5bd9 | ||
|  | 8f921a61da | ||
|  | cfd734d84f | ||
|  | 342a697e42 | ||
|  | 918f3cde94 | ||
|  | 7b82a8669d | ||
|  | 7116f100ee | ||
|  | 42fce45585 | ||
|  | 9da57daa7f | ||
|  | e302d23317 | ||
|  | 0edfa83951 | ||
|  | a5ba049427 | ||
|  | adba69a589 | ||
|  | cc73f72d13 | ||
|  | e4f90996af | ||
|  | 974c0d2b95 | ||
|  | d1fc2a115e | ||
|  | a9373c7fb0 | ||
|  | 8b604462ac | ||
|  | 51e4a73439 | ||
|  | d42cdcfd43 | ||
|  | c18acd0859 | ||
|  | 9699ee4eff | ||
|  | c78e504bfb | ||
|  | 0eeaac1f2b | ||
|  | b578517f91 | ||
|  | c009e9979e | ||
|  | 22b6097e95 | ||
|  | 8e3446a389 | ||
|  | 1747d7a1bb | ||
|  | 8e5a876b37 | ||
|  | c71b710d7e | ||
|  | 7440b87596 | ||
|  | 583a17d627 | ||
|  | caf1a22084 | ||
|  | 29abc5e921 | ||
|  | 098dae9a7e | ||
|  | aaa7affa46 | ||
|  | 40ca846cdc | ||
|  | da277f5b27 | ||
|  | 2a24f6e2ea | ||
|  | 98e8105ec5 | ||
|  | 4a94a2b4e8 | ||
|  | 2011349eb1 | ||
|  | 8057f4a678 | ||
|  | f9ec8a0828 | ||
|  | a0030c7bdb | ||
|  | 0e4448fd3f | ||
|  | 21d2d59b50 | ||
|  | 295f177271 | ||
|  | f3154313a8 | ||
|  | e37f3b4fa3 | ||
|  | 7e5c35d06e | ||
|  | 60756aa02b | ||
|  | 3779ab90de | ||
|  | 5b5037a844 | ||
|  | 03902b0b26 | ||
|  | 883feabb8b | ||
|  | 5fb79e3253 | ||
|  | c44811fbc2 | ||
|  | c3eaa694dd | ||
|  | bd8b8abfea | ||
|  | 1a6c2e2bac | ||
|  | e2e6ae937d | ||
|  | 5b9c5d2790 | ||
|  | 896a57d4ed | ||
|  | c3de8d3a67 | ||
|  | d1a92a0a2e | ||
|  | 5f626495fd | ||
|  | 238f3c89a7 | ||
|  | 6e724eb8a5 | ||
|  | 9aec1feae3 | ||
|  | 8517de128b | ||
|  | a3e15c910c | ||
|  | a6303de4d1 | ||
|  | 5356b0e118 | ||
|  | e31309f213 | ||
|  | 6f8a70834b | ||
|  | 327cc307b3 | ||
|  | f191ba6e69 | ||
|  | a2b89411b0 | ||
|  | f66efed777 | ||
|  | f61b59fa89 | ||
|  | 6288a72036 | ||
|  | a941f0ffb6 | ||
|  | d7373a5c04 | ||
|  | 2ff485d2e0 | ||
|  | 5a67068348 | ||
|  | d39af6c9eb | ||
|  | 1789025da9 | ||
|  | 696f49497b | ||
|  | e88eba1877 | ||
|  | f8b8a10b8f | ||
|  | 01e505a5f4 | ||
|  | 5b2d9a4668 | ||
|  | 71008dc819 | ||
|  | f27e943258 | ||
|  | 9301173f7d | ||
|  | 60d95475eb | ||
|  | c8ace2edc0 | ||
|  | 0b1ba9f997 | ||
|  | f3026e33fd | ||
|  | f014a97e9a | ||
|  | ddad09a936 | ||
|  | 5dd0654105 | ||
|  | b4b664e97a | ||
|  | 551771235b | ||
|  | eb201c4084 | ||
|  | 7bfc499ec8 | ||
|  | 71e7e9c9c3 | ||
|  | 8521775389 | ||
|  | 61ad8d4c10 | ||
|  | 38a4ccd9f2 | ||
|  | cf342dd00e | ||
|  | 08ab81c54c | ||
|  | d355382f70 | ||
|  | d171ce4fba | ||
|  | 5a90fece80 | ||
|  | 994935b5da | ||
|  | 874e667849 | ||
|  | 1817f6eaf6 | ||
|  | 2e19930178 | ||
|  | 2b01461748 | ||
|  | 24b9df475c | ||
|  | 011bab3c80 | ||
|  | 699c0c3e05 | ||
|  | 5f4b28960e | ||
|  | 3837913855 | ||
|  | df4db8fa4c | ||
|  | e11e26a352 | ||
|  | bee90abbc4 | ||
|  | 8782559c33 | ||
|  | 223ddc0f68 | ||
|  | b7d001da88 | ||
|  | 3592ebef08 | ||
|  | a783d21409 | ||
|  | 92b9dbd706 | ||
|  | 89bfcafb80 | ||
|  | a74a04c5d5 | ||
|  | 0c16f0ea22 | ||
|  | 003d43b03a | ||
|  | 17328bce53 | ||
|  | a3c7af95e1 | ||
|  | 0987c9a7cf | ||
|  | bab8c1eeff | ||
|  | 8b6cc95c1b | ||
|  | 90236b87de | ||
|  | b6a133cc64 | ||
|  | e48a3edacb | ||
|  | 9c8501a84e | ||
|  | bb157eefc6 | ||
|  | 4b325676f7 | ||
|  | 0b9646136a | ||
|  | 55f38b9c35 | ||
|  | e13924cd2d | ||
|  | 7afe00f06a | ||
|  | 87b9caa7dc | ||
|  | 63f8f469b0 | ||
|  | 42ecc087cb | 
| @@ -27,6 +27,15 @@ jobs: | ||||
|           key: repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo | ||||
|   test-installation: | ||||
|     docker: | ||||
|       - image: circleci/node:6.12 | ||||
|     working_directory: ~/repo | ||||
|     steps: | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn test:installation | ||||
|   test-0xjs: | ||||
|     docker: | ||||
|       - image: circleci/node:6.12 | ||||
| @@ -40,6 +49,10 @@ jobs: | ||||
|           command: npm run testrpc -- --db testrpc_snapshot | ||||
|           background: true | ||||
|       - run: yarn lerna:run --scope 0x.js test:circleci | ||||
|       - save_cache: | ||||
|           key: coverage-0xjs-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/0x.js/coverage/lcov.info | ||||
|   test-contracts: | ||||
|     docker: | ||||
|       - image: circleci/node:6.12 | ||||
| @@ -53,6 +66,10 @@ jobs: | ||||
|           command: npm run testrpc -- --db testrpc_snapshot | ||||
|           background: true | ||||
|       - run: yarn lerna:run --scope contracts test:circleci | ||||
|       - save_cache: | ||||
|           key: coverage-contracts-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/contracts/coverage/lcov.info | ||||
|   test-deployer: | ||||
|     docker: | ||||
|       - image: circleci/node:6.12 | ||||
| @@ -66,6 +83,10 @@ jobs: | ||||
|           command: npm run testrpc -- --db testrpc_snapshot | ||||
|           background: true | ||||
|       - run: yarn lerna:run --scope @0xproject/deployer test:circleci | ||||
|       - save_cache: | ||||
|           key: coverage-deployer-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/deployer/coverage/lcov.info | ||||
|   test-rest: | ||||
|     docker: | ||||
|       - image: circleci/node:6.12 | ||||
| @@ -79,6 +100,34 @@ jobs: | ||||
|           command: npm run testrpc -- --db testrpc_snapshot | ||||
|           background: true | ||||
|       - run: yarn lerna:run --ignore contracts --ignore 0x.js --ignore @0xproject/deployer test:circleci | ||||
|       - save_cache: | ||||
|           key: coverage-assert-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/assert/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-connect-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/connect/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-dev-utils-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/dev-utils/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-json-schemas-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/json-schemas/coverage/lcov.info | ||||
|       - save_cache: | ||||
|           key: coverage-subproviders-{{ .Environment.CIRCLE_SHA1 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/subproviders/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 }} | ||||
|           paths: | ||||
|             - ~/repo/packages/metacoin/coverage/lcov.info | ||||
|   lint: | ||||
|     working_directory: ~/repo | ||||
|     docker: | ||||
| @@ -97,11 +146,53 @@ jobs: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn prettier:ci | ||||
|   submit-coverage: | ||||
|     docker: | ||||
|       - image: circleci/node:6.12 | ||||
|     working_directory: ~/repo | ||||
|     steps: | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - repo-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-contracts-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-assert-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-connect-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-dev-utils-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-json-schemas-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-subproviders-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-sol-cov-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-deployer-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-0xjs-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - restore_cache: | ||||
|           keys: | ||||
|             - coverage-metacoin-{{ .Environment.CIRCLE_SHA1 }} | ||||
|       - run: yarn report_coverage | ||||
| workflows: | ||||
|   version: 2 | ||||
|   main: | ||||
|     jobs: | ||||
|       - build | ||||
|       - test-installation: | ||||
|           requires: | ||||
|             - build | ||||
|       - test-0xjs: | ||||
|           requires: | ||||
|             - build | ||||
| @@ -120,3 +211,9 @@ workflows: | ||||
|       - lint: | ||||
|           requires: | ||||
|             - build | ||||
|       - submit-coverage: | ||||
|           requires: | ||||
|             - test-0xjs | ||||
|             - test-deployer | ||||
|             - test-rest | ||||
|             - test-contracts | ||||
|   | ||||
							
								
								
									
										17
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -68,9 +68,24 @@ generated_docs/ | ||||
| TODO.md | ||||
|  | ||||
| packages/website/public/bundle* | ||||
| packages/react-docs/example/public/bundle* | ||||
|  | ||||
| # generated binaries | ||||
| bin/ | ||||
|  | ||||
| # generated contract artifacts | ||||
| packages/contracts/src/artifacts | ||||
| packages/sol-cov/test/fixtures/artifacts | ||||
| packages/metacoin/artifacts | ||||
| packages/0x.js/test/artifacts | ||||
| packages/migrations/src/artifacts | ||||
|  | ||||
| # generated contract wrappers | ||||
| packages/0x.js/src/contract_wrappers/generated/ | ||||
| packages/contracts/src/contract_wrappers/generated/ | ||||
| packages/metacoin/src/contract_wrappers | ||||
|  | ||||
| # solc-bin in deployer | ||||
| packages/deployer/solc_bin/ | ||||
|  | ||||
| # Monorepo scripts | ||||
| packages/*/scripts/ | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| lib | ||||
| .nyc_output | ||||
| /packages/contracts/src/artifacts | ||||
| /packages/metacoin/artifacts | ||||
| /packages/migrations/src/artifacts | ||||
| package.json | ||||
| scripts/postpublish_utils.js | ||||
|   | ||||
| @@ -36,7 +36,6 @@ | ||||
|  | ||||
| *   [ ] Change requires a change to the documentation. | ||||
| *   [ ] Added tests to cover my changes. | ||||
| *   [ ] Added new entries to the relevant CHANGELOGs. | ||||
| *   [ ] Updated the new versions of the changed packages in the relevant CHANGELOGs. | ||||
| *   [ ] 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. | ||||
|   | ||||
							
								
								
									
										96
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								README.md
									
									
									
									
									
								
							| @@ -10,39 +10,43 @@ This repository is a monorepo including the 0x protocol smart contracts and nume | ||||
| [whitepaper-url]: https://0xproject.com/pdfs/0x_white_paper.pdf | ||||
|  | ||||
| [](https://circleci.com/gh/0xProject/0x-monorepo) | ||||
| [](https://coveralls.io/github/0xProject/0x-monorepo?branch=master) | ||||
| [](https://coveralls.io/github/0xProject/0x-monorepo?branch=development) | ||||
| [](https://chat.0xproject.com) | ||||
| [](https://gitter.im/0xProject/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) | ||||
| [](https://opensource.org/licenses/Apache-2.0) | ||||
| [](https://greenkeeper.io/) | ||||
|  | ||||
| ### Published Packages | ||||
|  | ||||
| | Package                                                                                | Version                                                                                                                                           | Description                                                        | | ||||
| | -------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------ | | ||||
| | [`0x.js`](/packages/0x.js)                                                             | [](https://www.npmjs.com/package/0x.js)                                                             | A Javascript library for interacting with the 0x protocol          | | ||||
| | [`chai-as-promised-typescript-typings`](/packages/chai-as-promised-typescript-typings) | [](https://www.npmjs.com/package/chai-as-promised-typescript-typings) | Chai as promised typescript typings                                | | ||||
| | [`chai-typescript-typings`](/packages/chai-typescript-typings)                         | [](https://www.npmjs.com/package/chai-typescript-typings)                         | Chai typescript typings                                            | | ||||
| | [`web3-typescript-typings`](/packages/web3-typescript-typings)                         | [](https://www.npmjs.com/package/web3-typescript-typings)                         | Web3 typescript typings                                            | | ||||
| | [`@0xproject/abi-gen`](/packages/abi-gen)                                              | [](https://www.npmjs.com/package/@0xproject/abi-gen)                                   | Tool to generate TS wrappers from smart contract ABIs              | | ||||
| | [`@0xproject/assert`](/packages/assert)                                                | [](https://www.npmjs.com/package/@0xproject/assert)                                     | Type and schema assertions used by our packages                    | | ||||
| | [`@0xproject/connect`](/packages/connect)                                              | [](https://www.npmjs.com/package/@0xproject/connect)                                   | A Javascript library for interacting with the standard relayer api | | ||||
| | [`@0xproject/dev-utils`](/packages/dev-utils)                                          | [](https://www.npmjs.com/package/@0xproject/dev-utils)                               | Dev utils to be shared across 0x projects and packages             | | ||||
| | [`@0xproject/json-schemas`](/packages/json-schemas)                                    | [](https://www.npmjs.com/package/@0xproject/json-schemas)                         | 0x-related json schemas                                            | | ||||
| | [`@0xproject/subproviders`](/packages/subproviders)                                    | [](https://www.npmjs.com/package/@0xproject/subproviders)                         | Useful web3 subproviders (e.g LedgerSubprovider)                   | | ||||
| | [`@0xproject/tslint-config`](/packages/tslint-config)                                  | [](https://www.npmjs.com/package/@0xproject/tslint-config)                       | Custom 0x development TSLint rules                                 | | ||||
| | [`@0xproject/types`](/packages/types)                                                  | [](https://www.npmjs.com/package/@0xproject/types)                                       | Shared type declarations                                           | | ||||
| | [`@0xproject/utils`](/packages/utils)                                                  | [](https://www.npmjs.com/package/@0xproject/utils)                                       | Shared utilities                                                   | | ||||
| | [`@0xproject/web3-wrapper`](/packages/web3-wrapper)                                    | [](https://www.npmjs.com/package/@0xproject/web3-wrapper)                         | Web3 wrapper                                                       | | ||||
| | Package                                                         | Version                                                                                                                               | Description                                                                 | | ||||
| | --------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------- | | ||||
| | [`0x.js`](/packages/0x.js)                                      | [](https://www.npmjs.com/package/0x.js)                                                 | A Javascript library for interacting with the 0x protocol                   | | ||||
| | [`@0xproject/abi-gen`](/packages/abi-gen)                       | [](https://www.npmjs.com/package/@0xproject/abi-gen)                       | Tool to generate TS wrappers from smart contract ABIs                       | | ||||
| | [`@0xproject/assert`](/packages/assert)                         | [](https://www.npmjs.com/package/@0xproject/assert)                         | Type and schema assertions used by our packages                             | | ||||
| | [`@0xproject/base-contract`](/packages/base-contract)           | [](https://www.npmjs.com/package/@0xproject/base-contract)           | BaseContract used by auto-generated `abi-gen` wrapper contracts             | | ||||
| | [`@0xproject/connect`](/packages/connect)                       | [](https://www.npmjs.com/package/@0xproject/connect)                       | A Javascript library for interacting with the Standard Relayer API          | | ||||
| | [`@0xproject/deployer`](/packages/deployer)                     | [](https://www.npmjs.com/package/@0xproject/deployer)                     | Solidity project compiler and deployer framework                            | | ||||
| | [`@0xproject/dev-utils`](/packages/dev-utils)                   | [](https://www.npmjs.com/package/@0xproject/dev-utils)                   | Dev utils to be shared across 0x projects and packages                      | | ||||
| | [`@0xproject/json-schemas`](/packages/json-schemas)             | [](https://www.npmjs.com/package/@0xproject/json-schemas)             | 0x-related json schemas                                                     | | ||||
| | [`@0xproject/monorepo-scripts`](/packages/monorepo-scripts)     | [](https://www.npmjs.com/package/@0xproject/monorepo-scripts)     | Monorepo scripts                                                            | | ||||
| | [`@0xproject/react-docs`](/packages/react-docs)                 | [](https://www.npmjs.com/package/@0xproject/react-docs)                 | React documentation component for rendering TypeDoc & Doxity generated JSON | | ||||
| | [`@0xproject/react-shared`](/packages/react-shared)             | [](https://www.npmjs.com/package/@0xproject/react-shared)             | 0x shared react components                                                  | | ||||
| | [`@0xproject/sra-report`](/packages/sra-report)                 | [](https://www.npmjs.com/package/@0xproject/sra-report)                 | Generate reports for standard relayer API compliance                        | | ||||
| | [`@0xproject/sol-cov`](/packages/sol-cov)                       | [](https://www.npmjs.com/package/@0xproject/sol-cov)                       | Solidity test coverage tool                                                 | | ||||
| | [`@0xproject/subproviders`](/packages/subproviders)             | [](https://www.npmjs.com/package/@0xproject/subproviders)             | Useful web3 subproviders (e.g LedgerSubprovider)                            | | ||||
| | [`@0xproject/tslint-config`](/packages/tslint-config)           | [](https://www.npmjs.com/package/@0xproject/tslint-config)           | Custom 0x development TSLint rules                                          | | ||||
| | [`@0xproject/types`](/packages/types)                           | [](https://www.npmjs.com/package/@0xproject/types)                           | Shared type declarations                                                    | | ||||
| | [`@0xproject/typescript-typings`](/packages/typescript-typings) | [](https://www.npmjs.com/package/@0xproject/typescript-typings) | Repository of types for external packages                                   | | ||||
| | [`@0xproject/utils`](/packages/utils)                           | [](https://www.npmjs.com/package/@0xproject/utils)                           | Shared utilities                                                            | | ||||
| | [`@0xproject/web3-wrapper`](/packages/web3-wrapper)             | [](https://www.npmjs.com/package/@0xproject/web3-wrapper)             | Web3 wrapper                                                                | | ||||
|  | ||||
| ### Private Packages | ||||
|  | ||||
| | Package                                                     | Description                                                      | | ||||
| | ----------------------------------------------------------- | ---------------------------------------------------------------- | | ||||
| | [`@0xproject/contracts`](/packages/contracts)               | 0x solidity smart contracts & tests                              | | ||||
| | [`@0xproject/monorepo-scripts`](/packages/monorepo-scripts) | Shared monorepo scripts                                          | | ||||
| | [`@0xproject/testnet-faucets`](/packages/testnet-faucets)   | A faucet micro-service that dispenses test ERC20 tokens or Ether | | ||||
| | [`@0xproject/website`](/packages/website)                   | 0x website & Portal DApp                                         | | ||||
| | Package                                                         | Description                                                      | | ||||
| | --------------------------------------------------------------- | ---------------------------------------------------------------- | | ||||
| | [`@0xproject/contracts`](/packages/contracts)                   | 0x solidity smart contracts & tests                              | | ||||
| | [`@0xproject/react-docs-example`](/packages/react-docs-example) | Example documentation site created with `@0xproject/react-docs`  | | ||||
| | [`@0xproject/testnet-faucets`](/packages/testnet-faucets)       | A faucet micro-service that dispenses test ERC20 tokens or Ether | | ||||
| | [`@0xproject/website`](/packages/website)                       | 0x website & Portal DApp                                         | | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| @@ -51,13 +55,25 @@ Dedicated documentation pages: | ||||
| *   [0x.js Library](https://0xproject.com/docs/0xjs) | ||||
| *   [0x Connect](https://0xproject.com/docs/connect) | ||||
| *   [Smart contracts](https://0xproject.com/docs/contracts) | ||||
| *   [Subproviders](https://0xproject.com/docs/subproviders) | ||||
| *   [Deployer](https://0xproject.com/docs/deployer) | ||||
| *   [Web3-wrapper](https://0xproject.com/docs/web3-wrapper) | ||||
| *   [JSON-schemas](https://0xproject.com/docs/json-schemas) | ||||
| *   [Sol-cov](https://0xproject.com/docs/sol-cov) | ||||
| *   [Standard Relayer API](https://github.com/0xProject/standard-relayer-api/blob/master/README.md) | ||||
|  | ||||
| Most of the packages require additional typings for external dependencies. | ||||
| You can include those by prepending @0xproject/typescript-typings package to your [`typeRoots`](http://www.typescriptlang.org/docs/handbook/tsconfig-json.html) config. | ||||
|  | ||||
| ```json | ||||
| "typeRoots": ["node_modules/@0xproject/typescript-typings/types", "node_modules/@types"], | ||||
| ``` | ||||
|  | ||||
| ## Contributing | ||||
|  | ||||
| We strongly recommend that the community help us make improvements and determine the future direction of the protocol. To report bugs within this package, please create an issue in this repository. | ||||
|  | ||||
| Please read our [contribution guidelines](./CONTRIBUTING.md) before getting started. | ||||
| #### Read our [contribution guidelines](./CONTRIBUTING.md). | ||||
|  | ||||
| ### Install dependencies | ||||
|  | ||||
| @@ -75,13 +91,17 @@ yarn install | ||||
|  | ||||
| ### Build | ||||
|  | ||||
| Build all packages | ||||
| Build all packages. You need to do this before working on any given package. Although these packages | ||||
| as independent, when run from within the monorepo, they are internally symlinked, to make development | ||||
| easier. You can change several packages and run the changes without publishing them first to NPM. When | ||||
| running `rebuild`, Lerna will figure out the dependency order of all the packages, and build them in | ||||
| this order. | ||||
|  | ||||
| ```bash | ||||
| yarn lerna:run build | ||||
| yarn lerna:rebuild | ||||
| ``` | ||||
|  | ||||
| Continuously rebuild on exchange | ||||
| Or continuously rebuild on change: | ||||
|  | ||||
| ```bash | ||||
| yarn dev | ||||
| @@ -97,24 +117,6 @@ yarn lerna:run lint | ||||
|  | ||||
| ### Run Tests | ||||
|  | ||||
| Before running the tests, you will need to spin up a [TestRPC](https://www.npmjs.com/package/ethereumjs-testrpc) instance and deploy all the 0x smart contracts. | ||||
|  | ||||
| In a separate terminal, start TestRPC (a convenience command is provided as part of this repo) | ||||
|  | ||||
| ```bash | ||||
| yarn testrpc | ||||
| ``` | ||||
|  | ||||
| Then in your main terminal run | ||||
|  | ||||
| ``` | ||||
| cd packages/contracts | ||||
| yarn migrate | ||||
| cd .. | ||||
| ``` | ||||
|  | ||||
| And finally from the root project directory run | ||||
|  | ||||
| ```bash | ||||
| yarn lerna:run test | ||||
| yarn lerna:test | ||||
| ``` | ||||
|   | ||||
							
								
								
									
										27
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,27 +1,38 @@ | ||||
| { | ||||
|     "private": true, | ||||
|     "name": "0x-monorepo", | ||||
|     "workspaces": ["packages/*"], | ||||
|     "workspaces": [ | ||||
|         "packages/*" | ||||
|     ], | ||||
|     "scripts": { | ||||
|         "dev": "lerna run --parallel build:watch", | ||||
|         "testrpc": "testrpc -p 8545 --networkId 50 -m \"${npm_package_config_mnemonic}\"", | ||||
|         "prettier": "prettier --write '**/*.{ts,tsx,json,md}' --config .prettierrc", | ||||
|         "prettier:ci": "prettier --list-different '**/*.{ts,tsx,json,md}' --config .prettierrc", | ||||
|         "report_coverage": "lcov-result-merger 'packages/*/coverage/lcov.info' | coveralls", | ||||
|         "test:installation": "node ./packages/monorepo-scripts/lib/test_installation.js", | ||||
|         "lerna:install": "yarn install", | ||||
|         "lerna:run": "lerna run", | ||||
|         "lerna:rebuild": "lerna run clean; lerna run build;", | ||||
|         "lerna:publish": | ||||
|             "yarn install; lerna run clean; lerna run build; lerna publish --registry=https://registry.npmjs.org/" | ||||
|         "lerna:test": "lerna run test", | ||||
|         "lerna:clean": "lerna run clean", | ||||
|         "lerna:build": "lerna run build", | ||||
|         "lerna:rebuild": "run-s lerna:clean lerna:build", | ||||
|         "lerna:publish": "run-s lerna:install lerna:rebuild script:publish", | ||||
|         "lerna:publish:dry": "run-s lerna:install lerna:rebuild script:publish:dry", | ||||
|         "lerna:stage_docs": "lerna run docs:stage", | ||||
|         "script:publish": "node ./packages/monorepo-scripts/lib/publish.js", | ||||
|         "script:publish:dry": "IS_DRY_RUN=true yarn script:publish" | ||||
|     }, | ||||
|     "config": { | ||||
|         "mnemonic": "concert load couple harbor equip island argue ramp clarify fence smart topic" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/utils": "^0.3.4", | ||||
|         "async-child-process": "^1.1.1", | ||||
|         "coveralls": "^3.0.0", | ||||
|         "ethereumjs-testrpc": "^6.0.3", | ||||
|         "lcov-result-merger": "^2.0.0", | ||||
|         "lerna": "^2.5.1", | ||||
|         "prettier": "^1.11.0", | ||||
|         "publish-release": "0xproject/publish-release", | ||||
|         "semver-sort": "^0.0.4" | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "prettier": "^1.11.1" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -8,3 +8,4 @@ test/ | ||||
| /contract_templates/ | ||||
| /generated_docs/ | ||||
| /scripts/ | ||||
| /lib/src/monorepo_scripts/ | ||||
|   | ||||
							
								
								
									
										995
									
								
								packages/0x.js/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										995
									
								
								packages/0x.js/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,995 @@ | ||||
| [ | ||||
|     { | ||||
|         "version": "0.36.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Internal changes and refactoring" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fix redundant expired order removal bug", | ||||
|                 "pr": 527 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1524044013 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.36.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Moved Web3.Provider to `@0xproject/types:Provider`", | ||||
|                 "pr": 501 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add `zeroEx.exchange.getOrderStateAsync` to allow obtaining current OrderState for a signedOrder", | ||||
|                 "pr": 510 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1523462196 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.35.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Removed `ZeroExError.TransactionMiningTimeout` and moved it to '@0xproject/web3-wrapper' `Web3WrapperErrors.TransactionMiningTimeout`", | ||||
|                 "pr": 485 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1522673609 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.34.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Fix the bug causing `zeroEx.exchange.fillOrdersUpToAsync` validation to fail if there were some extra orders passed", | ||||
|                 "pr": 470 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Remove automatic instantiation of `zeroEx.orderStateWatcher`", | ||||
|                 "pr": 488 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add `zeroEx.createOrderStateWatcher` to allow creating arbitrary number of OrderStateWatchers", | ||||
|                 "pr": 488 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Added `stateLayer` setting to `OrderStateWatcherConfig` so OrderStateWatcher can be set to monitor different blockchain state layers", | ||||
|                 "pr": 488 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1522658513 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.33.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Consolidate all `console.log` calls into `logUtils` in the `@0xproject/utils` package", | ||||
|                 "pr": 452 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Consolidate `Order`, `SignedOrder`, and `ECSignature` into the `@0xproject/types` package", | ||||
|                 "pr": 456 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1521298800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.33.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add missing EthersJs typescript typings as dependency" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1520434800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.33.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Validate and lowercase all addresses in public methods", | ||||
|                 "pr": 373 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Improve validation to force passing contract addresses on private networks", | ||||
|                 "pr": 385 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Change `LogErrorContractEventArgs.errorId` type from `BigNumber` to `number`", | ||||
|                 "pr": 413 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Rename all public `_unsubscribeAll` methods to `unsubscribeAll`", | ||||
|                 "pr": 415 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Move web3 typings from devDep to dep since cannot use this package without it", | ||||
|                 "pr": 429 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1520089200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.32.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix publishing issue where .npmignore was not properly excluding undesired content", | ||||
|                 "pr": 389 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1518102000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.32.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Reorganized `BlockParamLiteral` export into `@0xproject/types` package", | ||||
|                 "pr": 355 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Now using `abi-gen` package to generate ContractEventArgs types", | ||||
|                 "pr": 371 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1517929200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.32.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add `zeroEx.etherToken.getContractAddressIfExists`", | ||||
|                 "pr": 350 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Fixed the bug causing order watcher to throw if there is an event with the same signature but different indexed fields", | ||||
|                 "pr": 366 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1517756400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.31.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix the bug causing order watcher to throw if makerToken === zrx", | ||||
|                 "pr": 357 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1517410800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.31.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add the `shouldAddPersonalMessagePrefix` parameter to `signOrderHashAsync` so that the caller can decide on whether to add the personalMessage prefix before relaying the request to the signer. Parity Signer, Ledger and TestRPC add the prefix themselves, Metamask expects it to have already been added.", | ||||
|                 "pr": 349 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1517238000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.30.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add Rinkeby testnet addresses to artifacts ", | ||||
|                 "pr": 337 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Move @0xproject/types to dependencies from devDependencies fixing missing type errors" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1517151600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.30.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix a bug allowing negative fill values ", | ||||
|                 "pr": 212 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fix a bug that made it impossible to pass a custom ZRX address ", | ||||
|                 "pr": 341 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1516719600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.30.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add an error parameter to the order watcher callback", | ||||
|                 "pr": 312 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fix a bug making it impossible to catch some errors from awaitTransactionMinedAsync", | ||||
|                 "pr": 312 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Fix a bug in fillOrdersUpTo validation making it impossible to fill up to if user doesn't have enough balance to fully fill all the orders", | ||||
|                 "pr": 321 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1516114800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.29.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed bignumber config issue #301", | ||||
|                 "pr": 305 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1515596400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.29.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Assert baseUnit amount supplied to `toUnitAmount` is integer amount.", | ||||
|                 "pr": 287 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "`toBaseUnitAmount` throws if amount supplied has too many decimals", | ||||
|                 "pr": 287 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1514386800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.28.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add `etherTokenAddress` arg to `depositAsync` and `withdrawAsync` methods on `zeroEx.etherToken`", | ||||
|                 "pr": 267 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Removed accidentally included `unsubscribeAll` method from `zeroEx.proxy`, `zeroEx.etherToken` and `zeroEx.tokenRegistry`", | ||||
|                 "pr": 267 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Removed `etherTokenContractAddress` from `ZeroEx` constructor arg `ZeroExConfig`", | ||||
|                 "pr": 267 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Rename `SubscriptionOpts` to `BlockRange`", | ||||
|                 "pr": 272 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add `zeroEx.etherToken.subscribe`, `zeroEx.etherToken.unsubscribe`, `zeroEx.etherToken.unsubscribeAll`", | ||||
|                 "pr": 277 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add `zeroEx.etherToken.getLogsAsync`", | ||||
|                 "pr": 277 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add new public types `BlockParamLiteral`, `EtherTokenEvents`, `EtherTokenContractEventArgs`, `DepositContractEventArgs`, `WithdrawalContractEventArgs`", | ||||
|                 "pr": 277 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Support `Deposit` and `Withdraw` events on etherToken", | ||||
|                 "pr": 277 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Improve the error message when taker is not a string", | ||||
|                 "pr": 278 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1513695600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.27.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Export `TransactionOpts` type" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1511794800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.27.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Make `ZeroExConfig` required parameter of `ZeroEx` constructor", | ||||
|                 "pr": 233 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add a required property `networkId` to `ZeroExConfig`", | ||||
|                 "pr": 233 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Make all `getContractAddress` functions, `zeroEx.exchange.subscribe`, `zeroEx.exchange.getZRXTokenAddress` sync", | ||||
|                 "pr": 233 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Remove `ZeroExError.ContractNotFound` and replace it with contract-specific errors", | ||||
|                 "pr": 233 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Make `DecodedLogEvent<A>` contain `LogWithDecodedArgs<A>` under log key instead of merging it in like web3 does", | ||||
|                 "pr": 234 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Rename `removed` to `isRemoved` in `DecodedLogEvent<A>`", | ||||
|                 "pr": 234 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add config allowing to specify gasPrice and gasLimit for every transaction sending method", | ||||
|                 "pr": 235 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "All transaction sending methods now call `estimateGas` if no gas amount was supplied", | ||||
|                 "pr": 235 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Modify order validation methods to validate against the `latest` block, not against the `pending` block", | ||||
|                 "pr": 236 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1511794800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.26.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add post-formatter for logs converting `blockNumber`, `logIndex`, `transactionIndex` from hexes to numbers", | ||||
|                 "pr": 231 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Remove support for Async callback types when used in Subscribe functions", | ||||
|                 "pr": 222 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "In OrderWatcher subscribe to ZRX Token Transfer and Approval events when maker token is different", | ||||
|                 "pr": 225 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1511190000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.25.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Standardise on Cancelled over Canceled", | ||||
|                 "pr": 217 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add missing `DecodedLogEvent` type to exported types", | ||||
|                 "pr": 205 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Normalized the transactionReceipt status to be `null|0|1`, 1 meaning transaction execution successful, 0 unsuccessful and `null` if it is a pre-byzantinium transaction.", | ||||
|                 "pr": 200 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1510498800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.23.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed unhandled promise rejection error in subscribe methods", | ||||
|                 "pr": 209 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Subscribe callbacks now receive an error object as their first argument" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1510412400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.22.6", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add a timeout parameter to transaction awaiting", | ||||
|                 "pr": 206 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1510239600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.22.5", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Re-publish v0.22.4 to fix publishing issue" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1509980400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.22.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Upgraded bignumber.js to a new version that ships with native typings" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1508857200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.22.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed an issue with new version of testrpc and unlimited proxy allowance", | ||||
|                 "pr": 199 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1508857200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.22.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed rounding of maker fill amount and incorrect validation of partial fees", | ||||
|                 "pr": 197 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1508770800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.22.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Started using `OrderFillRequest` interface instead of `OrderFillOrKillRequest` interface for `zeroEx.exchange.batchFillOrKill`", | ||||
|                 "pr": 187 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Removed `OrderFillOrKillRequest`", | ||||
|                 "pr": 187 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1508079600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.21.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Made 0x.js more type-safe by making `getLogsAsync` and `subscribe/subscribeAsync` generics parametrized with arg type", | ||||
|                 "pr": 194 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1507820400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.21.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed a bug causing order fills to throw `INSUFFICIENT_TAKER_ALLOWANCE`", | ||||
|                 "pr": 193 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1507734000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.21.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Exported `ContractEventArg` as a public type", | ||||
|                 "pr": 190 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1507647600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.21.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed a bug in subscriptions", | ||||
|                 "pr": 189 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1507647600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.21.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Complete rewrite of subscription logic", | ||||
|                 "pr": 182 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Subscriptions no longer return historical logs. If you want them - use `getLogsAsync`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Subscriptions now use [ethereumjs-blockstream](https://github.com/ethereumjs/ethereumjs-blockstream) under the hood" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Subscriptions correctly handle block re-orgs (forks)" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Subscriptions correctly backfill logs (connection problems)" | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "They no longer setup filters on the underlying nodes, so you can use them with infura without a filter Subprovider" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Removed `ContractEventEmitter` and added `LogEvent`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Renamed `zeroEx.token.subscribeAsync` to `zeroEx.token.subscribe`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.token.unsubscribe` and `zeroEx.exchange.unsubscribe`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Renamed `zeroEx.exchange.stopWatchingAllEventsAsync` to `zeroEx.exhange.unsubscribeAll`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Renamed `zeroEx.token.stopWatchingAllEventsAsync` to `zeroEx.token.unsubscribeAll`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fixed the batch fills validation by emulating all balance & proxy allowance changes", | ||||
|                 "pr": 185 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1507561200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.20.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add `zeroEx.token.getLogsAsync`", | ||||
|                 "pr": 178 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add `zeroEx.exchange.getLogsAsync`", | ||||
|                 "pr": 178 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fixed fees validation when one of the tokens transferred is ZRX", | ||||
|                 "pr": 181 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1507129200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.19.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Made order validation optional ", | ||||
|                 "pr": 172 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added Ropsten testnet support", | ||||
|                 "pr": 173 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fixed a bug causing awaitTransactionMinedAsync to DDos backend nodes", | ||||
|                 "pr": 175 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1506610800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.18.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added `zeroEx.exchange.validateOrderFillableOrThrowAsync` to simplify orderbook pruning", | ||||
|                 "pr": 170 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1506351600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.17.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Made `zeroEx.exchange.getZRXTokenAddressAsync` public", | ||||
|                 "pr": 171 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1506351600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.16.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added the ability to specify custom contract addresses to be used with 0x.js", | ||||
|                 "pr": 165 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "ZeroExConfig.exchangeContractAddress" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "ZeroExConfig.tokenRegistryContractAddress" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "ZeroExConfig.etherTokenContractAddress" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.tokenRegistry.getContractAddressAsync`", | ||||
|                 "pr": 165 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1505833200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.15.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Added the ability to specify a historical `blockNumber` at which to query the blockchain's state when calling a token or exchange method", | ||||
|                 "pr": 161 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1504796400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.14.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed an issue with bignumber.js types not found", | ||||
|                 "pr": 160 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1504710000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.14.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed an issue with Artifact type not found", | ||||
|                 "pr": 159 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1504710000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.14.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added `zeroEx.exchange.throwLogErrorsAsErrors` method to public interface", | ||||
|                 "pr": 157 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fixed an issue with overlapping async intervals in `zeroEx.awaitTransactionMinedAsync`", | ||||
|                 "pr": 157 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fixed an issue with log decoder returning `BigNumber`s as `strings`", | ||||
|                 "pr": 157 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1504623600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.13.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Made all the functions submitting transactions to the network to immediately return transaction hash", | ||||
|                 "pr": 151 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.awaitTransactionMinedAsync`", | ||||
|                 "pr": 151 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Added `TransactionReceiptWithDecodedLogs`, `LogWithDecodedArgs`, `DecodedLogArgs` to public types", | ||||
|                 "pr": 151 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added signature validation to `validateFillOrderThrowIfInvalidAsync`", | ||||
|                 "pr": 152 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1504623600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.12.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added the support for web3@1.x.x provider", | ||||
|                 "pr": 142 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added the optional `zeroExConfig`  parameter to the constructor of `ZeroEx`", | ||||
|                 "pr": 139 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added the ability to specify `gasPrice` when instantiating `ZeroEx`", | ||||
|                 "pr": 139 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1504278000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.11.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added `zeroEx.token.setUnlimitedProxyAllowanceAsync`", | ||||
|                 "pr": 137 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.token.setUnlimitedAllowanceAsync`", | ||||
|                 "pr": 137 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.token.UNLIMITED_ALLOWANCE_IN_BASE_UNITS`", | ||||
|                 "pr": 137 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1503500400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.10.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed a bug where checksummed addresses were being pulled from artifacts and not lower-cased.", | ||||
|                 "pr": 135 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1503500400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.10.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added `zeroEx.exchange.validateFillOrderThrowIfInvalidAsync`", | ||||
|                 "pr": 128 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.exchange.validateFillOrKillOrderThrowIfInvalidAsync`", | ||||
|                 "pr": 128 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.exchange.validateCancelOrderThrowIfInvalidAsync`", | ||||
|                 "pr": 128 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.exchange.isRoundingErrorAsync`", | ||||
|                 "pr": 128 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.proxy.getContractAddressAsync`", | ||||
|                 "pr": 130 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.tokenRegistry.getTokenAddressesAsync`", | ||||
|                 "pr": 132 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.tokenRegistry.getTokenAddressBySymbolIfExistsAsync`", | ||||
|                 "pr": 132 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.tokenRegistry.getTokenAddressByNameIfExistsAsync`", | ||||
|                 "pr": 132 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.tokenRegistry.getTokenBySymbolIfExistsAsync`", | ||||
|                 "pr": 132 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.tokenRegistry.getTokenByNameIfExistsAsync`", | ||||
|                 "pr": 132 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added clear error message when checksummed address is passed to a public method", | ||||
|                 "pr": 124 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fixes the description of `shouldThrowOnInsufficientBalanceOrAllowance` in docs", | ||||
|                 "pr": 127 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1503500400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.9.3", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Update contract artifacts to include latest Kovan and Mainnet deploys", | ||||
|                 "pr": 118 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1503327600 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.9.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "*This version was unpublished because of a publishing issue.*" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Update contract artifacts to include latest Kovan and Mainnet deploys", | ||||
|                 "pr": 118 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1503241200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.9.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed the bug causing `zeroEx.token.getBalanceAsync()` to fail if no addresses available", | ||||
|                 "pr": 120 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1502809200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.9.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Migrated to the new version of smart contracts", | ||||
|                 "pr": 101 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Removed the ability to call methods on multiple authorized Exchange smart contracts", | ||||
|                 "pr": 106 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Made `zeroEx.getOrderHashHex` a static method", | ||||
|                 "pr": 107 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Cached `net_version` requests and invalidate the cache on calls to `setProvider`", | ||||
|                 "pr": 95 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Renamed `zeroEx.exchange.batchCancelOrderAsync` to `zeroEx.exchange.batchCancelOrdersAsync`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Renamed `zeroEx.exchange.batchFillOrderAsync` to `zeroEx.exchange.batchFillOrdersAsync`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Updated to typescript v2.4", | ||||
|                 "pr": 104 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Fixed an issue with incorrect balance/allowance validation when ZRX is one of the tokens traded", | ||||
|                 "pr": 109 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1500994800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.8.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Added the ability to call methods on different authorized versions of the Exchange smart contract", | ||||
|                 "pr": 82 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Updated contract artifacts to reflect latest changes to the smart contracts (0xproject/contracts#59)" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.proxy.isAuthorizedAsync` and `zeroEx.proxy.getAuthorizedAddressesAsync`", | ||||
|                 "pr": 89 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added `zeroEx.token.subscribeAsync`", | ||||
|                 "pr": 90 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Made contract invalidation functions private", | ||||
|                 "pr": 90 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "`zeroEx.token.invalidateContractInstancesAsync`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "`zeroEx.exchange.invalidateContractInstancesAsync`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "`zeroEx.proxy.invalidateContractInstance`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "`zeroEx.tokenRegistry.invalidateContractInstance`" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fixed the bug where `zeroEx.setProviderAsync` didn't invalidate etherToken contract's instance" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1499094000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.7.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Added the ability to convert Ether to wrapped Ether tokens and back via `zeroEx.etherToken.depostAsync` and `zeroEx.etherToken.withdrawAsync`", | ||||
|                 "pr": 81 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1498402800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.7.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added Kovan smart contract artifacts", | ||||
|                 "pr": 78 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Started returning fillAmount from `fillOrderAsync` and `fillUpToAsync`", | ||||
|                 "pr": 72 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Started returning cancelledAmount from `cancelOrderAsync`", | ||||
|                 "pr": 72 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Renamed type `LogCancelArgs` to `LogCancelContractEventArgs` and `LogFillArgs` to `LogFillContractEventArgs`" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1498057200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.6.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Reduced bundle size" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Improved documentation" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1497970800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.6.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Improved documentation" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1497798000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.6.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Made `ZeroEx` class accept `Web3Provider` instance instead of `Web3` instance" | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Added types for contract event arguments" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1497798000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.5.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Fixed the bug in `postpublish` script that caused that only unminified UMD bundle was uploaded to release page" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1497452400 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.5.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added `postpublish` script to publish to Github Releases with assets." | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1497452400 | ||||
|     } | ||||
| ] | ||||
| @@ -1,4 +1,39 @@ | ||||
| # CHANGELOG | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.36.1 - _April 18, 2018_ | ||||
|  | ||||
|     * Internal changes and refactoring | ||||
|     * Fix redundant expired order removal bug (#527) | ||||
|  | ||||
| ## v0.36.0 - _April 12, 2018_ | ||||
|  | ||||
|     * Moved Web3.Provider to `@0xproject/types:Provider` (#501) | ||||
|     * Add `zeroEx.exchange.getOrderStateAsync` to allow obtaining current OrderState for a signedOrder (#510) | ||||
|  | ||||
| ## v0.35.0 - _April 2, 2018_ | ||||
|  | ||||
|     * Removed `ZeroExError.TransactionMiningTimeout` and moved it to '@0xproject/web3-wrapper' `Web3WrapperErrors.TransactionMiningTimeout` (#485) | ||||
|  | ||||
| ## v0.34.0 - _April 2, 2018_ | ||||
|  | ||||
|     * Fix the bug causing `zeroEx.exchange.fillOrdersUpToAsync` validation to fail if there were some extra orders passed (#470) | ||||
|     * Remove automatic instantiation of `zeroEx.orderStateWatcher` (#488) | ||||
|     * Add `zeroEx.createOrderStateWatcher` to allow creating arbitrary number of OrderStateWatchers (#488) | ||||
|     * Added `stateLayer` setting to `OrderStateWatcherConfig` so OrderStateWatcher can be set to monitor different blockchain state layers (#488) | ||||
|  | ||||
| ## v0.33.2 - _March 18, 2018_ | ||||
|  | ||||
|     * Consolidate all `console.log` calls into `logUtils` in the `@0xproject/utils` package (#452) | ||||
|     * Consolidate `Order`, `SignedOrder`, and `ECSignature` into the `@0xproject/types` package (#456) | ||||
|  | ||||
| ## v0.33.1 - _March 8, 2018_ | ||||
|  | ||||
|     * Add missing EthersJs typescript typings as dependency | ||||
|  | ||||
| ## v0.33.0 - _March 4, 2018_ | ||||
|  | ||||
| @@ -28,10 +63,7 @@ | ||||
|  | ||||
| ## v0.31.0 - _January 30, 2018_ | ||||
|  | ||||
|     * Add the `shouldAddPersonalMessagePrefix` parameter to `signOrderHashAsync` so that the | ||||
|     caller can decide on whether to add the personalMessage prefix before relaying the request | ||||
|     to the signer. Parity Signer, Ledger and TestRPC add the prefix themselves, Metamask expects | ||||
|     it to have already been added. (#349) | ||||
|     * Add the `shouldAddPersonalMessagePrefix` parameter to `signOrderHashAsync` so that the caller can decide on whether to add the personalMessage prefix before relaying the request to the signer. Parity Signer, Ledger and TestRPC add the prefix themselves, Metamask expects it to have already been added. (#349) | ||||
|  | ||||
| ## v0.30.2 - _January 29, 2018_ | ||||
|  | ||||
| @@ -147,16 +179,16 @@ | ||||
| ## v0.21.0 - _October 10, 2017_ | ||||
|  | ||||
|     * Complete rewrite of subscription logic (#182) | ||||
|         * Subscriptions no longer return historical logs. If you want them - use `getLogsAsync` | ||||
|         * Subscriptions now use [ethereumjs-blockstream](https://github.com/ethereumjs/ethereumjs-blockstream) under the hood | ||||
|             * Subscriptions correctly handle block re-orgs (forks) | ||||
|             * Subscriptions correctly backfill logs (connection problems) | ||||
|             * They no longer setup filters on the underlying nodes, so you can use them with infura without a filter Subprovider | ||||
|         * Removed `ContractEventEmitter` and added `LogEvent` | ||||
|         * Renamed `zeroEx.token.subscribeAsync` to `zeroEx.token.subscribe` | ||||
|         * Added `zeroEx.token.unsubscribe` and `zeroEx.exchange.unsubscribe` | ||||
|         * Renamed `zeroEx.exchange.stopWatchingAllEventsAsync` to `zeroEx.exhange.unsubscribeAll` | ||||
|         * Renamed `zeroEx.token.stopWatchingAllEventsAsync` to `zeroEx.token.unsubscribeAll` | ||||
|     * Subscriptions no longer return historical logs. If you want them - use `getLogsAsync` | ||||
|     * Subscriptions now use [ethereumjs-blockstream](https://github.com/ethereumjs/ethereumjs-blockstream) under the hood | ||||
|     * Subscriptions correctly handle block re-orgs (forks) | ||||
|     * Subscriptions correctly backfill logs (connection problems) | ||||
|     * They no longer setup filters on the underlying nodes, so you can use them with infura without a filter Subprovider | ||||
|     * Removed `ContractEventEmitter` and added `LogEvent` | ||||
|     * Renamed `zeroEx.token.subscribeAsync` to `zeroEx.token.subscribe` | ||||
|     * Added `zeroEx.token.unsubscribe` and `zeroEx.exchange.unsubscribe` | ||||
|     * Renamed `zeroEx.exchange.stopWatchingAllEventsAsync` to `zeroEx.exhange.unsubscribeAll` | ||||
|     * Renamed `zeroEx.token.stopWatchingAllEventsAsync` to `zeroEx.token.unsubscribeAll` | ||||
|     * Fixed the batch fills validation by emulating all balance & proxy allowance changes (#185) | ||||
|  | ||||
| ## v0.20.0 - _October 5, 2017_ | ||||
| @@ -182,9 +214,9 @@ | ||||
| ## v0.16.0 - _September 20, 2017_ | ||||
|  | ||||
|     * Added the ability to specify custom contract addresses to be used with 0x.js (#165) | ||||
|         * ZeroExConfig.exchangeContractAddress | ||||
|         * ZeroExConfig.tokenRegistryContractAddress | ||||
|         * ZeroExConfig.etherTokenContractAddress | ||||
|     * ZeroExConfig.exchangeContractAddress | ||||
|     * ZeroExConfig.tokenRegistryContractAddress | ||||
|     * ZeroExConfig.etherTokenContractAddress | ||||
|     * Added `zeroEx.tokenRegistry.getContractAddressAsync` (#165) | ||||
|  | ||||
| ## v0.15.0 - _September 8, 2017_ | ||||
| @@ -224,11 +256,11 @@ | ||||
|     * Added `zeroEx.token.setUnlimitedAllowanceAsync` (#137) | ||||
|     * Added `zeroEx.token.UNLIMITED_ALLOWANCE_IN_BASE_UNITS` (#137) | ||||
|  | ||||
| ## v0.10.4 - _Aug 24, 2017_ | ||||
| ## v0.10.4 - _August 24, 2017_ | ||||
|  | ||||
|     * Fixed a bug where checksummed addresses were being pulled from artifacts and not lower-cased. (#135) | ||||
|  | ||||
| ## v0.10.1 - _Aug 24, 2017_ | ||||
| ## v0.10.1 - _August 24, 2017_ | ||||
|  | ||||
|     * Added `zeroEx.exchange.validateFillOrderThrowIfInvalidAsync` (#128) | ||||
|     * Added `zeroEx.exchange.validateFillOrKillOrderThrowIfInvalidAsync` (#128) | ||||
| @@ -243,20 +275,20 @@ | ||||
|     * Added clear error message when checksummed address is passed to a public method (#124) | ||||
|     * Fixes the description of `shouldThrowOnInsufficientBalanceOrAllowance` in docs (#127) | ||||
|  | ||||
| ## v0.9.3 - _Aug 22, 2017_ | ||||
| ## v0.9.3 - _August 22, 2017_ | ||||
|  | ||||
|     * Update contract artifacts to include latest Kovan and Mainnet deploys (#118) | ||||
|  | ||||
| ## v0.9.2 - _Aug 21, 2017_ | ||||
| ## v0.9.2 - _August 21, 2017_ | ||||
|  | ||||
|     * *This version was unpublished because of a publishing issue.* | ||||
|     * Update contract artifacts to include latest Kovan and Mainnet deploys (#118) | ||||
|  | ||||
| ## v0.9.1 - _Aug. 16, 2017_ | ||||
| ## v0.9.1 - _August 16, 2017_ | ||||
|  | ||||
|     * Fixed the bug causing `zeroEx.token.getBalanceAsync()` to fail if no addresses available (#120) | ||||
|  | ||||
| ## v0.9.0 - _Jul. 26, 2017_ | ||||
| ## v0.9.0 - _July 26, 2017_ | ||||
|  | ||||
|     * Migrated to the new version of smart contracts (#101) | ||||
|     * Removed the ability to call methods on multiple authorized Exchange smart contracts (#106) | ||||
| @@ -267,48 +299,48 @@ | ||||
|     * Updated to typescript v2.4 (#104) | ||||
|     * Fixed an issue with incorrect balance/allowance validation when ZRX is one of the tokens traded (#109) | ||||
|  | ||||
| ## v0.8.0 - _Jul. 4, 2017_ | ||||
| ## v0.8.0 - _July 4, 2017_ | ||||
|  | ||||
|     * Added the ability to call methods on different authorized versions of the Exchange smart contract (#82) | ||||
|     * Updated contract artifacts to reflect latest changes to the smart contracts (0xproject/contracts#59) | ||||
|     * Added `zeroEx.proxy.isAuthorizedAsync` and `zeroEx.proxy.getAuthorizedAddressesAsync` (#89) | ||||
|     * Added `zeroEx.token.subscribeAsync` (#90) | ||||
|     * Made contract invalidation functions private (#90) | ||||
|         * `zeroEx.token.invalidateContractInstancesAsync` | ||||
|         * `zeroEx.exchange.invalidateContractInstancesAsync` | ||||
|         * `zeroEx.proxy.invalidateContractInstance` | ||||
|         * `zeroEx.tokenRegistry.invalidateContractInstance` | ||||
|     * `zeroEx.token.invalidateContractInstancesAsync` | ||||
|     * `zeroEx.exchange.invalidateContractInstancesAsync` | ||||
|     * `zeroEx.proxy.invalidateContractInstance` | ||||
|     * `zeroEx.tokenRegistry.invalidateContractInstance` | ||||
|     * Fixed the bug where `zeroEx.setProviderAsync` didn't invalidate etherToken contract's instance | ||||
|  | ||||
| ## v0.7.1 - _Jun. 26, 2017_ | ||||
| ## v0.7.1 - _June 26, 2017_ | ||||
|  | ||||
|     * Added the ability to convert Ether to wrapped Ether tokens and back via `zeroEx.etherToken.depostAsync` and `zeroEx.etherToken.withdrawAsync` (#81) | ||||
|  | ||||
| ## v0.7.0 - _Jun. 22, 2017_ | ||||
| ## v0.7.0 - _June 22, 2017_ | ||||
|  | ||||
|     * Added Kovan smart contract artifacts (#78) | ||||
|     * Started returning fillAmount from `fillOrderAsync` and `fillUpToAsync` (#72) | ||||
|     * Started returning cancelledAmount from `cancelOrderAsync` (#72) | ||||
|     * Renamed type `LogCancelArgs` to `LogCancelContractEventArgs` and `LogFillArgs` to `LogFillContractEventArgs` | ||||
|  | ||||
| ## v0.6.2 - _Jun. 21, 2017_ | ||||
| ## v0.6.2 - _June 21, 2017_ | ||||
|  | ||||
|     * Reduced bundle size | ||||
|     * Improved documentation | ||||
|  | ||||
| ## v0.6.1 - _Jun. 19, 2017_ | ||||
| ## v0.6.1 - _June 19, 2017_ | ||||
|  | ||||
|     * Improved documentation | ||||
|  | ||||
| ## v0.6.0 - _Jun. 19, 2017_ | ||||
| ## v0.6.0 - _June 19, 2017_ | ||||
|  | ||||
|     * Made `ZeroEx` class accept `Web3Provider` instance instead of `Web3` instance | ||||
|     * Added types for contract event arguments | ||||
|  | ||||
| ## v0.5.2 - _Jun. 15, 2017_ | ||||
| ## v0.5.2 - _June 15, 2017_ | ||||
|  | ||||
|     * Fixed the bug in `postpublish` script that caused that only unminified UMD bundle was uploaded to release page | ||||
|  | ||||
| ## v0.5.1 - _Jun. 15, 2017_ | ||||
| ## v0.5.1 - _June 15, 2017_ | ||||
|  | ||||
|     * Added `postpublish` script to publish to Github Releases with assets. | ||||
|   | ||||
| @@ -1,5 +1,9 @@ | ||||
| ## 0x.js | ||||
|  | ||||
| A TypeScript/Javascript library for interacting with the 0x protocol. | ||||
|  | ||||
| ### Read the [Documentation](https://0xproject.com/docs/0x.js). | ||||
|  | ||||
| ## Installation | ||||
|  | ||||
| 0x.js ships as both a [UMD](https://github.com/umdjs/umd) module and a [CommonJS](https://en.wikipedia.org/wiki/CommonJS) package. | ||||
| @@ -18,6 +22,14 @@ npm install 0x.js --save | ||||
| import { ZeroEx } from '0x.js'; | ||||
| ``` | ||||
|  | ||||
| If your project is in [TypeScript](https://www.typescriptlang.org/), add the following to your `tsconfig.json`: | ||||
|  | ||||
| ```json | ||||
| "compilerOptions": { | ||||
|     "typeRoots": ["node_modules/@0xproject/typescript-typings/types", "node_modules/@types"], | ||||
| } | ||||
| ``` | ||||
|  | ||||
| #### UMD: | ||||
|  | ||||
| **Install** | ||||
| @@ -30,10 +42,66 @@ Download the UMD module from our [releases page](https://github.com/0xProject/0x | ||||
| <script type="text/javascript" src="0x.js"></script> | ||||
| ``` | ||||
|  | ||||
| ## Documentation | ||||
| ## Contributing | ||||
|  | ||||
| Extensive documentation of 0x.js can be found on [our website][docs-url]. | ||||
| We strongly recommend that the community help us make improvements and determine the future direction of the protocol. To report bugs within this package, please create an issue in this repository. | ||||
|  | ||||
| [website-url]: https://0xproject.com/ | ||||
| [whitepaper-url]: https://0xproject.com/pdfs/0x_white_paper.pdf | ||||
| [docs-url]: https://0xproject.com/docs/0xjs | ||||
| Please read our [contribution guidelines](../../CONTRIBUTING.md) before getting started. | ||||
|  | ||||
| ### Install dependencies | ||||
|  | ||||
| If you don't have yarn workspaces enabled (Yarn < v1.0) - enable them: | ||||
|  | ||||
| ```bash | ||||
| yarn config set workspaces-experimental true | ||||
| ``` | ||||
|  | ||||
| Then install dependencies | ||||
|  | ||||
| ```bash | ||||
| yarn install | ||||
| ``` | ||||
|  | ||||
| ### Build | ||||
|  | ||||
| If this is your **first** time building this package, you must first build **all** packages within the monorepo. This is because packages that depend on other packages located inside this monorepo are symlinked when run from **within** the monorepo. This allows you to make changes across multiple packages without first publishing dependent packages to NPM. To build all packages, run the following from the monorepo root directory: | ||||
|  | ||||
| ```bash | ||||
| yarn lerna:rebuild | ||||
| ``` | ||||
|  | ||||
| Or continuously rebuild on change: | ||||
|  | ||||
| ```bash | ||||
| yarn dev | ||||
| ``` | ||||
|  | ||||
| You can also build this specific package by running the following from within its directory: | ||||
|  | ||||
| ```bash | ||||
| yarn build | ||||
| ``` | ||||
|  | ||||
| or continuously rebuild on change: | ||||
|  | ||||
| ```bash | ||||
| yarn build:watch | ||||
| ``` | ||||
|  | ||||
| ### Clean | ||||
|  | ||||
| ```bash | ||||
| yarn clean | ||||
| ``` | ||||
|  | ||||
| ### Lint | ||||
|  | ||||
| ```bash | ||||
| yarn lint | ||||
| ``` | ||||
|  | ||||
| ### Run Tests | ||||
|  | ||||
| ```bash | ||||
| yarn test | ||||
| ``` | ||||
|   | ||||
							
								
								
									
										0
									
								
								packages/0x.js/coverage/.gitkeep
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								packages/0x.js/coverage/.gitkeep
									
									
									
									
									
										Normal file
									
								
							| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "0x.js", | ||||
|     "version": "0.33.0", | ||||
|     "version": "0.36.1", | ||||
|     "description": "A javascript library for interacting with the 0x protocol", | ||||
|     "keywords": [ | ||||
|         "0x.js", | ||||
| @@ -15,23 +15,42 @@ | ||||
|         "build:watch": "tsc -w", | ||||
|         "prebuild": "run-s clean generate_contract_wrappers", | ||||
|         "build": "run-p build:umd:prod build:commonjs; exit 0;", | ||||
|         "docs:json": "typedoc --excludePrivate --excludeExternals --target ES5 --json $JSON_FILE_PATH $PROJECT_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", | ||||
|         "generate_contract_wrappers": "node ../abi-gen/lib/index.js --abis 'src/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'", | ||||
|         "generate_contract_wrappers": "node ../abi-gen/lib/index.js --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 . 'src/**/*.ts' 'test/**/*.ts'", | ||||
|         "test:circleci": "run-s test:coverage report_test_coverage", | ||||
|         "test:circleci": "run-s test:coverage", | ||||
|         "test": "run-s clean test:commonjs", | ||||
|         "test:coverage": "nyc npm run test --all", | ||||
|         "report_test_coverage": "nyc report --reporter=text-lcov | coveralls", | ||||
|         "update_contracts": "for i in ${npm_package_config_artifacts}; do copyfiles -u 4 ../contracts/build/contracts/$i.json ../0x.js/src/artifacts; done;", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp", | ||||
|         "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/src/artifacts/$i.json test/artifacts; done;", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp scripts", | ||||
|         "build:umd:prod": "NODE_ENV=production webpack", | ||||
|         "build:commonjs": "tsc && copyfiles -u 2 './src/artifacts/**/*.json' ./lib/src/artifacts;", | ||||
|         "build:commonjs": "tsc && yarn update_artifacts && 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 --timeout 10000 --bail --exit" | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js --timeout 10000 --bail --exit", | ||||
|         "manual:postpublish": "yarn build; node ./scripts/postpublish.js", | ||||
|         "docs:stage": "yarn build && 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": { | ||||
|         "artifacts": "TokenTransferProxy Exchange TokenRegistry Token EtherToken" | ||||
|         "compact_artifacts": "Exchange DummyToken ZRXToken Token EtherToken TokenTransferProxy TokenRegistry", | ||||
|         "contracts": "Exchange DummyToken ZRXToken Token WETH9 TokenTransferProxy MultiSigWallet MultiSigWalletWithTimeLock MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress MaliciousToken TokenRegistry Arbitrage EtherDelta AccountLevels", | ||||
|         "postpublish": { | ||||
|             "assets": [ | ||||
|                 "packages/0x.js/_bundles/index.js", | ||||
|                 "packages/0x.js/_bundles/index.min.js" | ||||
|             ], | ||||
|             "docPublishConfigs": { | ||||
|                 "extraFileIncludes": [ | ||||
|                     "../types/src/index.ts", | ||||
|                     "./src/contract_wrappers/generated/ether_token.ts", | ||||
|                     "./src/contract_wrappers/generated/token.ts", | ||||
|                     "./src/contract_wrappers/generated/exchange.ts" | ||||
|                 ], | ||||
|                 "s3BucketPath": "s3://doc-jsons/0x.js/", | ||||
|                 "s3StagingBucketPath": "s3://staging-doc-jsons/0x.js/" | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     "repository": { | ||||
|         "type": "git", | ||||
| @@ -42,51 +61,48 @@ | ||||
|         "node": ">=6.0.0" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/abi-gen": "^0.2.4", | ||||
|         "@0xproject/dev-utils": "^0.2.0", | ||||
|         "@0xproject/tslint-config": "^0.4.10", | ||||
|         "@0xproject/deployer": "^0.4.1", | ||||
|         "@0xproject/dev-utils": "^0.3.6", | ||||
|         "@0xproject/monorepo-scripts": "^0.1.18", | ||||
|         "@0xproject/subproviders": "^0.9.0", | ||||
|         "@0xproject/tslint-config": "^0.4.16", | ||||
|         "@types/bintrees": "^1.0.2", | ||||
|         "@types/jsonschema": "^1.1.1", | ||||
|         "@types/lodash": "^4.14.86", | ||||
|         "@types/lodash": "4.14.104", | ||||
|         "@types/mocha": "^2.2.42", | ||||
|         "@types/node": "^8.0.53", | ||||
|         "@types/request": "2.47.0", | ||||
|         "@types/sinon": "^2.2.2", | ||||
|         "@types/uuid": "^3.4.2", | ||||
|         "awesome-typescript-loader": "^3.1.3", | ||||
|         "chai": "^4.0.1", | ||||
|         "chai-as-promised": "^7.1.0", | ||||
|         "chai-as-promised-typescript-typings": "^0.0.10", | ||||
|         "chai-bignumber": "^2.0.1", | ||||
|         "chai-typescript-typings": "^0.0.4", | ||||
|         "copyfiles": "^1.2.0", | ||||
|         "coveralls": "^3.0.0", | ||||
|         "dirty-chai": "^2.0.1", | ||||
|         "ethers-typescript-typings": "^0.0.2", | ||||
|         "json-loader": "^0.5.4", | ||||
|         "mocha": "^4.0.1", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "nyc": "^11.0.1", | ||||
|         "opn-cli": "^3.1.0", | ||||
|         "prettier": "^1.11.1", | ||||
|         "request": "^2.81.0", | ||||
|         "request-promise-native": "^1.0.5", | ||||
|         "shx": "^0.2.2", | ||||
|         "sinon": "^4.0.0", | ||||
|         "source-map-support": "^0.5.0", | ||||
|         "truffle-hdwallet-provider": "^0.0.3", | ||||
|         "tslint": "5.8.0", | ||||
|         "typedoc": "0xProject/typedoc", | ||||
|         "types-bn": "^0.0.1", | ||||
|         "typescript": "2.7.1", | ||||
|         "web3-provider-engine": "^13.0.1", | ||||
|         "webpack": "^3.1.0" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0xproject/assert": "^0.1.0", | ||||
|         "@0xproject/base-contract": "^0.0.2", | ||||
|         "@0xproject/json-schemas": "^0.7.13", | ||||
|         "@0xproject/types": "^0.3.0", | ||||
|         "@0xproject/utils": "^0.4.0", | ||||
|         "@0xproject/web3-wrapper": "^0.2.0", | ||||
|         "@0xproject/assert": "^0.2.7", | ||||
|         "@0xproject/base-contract": "^0.2.1", | ||||
|         "@0xproject/json-schemas": "^0.7.21", | ||||
|         "@0xproject/types": "^0.6.1", | ||||
|         "@0xproject/typescript-typings": "^0.2.0", | ||||
|         "@0xproject/utils": "^0.5.2", | ||||
|         "@0xproject/web3-wrapper": "^0.6.1", | ||||
|         "bintrees": "^1.0.2", | ||||
|         "bn.js": "^4.11.8", | ||||
|         "ethereumjs-abi": "^0.6.4", | ||||
| @@ -96,7 +112,12 @@ | ||||
|         "js-sha3": "^0.7.0", | ||||
|         "lodash": "^4.17.4", | ||||
|         "uuid": "^3.1.0", | ||||
|         "web3": "^0.20.0", | ||||
|         "web3-typescript-typings": "^0.10.0" | ||||
|         "web3": "^0.20.0" | ||||
|     }, | ||||
|     "optionalDependencies": { | ||||
|         "@0xproject/migrations": "^0.0.1" | ||||
|     }, | ||||
|     "publishConfig": { | ||||
|         "access": "public" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,47 +0,0 @@ | ||||
| const execAsync = require('async-child-process').execAsync; | ||||
| const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const packageJSON = require('../package.json'); | ||||
| const tsConfig = require('../tsconfig.json'); | ||||
|  | ||||
| const cwd = __dirname + '/..'; | ||||
| const subPackageName = packageJSON.name; | ||||
| // Include any external packages that are part of the 0x.js public interface | ||||
| // to this array so that TypeDoc picks it up and adds it to the Docs JSON | ||||
| // So far, we only have @0xproject/types as part of 0x.js's public interface. | ||||
| const fileIncludes = [...tsConfig.include, '../types/src/index.ts']; | ||||
| const fileIncludesAdjusted = postpublish_utils.adjustFileIncludePaths(fileIncludes, __dirname); | ||||
| const projectFiles = fileIncludesAdjusted.join(' '); | ||||
| const S3BucketPath = 's3://0xjs-docs-jsons/'; | ||||
|  | ||||
| let tag; | ||||
| let version; | ||||
| postpublish_utils | ||||
|     .getLatestTagAndVersionAsync(subPackageName) | ||||
|     .then(function(result) { | ||||
|         tag = result.tag; | ||||
|         version = result.version; | ||||
|         const releaseName = postpublish_utils.getReleaseName(subPackageName, version); | ||||
|         const assets = [__dirname + '/../_bundles/index.js', __dirname + '/../_bundles/index.min.js']; | ||||
|         return postpublish_utils.publishReleaseNotesAsync(tag, releaseName, assets); | ||||
|     }) | ||||
|     .then(function(release) { | ||||
|         console.log('POSTPUBLISH: Release successful, generating docs...'); | ||||
|         const jsonFilePath = __dirname + '/../' + postpublish_utils.generatedDocsDirectoryName + '/index.json'; | ||||
|         return execAsync('JSON_FILE_PATH=' + jsonFilePath + ' PROJECT_FILES="' + projectFiles + '" yarn docs:json', { | ||||
|             cwd, | ||||
|         }); | ||||
|     }) | ||||
|     .then(function(result) { | ||||
|         if (result.stderr !== '') { | ||||
|             throw new Error(result.stderr); | ||||
|         } | ||||
|         const fileName = 'v' + version + '.json'; | ||||
|         console.log('POSTPUBLISH: Doc generation successful, uploading docs... as ', fileName); | ||||
|         const s3Url = S3BucketPath + fileName; | ||||
|         return execAsync('S3_URL=' + s3Url + ' yarn upload_docs_json', { | ||||
|             cwd, | ||||
|         }); | ||||
|     }) | ||||
|     .catch(function(err) { | ||||
|         throw err; | ||||
|     }); | ||||
| @@ -1,31 +0,0 @@ | ||||
| const execAsync = require('async-child-process').execAsync; | ||||
| const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const tsConfig = require('../tsconfig.json'); | ||||
|  | ||||
| const cwd = __dirname + '/..'; | ||||
| const S3BucketPath = 's3://staging-0xjs-docs-jsons/'; | ||||
| // Include any external packages that are part of the 0x.js public interface | ||||
| // to this array so that TypeDoc picks it up and adds it to the Docs JSON | ||||
| // So far, we only have @0xproject/types as part of 0x.js's public interface. | ||||
| const fileIncludes = [...tsConfig.include, '../types/src/index.ts']; | ||||
| const fileIncludesAdjusted = postpublish_utils.adjustFileIncludePaths(fileIncludes, __dirname); | ||||
| const projectFiles = fileIncludesAdjusted.join(' '); | ||||
| const jsonFilePath = __dirname + '/../' + postpublish_utils.generatedDocsDirectoryName + '/index.json'; | ||||
| const version = process.env.DOCS_VERSION; | ||||
|  | ||||
| execAsync('JSON_FILE_PATH=' + jsonFilePath + ' PROJECT_FILES="' + projectFiles + '" yarn docs:json', { | ||||
|     cwd, | ||||
| }) | ||||
|     .then(function(result) { | ||||
|         if (result.stderr !== '') { | ||||
|             throw new Error(result.stderr); | ||||
|         } | ||||
|         const fileName = 'v' + version + '.json'; | ||||
|         const s3Url = S3BucketPath + fileName; | ||||
|         return execAsync('S3_URL=' + s3Url + ' yarn upload_docs_json', { | ||||
|             cwd, | ||||
|         }); | ||||
|     }) | ||||
|     .catch(function(err) { | ||||
|         console.log(err); | ||||
|     }); | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { schemas, SchemaValidator } from '@0xproject/json-schemas'; | ||||
| import { TransactionReceiptWithDecodedLogs } from '@0xproject/types'; | ||||
| import { ECSignature, Order, Provider, SignedOrder, TransactionReceiptWithDecodedLogs } from '@0xproject/types'; | ||||
| import { AbiDecoder, BigNumber, intervalUtils } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as ethUtil from 'ethereumjs-util'; | ||||
| @@ -15,7 +15,7 @@ import { OrderStateWatcher } from './order_watcher/order_state_watcher'; | ||||
| import { zeroExConfigSchema } from './schemas/zero_ex_config_schema'; | ||||
| import { zeroExPrivateNetworkConfigSchema } from './schemas/zero_ex_private_network_config_schema'; | ||||
| import { zeroExPublicNetworkConfigSchema } from './schemas/zero_ex_public_network_config_schema'; | ||||
| import { ECSignature, Order, SignedOrder, Web3Provider, ZeroExConfig, ZeroExError } from './types'; | ||||
| import { OrderStateWatcherConfig, ZeroExConfig, ZeroExError } from './types'; | ||||
| import { assert } from './utils/assert'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { decorators } from './utils/decorators'; | ||||
| @@ -57,13 +57,7 @@ export class ZeroEx { | ||||
|      * tokenTransferProxy smart contract. | ||||
|      */ | ||||
|     public proxy: TokenTransferProxyWrapper; | ||||
|     /** | ||||
|      * An instance of the OrderStateWatcher class containing methods for watching a set of orders for relevant | ||||
|      * blockchain state changes. | ||||
|      */ | ||||
|     public orderStateWatcher: OrderStateWatcher; | ||||
|     private _web3Wrapper: Web3Wrapper; | ||||
|     private _abiDecoder: AbiDecoder; | ||||
|     /** | ||||
|      * Verifies that the elliptic curve signature `signature` was generated | ||||
|      * by signing `data` with the private key corresponding to the `signerAddress` address. | ||||
| @@ -83,7 +77,7 @@ export class ZeroEx { | ||||
|     } | ||||
|     /** | ||||
|      * Generates a pseudo-random 256-bit salt. | ||||
|      * The salt can be included in an 0x order, ensuring that the order generates a unique orderHash | ||||
|      * The salt can be included in a 0x order, ensuring that the order generates a unique orderHash | ||||
|      * and will not collide with other outstanding orders that are identical in all other parameters. | ||||
|      * @return  A pseudo-random 256-bit number that can be used as a salt. | ||||
|      */ | ||||
| @@ -121,10 +115,8 @@ export class ZeroEx { | ||||
|     public static toUnitAmount(amount: BigNumber, decimals: number): BigNumber { | ||||
|         assert.isValidBaseUnitAmount('amount', amount); | ||||
|         assert.isNumber('decimals', decimals); | ||||
|  | ||||
|         const aUnit = new BigNumber(10).pow(decimals); | ||||
|         const unit = amount.div(aUnit); | ||||
|         return unit; | ||||
|         const unitAmount = Web3Wrapper.toUnitAmount(amount, decimals); | ||||
|         return unitAmount; | ||||
|     } | ||||
|     /** | ||||
|      * A baseUnit is defined as the smallest denomination of a token. An amount expressed in baseUnits | ||||
| @@ -137,13 +129,7 @@ export class ZeroEx { | ||||
|     public static toBaseUnitAmount(amount: BigNumber, decimals: number): BigNumber { | ||||
|         assert.isBigNumber('amount', amount); | ||||
|         assert.isNumber('decimals', decimals); | ||||
|  | ||||
|         const unit = new BigNumber(10).pow(decimals); | ||||
|         const baseUnitAmount = amount.times(unit); | ||||
|         const hasDecimals = baseUnitAmount.decimalPlaces() !== 0; | ||||
|         if (hasDecimals) { | ||||
|             throw new Error(`Invalid unit amount: ${amount.toString()} - Too many decimal places`); | ||||
|         } | ||||
|         const baseUnitAmount = Web3Wrapper.toBaseUnitAmount(amount, decimals); | ||||
|         return baseUnitAmount; | ||||
|     } | ||||
|     /** | ||||
| @@ -159,12 +145,12 @@ export class ZeroEx { | ||||
|     } | ||||
|     /** | ||||
|      * Instantiates a new ZeroEx instance that provides the public interface to the 0x.js library. | ||||
|      * @param   provider    The Web3.js Provider instance you would like the 0x.js library to use for interacting with | ||||
|      * @param   provider    The Provider instance you would like the 0x.js library to use for interacting with | ||||
|      *                      the Ethereum network. | ||||
|      * @param   config      The configuration object. Look up the type for the description. | ||||
|      * @return  An instance of the 0x.js ZeroEx class. | ||||
|      */ | ||||
|     constructor(provider: Web3Provider, config: ZeroExConfig) { | ||||
|     constructor(provider: Provider, config: ZeroExConfig) { | ||||
|         assert.isWeb3Provider('provider', provider); | ||||
|         assert.doesConformToSchema('config', config, zeroExConfigSchema, [ | ||||
|             zeroExPrivateNetworkConfigSchema, | ||||
| @@ -172,21 +158,22 @@ export class ZeroEx { | ||||
|         ]); | ||||
|         const artifactJSONs = _.values(artifacts); | ||||
|         const abiArrays = _.map(artifactJSONs, artifact => artifact.abi); | ||||
|         this._abiDecoder = new AbiDecoder(abiArrays); | ||||
|         const defaults = { | ||||
|             gasPrice: config.gasPrice, | ||||
|         }; | ||||
|         this._web3Wrapper = new Web3Wrapper(provider, defaults); | ||||
|         _.forEach(abiArrays, abi => { | ||||
|             this._web3Wrapper.abiDecoder.addABI(abi); | ||||
|         }); | ||||
|         this.proxy = new TokenTransferProxyWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             config.tokenTransferProxyContractAddress, | ||||
|         ); | ||||
|         this.token = new TokenWrapper(this._web3Wrapper, config.networkId, this._abiDecoder, this.proxy); | ||||
|         this.token = new TokenWrapper(this._web3Wrapper, config.networkId, this.proxy); | ||||
|         this.exchange = new ExchangeWrapper( | ||||
|             this._web3Wrapper, | ||||
|             config.networkId, | ||||
|             this._abiDecoder, | ||||
|             this.token, | ||||
|             config.exchangeContractAddress, | ||||
|             config.zrxContractAddress, | ||||
| @@ -196,14 +183,7 @@ export class ZeroEx { | ||||
|             config.networkId, | ||||
|             config.tokenRegistryContractAddress, | ||||
|         ); | ||||
|         this.etherToken = new EtherTokenWrapper(this._web3Wrapper, config.networkId, this._abiDecoder, this.token); | ||||
|         this.orderStateWatcher = new OrderStateWatcher( | ||||
|             this._web3Wrapper, | ||||
|             this._abiDecoder, | ||||
|             this.token, | ||||
|             this.exchange, | ||||
|             config.orderWatcherConfig, | ||||
|         ); | ||||
|         this.etherToken = new EtherTokenWrapper(this._web3Wrapper, config.networkId, this.token); | ||||
|     } | ||||
|     /** | ||||
|      * Sets a new web3 provider for 0x.js. Updating the provider will stop all | ||||
| @@ -211,7 +191,7 @@ export class ZeroEx { | ||||
|      * @param   provider    The Web3Provider you would like the 0x.js library to use from now on. | ||||
|      * @param   networkId   The id of the network your provider is connected to | ||||
|      */ | ||||
|     public setProvider(provider: Web3Provider, networkId: number): void { | ||||
|     public setProvider(provider: Provider, networkId: number): void { | ||||
|         this._web3Wrapper.setProvider(provider); | ||||
|         (this.exchange as any)._invalidateContractInstances(); | ||||
|         (this.exchange as any)._setNetworkId(networkId); | ||||
| @@ -237,7 +217,7 @@ export class ZeroEx { | ||||
|      * This method currently supports TestRPC, Geth and Parity above and below V1.6.6 | ||||
|      * @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 Web3.Provider supplied to 0x.js. | ||||
|      *          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 | ||||
| @@ -260,7 +240,7 @@ export class ZeroEx { | ||||
|             msgHashHex = ethUtil.bufferToHex(msgHashBuff); | ||||
|         } | ||||
|  | ||||
|         const signature = await this._web3Wrapper.signTransactionAsync(normalizedSignerAddress, msgHashHex); | ||||
|         const signature = await this._web3Wrapper.signMessageAsync(normalizedSignerAddress, msgHashHex); | ||||
|  | ||||
|         // HACK: There is no consensus on whether the signatureHex string should be formatted as | ||||
|         // v + r + s OR r + s + v, and different clients (even different versions of the same client) | ||||
| @@ -297,44 +277,21 @@ export class ZeroEx { | ||||
|         pollingIntervalMs = 1000, | ||||
|         timeoutMs?: number, | ||||
|     ): Promise<TransactionReceiptWithDecodedLogs> { | ||||
|         let timeoutExceeded = false; | ||||
|         if (timeoutMs) { | ||||
|             setTimeout(() => (timeoutExceeded = true), timeoutMs); | ||||
|         } | ||||
|  | ||||
|         const txReceiptPromise = new Promise( | ||||
|             (resolve: (receipt: TransactionReceiptWithDecodedLogs) => void, reject) => { | ||||
|                 const intervalId = intervalUtils.setAsyncExcludingInterval( | ||||
|                     async () => { | ||||
|                         if (timeoutExceeded) { | ||||
|                             intervalUtils.clearAsyncExcludingInterval(intervalId); | ||||
|                             return reject(ZeroExError.TransactionMiningTimeout); | ||||
|                         } | ||||
|  | ||||
|                         const transactionReceipt = await this._web3Wrapper.getTransactionReceiptAsync(txHash); | ||||
|                         if (!_.isNull(transactionReceipt)) { | ||||
|                             intervalUtils.clearAsyncExcludingInterval(intervalId); | ||||
|                             const logsWithDecodedArgs = _.map( | ||||
|                                 transactionReceipt.logs, | ||||
|                                 this._abiDecoder.tryToDecodeLogOrNoop.bind(this._abiDecoder), | ||||
|                             ); | ||||
|                             const transactionReceiptWithDecodedLogArgs: TransactionReceiptWithDecodedLogs = { | ||||
|                                 ...transactionReceipt, | ||||
|                                 logs: logsWithDecodedArgs, | ||||
|                             }; | ||||
|                             resolve(transactionReceiptWithDecodedLogArgs); | ||||
|                         } | ||||
|                     }, | ||||
|                     pollingIntervalMs, | ||||
|                     (err: Error) => { | ||||
|                         intervalUtils.clearAsyncExcludingInterval(intervalId); | ||||
|                         reject(err); | ||||
|                     }, | ||||
|                 ); | ||||
|             }, | ||||
|         const transactionReceiptWithDecodedLogs = await this._web3Wrapper.awaitTransactionMinedAsync( | ||||
|             txHash, | ||||
|             pollingIntervalMs, | ||||
|             timeoutMs, | ||||
|         ); | ||||
|         const txReceipt = await txReceiptPromise; | ||||
|         return txReceipt; | ||||
|         return transactionReceiptWithDecodedLogs; | ||||
|     } | ||||
|     /** | ||||
|      * Instantiates and returns a new OrderStateWatcher 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 OrderStateWatcher class. | ||||
|      */ | ||||
|     public createOrderStateWatcher(config?: OrderStateWatcherConfig) { | ||||
|         return new OrderStateWatcher(this._web3Wrapper, this.token, this.exchange, config); | ||||
|     } | ||||
|     /* | ||||
|      * HACK: `TokenWrapper` needs a token transfer proxy address. `TokenTransferProxy` address is fetched from | ||||
|   | ||||
| @@ -0,0 +1,6 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| export abstract class BalanceAndProxyAllowanceFetcher { | ||||
|     public abstract async getBalanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber>; | ||||
|     public abstract async getProxyAllowanceAsync(tokenAddress: string, userAddress: string): Promise<BigNumber>; | ||||
| } | ||||
| @@ -0,0 +1,6 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| export abstract class OrderFilledCancelledFetcher { | ||||
|     public abstract async getFilledTakerAmountAsync(orderHash: string): Promise<BigNumber>; | ||||
|     public abstract async getCancelledTakerAmountAsync(orderHash: string): Promise<BigNumber>; | ||||
| } | ||||
| @@ -1,10 +1,10 @@ | ||||
| import * as DummyTokenArtifact from './artifacts/DummyToken.json'; | ||||
| import * as EtherTokenArtifact from './artifacts/EtherToken.json'; | ||||
| import * as ExchangeArtifact from './artifacts/Exchange.json'; | ||||
| import * as TokenArtifact from './artifacts/Token.json'; | ||||
| import * as TokenRegistryArtifact from './artifacts/TokenRegistry.json'; | ||||
| import * as TokenTransferProxyArtifact from './artifacts/TokenTransferProxy.json'; | ||||
| import * as ZRXArtifact from './artifacts/ZRX.json'; | ||||
| import * as DummyTokenArtifact from './compact_artifacts/DummyToken.json'; | ||||
| import * as EtherTokenArtifact from './compact_artifacts/EtherToken.json'; | ||||
| import * as ExchangeArtifact from './compact_artifacts/Exchange.json'; | ||||
| import * as TokenArtifact from './compact_artifacts/Token.json'; | ||||
| import * as TokenRegistryArtifact from './compact_artifacts/TokenRegistry.json'; | ||||
| import * as TokenTransferProxyArtifact from './compact_artifacts/TokenTransferProxy.json'; | ||||
| import * as ZRXArtifact from './compact_artifacts/ZRX.json'; | ||||
| import { Artifact } from './types'; | ||||
|  | ||||
| export const artifacts = { | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { BlockParamLiteral, LogWithDecodedArgs, RawLog } from '@0xproject/types'; | ||||
| import { BlockParamLiteral, ContractAbi, FilterObject, LogEntry, LogWithDecodedArgs, RawLog } from '@0xproject/types'; | ||||
| import { AbiDecoder, intervalUtils } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import { Block, BlockAndLogStreamer } from 'ethereumjs-blockstream'; | ||||
| @@ -32,19 +32,17 @@ const CONTRACT_NAME_TO_NOT_FOUND_ERROR: { | ||||
| export class ContractWrapper { | ||||
|     protected _web3Wrapper: Web3Wrapper; | ||||
|     protected _networkId: number; | ||||
|     private _abiDecoder?: AbiDecoder; | ||||
|     private _blockAndLogStreamerIfExists?: BlockAndLogStreamer; | ||||
|     private _blockAndLogStreamIntervalIfExists?: NodeJS.Timer; | ||||
|     private _filters: { [filterToken: string]: Web3.FilterObject }; | ||||
|     private _filters: { [filterToken: string]: FilterObject }; | ||||
|     private _filterCallbacks: { | ||||
|         [filterToken: string]: EventCallback<ContractEventArgs>; | ||||
|     }; | ||||
|     private _onLogAddedSubscriptionToken: string | undefined; | ||||
|     private _onLogRemovedSubscriptionToken: string | undefined; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, abiDecoder?: AbiDecoder) { | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number) { | ||||
|         this._web3Wrapper = web3Wrapper; | ||||
|         this._networkId = networkId; | ||||
|         this._abiDecoder = abiDecoder; | ||||
|         this._filters = {}; | ||||
|         this._filterCallbacks = {}; | ||||
|         this._blockAndLogStreamerIfExists = undefined; | ||||
| @@ -75,7 +73,7 @@ export class ContractWrapper { | ||||
|         address: string, | ||||
|         eventName: ContractEvents, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|         abi: Web3.ContractAbi, | ||||
|         abi: ContractAbi, | ||||
|         callback: EventCallback<ArgsType>, | ||||
|     ): string { | ||||
|         const filter = filterUtils.getFilter(address, eventName, indexFilterValues, abi); | ||||
| @@ -92,7 +90,7 @@ export class ContractWrapper { | ||||
|         eventName: ContractEvents, | ||||
|         blockRange: BlockRange, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|         abi: Web3.ContractAbi, | ||||
|         abi: ContractAbi, | ||||
|     ): Promise<Array<LogWithDecodedArgs<ArgsType>>> { | ||||
|         const filter = filterUtils.getFilter(address, eventName, indexFilterValues, abi, blockRange); | ||||
|         const logs = await this._web3Wrapper.getLogsAsync(filter); | ||||
| @@ -100,18 +98,18 @@ export class ContractWrapper { | ||||
|         return logsWithDecodedArguments; | ||||
|     } | ||||
|     protected _tryToDecodeLogOrNoop<ArgsType extends ContractEventArgs>( | ||||
|         log: Web3.LogEntry, | ||||
|         log: LogEntry, | ||||
|     ): LogWithDecodedArgs<ArgsType> | RawLog { | ||||
|         if (_.isUndefined(this._abiDecoder)) { | ||||
|         if (_.isUndefined(this._web3Wrapper.abiDecoder)) { | ||||
|             throw new Error(InternalZeroExError.NoAbiDecoder); | ||||
|         } | ||||
|         const logWithDecodedArgs = this._abiDecoder.tryToDecodeLogOrNoop(log); | ||||
|         const logWithDecodedArgs = this._web3Wrapper.abiDecoder.tryToDecodeLogOrNoop(log); | ||||
|         return logWithDecodedArgs; | ||||
|     } | ||||
|     protected async _getContractAbiAndAddressFromArtifactsAsync( | ||||
|         artifact: Artifact, | ||||
|         addressIfExists?: string, | ||||
|     ): Promise<[Web3.ContractAbi, string]> { | ||||
|     ): Promise<[ContractAbi, string]> { | ||||
|         let contractAddress: string; | ||||
|         if (_.isUndefined(addressIfExists)) { | ||||
|             if (_.isUndefined(artifact.networks[this._networkId])) { | ||||
| @@ -125,7 +123,7 @@ export class ContractWrapper { | ||||
|         if (!doesContractExist) { | ||||
|             throw new Error(CONTRACT_NAME_TO_NOT_FOUND_ERROR[artifact.contract_name]); | ||||
|         } | ||||
|         const abiAndAddress: [Web3.ContractAbi, string] = [artifact.abi, contractAddress]; | ||||
|         const abiAndAddress: [ContractAbi, string] = [artifact.abi, contractAddress]; | ||||
|         return abiAndAddress; | ||||
|     } | ||||
|     protected _getContractAddress(artifact: Artifact, addressIfExists?: string): string { | ||||
| @@ -139,8 +137,8 @@ export class ContractWrapper { | ||||
|             return addressIfExists; | ||||
|         } | ||||
|     } | ||||
|     private _onLogStateChanged<ArgsType extends ContractEventArgs>(isRemoved: boolean, log: Web3.LogEntry): void { | ||||
|         _.forEach(this._filters, (filter: Web3.FilterObject, filterToken: string) => { | ||||
|     private _onLogStateChanged<ArgsType extends ContractEventArgs>(isRemoved: boolean, log: LogEntry): void { | ||||
|         _.forEach(this._filters, (filter: FilterObject, filterToken: string) => { | ||||
|             if (filterUtils.matchesFilter(log, filter)) { | ||||
|                 const decodedLog = this._tryToDecodeLogOrNoop(log) as LogWithDecodedArgs<ArgsType>; | ||||
|                 const logEvent = { | ||||
|   | ||||
| @@ -21,8 +21,8 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|         [address: string]: EtherTokenContract; | ||||
|     } = {}; | ||||
|     private _tokenWrapper: TokenWrapper; | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, abiDecoder: AbiDecoder, tokenWrapper: TokenWrapper) { | ||||
|         super(web3Wrapper, networkId, abiDecoder); | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, tokenWrapper: TokenWrapper) { | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._tokenWrapper = tokenWrapper; | ||||
|     } | ||||
|     /** | ||||
| @@ -64,7 +64,7 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|      * equivalent number of wrapped ETH tokens. | ||||
|      * @param   etherTokenAddress   EtherToken address you wish to withdraw from. | ||||
|      * @param   amountInWei  Amount of ETH in Wei the caller wishes to withdraw. | ||||
|      * @param   withdrawer   The hex encoded user Ethereum address that would like to make the withdrawl. | ||||
|      * @param   withdrawer   The hex encoded user Ethereum address that would like to make the withdrawal. | ||||
|      * @param   txOpts       Transaction parameters. | ||||
|      * @return Transaction hash. | ||||
|      */ | ||||
| @@ -96,7 +96,7 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|     } | ||||
|     /** | ||||
|      * Gets historical logs without creating a subscription | ||||
|      * @param   etherTokenAddress   An address of the ether token that emmited the logs. | ||||
|      * @param   etherTokenAddress   An address of the ether token that emitted the logs. | ||||
|      * @param   eventName           The ether 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 | ||||
| @@ -191,7 +191,12 @@ export class EtherTokenWrapper extends ContractWrapper { | ||||
|             artifacts.EtherTokenArtifact, | ||||
|             etherTokenAddress, | ||||
|         ); | ||||
|         const contractInstance = new EtherTokenContract(this._web3Wrapper, abi, address); | ||||
|         const contractInstance = new EtherTokenContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         etherTokenContract = contractInstance; | ||||
|         this._etherTokenContractsByAddress[etherTokenAddress] = etherTokenContract; | ||||
|         return etherTokenContract; | ||||
|   | ||||
| @@ -1,31 +1,39 @@ | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { BlockParamLiteral, DecodedLogArgs, LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { | ||||
|     BlockParamLiteral, | ||||
|     DecodedLogArgs, | ||||
|     ECSignature, | ||||
|     LogEntry, | ||||
|     LogWithDecodedArgs, | ||||
|     Order, | ||||
|     SignedOrder, | ||||
| } from '@0xproject/types'; | ||||
| import { AbiDecoder, BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { artifacts } from '../artifacts'; | ||||
| import { SimpleBalanceAndProxyAllowanceFetcher } from '../fetchers/simple_balance_and_proxy_allowance_fetcher'; | ||||
| import { SimpleOrderFilledCancelledFetcher } from '../fetchers/simple_order_filled_cancelled_fetcher'; | ||||
| import { | ||||
|     BlockRange, | ||||
|     ECSignature, | ||||
|     EventCallback, | ||||
|     ExchangeContractErrCodes, | ||||
|     ExchangeContractErrs, | ||||
|     IndexedFilterValues, | ||||
|     MethodOpts, | ||||
|     Order, | ||||
|     OrderAddresses, | ||||
|     OrderCancellationRequest, | ||||
|     OrderFillRequest, | ||||
|     OrderState, | ||||
|     OrderTransactionOpts, | ||||
|     OrderValues, | ||||
|     SignedOrder, | ||||
|     ValidateOrderFillableOpts, | ||||
| } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
| import { decorators } from '../utils/decorators'; | ||||
| import { ExchangeTransferSimulator } from '../utils/exchange_transfer_simulator'; | ||||
| import { OrderStateUtils } from '../utils/order_state_utils'; | ||||
| import { OrderValidationUtils } from '../utils/order_validation_utils'; | ||||
| import { utils } from '../utils/utils'; | ||||
|  | ||||
| @@ -37,7 +45,6 @@ import { | ||||
|     LogErrorContractEventArgs, | ||||
| } from './generated/exchange'; | ||||
| import { TokenWrapper } from './token_wrapper'; | ||||
|  | ||||
| const SHOULD_VALIDATE_BY_DEFAULT = true; | ||||
|  | ||||
| interface ExchangeContractErrCodesToMsgs { | ||||
| @@ -83,12 +90,11 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|     constructor( | ||||
|         web3Wrapper: Web3Wrapper, | ||||
|         networkId: number, | ||||
|         abiDecoder: AbiDecoder, | ||||
|         tokenWrapper: TokenWrapper, | ||||
|         contractAddressIfExists?: string, | ||||
|         zrxContractAddressIfExists?: string, | ||||
|     ) { | ||||
|         super(web3Wrapper, networkId, abiDecoder); | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._tokenWrapper = tokenWrapper; | ||||
|         this._orderValidationUtils = new OrderValidationUtils(this); | ||||
|         this._contractAddressIfExists = contractAddressIfExists; | ||||
| @@ -167,7 +173,7 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|      * @param   shouldThrowOnInsufficientBalanceOrAllowance Whether or not you wish for the contract call to throw | ||||
|      *                                                      if upon execution the tokens cannot be transferred. | ||||
|      * @param   takerAddress                                The user Ethereum address who would like to fill this order. | ||||
|      *                                                      Must be available via the supplied Web3.Provider | ||||
|      *                                                      Must be available via the supplied Provider | ||||
|      *                                                      passed to 0x.js. | ||||
|      * @param   orderTransactionOpts                        Optional arguments this method accepts. | ||||
|      * @return  Transaction hash. | ||||
| @@ -232,7 +238,7 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|      *                                                      If set to false, the call will continue to fill subsequent | ||||
|      *                                                      signedOrders even when some cannot be filled. | ||||
|      * @param   takerAddress                                The user Ethereum address who would like to fill these | ||||
|      *                                                      orders. Must be available via the supplied Web3.Provider | ||||
|      *                                                      orders. Must be available via the supplied Provider | ||||
|      *                                                      passed to 0x.js. | ||||
|      * @param   orderTransactionOpts                        Optional arguments this method accepts. | ||||
|      * @return  Transaction hash. | ||||
| @@ -277,6 +283,9 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|                     zrxTokenAddress, | ||||
|                 ); | ||||
|                 filledTakerTokenAmount = filledTakerTokenAmount.plus(singleFilledTakerTokenAmount); | ||||
|                 if (filledTakerTokenAmount.eq(fillTakerTokenAmount)) { | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
| @@ -329,7 +338,7 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|      *                                                          cannot be filled. | ||||
|      * @param   takerAddress                                    The user Ethereum address who would like to fill | ||||
|      *                                                          these orders. Must be available via the supplied | ||||
|      *                                                          Web3.Provider passed to 0x.js. | ||||
|      *                                                          Provider passed to 0x.js. | ||||
|      * @param   orderTransactionOpts                            Optional arguments this method accepts. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
| @@ -410,7 +419,7 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|      *                                  signedOrder you wish to fill. | ||||
|      * @param   fillTakerTokenAmount    The total amount of the takerTokens you would like to fill. | ||||
|      * @param   takerAddress            The user Ethereum address who would like to fill this order. | ||||
|      *                                  Must be available via the supplied Web3.Provider passed to 0x.js. | ||||
|      *                                  Must be available via the supplied Provider passed to 0x.js. | ||||
|      * @param   orderTransactionOpts    Optional arguments this method accepts. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
| @@ -464,7 +473,7 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|      * filled (each to the specified fillAmount) or aborted. | ||||
|      * @param   orderFillRequests           An array of objects that conform to the OrderFillRequest interface. | ||||
|      * @param   takerAddress                The user Ethereum address who would like to fill there orders. | ||||
|      *                                      Must be available via the supplied Web3.Provider passed to 0x.js. | ||||
|      *                                      Must be available via the supplied Provider passed to 0x.js. | ||||
|      * @param   orderTransactionOpts        Optional arguments this method accepts. | ||||
|      * @return  Transaction hash. | ||||
|      */ | ||||
| @@ -759,7 +768,7 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|      *                                  signedOrder you wish to fill. | ||||
|      * @param   fillTakerTokenAmount    The total amount of the takerTokens you would like to fill. | ||||
|      * @param   takerAddress            The user Ethereum address who would like to fill this order. | ||||
|      *                                  Must be available via the supplied Web3.Provider passed to 0x.js. | ||||
|      *                                  Must be available via the supplied Provider passed to 0x.js. | ||||
|      */ | ||||
|     public async validateFillOrderThrowIfInvalidAsync( | ||||
|         signedOrder: SignedOrder, | ||||
| @@ -806,7 +815,7 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|      *                                  signedOrder you wish to fill. | ||||
|      * @param   fillTakerTokenAmount    The total amount of the takerTokens you would like to fill. | ||||
|      * @param   takerAddress            The user Ethereum address who would like to fill this order. | ||||
|      *                                  Must be available via the supplied Web3.Provider passed to 0x.js. | ||||
|      *                                  Must be available via the supplied Provider passed to 0x.js. | ||||
|      */ | ||||
|     public async validateFillOrKillOrderThrowIfInvalidAsync( | ||||
|         signedOrder: SignedOrder, | ||||
| @@ -853,10 +862,10 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|         return isRoundingError; | ||||
|     } | ||||
|     /** | ||||
|      * Checks if logs contain LogError, which is emmited by Exchange contract on transaction failure. | ||||
|      * Checks if logs contain LogError, which is emitted by Exchange contract on transaction failure. | ||||
|      * @param   logs   Transaction logs as returned by `zeroEx.awaitTransactionMinedAsync` | ||||
|      */ | ||||
|     public throwLogErrorsAsErrors(logs: Array<LogWithDecodedArgs<DecodedLogArgs> | Web3.LogEntry>): void { | ||||
|     public throwLogErrorsAsErrors(logs: Array<LogWithDecodedArgs<DecodedLogArgs> | LogEntry>): void { | ||||
|         const errLog = _.find(logs, { | ||||
|             event: ExchangeEvents.LogError, | ||||
|         }); | ||||
| @@ -867,6 +876,28 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|             throw new Error(errMessage); | ||||
|         } | ||||
|     } | ||||
|     /** | ||||
|      * Gets the latest OrderState of a signedOrder | ||||
|      * @param   signedOrder   The signedOrder | ||||
|      * @param   stateLayer    Optional, desired blockchain state layer (defaults to latest). | ||||
|      * @return  OrderState of the signedOrder | ||||
|      */ | ||||
|     public async getOrderStateAsync( | ||||
|         signedOrder: SignedOrder, | ||||
|         stateLayer: BlockParamLiteral = BlockParamLiteral.Latest, | ||||
|     ): Promise<OrderState> { | ||||
|         const simpleBalanceAndProxyAllowanceFetcher = new SimpleBalanceAndProxyAllowanceFetcher( | ||||
|             this._tokenWrapper, | ||||
|             stateLayer, | ||||
|         ); | ||||
|         const simpleOrderFilledCancelledFetcher = new SimpleOrderFilledCancelledFetcher(this, stateLayer); | ||||
|         const orderStateUtils = new OrderStateUtils( | ||||
|             simpleBalanceAndProxyAllowanceFetcher, | ||||
|             simpleOrderFilledCancelledFetcher, | ||||
|         ); | ||||
|         const orderState = orderStateUtils.getOrderStateAsync(signedOrder); | ||||
|         return orderState; | ||||
|     } | ||||
|     /** | ||||
|      * Returns the ZRX token address used by the exchange contract. | ||||
|      * @return Address of ZRX token | ||||
| @@ -914,7 +945,12 @@ export class ExchangeWrapper extends ContractWrapper { | ||||
|             artifacts.ExchangeArtifact, | ||||
|             this._contractAddressIfExists, | ||||
|         ); | ||||
|         const contractInstance = new ExchangeContract(this._web3Wrapper, abi, address); | ||||
|         const contractInstance = new ExchangeContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         this._exchangeContractIfExists = contractInstance; | ||||
|         return this._exchangeContractIfExists; | ||||
|     } | ||||
|   | ||||
| @@ -1 +0,0 @@ | ||||
| * | ||||
| @@ -121,7 +121,12 @@ export class TokenRegistryWrapper extends ContractWrapper { | ||||
|             artifacts.TokenRegistryArtifact, | ||||
|             this._contractAddressIfExists, | ||||
|         ); | ||||
|         const contractInstance = new TokenRegistryContract(this._web3Wrapper, abi, address); | ||||
|         const contractInstance = new TokenRegistryContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         this._tokenRegistryContractIfExists = contractInstance; | ||||
|         return this._tokenRegistryContractIfExists; | ||||
|     } | ||||
|   | ||||
| @@ -63,7 +63,12 @@ export class TokenTransferProxyWrapper extends ContractWrapper { | ||||
|             artifacts.TokenTransferProxyArtifact, | ||||
|             this._contractAddressIfExists, | ||||
|         ); | ||||
|         const contractInstance = new TokenTransferProxyContract(this._web3Wrapper, abi, address); | ||||
|         const contractInstance = new TokenTransferProxyContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         this._tokenTransferProxyContractIfExists = contractInstance; | ||||
|         return this._tokenTransferProxyContractIfExists; | ||||
|     } | ||||
|   | ||||
| @@ -22,13 +22,8 @@ export class TokenWrapper extends ContractWrapper { | ||||
|     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, | ||||
|         abiDecoder: AbiDecoder, | ||||
|         tokenTransferProxyWrapper: TokenTransferProxyWrapper, | ||||
|     ) { | ||||
|         super(web3Wrapper, networkId, abiDecoder); | ||||
|     constructor(web3Wrapper: Web3Wrapper, networkId: number, tokenTransferProxyWrapper: TokenTransferProxyWrapper) { | ||||
|         super(web3Wrapper, networkId); | ||||
|         this._tokenContractsByAddress = {}; | ||||
|         this._tokenTransferProxyWrapper = tokenTransferProxyWrapper; | ||||
|     } | ||||
| @@ -385,7 +380,7 @@ export class TokenWrapper extends ContractWrapper { | ||||
|     } | ||||
|     /** | ||||
|      * Gets historical logs without creating a subscription | ||||
|      * @param   tokenAddress        An address of the token that emmited the logs. | ||||
|      * @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 | ||||
| @@ -426,7 +421,12 @@ export class TokenWrapper extends ContractWrapper { | ||||
|             artifacts.TokenArtifact, | ||||
|             normalizedTokenAddress, | ||||
|         ); | ||||
|         const contractInstance = new TokenContract(this._web3Wrapper, abi, address); | ||||
|         const contractInstance = new TokenContract( | ||||
|             abi, | ||||
|             address, | ||||
|             this._web3Wrapper.getProvider(), | ||||
|             this._web3Wrapper.getContractDefaults(), | ||||
|         ); | ||||
|         tokenContract = contractInstance; | ||||
|         this._tokenContractsByAddress[normalizedTokenAddress] = tokenContract; | ||||
|         return tokenContract; | ||||
|   | ||||
| @@ -0,0 +1,28 @@ | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { BalanceAndProxyAllowanceFetcher } from '../abstract/balance_and_proxy_allowance_fetcher'; | ||||
| import { TokenWrapper } from '../contract_wrappers/token_wrapper'; | ||||
|  | ||||
| export class SimpleBalanceAndProxyAllowanceFetcher implements BalanceAndProxyAllowanceFetcher { | ||||
|     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; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,28 @@ | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { OrderFilledCancelledFetcher } from '../abstract/order_filled_cancelled_fetcher'; | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
|  | ||||
| export class SimpleOrderFilledCancelledFetcher implements OrderFilledCancelledFetcher { | ||||
|     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; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										37
									
								
								packages/0x.js/src/globals.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										37
									
								
								packages/0x.js/src/globals.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -1,43 +1,6 @@ | ||||
| declare module 'web3_beta'; | ||||
| declare module 'chai-bignumber'; | ||||
| declare module 'dirty-chai'; | ||||
| declare module 'request-promise-native'; | ||||
| declare module 'web3-provider-engine'; | ||||
| declare module 'web3-provider-engine/subproviders/rpc'; | ||||
|  | ||||
| // HACK: In order to merge the bignumber declaration added by chai-bignumber to the chai Assertion | ||||
| // interface we must use `namespace` as the Chai definitelyTyped definition does. Since we otherwise | ||||
| // disallow `namespace`, we disable tslint for the following. | ||||
| /* tslint:disable */ | ||||
| declare namespace Chai { | ||||
|     interface Assertion { | ||||
|         bignumber: Assertion; | ||||
|         // HACK: In order to comply with chai-as-promised we make eventually a `PromisedAssertion` not an `Assertion` | ||||
|         eventually: PromisedAssertion; | ||||
|     } | ||||
| } | ||||
| /* tslint:enable */ | ||||
|  | ||||
| declare module '*.json' { | ||||
|     const json: any; | ||||
|     /* tslint:disable */ | ||||
|     export default json; | ||||
|     /* tslint:enable */ | ||||
| } | ||||
|  | ||||
| declare module 'ethereumjs-abi' { | ||||
|     const soliditySHA3: (argTypes: string[], args: any[]) => Buffer; | ||||
| } | ||||
|  | ||||
| // truffle-hdwallet-provider declarations | ||||
| declare module 'truffle-hdwallet-provider' { | ||||
|     import * as Web3 from 'web3'; | ||||
|     class HDWalletProvider implements Web3.Provider { | ||||
|         constructor(mnemonic: string, rpcUrl: string); | ||||
|         public sendAsync( | ||||
|             payload: Web3.JSONRPCRequestPayload, | ||||
|             callback: (err: Error, result: Web3.JSONRPCResponsePayload) => void, | ||||
|         ): void; | ||||
|     } | ||||
|     export = HDWalletProvider; | ||||
| } | ||||
|   | ||||
							
								
								
									
										23
									
								
								packages/0x.js/src/globalsAugment.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								packages/0x.js/src/globalsAugment.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -1,23 +0,0 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| // HACK: This module overrides the Chai namespace so that we can use BigNumber types inside. | ||||
| // Source: https://github.com/Microsoft/TypeScript/issues/7352#issuecomment-191547232 | ||||
| declare global { | ||||
|     // HACK: In order to merge the bignumber declaration added by chai-bignumber to the chai Assertion | ||||
|     // interface we must use `namespace` as the Chai definitelyTyped definition does. Since we otherwise | ||||
|     // disallow `namespace`, we disable tslint for the following. | ||||
|     /* tslint:disable */ | ||||
|     namespace Chai { | ||||
|         interface NumberComparer { | ||||
|             (value: number | BigNumber, message?: string): Assertion; | ||||
|         } | ||||
|         interface NumericComparison { | ||||
|             greaterThan: NumberComparer; | ||||
|         } | ||||
|     } | ||||
|     /* tslint:enable */ | ||||
|     interface DecodedLogArg { | ||||
|         name: string; | ||||
|         value: string | BigNumber; | ||||
|     } | ||||
| } | ||||
| @@ -1,9 +1,6 @@ | ||||
| export { ZeroEx } from './0x'; | ||||
|  | ||||
| export { | ||||
|     Order, | ||||
|     SignedOrder, | ||||
|     ECSignature, | ||||
|     ZeroExError, | ||||
|     EventCallback, | ||||
|     ExchangeContractErrs, | ||||
| @@ -14,12 +11,10 @@ export { | ||||
|     OrderCancellationRequest, | ||||
|     OrderFillRequest, | ||||
|     ContractEventArgs, | ||||
|     Web3Provider, | ||||
|     ZeroExConfig, | ||||
|     MethodOpts, | ||||
|     OrderTransactionOpts, | ||||
|     TransactionOpts, | ||||
|     FilterObject, | ||||
|     LogEvent, | ||||
|     DecodedLogEvent, | ||||
|     EventWatcherCallback, | ||||
| @@ -31,9 +26,14 @@ export { | ||||
|  | ||||
| export { | ||||
|     BlockParamLiteral, | ||||
|     FilterObject, | ||||
|     BlockParam, | ||||
|     ContractEventArg, | ||||
|     LogWithDecodedArgs, | ||||
|     Order, | ||||
|     Provider, | ||||
|     SignedOrder, | ||||
|     ECSignature, | ||||
|     TransactionReceipt, | ||||
|     TransactionReceiptWithDecodedLogs, | ||||
| } from '@0xproject/types'; | ||||
|   | ||||
							
								
								
									
										8
									
								
								packages/0x.js/src/monorepo_scripts/postpublish.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								packages/0x.js/src/monorepo_scripts/postpublish.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| import { postpublishUtils } from '@0xproject/monorepo-scripts'; | ||||
|  | ||||
| import * as packageJSON from '../package.json'; | ||||
| import * as tsConfigJSON from '../tsconfig.json'; | ||||
|  | ||||
| const cwd = `${__dirname}/..`; | ||||
| // tslint:disable-next-line:no-floating-promises | ||||
| postpublishUtils.runAsync(packageJSON, tsConfigJSON, cwd); | ||||
							
								
								
									
										8
									
								
								packages/0x.js/src/monorepo_scripts/stage_docs.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								packages/0x.js/src/monorepo_scripts/stage_docs.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| import { postpublishUtils } from '@0xproject/monorepo-scripts'; | ||||
|  | ||||
| import * as packageJSON from '../package.json'; | ||||
| import * as tsConfigJSON from '../tsconfig.json'; | ||||
|  | ||||
| const cwd = `${__dirname}/..`; | ||||
| // tslint:disable-next-line:no-floating-promises | ||||
| postpublishUtils.publishDocsToStagingAsync(packageJSON, tsConfigJSON, cwd); | ||||
| @@ -1,9 +1,7 @@ | ||||
| import { BlockParamLiteral, LogEntry } from '@0xproject/types'; | ||||
| import { intervalUtils } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
|  | ||||
| import { EventWatcherCallback, ZeroExError } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
| @@ -15,7 +13,7 @@ enum LogEventState { | ||||
|     Added, | ||||
| } | ||||
|  | ||||
| /* | ||||
| /** | ||||
|  * The EventWatcher watches for blockchain events at the specified block confirmation | ||||
|  * depth. | ||||
|  */ | ||||
| @@ -23,9 +21,15 @@ export class EventWatcher { | ||||
|     private _web3Wrapper: Web3Wrapper; | ||||
|     private _pollingIntervalMs: number; | ||||
|     private _intervalIdIfExists?: NodeJS.Timer; | ||||
|     private _lastEvents: Web3.LogEntry[] = []; | ||||
|     constructor(web3Wrapper: Web3Wrapper, pollingIntervalIfExistsMs: undefined | number) { | ||||
|     private _lastEvents: LogEntry[] = []; | ||||
|     private _stateLayer: BlockParamLiteral; | ||||
|     constructor( | ||||
|         web3Wrapper: Web3Wrapper, | ||||
|         pollingIntervalIfExistsMs: undefined | number, | ||||
|         stateLayer: BlockParamLiteral = BlockParamLiteral.Latest, | ||||
|     ) { | ||||
|         this._web3Wrapper = web3Wrapper; | ||||
|         this._stateLayer = stateLayer; | ||||
|         this._pollingIntervalMs = _.isUndefined(pollingIntervalIfExistsMs) | ||||
|             ? DEFAULT_EVENT_POLLING_INTERVAL_MS | ||||
|             : pollingIntervalIfExistsMs; | ||||
| @@ -69,16 +73,16 @@ export class EventWatcher { | ||||
|         await this._emitDifferencesAsync(newEvents, LogEventState.Added, callback); | ||||
|         this._lastEvents = pendingEvents; | ||||
|     } | ||||
|     private async _getEventsAsync(): Promise<Web3.LogEntry[]> { | ||||
|     private async _getEventsAsync(): Promise<LogEntry[]> { | ||||
|         const eventFilter = { | ||||
|             fromBlock: BlockParamLiteral.Pending, | ||||
|             toBlock: BlockParamLiteral.Pending, | ||||
|             fromBlock: this._stateLayer, | ||||
|             toBlock: this._stateLayer, | ||||
|         }; | ||||
|         const events = await this._web3Wrapper.getLogsAsync(eventFilter); | ||||
|         return events; | ||||
|     } | ||||
|     private async _emitDifferencesAsync( | ||||
|         logs: Web3.LogEntry[], | ||||
|         logs: LogEntry[], | ||||
|         logEventState: LogEventState, | ||||
|         callback: EventWatcherCallback, | ||||
|     ): Promise<void> { | ||||
|   | ||||
| @@ -48,6 +48,9 @@ export class ExpirationWatcher { | ||||
|         this._orderHashByExpirationRBTree.insert(orderHash); | ||||
|     } | ||||
|     public removeOrder(orderHash: string): void { | ||||
|         if (_.isUndefined(this._expiration[orderHash])) { | ||||
|             return; // noop since order already removed | ||||
|         } | ||||
|         this._orderHashByExpirationRBTree.remove(orderHash); | ||||
|         delete this._expiration[orderHash]; | ||||
|     } | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { schemas } from '@0xproject/json-schemas'; | ||||
| import { BlockParamLiteral, LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { BlockParamLiteral, LogWithDecodedArgs, SignedOrder } from '@0xproject/types'; | ||||
| import { AbiDecoder, intervalUtils } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
| @@ -31,7 +31,6 @@ import { | ||||
|     OnOrderStateChangeCallback, | ||||
|     OrderState, | ||||
|     OrderStateWatcherConfig, | ||||
|     SignedOrder, | ||||
|     ZeroExError, | ||||
| } from '../types'; | ||||
| import { assert } from '../utils/assert'; | ||||
| @@ -60,7 +59,7 @@ const DEFAULT_CLEANUP_JOB_INTERVAL_MS = 1000 * 60 * 60; // 1h | ||||
| /** | ||||
|  * This class includes all the functionality related to watching a set of orders | ||||
|  * for potential changes in order validity/fillability. The orderWatcher notifies | ||||
|  * the subscriber of these changes so that a final decison can be made on whether | ||||
|  * the subscriber of these changes so that a final decision can be made on whether | ||||
|  * the order should be deemed invalid. | ||||
|  */ | ||||
| export class OrderStateWatcher { | ||||
| @@ -70,7 +69,6 @@ export class OrderStateWatcher { | ||||
|     private _callbackIfExists?: OnOrderStateChangeCallback; | ||||
|     private _eventWatcher: EventWatcher; | ||||
|     private _web3Wrapper: Web3Wrapper; | ||||
|     private _abiDecoder: AbiDecoder; | ||||
|     private _expirationWatcher: ExpirationWatcher; | ||||
|     private _orderStateUtils: OrderStateUtils; | ||||
|     private _orderFilledCancelledLazyStore: OrderFilledCancelledLazyStore; | ||||
| @@ -79,20 +77,17 @@ export class OrderStateWatcher { | ||||
|     private _cleanupJobIntervalIdIfExists?: NodeJS.Timer; | ||||
|     constructor( | ||||
|         web3Wrapper: Web3Wrapper, | ||||
|         abiDecoder: AbiDecoder, | ||||
|         token: TokenWrapper, | ||||
|         exchange: ExchangeWrapper, | ||||
|         config?: OrderStateWatcherConfig, | ||||
|     ) { | ||||
|         this._abiDecoder = abiDecoder; | ||||
|         this._web3Wrapper = web3Wrapper; | ||||
|         const pollingIntervalIfExistsMs = _.isUndefined(config) ? undefined : config.eventPollingIntervalMs; | ||||
|         this._eventWatcher = new EventWatcher(web3Wrapper, pollingIntervalIfExistsMs); | ||||
|         this._balanceAndProxyAllowanceLazyStore = new BalanceAndProxyAllowanceLazyStore( | ||||
|             token, | ||||
|             BlockParamLiteral.Pending, | ||||
|         ); | ||||
|         this._orderFilledCancelledLazyStore = new OrderFilledCancelledLazyStore(exchange); | ||||
|         const stateLayer = | ||||
|             _.isUndefined(config) || _.isUndefined(config.stateLayer) ? BlockParamLiteral.Latest : config.stateLayer; | ||||
|         this._eventWatcher = new EventWatcher(web3Wrapper, pollingIntervalIfExistsMs, stateLayer); | ||||
|         this._balanceAndProxyAllowanceLazyStore = new BalanceAndProxyAllowanceLazyStore(token, stateLayer); | ||||
|         this._orderFilledCancelledLazyStore = new OrderFilledCancelledLazyStore(exchange, stateLayer); | ||||
|         this._orderStateUtils = new OrderStateUtils( | ||||
|             this._balanceAndProxyAllowanceLazyStore, | ||||
|             this._orderFilledCancelledLazyStore, | ||||
| @@ -136,7 +131,7 @@ export class OrderStateWatcher { | ||||
|         } | ||||
|         delete this._orderByOrderHash[orderHash]; | ||||
|         delete this._orderStateByOrderHashCache[orderHash]; | ||||
|         const exchange = (this._orderFilledCancelledLazyStore as any)._exchange as ExchangeWrapper; | ||||
|         const exchange = (this._orderFilledCancelledLazyStore as any)._exchangeWrapper as ExchangeWrapper; | ||||
|         const zrxTokenAddress = exchange.getZRXTokenAddress(); | ||||
|  | ||||
|         this._removeFromDependentOrderHashes(signedOrder.maker, zrxTokenAddress, orderHash); | ||||
| @@ -232,7 +227,7 @@ export class OrderStateWatcher { | ||||
|             return; | ||||
|         } | ||||
|         const log = logIfExists as LogEvent; // At this moment we are sure that no error occured and log is defined. | ||||
|         const maybeDecodedLog = this._abiDecoder.tryToDecodeLogOrNoop<ContractEventArgs>(log); | ||||
|         const maybeDecodedLog = this._web3Wrapper.abiDecoder.tryToDecodeLogOrNoop<ContractEventArgs>(log); | ||||
|         const isLogDecoded = !_.isUndefined(((maybeDecodedLog as any) as LogWithDecodedArgs<ContractEventArgs>).event); | ||||
|         if (!isLogDecoded) { | ||||
|             return; // noop | ||||
| @@ -379,7 +374,7 @@ export class OrderStateWatcher { | ||||
|         } | ||||
|     } | ||||
|     private _getZRXTokenAddress(): string { | ||||
|         const exchange = (this._orderFilledCancelledLazyStore as any)._exchange as ExchangeWrapper; | ||||
|         const exchange = (this._orderFilledCancelledLazyStore as any)._exchangeWrapper as ExchangeWrapper; | ||||
|         const zrxTokenAddress = exchange.getZRXTokenAddress(); | ||||
|         return zrxTokenAddress; | ||||
|     } | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| import { SignedOrder } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { SignedOrder } from '../types'; | ||||
|  | ||||
| export class RemainingFillableCalculator { | ||||
|     private _signedOrder: SignedOrder; | ||||
|     private _isMakerTokenZRX: boolean; | ||||
|   | ||||
| @@ -2,13 +2,14 @@ import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { BalanceAndProxyAllowanceFetcher } from '../abstract/balance_and_proxy_allowance_fetcher'; | ||||
| import { TokenWrapper } from '../contract_wrappers/token_wrapper'; | ||||
|  | ||||
| /** | ||||
|  * Copy on read store for balances/proxyAllowances of tokens/accounts | ||||
|  */ | ||||
| export class BalanceAndProxyAllowanceLazyStore { | ||||
|     private _token: TokenWrapper; | ||||
| export class BalanceAndProxyAllowanceLazyStore implements BalanceAndProxyAllowanceFetcher { | ||||
|     private _tokenWrapper: TokenWrapper; | ||||
|     private _defaultBlock: BlockParamLiteral; | ||||
|     private _balance: { | ||||
|         [tokenAddress: string]: { | ||||
| @@ -21,7 +22,7 @@ export class BalanceAndProxyAllowanceLazyStore { | ||||
|         }; | ||||
|     }; | ||||
|     constructor(token: TokenWrapper, defaultBlock: BlockParamLiteral) { | ||||
|         this._token = token; | ||||
|         this._tokenWrapper = token; | ||||
|         this._defaultBlock = defaultBlock; | ||||
|         this._balance = {}; | ||||
|         this._proxyAllowance = {}; | ||||
| @@ -31,7 +32,7 @@ export class BalanceAndProxyAllowanceLazyStore { | ||||
|             const methodOpts = { | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const balance = await this._token.getBalanceAsync(tokenAddress, userAddress, methodOpts); | ||||
|             const balance = await this._tokenWrapper.getBalanceAsync(tokenAddress, userAddress, methodOpts); | ||||
|             this.setBalance(tokenAddress, userAddress, balance); | ||||
|         } | ||||
|         const cachedBalance = this._balance[tokenAddress][userAddress]; | ||||
| @@ -59,7 +60,11 @@ export class BalanceAndProxyAllowanceLazyStore { | ||||
|             const methodOpts = { | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const proxyAllowance = await this._token.getProxyAllowanceAsync(tokenAddress, userAddress, methodOpts); | ||||
|             const proxyAllowance = await this._tokenWrapper.getProxyAllowanceAsync( | ||||
|                 tokenAddress, | ||||
|                 userAddress, | ||||
|                 methodOpts, | ||||
|             ); | ||||
|             this.setProxyAllowance(tokenAddress, userAddress, proxyAllowance); | ||||
|         } | ||||
|         const cachedProxyAllowance = this._proxyAllowance[tokenAddress][userAddress]; | ||||
|   | ||||
| @@ -2,30 +2,33 @@ import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { OrderFilledCancelledFetcher } from '../abstract/order_filled_cancelled_fetcher'; | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
|  | ||||
| /** | ||||
|  * Copy on read store for filled/cancelled taker amounts | ||||
|  */ | ||||
| export class OrderFilledCancelledLazyStore { | ||||
|     private _exchange: ExchangeWrapper; | ||||
| export class OrderFilledCancelledLazyStore implements OrderFilledCancelledFetcher { | ||||
|     private _exchangeWrapper: ExchangeWrapper; | ||||
|     private _defaultBlock: BlockParamLiteral; | ||||
|     private _filledTakerAmount: { | ||||
|         [orderHash: string]: BigNumber; | ||||
|     }; | ||||
|     private _cancelledTakerAmount: { | ||||
|         [orderHash: string]: BigNumber; | ||||
|     }; | ||||
|     constructor(exchange: ExchangeWrapper) { | ||||
|         this._exchange = exchange; | ||||
|     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: BlockParamLiteral.Pending, | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const filledTakerAmount = await this._exchange.getFilledTakerAmountAsync(orderHash, methodOpts); | ||||
|             const filledTakerAmount = await this._exchangeWrapper.getFilledTakerAmountAsync(orderHash, methodOpts); | ||||
|             this.setFilledTakerAmount(orderHash, filledTakerAmount); | ||||
|         } | ||||
|         const cachedFilled = this._filledTakerAmount[orderHash]; | ||||
| @@ -40,9 +43,12 @@ export class OrderFilledCancelledLazyStore { | ||||
|     public async getCancelledTakerAmountAsync(orderHash: string): Promise<BigNumber> { | ||||
|         if (_.isUndefined(this._cancelledTakerAmount[orderHash])) { | ||||
|             const methodOpts = { | ||||
|                 defaultBlock: BlockParamLiteral.Pending, | ||||
|                 defaultBlock: this._defaultBlock, | ||||
|             }; | ||||
|             const cancelledTakerAmount = await this._exchange.getCancelledTakerAmountAsync(orderHash, methodOpts); | ||||
|             const cancelledTakerAmount = await this._exchangeWrapper.getCancelledTakerAmountAsync( | ||||
|                 orderHash, | ||||
|                 methodOpts, | ||||
|             ); | ||||
|             this.setCancelledTakerAmount(orderHash, cancelledTakerAmount); | ||||
|         } | ||||
|         const cachedCancelled = this._cancelledTakerAmount[orderHash]; | ||||
|   | ||||
| @@ -1,6 +1,16 @@ | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
|  | ||||
| import { BlockParam, BlockParamLiteral, ContractEventArg, LogWithDecodedArgs } from '@0xproject/types'; | ||||
| import { | ||||
|     BlockParam, | ||||
|     BlockParamLiteral, | ||||
|     ContractAbi, | ||||
|     ContractEventArg, | ||||
|     FilterObject, | ||||
|     LogEntryEvent, | ||||
|     LogWithDecodedArgs, | ||||
|     Order, | ||||
|     SignedOrder, | ||||
| } from '@0xproject/types'; | ||||
|  | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| @@ -28,7 +38,6 @@ export enum ZeroExError { | ||||
|     NoNetworkId = 'NO_NETWORK_ID', | ||||
|     SubscriptionNotFound = 'SUBSCRIPTION_NOT_FOUND', | ||||
|     SubscriptionAlreadyPresent = 'SUBSCRIPTION_ALREADY_PRESENT', | ||||
|     TransactionMiningTimeout = 'TRANSACTION_MINING_TIMEOUT', | ||||
| } | ||||
|  | ||||
| export enum InternalZeroExError { | ||||
| @@ -37,20 +46,11 @@ export enum InternalZeroExError { | ||||
|     WethNotInTokenRegistry = 'WETH_NOT_IN_TOKEN_REGISTRY', | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Elliptic Curve signature | ||||
|  */ | ||||
| export interface ECSignature { | ||||
|     v: number; | ||||
|     r: string; | ||||
|     s: string; | ||||
| } | ||||
|  | ||||
| export type OrderAddresses = [string, string, string, string, string]; | ||||
|  | ||||
| export type OrderValues = [BigNumber, BigNumber, BigNumber, BigNumber, BigNumber, BigNumber]; | ||||
|  | ||||
| export type LogEvent = Web3.LogEntryEvent; | ||||
| export type LogEvent = LogEntryEvent; | ||||
| export interface DecodedLogEvent<ArgsType> { | ||||
|     isRemoved: boolean; | ||||
|     log: LogWithDecodedArgs<ArgsType>; | ||||
| @@ -107,25 +107,6 @@ export interface ContractEvent { | ||||
|  | ||||
| export type ContractEventArgs = ExchangeContractEventArgs | TokenContractEventArgs | EtherTokenContractEventArgs; | ||||
|  | ||||
| export interface Order { | ||||
|     maker: string; | ||||
|     taker: string; | ||||
|     makerFee: BigNumber; | ||||
|     takerFee: BigNumber; | ||||
|     makerTokenAmount: BigNumber; | ||||
|     takerTokenAmount: BigNumber; | ||||
|     makerTokenAddress: string; | ||||
|     takerTokenAddress: string; | ||||
|     salt: BigNumber; | ||||
|     exchangeContractAddress: string; | ||||
|     feeRecipient: string; | ||||
|     expirationUnixTimestampSec: BigNumber; | ||||
| } | ||||
|  | ||||
| export interface SignedOrder extends Order { | ||||
|     ecSignature: ECSignature; | ||||
| } | ||||
|  | ||||
| //                          [address, name, symbol, decimals, ipfsHash, swarmHash] | ||||
| export type TokenMetadata = [string, string, string, number, string, string]; | ||||
|  | ||||
| @@ -174,28 +155,22 @@ export type AsyncMethod = (...args: any[]) => Promise<any>; | ||||
| export type SyncMethod = (...args: any[]) => any; | ||||
|  | ||||
| /** | ||||
|  * We re-export the `Web3.Provider` type specified in the Web3 Typescript typings | ||||
|  * since it is the type of the `provider` argument to the `ZeroEx` constructor. | ||||
|  * It is however a `Web3` library type, not a native `0x.js` type. To learn more | ||||
|  * about providers, visit https://0xproject.com/wiki#Web3-Provider-Explained | ||||
|  */ | ||||
| export type Web3Provider = Web3.Provider; | ||||
|  | ||||
| /* | ||||
|  * orderExpirationCheckingIntervalMs: How often to check for expired orders. Default: 50 | ||||
|  * eventPollingIntervalMs: How often to poll the Ethereum node for new events. Defaults: 200 | ||||
|  * orderExpirationCheckingIntervalMs: How often to check for expired orders. Default=50. | ||||
|  * eventPollingIntervalMs: How often to poll the Ethereum node for new events. Default=200. | ||||
|  * expirationMarginMs: Amount of time before order expiry that you'd like to be notified | ||||
|  * of an orders expiration. Defaults: 0 | ||||
|  * cleanupJobIntervalMs: How often to run a cleanup job which revalidates all the orders. Defaults: 1h | ||||
|  * of an orders expiration. Default=0. | ||||
|  * cleanupJobIntervalMs: How often to run a cleanup job which revalidates all the orders. Default=1hr. | ||||
|  * stateLayer: Optional blockchain state layer OrderWatcher will monitor for new events. Default=latest. | ||||
|  */ | ||||
| export interface OrderStateWatcherConfig { | ||||
|     orderExpirationCheckingIntervalMs?: number; | ||||
|     eventPollingIntervalMs?: number; | ||||
|     expirationMarginMs?: number; | ||||
|     cleanupJobIntervalMs?: number; | ||||
|     stateLayer: BlockParamLiteral; | ||||
| } | ||||
|  | ||||
| /* | ||||
| /** | ||||
|  * networkId: The id of the underlying ethereum network your provider is connected to. (1-mainnet, 3-ropsten, 4-rinkeby, 42-kovan, 50-testrpc) | ||||
|  * gasPrice: Gas price to use with every transaction | ||||
|  * exchangeContractAddress: The address of an exchange contract to use | ||||
| @@ -218,7 +193,7 @@ export type ArtifactContractName = 'ZRX' | 'TokenTransferProxy' | 'TokenRegistry | ||||
|  | ||||
| export interface Artifact { | ||||
|     contract_name: ArtifactContractName; | ||||
|     abi: Web3.ContractAbi; | ||||
|     abi: ContractAbi; | ||||
|     networks: { | ||||
|         [networkId: number]: { | ||||
|             address: string; | ||||
| @@ -226,7 +201,7 @@ export interface Artifact { | ||||
|     }; | ||||
| } | ||||
|  | ||||
| /* | ||||
| /** | ||||
|  * expectedFillTakerTokenAmount: If specified, the validation method will ensure that the | ||||
|  * supplied order maker has a sufficient allowance/balance to fill this amount of the order's | ||||
|  * takerTokenAmount. If not specified, the validation method ensures that the maker has a sufficient | ||||
| @@ -236,17 +211,17 @@ export interface ValidateOrderFillableOpts { | ||||
|     expectedFillTakerTokenAmount?: BigNumber; | ||||
| } | ||||
|  | ||||
| /* | ||||
| /** | ||||
|  * defaultBlock: The block up to which to query the blockchain state. Setting this to a historical block number | ||||
|  * let's the user query the blockchain's state at an arbitrary point in time. In order for this to work, the | ||||
|  * backing  Ethereum node must keep the entire historical state of the chain (e.g setting `--pruning=archive` | ||||
|  * flag when  running Parity). | ||||
|  */ | ||||
| export interface MethodOpts { | ||||
|     defaultBlock?: Web3.BlockParam; | ||||
|     defaultBlock?: BlockParam; | ||||
| } | ||||
|  | ||||
| /* | ||||
| /** | ||||
|  * gasPrice: Gas price in Wei to use for a transaction | ||||
|  * gasLimit: The amount of gas to send with a transaction | ||||
|  */ | ||||
| @@ -255,16 +230,14 @@ export interface TransactionOpts { | ||||
|     gasLimit?: number; | ||||
| } | ||||
|  | ||||
| /* | ||||
| /** | ||||
|  * shouldValidate: Flag indicating whether the library should make attempts to validate a transaction before | ||||
|  * broadcasting it. For example, order has a valid signature, maker has sufficient funds, etc. Default: true | ||||
|  * broadcasting it. For example, order has a valid signature, maker has sufficient funds, etc. Default=true. | ||||
|  */ | ||||
| export interface OrderTransactionOpts extends TransactionOpts { | ||||
|     shouldValidate?: boolean; | ||||
| } | ||||
|  | ||||
| export type FilterObject = Web3.FilterObject; | ||||
|  | ||||
| export enum TradeSide { | ||||
|     Maker = 'maker', | ||||
|     Taker = 'taker', | ||||
|   | ||||
| @@ -3,11 +3,11 @@ import { assert as sharedAssert } from '@0xproject/assert'; | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { Schema } from '@0xproject/json-schemas'; | ||||
| // tslint:disable-next-line:no-unused-variable | ||||
| import { ECSignature } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { ECSignature } from '../types'; | ||||
| import { signatureUtils } from '../utils/signature_utils'; | ||||
|  | ||||
| export const assert = { | ||||
|   | ||||
| @@ -1,8 +1,16 @@ | ||||
| import { | ||||
|     ConstructorAbi, | ||||
|     ContractAbi, | ||||
|     EventAbi, | ||||
|     FallbackAbi, | ||||
|     FilterObject, | ||||
|     LogEntry, | ||||
|     MethodAbi, | ||||
| } from '@0xproject/types'; | ||||
| import * as ethUtil from 'ethereumjs-util'; | ||||
| import * as jsSHA3 from 'js-sha3'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as uuid from 'uuid/v4'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { BlockRange, ContractEvents, IndexedFilterValues } from '../types'; | ||||
|  | ||||
| @@ -16,15 +24,15 @@ export const filterUtils = { | ||||
|         address: string, | ||||
|         eventName: ContractEvents, | ||||
|         indexFilterValues: IndexedFilterValues, | ||||
|         abi: Web3.ContractAbi, | ||||
|         abi: ContractAbi, | ||||
|         blockRange?: BlockRange, | ||||
|     ): Web3.FilterObject { | ||||
|         const eventAbi = _.find(abi, { name: eventName }) as Web3.EventAbi; | ||||
|     ): FilterObject { | ||||
|         const eventAbi = _.find(abi, { name: eventName }) as EventAbi; | ||||
|         const eventSignature = filterUtils.getEventSignatureFromAbiByName(eventAbi, eventName); | ||||
|         const topicForEventSignature = ethUtil.addHexPrefix(jsSHA3.keccak256(eventSignature)); | ||||
|         const topicsForIndexedArgs = filterUtils.getTopicsForIndexedArgs(eventAbi, indexFilterValues); | ||||
|         const topics = [topicForEventSignature, ...topicsForIndexedArgs]; | ||||
|         let filter: Web3.FilterObject = { | ||||
|         let filter: FilterObject = { | ||||
|             address, | ||||
|             topics, | ||||
|         }; | ||||
| @@ -36,12 +44,12 @@ export const filterUtils = { | ||||
|         } | ||||
|         return filter; | ||||
|     }, | ||||
|     getEventSignatureFromAbiByName(eventAbi: Web3.EventAbi, eventName: ContractEvents): string { | ||||
|     getEventSignatureFromAbiByName(eventAbi: EventAbi, eventName: ContractEvents): string { | ||||
|         const types = _.map(eventAbi.inputs, 'type'); | ||||
|         const signature = `${eventAbi.name}(${types.join(',')})`; | ||||
|         return signature; | ||||
|     }, | ||||
|     getTopicsForIndexedArgs(abi: Web3.EventAbi, indexFilterValues: IndexedFilterValues): Array<string | null> { | ||||
|     getTopicsForIndexedArgs(abi: EventAbi, indexFilterValues: IndexedFilterValues): Array<string | null> { | ||||
|         const topics: Array<string | null> = []; | ||||
|         for (const eventInput of abi.inputs) { | ||||
|             if (!eventInput.indexed) { | ||||
| @@ -60,7 +68,7 @@ export const filterUtils = { | ||||
|         } | ||||
|         return topics; | ||||
|     }, | ||||
|     matchesFilter(log: Web3.LogEntry, filter: Web3.FilterObject): boolean { | ||||
|     matchesFilter(log: LogEntry, filter: FilterObject): boolean { | ||||
|         if (!_.isUndefined(filter.address) && log.address !== filter.address) { | ||||
|             return false; | ||||
|         } | ||||
|   | ||||
| @@ -1,25 +1,19 @@ | ||||
| import { SignedOrder } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { ZeroEx } from '../0x'; | ||||
| import { BalanceAndProxyAllowanceFetcher } from '../abstract/balance_and_proxy_allowance_fetcher'; | ||||
| import { OrderFilledCancelledFetcher } from '../abstract/order_filled_cancelled_fetcher'; | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
| import { RemainingFillableCalculator } from '../order_watcher/remaining_fillable_calculator'; | ||||
| import { BalanceAndProxyAllowanceLazyStore } from '../stores/balance_proxy_allowance_lazy_store'; | ||||
| import { OrderFilledCancelledLazyStore } from '../stores/order_filled_cancelled_lazy_store'; | ||||
| import { | ||||
|     ExchangeContractErrs, | ||||
|     OrderRelevantState, | ||||
|     OrderState, | ||||
|     OrderStateInvalid, | ||||
|     OrderStateValid, | ||||
|     SignedOrder, | ||||
| } from '../types'; | ||||
| import { ExchangeContractErrs, OrderRelevantState, OrderState, OrderStateInvalid, OrderStateValid } from '../types'; | ||||
|  | ||||
| const ACCEPTABLE_RELATIVE_ROUNDING_ERROR = 0.0001; | ||||
|  | ||||
| export class OrderStateUtils { | ||||
|     private _balanceAndProxyAllowanceLazyStore: BalanceAndProxyAllowanceLazyStore; | ||||
|     private _orderFilledCancelledLazyStore: OrderFilledCancelledLazyStore; | ||||
|     private _balanceAndProxyAllowanceFetcher: BalanceAndProxyAllowanceFetcher; | ||||
|     private _orderFilledCancelledFetcher: OrderFilledCancelledFetcher; | ||||
|     private static _validateIfOrderIsValid(signedOrder: SignedOrder, orderRelevantState: OrderRelevantState): void { | ||||
|         const unavailableTakerTokenAmount = orderRelevantState.cancelledTakerTokenAmount.add( | ||||
|             orderRelevantState.filledTakerTokenAmount, | ||||
| @@ -55,11 +49,11 @@ export class OrderStateUtils { | ||||
|         } | ||||
|     } | ||||
|     constructor( | ||||
|         balanceAndProxyAllowanceLazyStore: BalanceAndProxyAllowanceLazyStore, | ||||
|         orderFilledCancelledLazyStore: OrderFilledCancelledLazyStore, | ||||
|         balanceAndProxyAllowanceFetcher: BalanceAndProxyAllowanceFetcher, | ||||
|         orderFilledCancelledFetcher: OrderFilledCancelledFetcher, | ||||
|     ) { | ||||
|         this._balanceAndProxyAllowanceLazyStore = balanceAndProxyAllowanceLazyStore; | ||||
|         this._orderFilledCancelledLazyStore = orderFilledCancelledLazyStore; | ||||
|         this._balanceAndProxyAllowanceFetcher = balanceAndProxyAllowanceFetcher; | ||||
|         this._orderFilledCancelledFetcher = orderFilledCancelledFetcher; | ||||
|     } | ||||
|     public async getOrderStateAsync(signedOrder: SignedOrder): Promise<OrderState> { | ||||
|         const orderRelevantState = await this.getOrderRelevantStateAsync(signedOrder); | ||||
| @@ -86,27 +80,27 @@ export class OrderStateUtils { | ||||
|         // If we pass it from the instantiator - there is no opportunity to get it there | ||||
|         // because JS doesn't support async constructors. | ||||
|         // Moreover - it's cached under the hood so it's equivalent to an async constructor. | ||||
|         const exchange = (this._orderFilledCancelledLazyStore as any)._exchange as ExchangeWrapper; | ||||
|         const exchange = (this._orderFilledCancelledFetcher as any)._exchangeWrapper as ExchangeWrapper; | ||||
|         const zrxTokenAddress = exchange.getZRXTokenAddress(); | ||||
|         const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|         const makerBalance = await this._balanceAndProxyAllowanceLazyStore.getBalanceAsync( | ||||
|         const makerBalance = await this._balanceAndProxyAllowanceFetcher.getBalanceAsync( | ||||
|             signedOrder.makerTokenAddress, | ||||
|             signedOrder.maker, | ||||
|         ); | ||||
|         const makerProxyAllowance = await this._balanceAndProxyAllowanceLazyStore.getProxyAllowanceAsync( | ||||
|         const makerProxyAllowance = await this._balanceAndProxyAllowanceFetcher.getProxyAllowanceAsync( | ||||
|             signedOrder.makerTokenAddress, | ||||
|             signedOrder.maker, | ||||
|         ); | ||||
|         const makerFeeBalance = await this._balanceAndProxyAllowanceLazyStore.getBalanceAsync( | ||||
|         const makerFeeBalance = await this._balanceAndProxyAllowanceFetcher.getBalanceAsync( | ||||
|             zrxTokenAddress, | ||||
|             signedOrder.maker, | ||||
|         ); | ||||
|         const makerFeeProxyAllowance = await this._balanceAndProxyAllowanceLazyStore.getProxyAllowanceAsync( | ||||
|         const makerFeeProxyAllowance = await this._balanceAndProxyAllowanceFetcher.getProxyAllowanceAsync( | ||||
|             zrxTokenAddress, | ||||
|             signedOrder.maker, | ||||
|         ); | ||||
|         const filledTakerTokenAmount = await this._orderFilledCancelledLazyStore.getFilledTakerAmountAsync(orderHash); | ||||
|         const cancelledTakerTokenAmount = await this._orderFilledCancelledLazyStore.getCancelledTakerAmountAsync( | ||||
|         const filledTakerTokenAmount = await this._orderFilledCancelledFetcher.getFilledTakerAmountAsync(orderHash); | ||||
|         const cancelledTakerTokenAmount = await this._orderFilledCancelledFetcher.getCancelledTakerAmountAsync( | ||||
|             orderHash, | ||||
|         ); | ||||
|         const unavailableTakerTokenAmount = await exchange.getUnavailableTakerAmountAsync(orderHash); | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| import { Order, SignedOrder } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { ZeroEx } from '../0x'; | ||||
| import { ExchangeWrapper } from '../contract_wrappers/exchange_wrapper'; | ||||
| import { ExchangeContractErrs, Order, SignedOrder, TradeSide, TransferType, ZeroExError } from '../types'; | ||||
| import { ExchangeContractErrs, TradeSide, TransferType, ZeroExError } from '../types'; | ||||
| import { constants } from '../utils/constants'; | ||||
| import { utils } from '../utils/utils'; | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| import { ECSignature } from '@0xproject/types'; | ||||
| import * as ethUtil from 'ethereumjs-util'; | ||||
|  | ||||
| import { ECSignature } from '../types'; | ||||
|  | ||||
| export const signatureUtils = { | ||||
|     isValidSignature(data: string, signature: ECSignature, signerAddress: string): boolean { | ||||
|         const dataBuff = ethUtil.toBuffer(data); | ||||
|   | ||||
| @@ -1,12 +1,10 @@ | ||||
| import { SolidityTypes } from '@0xproject/types'; | ||||
| import { Order, SignedOrder, SolidityTypes } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import BN = require('bn.js'); | ||||
| import * as ethABI from 'ethereumjs-abi'; | ||||
| import * as ethUtil from 'ethereumjs-util'; | ||||
| import * as _ from 'lodash'; | ||||
|  | ||||
| import { Order, SignedOrder } from '../types'; | ||||
|  | ||||
| export const utils = { | ||||
|     /** | ||||
|      * Converts BigNumber instance to BN | ||||
| @@ -17,10 +15,6 @@ export const utils = { | ||||
|     bigNumberToBN(value: BigNumber) { | ||||
|         return new BN(value.toString(), 10); | ||||
|     }, | ||||
|     consoleLog(message: string): void { | ||||
|         // tslint:disable-next-line: no-console | ||||
|         console.log(message); | ||||
|     }, | ||||
|     spawnSwitchErr(name: string, value: any): Error { | ||||
|         return new Error(`Unexpected switch value: ${value} encountered for ${name}`); | ||||
|     }, | ||||
|   | ||||
| @@ -1,28 +1,39 @@ | ||||
| import { Deployer } from '@0xproject/deployer'; | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| // HACK: This dependency is optional since it is only available when run from within | ||||
| // the monorepo. tslint doesn't handle optional dependencies | ||||
| // tslint:disable-next-line:no-implicit-dependencies | ||||
| import { runMigrationsAsync } from '@0xproject/migrations'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'mocha'; | ||||
| import * as path from 'path'; | ||||
| import * as Sinon from 'sinon'; | ||||
|  | ||||
| import { ApprovalContractEventArgs, LogWithDecodedArgs, Order, TokenEvents, ZeroEx } from '../src'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { deployer } from './utils/deployer'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
|  | ||||
| const SHOULD_ADD_PERSONAL_MESSAGE_PREFIX = false; | ||||
|  | ||||
| describe('ZeroEx library', () => { | ||||
|     const web3 = web3Factory.create(); | ||||
|     const config = { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     const zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|     let zeroEx: ZeroEx; | ||||
|     before(async () => { | ||||
|         await runMigrationsAsync(deployer); | ||||
|         const config = { | ||||
|             networkId: constants.TESTRPC_NETWORK_ID, | ||||
|         }; | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|     }); | ||||
|     describe('#setProvider', () => { | ||||
|         it('overrides provider in nested web3s and invalidates contractInstances', async () => { | ||||
|             // Instantiate the contract instances with the current provider | ||||
| @@ -31,21 +42,20 @@ describe('ZeroEx library', () => { | ||||
|             expect((zeroEx.exchange as any)._exchangeContractIfExists).to.not.be.undefined(); | ||||
|             expect((zeroEx.tokenRegistry as any)._tokenRegistryContractIfExists).to.not.be.undefined(); | ||||
|  | ||||
|             const newProvider = web3Factory.getRpcProvider(); | ||||
|             // Add property to newProvider so that we can differentiate it from old provider | ||||
|             (newProvider as any).zeroExTestId = 1; | ||||
|             zeroEx.setProvider(newProvider, constants.TESTRPC_NETWORK_ID); | ||||
|             (provider as any).zeroExTestId = 1; | ||||
|             zeroEx.setProvider(provider, constants.TESTRPC_NETWORK_ID); | ||||
|  | ||||
|             // 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 web3 wrapper instances return the updated provider | ||||
|             const nestedWeb3WrapperProvider = (zeroEx as any)._web3Wrapper.getCurrentProvider(); | ||||
|             const nestedWeb3WrapperProvider = (zeroEx as any)._web3Wrapper.getProvider(); | ||||
|             expect(nestedWeb3WrapperProvider.zeroExTestId).to.be.a('number'); | ||||
|             const exchangeWeb3WrapperProvider = (zeroEx.exchange as any)._web3Wrapper.getCurrentProvider(); | ||||
|             const exchangeWeb3WrapperProvider = (zeroEx.exchange as any)._web3Wrapper.getProvider(); | ||||
|             expect(exchangeWeb3WrapperProvider.zeroExTestId).to.be.a('number'); | ||||
|             const tokenRegistryWeb3WrapperProvider = (zeroEx.tokenRegistry as any)._web3Wrapper.getCurrentProvider(); | ||||
|             const tokenRegistryWeb3WrapperProvider = (zeroEx.tokenRegistry as any)._web3Wrapper.getProvider(); | ||||
|             expect(tokenRegistryWeb3WrapperProvider.zeroExTestId).to.be.a('number'); | ||||
|         }); | ||||
|     }); | ||||
| @@ -216,7 +226,7 @@ describe('ZeroEx library', () => { | ||||
|                 s: '0x050aa3cc1f2c435e67e114cdce54b9527b4f50548342401bc5d2b77adbdacb02', | ||||
|             }; | ||||
|             stubs = [ | ||||
|                 Sinon.stub((zeroEx as any)._web3Wrapper, 'signTransactionAsync').returns(Promise.resolve(signature)), | ||||
|                 Sinon.stub((zeroEx as any)._web3Wrapper, 'signMessageAsync').returns(Promise.resolve(signature)), | ||||
|                 Sinon.stub(ZeroEx, 'isValidSignature').returns(true), | ||||
|             ]; | ||||
|  | ||||
| @@ -237,7 +247,7 @@ describe('ZeroEx library', () => { | ||||
|                 s: '0x2dea66f25a608bbae457e020fb6decb763deb8b7192abab624997242da248960', | ||||
|             }; | ||||
|             stubs = [ | ||||
|                 Sinon.stub((zeroEx as any)._web3Wrapper, 'signTransactionAsync').returns(Promise.resolve(signature)), | ||||
|                 Sinon.stub((zeroEx as any)._web3Wrapper, 'signMessageAsync').returns(Promise.resolve(signature)), | ||||
|                 Sinon.stub(ZeroEx, 'isValidSignature').returns(true), | ||||
|             ]; | ||||
|  | ||||
| @@ -278,7 +288,7 @@ describe('ZeroEx library', () => { | ||||
|                 exchangeContractAddress: ZeroEx.NULL_ADDRESS, | ||||
|                 networkId: constants.TESTRPC_NETWORK_ID, | ||||
|             }; | ||||
|             const zeroExWithWrongExchangeAddress = new ZeroEx(web3.currentProvider, zeroExConfig); | ||||
|             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 () => { | ||||
| @@ -286,7 +296,7 @@ describe('ZeroEx library', () => { | ||||
|                 tokenRegistryContractAddress: ZeroEx.NULL_ADDRESS, | ||||
|                 networkId: constants.TESTRPC_NETWORK_ID, | ||||
|             }; | ||||
|             const zeroExWithWrongTokenRegistryAddress = new ZeroEx(web3.currentProvider, zeroExConfig); | ||||
|             const zeroExWithWrongTokenRegistryAddress = new ZeroEx(provider, zeroExConfig); | ||||
|             expect(zeroExWithWrongTokenRegistryAddress.tokenRegistry.getContractAddress()).to.be.equal( | ||||
|                 ZeroEx.NULL_ADDRESS, | ||||
|             ); | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { web3Factory } from '@0xproject/dev-utils'; | ||||
| import * as fs from 'fs'; | ||||
| import HDWalletProvider = require('truffle-hdwallet-provider'); | ||||
|  | ||||
| import { ZeroEx } from '../src'; | ||||
|  | ||||
| @@ -14,14 +14,11 @@ const TIMEOUT = 10000; | ||||
| describe('Artifacts', () => { | ||||
|     describe('contracts are deployed on kovan', () => { | ||||
|         const kovanRpcUrl = constants.KOVAN_RPC_URL; | ||||
|         const packageJSONContent = fs.readFileSync('package.json', 'utf-8'); | ||||
|         const packageJSON = JSON.parse(packageJSONContent); | ||||
|         const mnemonic = packageJSON.config.mnemonic; | ||||
|         const web3Provider = new HDWalletProvider(mnemonic, kovanRpcUrl); | ||||
|         const provider = web3Factory.create({ rpcUrl: kovanRpcUrl }).currentProvider; | ||||
|         const config = { | ||||
|             networkId: constants.KOVAN_NETWORK_ID, | ||||
|         }; | ||||
|         const zeroEx = new ZeroEx(web3Provider, config); | ||||
|         const zeroEx = new ZeroEx(provider, config); | ||||
|         it('token registry contract is deployed', async () => { | ||||
|             await (zeroEx.tokenRegistry as any)._getTokenRegistryContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
| @@ -34,14 +31,11 @@ describe('Artifacts', () => { | ||||
|     }); | ||||
|     describe('contracts are deployed on ropsten', () => { | ||||
|         const ropstenRpcUrl = constants.ROPSTEN_RPC_URL; | ||||
|         const packageJSONContent = fs.readFileSync('package.json', 'utf-8'); | ||||
|         const packageJSON = JSON.parse(packageJSONContent); | ||||
|         const mnemonic = packageJSON.config.mnemonic; | ||||
|         const web3Provider = new HDWalletProvider(mnemonic, ropstenRpcUrl); | ||||
|         const provider = web3Factory.create({ rpcUrl: ropstenRpcUrl }).currentProvider; | ||||
|         const config = { | ||||
|             networkId: constants.ROPSTEN_NETWORK_ID, | ||||
|         }; | ||||
|         const zeroEx = new ZeroEx(web3Provider, config); | ||||
|         const zeroEx = new ZeroEx(provider, config); | ||||
|         it('token registry contract is deployed', async () => { | ||||
|             await (zeroEx.tokenRegistry as any)._getTokenRegistryContractAsync(); | ||||
|         }).timeout(TIMEOUT); | ||||
|   | ||||
| @@ -6,15 +6,15 @@ import { ZeroEx } from '../src'; | ||||
| import { assert } from '../src/utils/assert'; | ||||
|  | ||||
| import { constants } from './utils/constants'; | ||||
| import { provider } from './utils/web3_wrapper'; | ||||
|  | ||||
| const expect = chai.expect; | ||||
|  | ||||
| describe('Assertion library', () => { | ||||
|     const web3 = web3Factory.create(); | ||||
|     const config = { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     const zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|     const zeroEx = new ZeroEx(provider, config); | ||||
|     describe('#isSenderAddressHexAsync', () => { | ||||
|         it('throws when address is invalid', async () => { | ||||
|             const address = '0xdeadbeef'; | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as chai from 'chai'; | ||||
| import 'mocha'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { | ||||
|     ApprovalContractEventArgs, | ||||
| @@ -23,10 +23,11 @@ import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { reportNodeCallbackErrors } from './utils/report_callback_errors'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| // Since the address depositing/withdrawing ETH/WETH also needs to pay gas costs for the transaction, | ||||
| // a small amount of ETH will be used to pay this gas cost. We therefore check that the difference between | ||||
| @@ -35,7 +36,6 @@ const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const MAX_REASONABLE_GAS_COST_IN_WEI = 62517; | ||||
|  | ||||
| describe('EtherTokenWrapper', () => { | ||||
|     let web3: Web3; | ||||
|     let zeroEx: ZeroEx; | ||||
|     let tokens: Token[]; | ||||
|     let userAddresses: string[]; | ||||
| @@ -54,13 +54,12 @@ describe('EtherTokenWrapper', () => { | ||||
|     const depositAmount = new BigNumber(42); | ||||
|     const withdrawalAmount = new BigNumber(42); | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, zeroExConfig); | ||||
|         zeroEx = new ZeroEx(provider, zeroExConfig); | ||||
|         tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         addressWithETH = userAddresses[0]; | ||||
|         wethContractAddress = zeroEx.etherToken.getContractAddressIfExists() as string; | ||||
|         depositWeiAmount = (zeroEx as any)._web3Wrapper.toWei(new BigNumber(5)); | ||||
|         depositWeiAmount = Web3Wrapper.toWei(new BigNumber(5)); | ||||
|         decimalPlaces = 7; | ||||
|         addressWithoutFunds = userAddresses[1]; | ||||
|     }); | ||||
| @@ -79,7 +78,7 @@ describe('EtherTokenWrapper', () => { | ||||
|             const UNKNOWN_NETWORK_NETWORK_ID = 10; | ||||
|             expect( | ||||
|                 () => | ||||
|                     new ZeroEx(web3.currentProvider, { | ||||
|                     new ZeroEx(provider, { | ||||
|                         networkId: UNKNOWN_NETWORK_NETWORK_ID, | ||||
|                     } as any), | ||||
|             ).to.throw(); | ||||
| @@ -106,7 +105,7 @@ describe('EtherTokenWrapper', () => { | ||||
|         it('should throw if user has insufficient ETH balance for deposit', async () => { | ||||
|             const preETHBalance = await (zeroEx as any)._web3Wrapper.getBalanceInWeiAsync(addressWithETH); | ||||
|  | ||||
|             const extraETHBalance = (zeroEx as any)._web3Wrapper.toWei(5, 'ether'); | ||||
|             const extraETHBalance = Web3Wrapper.toWei(new BigNumber(5)); | ||||
|             const overETHBalanceinWei = preETHBalance.add(extraETHBalance); | ||||
|  | ||||
|             return expect( | ||||
| @@ -138,7 +137,7 @@ describe('EtherTokenWrapper', () => { | ||||
|             gasCost = expectedETHBalance.minus(postETHBalance); | ||||
|             expect(gasCost).to.be.bignumber.lte(MAX_REASONABLE_GAS_COST_IN_WEI); | ||||
|         }); | ||||
|         it('should throw if user has insufficient WETH balance for withdrawl', async () => { | ||||
|         it('should throw if user has insufficient WETH balance for withdrawal', async () => { | ||||
|             const preWETHBalance = await zeroEx.token.getBalanceAsync(wethContractAddress, addressWithETH); | ||||
|             expect(preWETHBalance).to.be.bignumber.equal(0); | ||||
|  | ||||
| @@ -261,8 +260,7 @@ describe('EtherTokenWrapper', () => { | ||||
|                     callbackNeverToBeCalled, | ||||
|                 ); | ||||
|                 const callbackToBeCalled = reportNodeCallbackErrors(done)(); | ||||
|                 const newProvider = web3Factory.getRpcProvider(); | ||||
|                 zeroEx.setProvider(newProvider, constants.TESTRPC_NETWORK_ID); | ||||
|                 zeroEx.setProvider(provider, constants.TESTRPC_NETWORK_ID); | ||||
|                 await zeroEx.etherToken.depositAsync(etherTokenAddress, transferAmount, addressWithETH); | ||||
|                 zeroEx.etherToken.subscribe( | ||||
|                     etherTokenAddress, | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| import { web3Factory } from '@0xproject/dev-utils'; | ||||
| import { LogEntry } from '@0xproject/types'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'mocha'; | ||||
| import * as Sinon from 'sinon'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { LogEvent } from '../src'; | ||||
| import { EventWatcher } from '../src/order_watcher/event_watcher'; | ||||
| @@ -12,16 +12,16 @@ import { DoneCallback } from '../src/types'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { reportNodeCallbackErrors } from './utils/report_callback_errors'; | ||||
| import { provider } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
|  | ||||
| describe('EventWatcher', () => { | ||||
|     let web3: Web3; | ||||
|     let stubs: Sinon.SinonStub[] = []; | ||||
|     let eventWatcher: EventWatcher; | ||||
|     let web3Wrapper: Web3Wrapper; | ||||
|     const logA: Web3.LogEntry = { | ||||
|     const logA: LogEntry = { | ||||
|         address: '0x71d271f8b14adef568f8f28f1587ce7271ac4ca5', | ||||
|         blockHash: null, | ||||
|         blockNumber: null, | ||||
| @@ -31,7 +31,7 @@ describe('EventWatcher', () => { | ||||
|         transactionHash: '0x004881d38cd4a8f72f1a0d68c8b9b8124504706041ff37019c1d1ed6bfda8e17', | ||||
|         transactionIndex: 0, | ||||
|     }; | ||||
|     const logB: Web3.LogEntry = { | ||||
|     const logB: LogEntry = { | ||||
|         address: '0x8d12a197cb00d4747a1fe03395095ce2a5cc6819', | ||||
|         blockHash: null, | ||||
|         blockNumber: null, | ||||
| @@ -41,7 +41,7 @@ describe('EventWatcher', () => { | ||||
|         transactionHash: '0x01ef3c048b18d9b09ea195b4ed94cf8dd5f3d857a1905ff886b152cfb1166f25', | ||||
|         transactionIndex: 0, | ||||
|     }; | ||||
|     const logC: Web3.LogEntry = { | ||||
|     const logC: LogEntry = { | ||||
|         address: '0x1d271f8b174adef58f1587ce68f8f27271ac4ca5', | ||||
|         blockHash: null, | ||||
|         blockNumber: null, | ||||
| @@ -52,9 +52,8 @@ describe('EventWatcher', () => { | ||||
|         transactionIndex: 0, | ||||
|     }; | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         const pollingIntervalMs = 10; | ||||
|         web3Wrapper = new Web3Wrapper(web3.currentProvider); | ||||
|         web3Wrapper = new Web3Wrapper(provider); | ||||
|         eventWatcher = new EventWatcher(web3Wrapper, pollingIntervalMs); | ||||
|     }); | ||||
|     afterEach(() => { | ||||
| @@ -64,7 +63,7 @@ describe('EventWatcher', () => { | ||||
|         eventWatcher.unsubscribe(); | ||||
|     }); | ||||
|     it('correctly emits initial log events', (done: DoneCallback) => { | ||||
|         const logs: Web3.LogEntry[] = [logA, logB]; | ||||
|         const logs: LogEntry[] = [logA, logB]; | ||||
|         const expectedLogEvents = [ | ||||
|             { | ||||
|                 removed: false, | ||||
| @@ -89,8 +88,8 @@ describe('EventWatcher', () => { | ||||
|         eventWatcher.subscribe(callback); | ||||
|     }); | ||||
|     it('correctly computes the difference and emits only changes', (done: DoneCallback) => { | ||||
|         const initialLogs: Web3.LogEntry[] = [logA, logB]; | ||||
|         const changedLogs: Web3.LogEntry[] = [logA, logC]; | ||||
|         const initialLogs: LogEntry[] = [logA, logB]; | ||||
|         const changedLogs: LogEntry[] = [logA, logC]; | ||||
|         const expectedLogEvents = [ | ||||
|             { | ||||
|                 removed: false, | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle, devConstants } from '@0xproject/dev-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| @@ -9,17 +9,17 @@ import { ExchangeTransferSimulator } from '../src/utils/exchange_transfer_simula | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| describe('ExchangeTransferSimulator', () => { | ||||
|     const web3 = web3Factory.create(); | ||||
|     const config = { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     const zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|     const zeroEx = new ZeroEx(provider, config); | ||||
|     const transferAmount = new BigNumber(5); | ||||
|     let userAddresses: string[]; | ||||
|     let tokens: Token[]; | ||||
|   | ||||
| @@ -4,7 +4,6 @@ import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'mocha'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { | ||||
|     BlockRange, | ||||
| @@ -15,6 +14,7 @@ import { | ||||
|     LogFillContractEventArgs, | ||||
|     OrderCancellationRequest, | ||||
|     OrderFillRequest, | ||||
|     OrderState, | ||||
|     SignedOrder, | ||||
|     Token, | ||||
|     ZeroEx, | ||||
| @@ -26,15 +26,15 @@ import { constants } from './utils/constants'; | ||||
| import { FillScenarios } from './utils/fill_scenarios'; | ||||
| import { reportNodeCallbackErrors } from './utils/report_callback_errors'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| const NON_EXISTENT_ORDER_HASH = '0x79370342234e7acd6bbeac335bd3bb1d368383294b64b8160a00f4060e4d3777'; | ||||
|  | ||||
| describe('ExchangeWrapper', () => { | ||||
|     let web3: Web3; | ||||
|     let zeroEx: ZeroEx; | ||||
|     let tokenUtils: TokenUtils; | ||||
|     let tokens: Token[]; | ||||
| @@ -46,8 +46,7 @@ describe('ExchangeWrapper', () => { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|         exchangeContractAddress = zeroEx.exchange.getContractAddress(); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
| @@ -597,6 +596,19 @@ describe('ExchangeWrapper', () => { | ||||
|                     const remainingFillAmount = fillableAmount.minus(1); | ||||
|                     expect(anotherFilledAmount).to.be.bignumber.equal(remainingFillAmount); | ||||
|                 }); | ||||
|                 it('should successfully fill up to specified amount and leave the rest of the orders untouched', async () => { | ||||
|                     const txHash = await zeroEx.exchange.fillOrdersUpToAsync( | ||||
|                         signedOrders, | ||||
|                         fillableAmount, | ||||
|                         shouldThrowOnInsufficientBalanceOrAllowance, | ||||
|                         takerAddress, | ||||
|                     ); | ||||
|                     await zeroEx.awaitTransactionMinedAsync(txHash); | ||||
|                     const filledAmount = await zeroEx.exchange.getFilledTakerAmountAsync(signedOrderHashHex); | ||||
|                     const zeroAmount = await zeroEx.exchange.getFilledTakerAmountAsync(anotherOrderHashHex); | ||||
|                     expect(filledAmount).to.be.bignumber.equal(fillableAmount); | ||||
|                     expect(zeroAmount).to.be.bignumber.equal(0); | ||||
|                 }); | ||||
|                 it('should successfully fill up to specified amount even if filling all orders would fail', async () => { | ||||
|                     const missingBalance = new BigNumber(1); // User will still have enough balance to fill up to 9, | ||||
|                     // but won't have 10 to fully fill all orders in a batch. | ||||
| @@ -965,8 +977,7 @@ describe('ExchangeWrapper', () => { | ||||
|                 ); | ||||
|                 zeroEx.exchange.subscribe(ExchangeEvents.LogFill, indexFilterValues, callbackNeverToBeCalled); | ||||
|  | ||||
|                 const newProvider = web3Factory.getRpcProvider(); | ||||
|                 zeroEx.setProvider(newProvider, constants.TESTRPC_NETWORK_ID); | ||||
|                 zeroEx.setProvider(provider, constants.TESTRPC_NETWORK_ID); | ||||
|  | ||||
|                 const callback = reportNodeCallbackErrors(done)( | ||||
|                     (logEvent: DecodedLogEvent<LogFillContractEventArgs>) => { | ||||
| @@ -1144,4 +1155,41 @@ describe('ExchangeWrapper', () => { | ||||
|             expect(args.maker).to.be.equal(differentMakerAddress); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#getOrderStateAsync', () => { | ||||
|         let maker: string; | ||||
|         let taker: string; | ||||
|         let makerToken: Token; | ||||
|         let takerToken: Token; | ||||
|         let signedOrder: SignedOrder; | ||||
|         let orderState: OrderState; | ||||
|         const fillableAmount = ZeroEx.toBaseUnitAmount(new BigNumber(5), constants.ZRX_DECIMALS); | ||||
|         before(async () => { | ||||
|             [, maker, taker] = userAddresses; | ||||
|             tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|             [makerToken, takerToken] = tokenUtils.getDummyTokens(); | ||||
|         }); | ||||
|         it('should report orderStateValid when order is fillable', async () => { | ||||
|             signedOrder = await fillScenarios.createFillableSignedOrderAsync( | ||||
|                 makerToken.address, | ||||
|                 takerToken.address, | ||||
|                 maker, | ||||
|                 taker, | ||||
|                 fillableAmount, | ||||
|             ); | ||||
|             orderState = await zeroEx.exchange.getOrderStateAsync(signedOrder); | ||||
|             expect(orderState.isValid).to.be.true(); | ||||
|         }); | ||||
|         it('should report orderStateInvalid when maker allowance set to 0', async () => { | ||||
|             signedOrder = await fillScenarios.createFillableSignedOrderAsync( | ||||
|                 makerToken.address, | ||||
|                 takerToken.address, | ||||
|                 maker, | ||||
|                 taker, | ||||
|                 fillableAmount, | ||||
|             ); | ||||
|             await zeroEx.token.setProxyAllowanceAsync(makerToken.address, maker, new BigNumber(0)); | ||||
|             orderState = await zeroEx.exchange.getOrderStateAsync(signedOrder); | ||||
|             expect(orderState.isValid).to.be.false(); | ||||
|         }); | ||||
|     }); | ||||
| }); // tslint:disable:max-file-line-count | ||||
|   | ||||
| @@ -1,10 +1,9 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle, devConstants } from '@0xproject/dev-utils'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'mocha'; | ||||
| import * as Sinon from 'sinon'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { ZeroEx } from '../src/0x'; | ||||
| import { ExpirationWatcher } from '../src/order_watcher/expiration_watcher'; | ||||
| @@ -16,13 +15,13 @@ import { constants } from './utils/constants'; | ||||
| import { FillScenarios } from './utils/fill_scenarios'; | ||||
| import { reportNoErrorCallbackErrors } from './utils/report_callback_errors'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| describe('ExpirationWatcher', () => { | ||||
|     let web3: Web3; | ||||
|     let zeroEx: ZeroEx; | ||||
|     let tokenUtils: TokenUtils; | ||||
|     let tokens: Token[]; | ||||
| @@ -41,11 +40,10 @@ describe('ExpirationWatcher', () => { | ||||
|     let timer: Sinon.SinonFakeTimers; | ||||
|     let expirationWatcher: ExpirationWatcher; | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         const config = { | ||||
|             networkId: constants.TESTRPC_NETWORK_ID, | ||||
|         }; | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|         exchangeContractAddress = zeroEx.exchange.getContractAddress(); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|   | ||||
| @@ -1,9 +1,8 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle, devConstants } from '@0xproject/dev-utils'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'mocha'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { | ||||
|     ExchangeContractErrs, | ||||
| @@ -15,6 +14,7 @@ import { | ||||
|     ZeroEx, | ||||
|     ZeroExError, | ||||
| } from '../src'; | ||||
| import { OrderStateWatcher } from '../src/order_watcher/order_state_watcher'; | ||||
| import { DoneCallback } from '../src/types'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| @@ -22,15 +22,15 @@ import { constants } from './utils/constants'; | ||||
| import { FillScenarios } from './utils/fill_scenarios'; | ||||
| import { reportNodeCallbackErrors } from './utils/report_callback_errors'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| const TIMEOUT_MS = 150; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| describe('OrderStateWatcher', () => { | ||||
|     let web3: Web3; | ||||
|     let zeroEx: ZeroEx; | ||||
|     let tokens: Token[]; | ||||
|     let tokenUtils: TokenUtils; | ||||
| @@ -43,14 +43,15 @@ describe('OrderStateWatcher', () => { | ||||
|     let maker: string; | ||||
|     let taker: string; | ||||
|     let signedOrder: SignedOrder; | ||||
|     let orderStateWatcher: OrderStateWatcher; | ||||
|     const config = { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     const decimals = constants.ZRX_DECIMALS; | ||||
|     const fillableAmount = ZeroEx.toBaseUnitAmount(new BigNumber(5), decimals); | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|         orderStateWatcher = zeroEx.createOrderStateWatcher(); | ||||
|         exchangeContractAddress = zeroEx.exchange.getContractAddress(); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         [, maker, taker] = userAddresses; | ||||
| @@ -77,17 +78,17 @@ describe('OrderStateWatcher', () => { | ||||
|                 fillableAmount, | ||||
|             ); | ||||
|             const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|             zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|             expect((zeroEx.orderStateWatcher as any)._orderByOrderHash).to.include({ | ||||
|             orderStateWatcher.addOrder(signedOrder); | ||||
|             expect((orderStateWatcher as any)._orderByOrderHash).to.include({ | ||||
|                 [orderHash]: signedOrder, | ||||
|             }); | ||||
|             let dependentOrderHashes = (zeroEx.orderStateWatcher as any)._dependentOrderHashes; | ||||
|             let dependentOrderHashes = (orderStateWatcher as any)._dependentOrderHashes; | ||||
|             expect(dependentOrderHashes[signedOrder.maker][signedOrder.makerTokenAddress]).to.have.keys(orderHash); | ||||
|             zeroEx.orderStateWatcher.removeOrder(orderHash); | ||||
|             expect((zeroEx.orderStateWatcher as any)._orderByOrderHash).to.not.include({ | ||||
|             orderStateWatcher.removeOrder(orderHash); | ||||
|             expect((orderStateWatcher as any)._orderByOrderHash).to.not.include({ | ||||
|                 [orderHash]: signedOrder, | ||||
|             }); | ||||
|             dependentOrderHashes = (zeroEx.orderStateWatcher as any)._dependentOrderHashes; | ||||
|             dependentOrderHashes = (orderStateWatcher as any)._dependentOrderHashes; | ||||
|             expect(dependentOrderHashes[signedOrder.maker]).to.be.undefined(); | ||||
|         }); | ||||
|         it('should no-op when removing a non-existing order', async () => { | ||||
| @@ -104,23 +105,23 @@ describe('OrderStateWatcher', () => { | ||||
|                 .split('') | ||||
|                 .reverse() | ||||
|                 .join('')}`; | ||||
|             zeroEx.orderStateWatcher.removeOrder(nonExistentOrderHash); | ||||
|             orderStateWatcher.removeOrder(nonExistentOrderHash); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#subscribe', async () => { | ||||
|         afterEach(async () => { | ||||
|             zeroEx.orderStateWatcher.unsubscribe(); | ||||
|             orderStateWatcher.unsubscribe(); | ||||
|         }); | ||||
|         it('should fail when trying to subscribe twice', async () => { | ||||
|             zeroEx.orderStateWatcher.subscribe(_.noop); | ||||
|             expect(() => zeroEx.orderStateWatcher.subscribe(_.noop)).to.throw(ZeroExError.SubscriptionAlreadyPresent); | ||||
|             orderStateWatcher.subscribe(_.noop); | ||||
|             expect(() => orderStateWatcher.subscribe(_.noop)).to.throw(ZeroExError.SubscriptionAlreadyPresent); | ||||
|         }); | ||||
|     }); | ||||
|     describe('tests with cleanup', async () => { | ||||
|         afterEach(async () => { | ||||
|             zeroEx.orderStateWatcher.unsubscribe(); | ||||
|             orderStateWatcher.unsubscribe(); | ||||
|             const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|             zeroEx.orderStateWatcher.removeOrder(orderHash); | ||||
|             orderStateWatcher.removeOrder(orderHash); | ||||
|         }); | ||||
|         it('should emit orderStateInvalid when maker allowance set to 0 for watched order', (done: DoneCallback) => { | ||||
|             (async () => { | ||||
| @@ -132,14 +133,14 @@ describe('OrderStateWatcher', () => { | ||||
|                     fillableAmount, | ||||
|                 ); | ||||
|                 const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     expect(orderState.isValid).to.be.false(); | ||||
|                     const invalidOrderState = orderState as OrderStateInvalid; | ||||
|                     expect(invalidOrderState.orderHash).to.be.equal(orderHash); | ||||
|                     expect(invalidOrderState.error).to.be.equal(ExchangeContractErrs.InsufficientMakerAllowance); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|                 await zeroEx.token.setProxyAllowanceAsync(makerToken.address, maker, new BigNumber(0)); | ||||
|             })().catch(done); | ||||
|         }); | ||||
| @@ -152,11 +153,11 @@ describe('OrderStateWatcher', () => { | ||||
|                     taker, | ||||
|                     fillableAmount, | ||||
|                 ); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     throw new Error('OrderState callback fired for irrelevant order'); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|                 const notTheMaker = userAddresses[0]; | ||||
|                 const anyRecipient = taker; | ||||
|                 const transferAmount = new BigNumber(2); | ||||
| @@ -176,14 +177,14 @@ describe('OrderStateWatcher', () => { | ||||
|                     fillableAmount, | ||||
|                 ); | ||||
|                 const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     expect(orderState.isValid).to.be.false(); | ||||
|                     const invalidOrderState = orderState as OrderStateInvalid; | ||||
|                     expect(invalidOrderState.orderHash).to.be.equal(orderHash); | ||||
|                     expect(invalidOrderState.error).to.be.equal(ExchangeContractErrs.InsufficientMakerBalance); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|                 const anyRecipient = taker; | ||||
|                 const makerBalance = await zeroEx.token.getBalanceAsync(makerToken.address, maker); | ||||
|                 await zeroEx.token.transferAsync(makerToken.address, maker, anyRecipient, makerBalance); | ||||
| @@ -199,7 +200,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     fillableAmount, | ||||
|                 ); | ||||
|                 const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     expect(orderState.isValid).to.be.false(); | ||||
| @@ -207,7 +208,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     expect(invalidOrderState.orderHash).to.be.equal(orderHash); | ||||
|                     expect(invalidOrderState.error).to.be.equal(ExchangeContractErrs.OrderRemainingFillAmountZero); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|  | ||||
|                 const shouldThrowOnInsufficientBalanceOrAllowance = true; | ||||
|                 await zeroEx.exchange.fillOrderAsync( | ||||
| @@ -231,7 +232,7 @@ describe('OrderStateWatcher', () => { | ||||
|                 const makerBalance = await zeroEx.token.getBalanceAsync(makerToken.address, maker); | ||||
|                 const fillAmountInBaseUnits = new BigNumber(2); | ||||
|                 const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     expect(orderState.isValid).to.be.true(); | ||||
| @@ -248,7 +249,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     ); | ||||
|                     expect(orderRelevantState.makerBalance).to.be.bignumber.equal(remainingMakerBalance); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|                 const shouldThrowOnInsufficientBalanceOrAllowance = true; | ||||
|                 await zeroEx.exchange.fillOrderAsync( | ||||
|                     signedOrder, | ||||
| @@ -273,8 +274,8 @@ describe('OrderStateWatcher', () => { | ||||
|                     taker, | ||||
|                 ); | ||||
|                 const callback = reportNodeCallbackErrors(done)(); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|                 await zeroEx.token.setProxyAllowanceAsync(zrxTokenAddress, maker, new BigNumber(0)); | ||||
|             })().catch(done); | ||||
|         }); | ||||
| @@ -293,7 +294,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     ); | ||||
|                     const fillAmountInBaseUnits = ZeroEx.toBaseUnitAmount(new BigNumber(2), decimals); | ||||
|                     const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                     zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                     orderStateWatcher.addOrder(signedOrder); | ||||
|                     const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                         expect(orderState.isValid).to.be.true(); | ||||
|                         const validOrderState = orderState as OrderStateValid; | ||||
| @@ -306,7 +307,7 @@ describe('OrderStateWatcher', () => { | ||||
|                             ZeroEx.toBaseUnitAmount(new BigNumber(8), decimals), | ||||
|                         ); | ||||
|                     }); | ||||
|                     zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                     orderStateWatcher.subscribe(callback); | ||||
|                     const shouldThrowOnInsufficientBalanceOrAllowance = true; | ||||
|                     await zeroEx.exchange.fillOrderAsync( | ||||
|                         signedOrder, | ||||
| @@ -327,7 +328,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     ); | ||||
|  | ||||
|                     const changedMakerApprovalAmount = ZeroEx.toBaseUnitAmount(new BigNumber(3), decimals); | ||||
|                     zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                     orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                     const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                         const validOrderState = orderState as OrderStateValid; | ||||
| @@ -339,7 +340,7 @@ describe('OrderStateWatcher', () => { | ||||
|                             changedMakerApprovalAmount, | ||||
|                         ); | ||||
|                     }); | ||||
|                     zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                     orderStateWatcher.subscribe(callback); | ||||
|                     await zeroEx.token.setProxyAllowanceAsync(makerToken.address, maker, changedMakerApprovalAmount); | ||||
|                 })().catch(done); | ||||
|             }); | ||||
| @@ -357,7 +358,7 @@ describe('OrderStateWatcher', () => { | ||||
|  | ||||
|                     const remainingAmount = ZeroEx.toBaseUnitAmount(new BigNumber(1), decimals); | ||||
|                     const transferAmount = makerBalance.sub(remainingAmount); | ||||
|                     zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                     orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                     const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                         expect(orderState.isValid).to.be.true(); | ||||
| @@ -370,7 +371,7 @@ describe('OrderStateWatcher', () => { | ||||
|                             remainingAmount, | ||||
|                         ); | ||||
|                     }); | ||||
|                     zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                     orderStateWatcher.subscribe(callback); | ||||
|                     await zeroEx.token.transferAsync(makerToken.address, maker, ZeroEx.NULL_ADDRESS, transferAmount); | ||||
|                 })().catch(done); | ||||
|             }); | ||||
| @@ -392,7 +393,7 @@ describe('OrderStateWatcher', () => { | ||||
|  | ||||
|                     const remainingTokenAmount = ZeroEx.toBaseUnitAmount(new BigNumber(4), decimals); | ||||
|                     const transferTokenAmount = makerFee.sub(remainingTokenAmount); | ||||
|                     zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                     orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                     const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                         expect(orderState.isValid).to.be.true(); | ||||
| @@ -402,7 +403,7 @@ describe('OrderStateWatcher', () => { | ||||
|                             remainingTokenAmount, | ||||
|                         ); | ||||
|                     }); | ||||
|                     zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                     orderStateWatcher.subscribe(callback); | ||||
|                     await zeroEx.exchange.cancelOrderAsync(signedOrder, transferTokenAmount); | ||||
|                 })().catch(done); | ||||
|             }); | ||||
| @@ -426,7 +427,7 @@ describe('OrderStateWatcher', () => { | ||||
|  | ||||
|                     const remainingTokenAmount = ZeroEx.toBaseUnitAmount(new BigNumber(4), decimals); | ||||
|                     const transferTokenAmount = makerFee.sub(remainingTokenAmount); | ||||
|                     zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                     orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                     const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                         const validOrderState = orderState as OrderStateValid; | ||||
| @@ -435,7 +436,7 @@ describe('OrderStateWatcher', () => { | ||||
|                             remainingFeeAmount, | ||||
|                         ); | ||||
|                     }); | ||||
|                     zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                     orderStateWatcher.subscribe(callback); | ||||
|                     await zeroEx.token.setProxyAllowanceAsync(zrxTokenAddress, maker, remainingFeeAmount); | ||||
|                     await zeroEx.token.transferAsync( | ||||
|                         makerToken.address, | ||||
| @@ -461,7 +462,7 @@ describe('OrderStateWatcher', () => { | ||||
|                         feeRecipient, | ||||
|                     ); | ||||
|  | ||||
|                     zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                     orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                     const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                         const validOrderState = orderState as OrderStateValid; | ||||
| @@ -470,7 +471,7 @@ describe('OrderStateWatcher', () => { | ||||
|                             fillableAmount, | ||||
|                         ); | ||||
|                     }); | ||||
|                     zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                     orderStateWatcher.subscribe(callback); | ||||
|                     await zeroEx.token.setProxyAllowanceAsync( | ||||
|                         makerToken.address, | ||||
|                         maker, | ||||
| @@ -489,7 +490,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     fillableAmount, | ||||
|                 ); | ||||
|                 const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     expect(orderState.isValid).to.be.false(); | ||||
| @@ -497,7 +498,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     expect(invalidOrderState.orderHash).to.be.equal(orderHash); | ||||
|                     expect(invalidOrderState.error).to.be.equal(ExchangeContractErrs.OrderRemainingFillAmountZero); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|  | ||||
|                 await zeroEx.exchange.cancelOrderAsync(signedOrder, fillableAmount); | ||||
|             })().catch(done); | ||||
| @@ -513,7 +514,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     fillableAmount, | ||||
|                 ); | ||||
|                 const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     expect(orderState.isValid).to.be.false(); | ||||
| @@ -521,7 +522,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     expect(invalidOrderState.orderHash).to.be.equal(orderHash); | ||||
|                     expect(invalidOrderState.error).to.be.equal(ExchangeContractErrs.OrderFillRoundingError); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|                 await zeroEx.exchange.cancelOrderAsync( | ||||
|                     signedOrder, | ||||
|                     fillableAmount.minus(remainingFillableAmountInBaseUnits), | ||||
| @@ -540,7 +541,7 @@ describe('OrderStateWatcher', () => { | ||||
|  | ||||
|                 const cancelAmountInBaseUnits = new BigNumber(2); | ||||
|                 const orderHash = ZeroEx.getOrderHashHex(signedOrder); | ||||
|                 zeroEx.orderStateWatcher.addOrder(signedOrder); | ||||
|                 orderStateWatcher.addOrder(signedOrder); | ||||
|  | ||||
|                 const callback = reportNodeCallbackErrors(done)((orderState: OrderState) => { | ||||
|                     expect(orderState.isValid).to.be.true(); | ||||
| @@ -549,7 +550,7 @@ describe('OrderStateWatcher', () => { | ||||
|                     const orderRelevantState = validOrderState.orderRelevantState; | ||||
|                     expect(orderRelevantState.cancelledTakerTokenAmount).to.be.bignumber.equal(cancelAmountInBaseUnits); | ||||
|                 }); | ||||
|                 zeroEx.orderStateWatcher.subscribe(callback); | ||||
|                 orderStateWatcher.subscribe(callback); | ||||
|                 await zeroEx.exchange.cancelOrderAsync(signedOrder, cancelAmountInBaseUnits); | ||||
|             })().catch(done); | ||||
|         }); | ||||
|   | ||||
| @@ -1,9 +1,8 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle, devConstants } from '@0xproject/dev-utils'; | ||||
| import { BlockParamLiteral } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import * as Sinon from 'sinon'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { ExchangeContractErrs, SignedOrder, Token, ZeroEx, ZeroExError } from '../src'; | ||||
| import { TradeSide, TransferType } from '../src/types'; | ||||
| @@ -14,13 +13,13 @@ import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { FillScenarios } from './utils/fill_scenarios'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| describe('OrderValidation', () => { | ||||
|     let web3: Web3; | ||||
|     let zeroEx: ZeroEx; | ||||
|     let userAddresses: string[]; | ||||
|     let tokens: Token[]; | ||||
| @@ -40,8 +39,7 @@ describe('OrderValidation', () => { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|         exchangeContractAddress = zeroEx.exchange.getContractAddress(); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         [coinbase, makerAddress, takerAddress, feeRecipient] = userAddresses; | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| import { ECSignature, SignedOrder } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as chai from 'chai'; | ||||
| import 'mocha'; | ||||
|  | ||||
| import { ZeroEx } from '../src/0x'; | ||||
| import { RemainingFillableCalculator } from '../src/order_watcher/remaining_fillable_calculator'; | ||||
| import { ECSignature, SignedOrder } from '../src/types'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,8 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle, devConstants } from '@0xproject/dev-utils'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import * as _ from 'lodash'; | ||||
| import 'mocha'; | ||||
| import * as Sinon from 'sinon'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { ApprovalContractEventArgs, DecodedLogEvent, Token, TokenEvents, ZeroEx } from '../src'; | ||||
| import { DoneCallback } from '../src/types'; | ||||
| @@ -11,12 +10,12 @@ import { DoneCallback } from '../src/types'; | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { assertNodeCallbackError } from './utils/report_callback_errors'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| describe('SubscriptionTest', () => { | ||||
|     let web3: Web3; | ||||
|     let zeroEx: ZeroEx; | ||||
|     let userAddresses: string[]; | ||||
|     let tokens: Token[]; | ||||
| @@ -26,8 +25,7 @@ describe('SubscriptionTest', () => { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|         coinbase = userAddresses[0]; | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle, devConstants } from '@0xproject/dev-utils'; | ||||
| import { schemas, SchemaValidator } from '@0xproject/json-schemas'; | ||||
| import * as chai from 'chai'; | ||||
| import * as _ from 'lodash'; | ||||
| @@ -8,10 +8,11 @@ import { Token, ZeroEx } from '../src'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| const TOKEN_REGISTRY_SIZE_AFTER_MIGRATION = 7; | ||||
|  | ||||
| @@ -30,8 +31,7 @@ describe('TokenRegistryWrapper', () => { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     before(async () => { | ||||
|         const web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|         tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|         _.map(tokens, token => { | ||||
|             tokenAddressBySymbol[token.symbol] = token.address; | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| import { web3Factory } from '@0xproject/dev-utils'; | ||||
| import * as chai from 'chai'; | ||||
|  | ||||
| import { ZeroEx } from '../src'; | ||||
|  | ||||
| import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { provider } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| @@ -15,8 +15,7 @@ describe('TokenTransferProxyWrapper', () => { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     before(async () => { | ||||
|         const web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|     }); | ||||
|     describe('#isAuthorizedAsync', () => { | ||||
|         it('should return false if the address is not authorized', async () => { | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { BlockchainLifecycle, devConstants } from '@0xproject/dev-utils'; | ||||
| import { EmptyWalletSubprovider } from '@0xproject/subproviders'; | ||||
| import { Provider } from '@0xproject/types'; | ||||
| import { BigNumber } from '@0xproject/utils'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as chai from 'chai'; | ||||
| import 'mocha'; | ||||
| import * as Web3 from 'web3'; | ||||
| import Web3ProviderEngine = require('web3-provider-engine'); | ||||
|  | ||||
| import { | ||||
|     ApprovalContractEventArgs, | ||||
| @@ -22,27 +23,24 @@ import { chaiSetup } from './utils/chai_setup'; | ||||
| import { constants } from './utils/constants'; | ||||
| import { reportNodeCallbackErrors } from './utils/report_callback_errors'; | ||||
| import { TokenUtils } from './utils/token_utils'; | ||||
| import { provider, web3Wrapper } from './utils/web3_wrapper'; | ||||
|  | ||||
| chaiSetup.configure(); | ||||
| const expect = chai.expect; | ||||
| const blockchainLifecycle = new BlockchainLifecycle(); | ||||
| const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper); | ||||
|  | ||||
| describe('TokenWrapper', () => { | ||||
|     let web3: Web3; | ||||
|     let zeroEx: ZeroEx; | ||||
|     let userAddresses: string[]; | ||||
|     let tokens: Token[]; | ||||
|     let tokenUtils: TokenUtils; | ||||
|     let coinbase: string; | ||||
|     let addressWithoutFunds: string; | ||||
|     let web3Wrapper: Web3Wrapper; | ||||
|     const config = { | ||||
|         networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     }; | ||||
|     before(async () => { | ||||
|         web3 = web3Factory.create(); | ||||
|         zeroEx = new ZeroEx(web3.currentProvider, config); | ||||
|         web3Wrapper = new Web3Wrapper(web3.currentProvider); | ||||
|         zeroEx = new ZeroEx(provider, config); | ||||
|         userAddresses = await zeroEx.getAvailableAddressesAsync(); | ||||
|         tokens = await zeroEx.tokenRegistry.getTokensAsync(); | ||||
|         tokenUtils = new TokenUtils(tokens); | ||||
| @@ -167,7 +165,7 @@ describe('TokenWrapper', () => { | ||||
|         }); | ||||
|     }); | ||||
|     describe('#getBalanceAsync', () => { | ||||
|         describe('With web3 provider with accounts', () => { | ||||
|         describe('With provider with accounts', () => { | ||||
|             it('should return the balance for an existing ERC20 token', async () => { | ||||
|                 const token = tokens[0]; | ||||
|                 const ownerAddress = coinbase; | ||||
| @@ -190,14 +188,14 @@ describe('TokenWrapper', () => { | ||||
|                 return expect(balance).to.be.bignumber.equal(expectedBalance); | ||||
|             }); | ||||
|         }); | ||||
|         describe('With web3 provider without accounts', () => { | ||||
|         describe('With provider without accounts', () => { | ||||
|             let zeroExWithoutAccounts: ZeroEx; | ||||
|             before(async () => { | ||||
|                 const hasAddresses = false; | ||||
|                 const web3WithoutAccounts = web3Factory.create(hasAddresses); | ||||
|                 zeroExWithoutAccounts = new ZeroEx(web3WithoutAccounts.currentProvider, config); | ||||
|                 const emptyWalletProvider = addEmptyWalletSubprovider(provider); | ||||
|                 zeroExWithoutAccounts = new ZeroEx(emptyWalletProvider, config); | ||||
|             }); | ||||
|             it('should return balance even when called with Web3 provider instance without addresses', async () => { | ||||
|             it('should return balance even when called with provider instance without addresses', async () => { | ||||
|                 const token = tokens[0]; | ||||
|                 const ownerAddress = coinbase; | ||||
|                 const balance = await zeroExWithoutAccounts.token.getBalanceAsync(token.address, ownerAddress); | ||||
| @@ -280,7 +278,7 @@ describe('TokenWrapper', () => { | ||||
|         }); | ||||
|     }); | ||||
|     describe('#getAllowanceAsync', () => { | ||||
|         describe('With web3 provider with accounts', () => { | ||||
|         describe('With provider with accounts', () => { | ||||
|             it('should get the proxy allowance', async () => { | ||||
|                 const token = tokens[0]; | ||||
|                 const ownerAddress = coinbase; | ||||
| @@ -302,12 +300,12 @@ describe('TokenWrapper', () => { | ||||
|                 return expect(allowance).to.be.bignumber.equal(expectedAllowance); | ||||
|             }); | ||||
|         }); | ||||
|         describe('With web3 provider without accounts', () => { | ||||
|         describe('With provider without accounts', () => { | ||||
|             let zeroExWithoutAccounts: ZeroEx; | ||||
|             before(async () => { | ||||
|                 const hasAddresses = false; | ||||
|                 const web3WithoutAccounts = web3Factory.create(hasAddresses); | ||||
|                 zeroExWithoutAccounts = new ZeroEx(web3WithoutAccounts.currentProvider, config); | ||||
|                 const emptyWalletProvider = addEmptyWalletSubprovider(provider); | ||||
|                 zeroExWithoutAccounts = new ZeroEx(emptyWalletProvider, config); | ||||
|             }); | ||||
|             it('should get the proxy allowance', async () => { | ||||
|                 const token = tokens[0]; | ||||
| @@ -427,8 +425,7 @@ describe('TokenWrapper', () => { | ||||
|                 ); | ||||
|                 zeroEx.token.subscribe(tokenAddress, TokenEvents.Transfer, indexFilterValues, callbackNeverToBeCalled); | ||||
|                 const callbackToBeCalled = reportNodeCallbackErrors(done)(); | ||||
|                 const newProvider = web3Factory.getRpcProvider(); | ||||
|                 zeroEx.setProvider(newProvider, constants.TESTRPC_NETWORK_ID); | ||||
|                 zeroEx.setProvider(provider, constants.TESTRPC_NETWORK_ID); | ||||
|                 zeroEx.token.subscribe(tokenAddress, TokenEvents.Transfer, indexFilterValues, callbackToBeCalled); | ||||
|                 await zeroEx.token.transferAsync(tokenAddress, coinbase, addressWithoutFunds, transferAmount); | ||||
|             })().catch(done); | ||||
| @@ -518,3 +515,14 @@ describe('TokenWrapper', () => { | ||||
|     }); | ||||
| }); | ||||
| // tslint:disable:max-file-line-count | ||||
|  | ||||
| function addEmptyWalletSubprovider(p: Provider): Provider { | ||||
|     const providerEngine = new Web3ProviderEngine(); | ||||
|     providerEngine.addProvider(new EmptyWalletSubprovider()); | ||||
|     const currentSubproviders = (p as any)._providers; | ||||
|     for (const subprovider of currentSubproviders) { | ||||
|         providerEngine.addProvider(subprovider); | ||||
|     } | ||||
|     providerEngine.start(); | ||||
|     return providerEngine; | ||||
| } | ||||
|   | ||||
							
								
								
									
										18
									
								
								packages/0x.js/test/utils/deployer.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								packages/0x.js/test/utils/deployer.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| import { Deployer } from '@0xproject/deployer'; | ||||
| import { devConstants } from '@0xproject/dev-utils'; | ||||
| import * as path from 'path'; | ||||
|  | ||||
| import { constants } from './constants'; | ||||
|  | ||||
| import { provider } from './web3_wrapper'; | ||||
|  | ||||
| const artifactsDir = path.resolve('test', 'artifacts'); | ||||
| const deployerOpts = { | ||||
|     artifactsDir, | ||||
|     provider, | ||||
|     networkId: constants.TESTRPC_NETWORK_ID, | ||||
|     defaults: { | ||||
|         gas: devConstants.GAS_ESTIMATE, | ||||
|     }, | ||||
| }; | ||||
| export const deployer = new Deployer(deployerOpts); | ||||
| @@ -36,7 +36,12 @@ export class FillScenarios { | ||||
|         for (const token of this._tokens) { | ||||
|             if (token.symbol !== 'ZRX' && token.symbol !== 'WETH') { | ||||
|                 const defaults = {}; | ||||
|                 const dummyToken = new DummyTokenContract(web3Wrapper, artifacts.DummyTokenArtifact.abi, token.address); | ||||
|                 const dummyToken = new DummyTokenContract( | ||||
|                     artifacts.DummyTokenArtifact.abi, | ||||
|                     token.address, | ||||
|                     web3Wrapper.getProvider(), | ||||
|                     web3Wrapper.getContractDefaults(), | ||||
|                 ); | ||||
|                 const tokenSupply = ZeroEx.toBaseUnitAmount(INITIAL_COINBASE_TOKEN_SUPPLY_IN_UNITS, token.decimals); | ||||
|                 const txHash = await dummyToken.setBalance.sendTransactionAsync(this._coinbase, tokenSupply, { | ||||
|                     from: this._coinbase, | ||||
|   | ||||
							
								
								
									
										12
									
								
								packages/0x.js/test/utils/web3_wrapper.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								packages/0x.js/test/utils/web3_wrapper.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| import { devConstants, web3Factory } from '@0xproject/dev-utils'; | ||||
| import { Provider } from '@0xproject/types'; | ||||
| import { Web3Wrapper } from '@0xproject/web3-wrapper'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { constants } from './constants'; | ||||
|  | ||||
| const web3 = web3Factory.create({ shouldUseInProcessGanache: true }); | ||||
| const provider: Provider = web3.currentProvider; | ||||
| const web3Wrapper = new Web3Wrapper(web3.currentProvider); | ||||
|  | ||||
| export { provider, web3Wrapper }; | ||||
| @@ -1,17 +1,7 @@ | ||||
| { | ||||
|     "extends": "../../tsconfig", | ||||
|     "compilerOptions": { | ||||
|         "outDir": "lib", | ||||
|         "noImplicitThis": false | ||||
|         "outDir": "lib" | ||||
|     }, | ||||
|     "include": [ | ||||
|         "./src/**/*", | ||||
|         "./test/**/*", | ||||
|         "../../node_modules/types-bn/index.d.ts", | ||||
|         "../../node_modules/types-ethereumjs-util/index.d.ts", | ||||
|         "../../node_modules/ethers-typescript-typings/index.d.ts", | ||||
|         "../../node_modules/web3-typescript-typings/index.d.ts", | ||||
|         "../../node_modules/chai-typescript-typings/index.d.ts", | ||||
|         "../../node_modules/chai-as-promised-typescript-typings/index.d.ts" | ||||
|     ] | ||||
|     "include": ["./src/**/*", "./test/**/*"] | ||||
| } | ||||
|   | ||||
| @@ -3,3 +3,4 @@ yarn-error.log | ||||
| /src/ | ||||
| /scripts/ | ||||
| tsconfig.json | ||||
| /lib/monorepo_scripts/ | ||||
|   | ||||
							
								
								
									
										111
									
								
								packages/abi-gen/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								packages/abi-gen/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,111 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1524044013, | ||||
|         "version": "0.2.11", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1523462196, | ||||
|         "version": "0.2.10", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1522673609, | ||||
|         "version": "0.2.9", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1522658513, | ||||
|         "version": "0.2.8", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.2.5", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Consolidate all `console.log` calls into `logUtils` in the `@0xproject/utils` package", | ||||
|                 "pr": 452 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1521298800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.2.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add a `backend` parameter that allows you to specify the Ethereum library you use in your templates (`web3` or `ethers`). Ethers auto-converts small ints to numbers whereas Web3 doesn't. Defaults to `web3`", | ||||
|                 "pr": 413 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Add support for [tuple types](https://solidity.readthedocs.io/en/develop/abi-spec.html#handling-tuple-types)", | ||||
|                 "pr": 413 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add `hasReturnValue` to context data", | ||||
|                 "pr": 413 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1520089200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.2.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix publishing issue where .npmignore was not properly excluding undesired content", | ||||
|                 "pr": 389 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1518102000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.2.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Added CLI options for explicit specifying location of partials and main template", | ||||
|                 "pr": 346 | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Added CLI option to specify networkId, adding support for the JSON artifact format found in @0xproject/contracts", | ||||
|                 "pr": 388 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1517929200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.1.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fixed array typings with union types", | ||||
|                 "pr": 295 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add event ABIs to context data passed to templates", | ||||
|                 "pr": 302 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add constructor ABIs to context data passed to templates", | ||||
|                 "pr": 304 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1515596400 | ||||
|     } | ||||
| ] | ||||
| @@ -1,6 +1,31 @@ | ||||
| # CHANGELOG | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| ## v0.2.3 - _March 4, 2018_ | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.2.11 - _April 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.10 - _April 12, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.9 - _April 2, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.8 - _April 2, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.5 - _March 18, 2018_ | ||||
|  | ||||
|     * Consolidate all `console.log` calls into `logUtils` in the `@0xproject/utils` package (#452) | ||||
|  | ||||
| ## v0.2.4 - _March 4, 2018_ | ||||
|  | ||||
|     * Add a `backend` parameter that allows you to specify the Ethereum library you use in your templates (`web3` or `ethers`). Ethers auto-converts small ints to numbers whereas Web3 doesn't. Defaults to `web3` (#413) | ||||
|     * Add support for [tuple types](https://solidity.readthedocs.io/en/develop/abi-spec.html#handling-tuple-types) (#413) | ||||
|   | ||||
| @@ -16,24 +16,33 @@ For an example of the generated [wrapper files](https://github.com/0xProject/0x- | ||||
| ``` | ||||
| abi-gen | ||||
| Options: | ||||
|   --help           Show help                                           [boolean] | ||||
|   --version        Show version number                                 [boolean] | ||||
|   --abiGlob        Glob pattern to search for ABI JSON files [string] [required] | ||||
|   --templates      Folder where to search for templates      [string] [required] | ||||
|   --output         Folder where to put the output files      [string] [required] | ||||
|   --help               Show help                                       [boolean] | ||||
|   --version            Show version number                             [boolean] | ||||
|   --abis               Glob pattern to search for ABI JSON files | ||||
|                                                              [string] [required] | ||||
|   --output, -o, --out  Folder where to put the output files  [string] [required] | ||||
|   --partials           Glob pattern for the partial template files      [string] | ||||
|   --template           Path for the main template file that will be used to | ||||
|                        generate each contract                [string] [required] | ||||
|   --backend            The backing Ethereum library your app uses. Either 'web3' | ||||
|                        or 'ethers'. Ethers auto-converts small ints to numbers | ||||
|                        whereas Web3 doesn't. | ||||
|                           [string] [choices: "web3", "ethers"] [default: "web3"] | ||||
|   --network-id         ID of the network where contract ABIs are nested in | ||||
|                        artifacts                          [number] [default: 50] | ||||
| ``` | ||||
|  | ||||
| ## ABI files | ||||
|  | ||||
| You're required to pass a [glob](<https://en.wikipedia.org/wiki/Glob_(programming)>) template where your abi files are located. | ||||
| TL;DR - here is the example from 0x.js. | ||||
|  | ||||
| `--abiGlob 'src/artifacts/@(Exchange|Token|TokenTransferProxy|EtherToken|TokenRegistry).json` | ||||
| `--abis 'src/artifacts/@(Exchange|Token|TokenTransferProxy|EtherToken|TokenRegistry).json` | ||||
|  | ||||
| We could've just used `--abiGlob 'src/artifacts/*.json` but we wanted to exclude some of the abi files. | ||||
| We could've just used `--abis 'src/artifacts/*.json` but we wanted to exclude some of the abi files. | ||||
|  | ||||
| The abi file should be either a [Truffle](http://truffleframework.com/) contract artifact (a JSON object with an abi key) or a JSON abi array. | ||||
|  | ||||
| You need to also specify the location of your main template used for every contract `--template` as well as the partial templates `--partials` that can later be used from the main one. | ||||
|  | ||||
| ## 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. | ||||
| @@ -48,3 +57,61 @@ See the [type definition](https://github.com/0xProject/0x-monorepo/tree/developm | ||||
| ## Output files | ||||
|  | ||||
| Output files will be generated within an output folder with names converted to camel case and taken from abi file names. If you already have some files in that folder they will be overwritten. | ||||
|  | ||||
| ## Contributing | ||||
|  | ||||
| We welcome improvements and fixes from the wider community! To report bugs within this package, please create an issue in this repository. | ||||
|  | ||||
| Please read our [contribution guidelines](../../CONTRIBUTING.md) before getting started. | ||||
|  | ||||
| ### Install dependencies | ||||
|  | ||||
| If you don't have yarn workspaces enabled (Yarn < v1.0) - enable them: | ||||
|  | ||||
| ```bash | ||||
| yarn config set workspaces-experimental true | ||||
| ``` | ||||
|  | ||||
| Then install dependencies | ||||
|  | ||||
| ```bash | ||||
| yarn install | ||||
| ``` | ||||
|  | ||||
| ### Build | ||||
|  | ||||
| If this is your **first** time building this package, you must first build **all** packages within the monorepo. This is because packages that depend on other packages located inside this monorepo are symlinked when run from **within** the monorepo. This allows you to make changes across multiple packages without first publishing dependent packages to NPM. To build all packages, run the following from the monorepo root directory: | ||||
|  | ||||
| ```bash | ||||
| yarn lerna:rebuild | ||||
| ``` | ||||
|  | ||||
| Or continuously rebuild on change: | ||||
|  | ||||
| ```bash | ||||
| yarn dev | ||||
| ``` | ||||
|  | ||||
| You can also build this specific package by running the following from within its directory: | ||||
|  | ||||
| ```bash | ||||
| yarn build | ||||
| ``` | ||||
|  | ||||
| or continuously rebuild on change: | ||||
|  | ||||
| ```bash | ||||
| yarn build:watch | ||||
| ``` | ||||
|  | ||||
| ### Clean | ||||
|  | ||||
| ```bash | ||||
| yarn clean | ||||
| ``` | ||||
|  | ||||
| ### Lint | ||||
|  | ||||
| ```bash | ||||
| yarn lint | ||||
| ``` | ||||
|   | ||||
| @@ -1,14 +1,15 @@ | ||||
| { | ||||
|     "name": "@0xproject/abi-gen", | ||||
|     "version": "0.2.4", | ||||
|     "version": "0.2.11", | ||||
|     "description": "Generate contract wrappers from ABI and handlebars templates", | ||||
|     "main": "lib/index.js", | ||||
|     "types": "lib/index.d.ts", | ||||
|     "scripts": { | ||||
|         "build:watch": "tsc -w", | ||||
|         "lint": "tslint --project . 'src/**/*.ts'", | ||||
|         "clean": "shx rm -rf lib", | ||||
|         "build": "tsc" | ||||
|         "clean": "shx rm -rf lib scripts", | ||||
|         "build": "tsc && copyfiles -u 2 './lib/monorepo_scripts/**/*' ./scripts", | ||||
|         "manual:postpublish": "yarn build; node ./scripts/postpublish.js" | ||||
|     }, | ||||
|     "bin": { | ||||
|         "abi-gen": "lib/index.js" | ||||
| @@ -23,27 +24,32 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x-monorepo/packages/abi-gen/README.md", | ||||
|     "dependencies": { | ||||
|         "@0xproject/utils": "^0.4.0", | ||||
|         "@0xproject/types": "^0.6.1", | ||||
|         "@0xproject/typescript-typings": "^0.2.0", | ||||
|         "@0xproject/utils": "^0.5.2", | ||||
|         "chalk": "^2.3.0", | ||||
|         "glob": "^7.1.2", | ||||
|         "handlebars": "^4.0.11", | ||||
|         "lodash": "^4.17.4", | ||||
|         "mkdirp": "^0.5.1", | ||||
|         "to-snake-case": "^1.0.0", | ||||
|         "web3": "^0.20.0", | ||||
|         "yargs": "^10.0.3" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@0xproject/tslint-config": "^0.4.10", | ||||
|         "@0xproject/monorepo-scripts": "^0.1.18", | ||||
|         "@0xproject/tslint-config": "^0.4.16", | ||||
|         "@types/glob": "^5.0.33", | ||||
|         "@types/handlebars": "^4.0.36", | ||||
|         "@types/mkdirp": "^0.5.1", | ||||
|         "@types/node": "^8.0.53", | ||||
|         "@types/yargs": "^10.0.0", | ||||
|         "copyfiles": "^1.2.0", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "typescript": "2.7.1", | ||||
|         "web3-typescript-typings": "^0.10.0" | ||||
|         "typescript": "2.7.1" | ||||
|     }, | ||||
|     "publishConfig": { | ||||
|         "access": "public" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,5 +0,0 @@ | ||||
| const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const packageJSON = require('../package.json'); | ||||
|  | ||||
| const subPackageName = packageJSON.name; | ||||
| postpublish_utils.standardPostPublishAsync(subPackageName); | ||||
							
								
								
									
										8
									
								
								packages/abi-gen/src/globals.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								packages/abi-gen/src/globals.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,6 @@ | ||||
| declare function toSnakeCase(str: string): string; | ||||
| declare module 'to-snake-case' { | ||||
|     export = toSnakeCase; | ||||
| declare module '*.json' { | ||||
|     const json: any; | ||||
|     /* tslint:disable */ | ||||
|     export default json; | ||||
|     /* tslint:enable */ | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| #!/usr/bin/env node | ||||
|  | ||||
| import { AbiDefinition, ConstructorAbi, EventAbi, MethodAbi } from '@0xproject/types'; | ||||
| import { abiUtils, logUtils } from '@0xproject/utils'; | ||||
| import chalk from 'chalk'; | ||||
| import * as fs from 'fs'; | ||||
| import { sync as globSync } from 'glob'; | ||||
| @@ -9,9 +11,8 @@ import * as mkdirp from 'mkdirp'; | ||||
| import * as yargs from 'yargs'; | ||||
|  | ||||
| import toSnakeCase = require('to-snake-case'); | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { ContextData, ContractsBackend, ParamKind } from './types'; | ||||
| import { ContextData, ContractsBackend, Method, ParamKind } from './types'; | ||||
| import { utils } from './utils'; | ||||
|  | ||||
| const ABI_TYPE_CONSTRUCTOR = 'constructor'; | ||||
| @@ -62,7 +63,7 @@ const args = yargs | ||||
|  | ||||
| function registerPartials(partialsGlob: string) { | ||||
|     const partialTemplateFileNames = globSync(partialsGlob); | ||||
|     utils.log(`Found ${chalk.green(`${partialTemplateFileNames.length}`)} ${chalk.bold('partial')} templates`); | ||||
|     logUtils.log(`Found ${chalk.green(`${partialTemplateFileNames.length}`)} ${chalk.bold('partial')} templates`); | ||||
|     for (const partialTemplateFileName of partialTemplateFileNames) { | ||||
|         const namedContent = utils.getNamedContent(partialTemplateFileName); | ||||
|         Handlebars.registerPartial(namedContent.name, namedContent.content); | ||||
| @@ -77,12 +78,11 @@ function writeOutputFile(name: string, renderedTsCode: string): void { | ||||
|     } | ||||
|     const filePath = `${args.output}/${fileName}.ts`; | ||||
|     fs.writeFileSync(filePath, renderedTsCode); | ||||
|     utils.log(`Created: ${chalk.bold(filePath)}`); | ||||
|     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) { | ||||
|     registerPartials(args.partials); | ||||
| } | ||||
| @@ -91,17 +91,17 @@ const template = Handlebars.compile<ContextData>(mainTemplate.content); | ||||
| const abiFileNames = globSync(args.abis); | ||||
|  | ||||
| if (_.isEmpty(abiFileNames)) { | ||||
|     utils.log(`${chalk.red(`No ABI files found.`)}`); | ||||
|     utils.log(`Please make sure you've passed the correct folder name and that the files have | ||||
|     logUtils.log(`${chalk.red(`No ABI files found.`)}`); | ||||
|     logUtils.log(`Please make sure you've passed the correct folder name and that the files have | ||||
|                ${chalk.bold('*.json')} extensions`); | ||||
|     process.exit(1); | ||||
| } else { | ||||
|     utils.log(`Found ${chalk.green(`${abiFileNames.length}`)} ${chalk.bold('ABI')} files`); | ||||
|     logUtils.log(`Found ${chalk.green(`${abiFileNames.length}`)} ${chalk.bold('ABI')} files`); | ||||
|     mkdirp.sync(args.output); | ||||
| } | ||||
| for (const abiFileName of abiFileNames) { | ||||
|     const namedContent = utils.getNamedContent(abiFileName); | ||||
|     utils.log(`Processing: ${chalk.bold(namedContent.name)}...`); | ||||
|     logUtils.log(`Processing: ${chalk.bold(namedContent.name)}...`); | ||||
|     const parsedContent = JSON.parse(namedContent.content); | ||||
|     let ABI; | ||||
|     if (_.isArray(parsedContent)) { | ||||
| @@ -112,24 +112,25 @@ for (const abiFileName of abiFileNames) { | ||||
|         ABI = parsedContent.networks[args.networkId].abi; // 0x contracts package artifact | ||||
|     } | ||||
|     if (_.isUndefined(ABI)) { | ||||
|         utils.log(`${chalk.red(`ABI not found in ${abiFileName}.`)}`); | ||||
|         utils.log( | ||||
|         logUtils.log(`${chalk.red(`ABI not found in ${abiFileName}.`)}`); | ||||
|         logUtils.log( | ||||
|             `Please make sure your ABI file is either an array with ABI entries or a truffle artifact or 0x deployer artifact`, | ||||
|         ); | ||||
|         process.exit(1); | ||||
|     } | ||||
|  | ||||
|     let ctor = ABI.find((abi: Web3.AbiDefinition) => abi.type === ABI_TYPE_CONSTRUCTOR) as Web3.ConstructorAbi; | ||||
|     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 | ||||
|     } | ||||
|  | ||||
|     const methodAbis = ABI.filter((abi: Web3.AbiDefinition) => abi.type === ABI_TYPE_METHOD) as Web3.MethodAbi[]; | ||||
|     const methodsData = _.map(methodAbis, methodAbi => { | ||||
|         _.map(methodAbi.inputs, (input, i: number) => { | ||||
|     const methodAbis = ABI.filter((abi: AbiDefinition) => abi.type === ABI_TYPE_METHOD) as MethodAbi[]; | ||||
|     const sanitizedMethodAbis = abiUtils.renameOverloadedMethods(methodAbis) as MethodAbi[]; | ||||
|     const methodsData = _.map(methodAbis, (methodAbi, methodAbiIndex: number) => { | ||||
|         _.forEach(methodAbi.inputs, (input, inputIndex: number) => { | ||||
|             if (_.isEmpty(input.name)) { | ||||
|                 // Auto-generated getters don't have parameter names | ||||
|                 input.name = `index_${i}`; | ||||
|                 input.name = `index_${inputIndex}`; | ||||
|             } | ||||
|         }); | ||||
|         // This will make templates simpler | ||||
| @@ -137,11 +138,13 @@ for (const abiFileName of abiFileNames) { | ||||
|             ...methodAbi, | ||||
|             singleReturnValue: methodAbi.outputs.length === 1, | ||||
|             hasReturnValue: methodAbi.outputs.length !== 0, | ||||
|             tsName: sanitizedMethodAbis[methodAbiIndex].name, | ||||
|             functionSignature: abiUtils.getFunctionSignature(methodAbi), | ||||
|         }; | ||||
|         return methodData; | ||||
|     }); | ||||
|  | ||||
|     const eventAbis = ABI.filter((abi: Web3.AbiDefinition) => abi.type === ABI_TYPE_EVENT) as Web3.EventAbi[]; | ||||
|     const eventAbis = ABI.filter((abi: AbiDefinition) => abi.type === ABI_TYPE_EVENT) as EventAbi[]; | ||||
|  | ||||
|     const contextData = { | ||||
|         contractName: namedContent.name, | ||||
|   | ||||
							
								
								
									
										8
									
								
								packages/abi-gen/src/monorepo_scripts/postpublish.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								packages/abi-gen/src/monorepo_scripts/postpublish.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| import { postpublishUtils } from '@0xproject/monorepo-scripts'; | ||||
|  | ||||
| import * as packageJSON from '../package.json'; | ||||
| import * as tsConfigJSON from '../tsconfig.json'; | ||||
|  | ||||
| const cwd = `${__dirname}/..`; | ||||
| // tslint:disable-next-line:no-floating-promises | ||||
| postpublishUtils.runAsync(packageJSON, tsConfigJSON, cwd); | ||||
| @@ -1,29 +1,24 @@ | ||||
| import * as Web3 from 'web3'; | ||||
| import { EventAbi, MethodAbi } from '@0xproject/types'; | ||||
|  | ||||
| export enum ParamKind { | ||||
|     Input = 'input', | ||||
|     Output = 'output', | ||||
| } | ||||
|  | ||||
| export enum AbiType { | ||||
|     Function = 'function', | ||||
|     Constructor = 'constructor', | ||||
|     Event = 'event', | ||||
|     Fallback = 'fallback', | ||||
| } | ||||
|  | ||||
| export enum ContractsBackend { | ||||
|     Web3 = 'web3', | ||||
|     Ethers = 'ethers', | ||||
| } | ||||
|  | ||||
| export interface Method extends Web3.MethodAbi { | ||||
| export interface Method extends MethodAbi { | ||||
|     singleReturnValue: boolean; | ||||
|     hasReturnValue: boolean; | ||||
|     tsName: string; | ||||
|     functionSignature: string; | ||||
| } | ||||
|  | ||||
| export interface ContextData { | ||||
|     contractName: string; | ||||
|     methods: Method[]; | ||||
|     events: Web3.EventAbi[]; | ||||
|     events: EventAbi[]; | ||||
| } | ||||
|   | ||||
| @@ -1,17 +1,12 @@ | ||||
| import { AbiType, ConstructorAbi, DataItem } from '@0xproject/types'; | ||||
| import * as fs from 'fs'; | ||||
| import * as _ from 'lodash'; | ||||
| import * as path from 'path'; | ||||
| import * as Web3 from 'web3'; | ||||
|  | ||||
| import { AbiType, ContractsBackend, ParamKind } from './types'; | ||||
| import { ContractsBackend, ParamKind } from './types'; | ||||
|  | ||||
| export const utils = { | ||||
|     solTypeToTsType( | ||||
|         paramKind: ParamKind, | ||||
|         backend: ContractsBackend, | ||||
|         solType: string, | ||||
|         components?: Web3.DataItem[], | ||||
|     ): string { | ||||
|     solTypeToTsType(paramKind: ParamKind, backend: ContractsBackend, solType: string, components?: DataItem[]): string { | ||||
|         const trailingArrayRegex = /\[\d*\]$/; | ||||
|         if (solType.match(trailingArrayRegex)) { | ||||
|             const arrayItemSolType = solType.replace(trailingArrayRegex, ''); | ||||
| @@ -73,9 +68,6 @@ export const utils = { | ||||
|     isObjectType(tsType: string): boolean { | ||||
|         return /^{.*}$/.test(tsType); | ||||
|     }, | ||||
|     log(...args: any[]): void { | ||||
|         console.log(...args); // tslint:disable-line:no-console | ||||
|     }, | ||||
|     getPartialNameFromFileName(filename: string): string { | ||||
|         const name = path.parse(filename).name; | ||||
|         return name; | ||||
| @@ -92,7 +84,7 @@ export const utils = { | ||||
|             throw new Error(`Failed to read ${filename}: ${err}`); | ||||
|         } | ||||
|     }, | ||||
|     getEmptyConstructor(): Web3.ConstructorAbi { | ||||
|     getEmptyConstructor(): ConstructorAbi { | ||||
|         return { | ||||
|             type: AbiType.Constructor, | ||||
|             stateMutability: 'nonpayable', | ||||
|   | ||||
| @@ -3,5 +3,5 @@ | ||||
|     "compilerOptions": { | ||||
|         "outDir": "lib" | ||||
|     }, | ||||
|     "include": ["./src/**/*", "./test/**/*", "../../node_modules/web3-typescript-typings/index.d.ts"] | ||||
|     "include": ["./src/**/*", "./test/**/*"] | ||||
| } | ||||
|   | ||||
| @@ -4,3 +4,4 @@ yarn-error.log | ||||
| /scripts/ | ||||
| test/ | ||||
| tsconfig.json | ||||
| /lib/src/monorepo_scripts/ | ||||
|   | ||||
							
								
								
									
										85
									
								
								packages/assert/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								packages/assert/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1524044013, | ||||
|         "version": "0.2.7", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1523462196, | ||||
|         "version": "0.2.6", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1522673609, | ||||
|         "version": "0.2.5", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1522658513, | ||||
|         "version": "0.2.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.2.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Rename `isHttpUrl` to `isWebUri`", | ||||
|                 "pr": 412 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1520434800 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.1.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Remove isETHAddressHex checksum address check and assume address will be lowercased ", | ||||
|                 "pr": 373 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Add an optional parameter `subSchemas` to `doesConformToSchema` method", | ||||
|                 "pr": 385 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1520089200 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.0.18", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Fix publishing issue where .npmignore was not properly excluding undesired content", | ||||
|                 "pr": 389 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1486566000 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.0.4", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Re-publish Assert previously published under NPM package @0xproject/0x-assert" | ||||
|             }, | ||||
|             { | ||||
|                 "note": | ||||
|                     "Added assertion isValidBaseUnitAmount which checks both that the value is a valid bigNumber and that it does not contain decimals." | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1510585200 | ||||
|     } | ||||
| ] | ||||
| @@ -1,4 +1,29 @@ | ||||
| # CHANGELOG | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.2.7 - _April 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.6 - _April 12, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.5 - _April 2, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.4 - _April 2, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.0 - _March 8, 2018_ | ||||
|  | ||||
|     * Rename `isHttpUrl` to `isWebUri` (#412) | ||||
|  | ||||
| ## v0.1.0 - _March 4, 2018_ | ||||
|  | ||||
|   | ||||
| @@ -16,13 +16,21 @@ import { assert } from '@0xproject/assert'; | ||||
| assert.isValidBaseUnitAmount('baseUnitAmount', baseUnitAmount); | ||||
| ``` | ||||
|  | ||||
| If your project is in [TypeScript](https://www.typescriptlang.org/), add the following to your `tsconfig.json`: | ||||
|  | ||||
| ```json | ||||
| "compilerOptions": { | ||||
|     "typeRoots": ["node_modules/@0xproject/typescript-typings/types", "node_modules/@types"], | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ## Contributing | ||||
|  | ||||
| We strongly encourage that the community help us make improvements and determine the future direction of the protocol. To report bugs within this package, please create an issue in this repository. | ||||
| We welcome improvements and fixes from the wider community! To report bugs within this package, please create an issue in this repository. | ||||
|  | ||||
| Please read our [contribution guidelines](../../CONTRIBUTING.md) before getting started. | ||||
|  | ||||
| ### Install Dependencies | ||||
| ### Install dependencies | ||||
|  | ||||
| If you don't have yarn workspaces enabled (Yarn < v1.0) - enable them: | ||||
|  | ||||
| @@ -38,10 +46,36 @@ yarn install | ||||
|  | ||||
| ### Build | ||||
|  | ||||
| If this is your **first** time building this package, you must first build **all** packages within the monorepo. This is because packages that depend on other packages located inside this monorepo are symlinked when run from **within** the monorepo. This allows you to make changes across multiple packages without first publishing dependent packages to NPM. To build all packages, run the following from the monorepo root directory: | ||||
|  | ||||
| ```bash | ||||
| yarn lerna:rebuild | ||||
| ``` | ||||
|  | ||||
| Or continuously rebuild on change: | ||||
|  | ||||
| ```bash | ||||
| yarn dev | ||||
| ``` | ||||
|  | ||||
| You can also build this specific package by running the following from within its directory: | ||||
|  | ||||
| ```bash | ||||
| yarn build | ||||
| ``` | ||||
|  | ||||
| or continuously rebuild on change: | ||||
|  | ||||
| ```bash | ||||
| yarn build:watch | ||||
| ``` | ||||
|  | ||||
| ### Clean | ||||
|  | ||||
| ```bash | ||||
| yarn clean | ||||
| ``` | ||||
|  | ||||
| ### Lint | ||||
|  | ||||
| ```bash | ||||
|   | ||||
							
								
								
									
										0
									
								
								packages/assert/coverage/.gitkeep
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								packages/assert/coverage/.gitkeep
									
									
									
									
									
										Normal file
									
								
							| @@ -1,18 +1,21 @@ | ||||
| { | ||||
|     "name": "@0xproject/assert", | ||||
|     "version": "0.1.0", | ||||
|     "version": "0.2.7", | ||||
|     "description": "Provides a standard way of performing type and schema validation across 0x projects", | ||||
|     "main": "lib/src/index.js", | ||||
|     "types": "lib/src/index.d.ts", | ||||
|     "scripts": { | ||||
|         "build:watch": "tsc -w", | ||||
|         "build": "tsc", | ||||
|         "clean": "shx rm -rf _bundles lib test_temp", | ||||
|         "build": "tsc && copyfiles -u 3 './lib/src/monorepo_scripts/**/*' ./scripts", | ||||
|         "clean": "shx rm -rf lib test_temp scripts", | ||||
|         "lint": "tslint --project . 'src/**/*.ts' 'test/**/*.ts'", | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js", | ||||
|         "run_mocha": "mocha lib/test/**/*_test.js --exit", | ||||
|         "prepublishOnly": "run-p build", | ||||
|         "test": "run-s clean build run_mocha", | ||||
|         "test:circleci": "yarn 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", | ||||
|         "manual:postpublish": "yarn build; node ./scripts/postpublish.js" | ||||
|     }, | ||||
|     "license": "Apache-2.0", | ||||
|     "repository": { | ||||
| @@ -24,23 +27,29 @@ | ||||
|     }, | ||||
|     "homepage": "https://github.com/0xProject/0x-monorepo/packages/assert/README.md", | ||||
|     "devDependencies": { | ||||
|         "@0xproject/tslint-config": "^0.4.10", | ||||
|         "@types/lodash": "^4.14.86", | ||||
|         "@0xproject/monorepo-scripts": "^0.1.18", | ||||
|         "@0xproject/tslint-config": "^0.4.16", | ||||
|         "@types/lodash": "4.14.104", | ||||
|         "@types/mocha": "^2.2.42", | ||||
|         "@types/valid-url": "^1.0.2", | ||||
|         "chai": "^4.0.1", | ||||
|         "chai-typescript-typings": "^0.0.4", | ||||
|         "copyfiles": "^1.2.0", | ||||
|         "dirty-chai": "^2.0.1", | ||||
|         "mocha": "^4.0.1", | ||||
|         "npm-run-all": "^4.1.2", | ||||
|         "nyc": "^11.0.1", | ||||
|         "shx": "^0.2.2", | ||||
|         "tslint": "5.8.0", | ||||
|         "typescript": "2.7.1" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@0xproject/json-schemas": "^0.7.13", | ||||
|         "@0xproject/utils": "^0.4.0", | ||||
|         "@0xproject/json-schemas": "^0.7.21", | ||||
|         "@0xproject/typescript-typings": "^0.2.0", | ||||
|         "@0xproject/utils": "^0.5.2", | ||||
|         "lodash": "^4.17.4", | ||||
|         "valid-url": "^1.0.9" | ||||
|     }, | ||||
|     "publishConfig": { | ||||
|         "access": "public" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,5 +0,0 @@ | ||||
| const postpublish_utils = require('../../../scripts/postpublish_utils'); | ||||
| const packageJSON = require('../package.json'); | ||||
|  | ||||
| const subPackageName = packageJSON.name; | ||||
| postpublish_utils.standardPostPublishAsync(subPackageName); | ||||
							
								
								
									
										7
									
								
								packages/assert/src/globals.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								packages/assert/src/globals.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -1 +1,6 @@ | ||||
| declare module 'dirty-chai'; | ||||
| declare module '*.json' { | ||||
|     const json: any; | ||||
|     /* tslint:disable */ | ||||
|     export default json; | ||||
|     /* tslint:enable */ | ||||
| } | ||||
|   | ||||
| @@ -61,7 +61,7 @@ export const assert = { | ||||
|     }, | ||||
|     isWeb3Provider(variableName: string, value: any): void { | ||||
|         const isWeb3Provider = _.isFunction(value.send) || _.isFunction(value.sendAsync); | ||||
|         this.assert(isWeb3Provider, this.typeAssertionMessage(variableName, 'Web3.Provider', value)); | ||||
|         this.assert(isWeb3Provider, this.typeAssertionMessage(variableName, 'Provider', value)); | ||||
|     }, | ||||
|     doesConformToSchema(variableName: string, value: any, schema: Schema, subSchemas?: Schema[]): void { | ||||
|         const schemaValidator = new SchemaValidator(); | ||||
| @@ -75,9 +75,9 @@ Encountered: ${JSON.stringify(value, null, '\t')} | ||||
| Validation errors: ${validationResult.errors.join(', ')}`; | ||||
|         this.assert(!hasValidationErrors, msg); | ||||
|     }, | ||||
|     isHttpUrl(variableName: string, value: any): void { | ||||
|     isWebUri(variableName: string, value: any): void { | ||||
|         const isValidUrl = !_.isUndefined(validUrl.isWebUri(value)); | ||||
|         this.assert(isValidUrl, this.typeAssertionMessage(variableName, 'http url', value)); | ||||
|         this.assert(isValidUrl, this.typeAssertionMessage(variableName, 'web uri', value)); | ||||
|     }, | ||||
|     isUri(variableName: string, value: any): void { | ||||
|         const isValidUri = !_.isUndefined(validUrl.isUri(value)); | ||||
|   | ||||
							
								
								
									
										8
									
								
								packages/assert/src/monorepo_scripts/postpublish.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								packages/assert/src/monorepo_scripts/postpublish.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| import { postpublishUtils } from '@0xproject/monorepo-scripts'; | ||||
|  | ||||
| import * as packageJSON from '../package.json'; | ||||
| import * as tsConfigJSON from '../tsconfig.json'; | ||||
|  | ||||
| const cwd = `${__dirname}/..`; | ||||
| // tslint:disable-next-line:no-floating-promises | ||||
| postpublishUtils.runAsync(packageJSON, tsConfigJSON, cwd); | ||||
| @@ -183,7 +183,7 @@ describe('Assertions', () => { | ||||
|             ); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#isHttpUrl', () => { | ||||
|     describe('#isWebUri', () => { | ||||
|         it('should not throw for valid input', () => { | ||||
|             const validInputs = [ | ||||
|                 'http://www.google.com', | ||||
| @@ -191,7 +191,7 @@ describe('Assertions', () => { | ||||
|                 'https://api.radarrelay.com/0x/v0/', | ||||
|                 'https://zeroex.beta.radarrelay.com:8000/0x/v0/', | ||||
|             ]; | ||||
|             validInputs.forEach(input => expect(assert.isHttpUrl.bind(assert, variableName, input)).to.not.throw()); | ||||
|             validInputs.forEach(input => expect(assert.isWebUri.bind(assert, variableName, input)).to.not.throw()); | ||||
|         }); | ||||
|         it('should throw for invalid input', () => { | ||||
|             const invalidInputs = [ | ||||
| @@ -205,7 +205,7 @@ describe('Assertions', () => { | ||||
|                 'user:password@api.example-relayer.net', | ||||
|                 '//api.example-relayer.net', | ||||
|             ]; | ||||
|             invalidInputs.forEach(input => expect(assert.isHttpUrl.bind(assert, variableName, input)).to.throw()); | ||||
|             invalidInputs.forEach(input => expect(assert.isWebUri.bind(assert, variableName, input)).to.throw()); | ||||
|         }); | ||||
|     }); | ||||
|     describe('#isUri', () => { | ||||
|   | ||||
| @@ -3,10 +3,5 @@ | ||||
|     "compilerOptions": { | ||||
|         "outDir": "lib" | ||||
|     }, | ||||
|     "include": [ | ||||
|         "./src/**/*", | ||||
|         "./test/**/*", | ||||
|         "../../node_modules/web3-typescript-typings/index.d.ts", | ||||
|         "../../node_modules/chai-typescript-typings/index.d.ts" | ||||
|     ] | ||||
|     "include": ["./src/**/*", "./test/**/*"] | ||||
| } | ||||
|   | ||||
| @@ -3,3 +3,4 @@ yarn-error.log | ||||
| /scripts/ | ||||
| /src/ | ||||
| tsconfig.json | ||||
| /lib/monorepo_scripts/ | ||||
|   | ||||
							
								
								
									
										57
									
								
								packages/base-contract/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								packages/base-contract/CHANGELOG.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | ||||
| [ | ||||
|     { | ||||
|         "timestamp": 1524044013, | ||||
|         "version": "0.2.1", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.2.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Contract wrappers now accept Provider and defaults instead of Web3Wrapper", | ||||
|                 "pr": 501 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1523462196 | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.1.0", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Add tests for traversing ABI tree", | ||||
|                 "pr": 485 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fix ABI tuples traversing", | ||||
|                 "pr": 485 | ||||
|             }, | ||||
|             { | ||||
|                 "note": "Fix ABI arrays traversing", | ||||
|                 "pr": 485 | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1522673609 | ||||
|     }, | ||||
|     { | ||||
|         "timestamp": 1522658513, | ||||
|         "version": "0.0.6", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Dependencies updated" | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     { | ||||
|         "version": "0.0.2", | ||||
|         "changes": [ | ||||
|             { | ||||
|                 "note": "Initial release" | ||||
|             } | ||||
|         ], | ||||
|         "timestamp": 1520089200 | ||||
|     } | ||||
| ] | ||||
| @@ -1,5 +1,28 @@ | ||||
| # CHANGELOG | ||||
| <!-- | ||||
| This file is auto-generated using the monorepo-scripts package. Don't edit directly. | ||||
| Edit the package's CHANGELOG.json file only. | ||||
| --> | ||||
|  | ||||
| ## v0.0.1 - _March 4, 2018_ | ||||
| CHANGELOG | ||||
|  | ||||
| ## v0.2.1 - _April 18, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.2.0 - _April 12, 2018_ | ||||
|  | ||||
|     * Contract wrappers now accept Provider and defaults instead of Web3Wrapper (#501) | ||||
|  | ||||
| ## v0.1.0 - _April 2, 2018_ | ||||
|  | ||||
|     * Add tests for traversing ABI tree (#485) | ||||
|     * Fix ABI tuples traversing (#485) | ||||
|     * Fix ABI arrays traversing (#485) | ||||
|  | ||||
| ## v0.0.6 - _April 2, 2018_ | ||||
|  | ||||
|     * Dependencies updated | ||||
|  | ||||
| ## v0.0.2 - _March 4, 2018_ | ||||
|  | ||||
|     * Initial release | ||||
|   | ||||
| @@ -8,6 +8,14 @@ BaseContract to derive all auto-generated wrappers from | ||||
| yarn add @0xproject/base-contract | ||||
| ``` | ||||
|  | ||||
| If your project is in [TypeScript](https://www.typescriptlang.org/), add the following to your `tsconfig.json`: | ||||
|  | ||||
| ```json | ||||
| "compilerOptions": { | ||||
|     "typeRoots": ["node_modules/@0xproject/typescript-typings/types", "node_modules/@types"], | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| ```javascript | ||||
|   | ||||
							
								
								
									
										0
									
								
								packages/base-contract/coverage/.gitkeep
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								packages/base-contract/coverage/.gitkeep
									
									
									
									
									
										Normal file
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user