diff options
Diffstat (limited to 'README.md')
-rw-r--r-- | README.md | 117 |
1 files changed, 59 insertions, 58 deletions
@@ -2,7 +2,7 @@ --- -[0x][website-url] is an open protocol that facilitates trustless, low friction exchange of Ethereum-based assets. A full description of the protocol may be found in our [whitepaper][whitepaper-url]. +[0x][website-url] is an open protocol that facilitates trustless, low friction exchange of Ethereum-based assets. For more information on how it works, check out the [0x protocol specification](https://github.com/0xProject/0x-protocol-specification/blob/master/v2/v2-specification.md). This repository is a monorepo including the 0x protocol smart contracts and numerous developer tools. Each public sub-package is independently published to NPM. @@ -18,71 +18,72 @@ If you're developing on 0x now or are interested in using 0x infrastructure in t [data:image/s3,"s3://crabby-images/fcf48/fcf485d8b13851e7f1845b3c5b99fb487789149b" alt="Join the chat at https://gitter.im/0xProject/Lobby"](https://gitter.im/0xProject/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) [data:image/s3,"s3://crabby-images/17683/1768380119c0c89a3a7922cc565ecc789708079d" alt="License"](https://opensource.org/licenses/Apache-2.0) -### Published Packages - -#### TypeScript/JavaScript - -| Package | Version | Description | -| -------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------ | -| [`0x.js`](/packages/0x.js) | [data:image/s3,"s3://crabby-images/b552e/b552e701b568e3a3d37c34cf06e3528c44f8508d" alt="npm"](https://www.npmjs.com/package/0x.js) | A Javascript library for interacting with the 0x protocol | -| [`@0x/abi-gen`](/packages/abi-gen) | [data:image/s3,"s3://crabby-images/e748f/e748f30c74838573b9ec42c562dd6a96867a2436" alt="npm"](https://www.npmjs.com/package/@0x/abi-gen) | Tool to generate TS wrappers from smart contract ABIs | -| [`@0x/abi-gen-wrappers`](/packages/abi-gen-wrappers) | [data:image/s3,"s3://crabby-images/50fb9/50fb939a6f38ccced2b41436cc4a4e35bfcc7050" alt="npm"](https://www.npmjs.com/package/@0x/abi-gen-wrappers) | Low-level 0x smart contract wrappers generated using @0x/abi-gen | -| [`@0x/assert`](/packages/assert) | [data:image/s3,"s3://crabby-images/1dff6/1dff6909ac126bfd43c8aae7d04057871fe4d52f" alt="npm"](https://www.npmjs.com/package/@0x/assert) | Type and schema assertions used by our packages | -| [`@0x/asset-buyer`](/packages/asset-buyer) | [data:image/s3,"s3://crabby-images/f302c/f302c3d5333f0c56fa41fb05eb624126b9d15fef" alt="npm"](https://www.npmjs.com/package/@0x/asset-buyer) | Convenience package for discovering and buying assets with Ether | -| [`@0x/base-contract`](/packages/base-contract) | [data:image/s3,"s3://crabby-images/e52fb/e52fb1567c6353027618980bc9acb5a713556941" alt="npm"](https://www.npmjs.com/package/@0x/base-contract) | BaseContract used by auto-generated `abi-gen` wrapper contracts | -| [`@0x/connect`](/packages/connect) | [data:image/s3,"s3://crabby-images/2aaeb/2aaeb07bc77542ede19f7a12f799d3e9a0ad5297" alt="npm"](https://www.npmjs.com/package/@0x/connect) | A Javascript library for interacting with the Standard Relayer API | -| [`@0x/contract-addresses`](/packages/contract-addresses) | [data:image/s3,"s3://crabby-images/9dbdd/9dbddbe2034fa10f4f69b5ceadbd16c795cf09f9" alt="npm"](https://www.npmjs.com/package/@0x/contract-addresses) | Used to get known addresses of deployed 0x contracts | -| [`@0x/contract-artifacts`](/packages/contract-artifacts) | [data:image/s3,"s3://crabby-images/85655/85655004733289bde8f70c4e48a620016ac56a73" alt="npm"](https://www.npmjs.com/package/@0x/contract-artifacts) | 0x smart contract compilation artifacts | -| [`@0x/contract-wrappers`](/packages/contract-wrappers) | [data:image/s3,"s3://crabby-images/df8ae/df8ae94ad179a57c0f71901bfcd36d95b98aef00" alt="npm"](https://www.npmjs.com/package/@0x/contract-wrappers) | Smart TS wrappers for 0x smart contracts | -| [`@0x/dev-utils`](/packages/dev-utils) | [data:image/s3,"s3://crabby-images/ae943/ae943c3e93e8b7665875e4120c3d5f017fc970d1" alt="npm"](https://www.npmjs.com/package/@0x/dev-utils) | Dev utils to be shared across 0x projects and packages | -| [`@0x/fill-scenarios`](/packages/fill-scenarios) | [data:image/s3,"s3://crabby-images/1e8a2/1e8a220dd560899cea7a605a36d2c2791e5f3b47" alt="npm"](https://www.npmjs.com/package/@0x/fill-scenarios) | 0x order fill scenario generation | -| [`@0x/json-schemas`](/packages/json-schemas) | [data:image/s3,"s3://crabby-images/e26ca/e26cac72953546221f6cdc4d4147bae83c65af0c" alt="npm"](https://www.npmjs.com/package/@0x/json-schemas) | 0x-related json schemas | -| [`@0x/migrations`](/packages/migrations) | [data:image/s3,"s3://crabby-images/0890e/0890e82999eb5a8acc25d0c49ccad0dfa1d09608" alt="npm"](https://www.npmjs.com/package/@0x/migrations) | 0x smart contract migrations | -| [`@0x/order-utils`](/packages/order-utils) | [data:image/s3,"s3://crabby-images/e0d44/e0d442f29643fa7bfb4b75b837297ed17b7e3a9f" alt="npm"](https://www.npmjs.com/package/@0x/order-utils) | A set of utilities for generating, parsing, signing and validating 0x orders | -| [`@0x/order-watcher`](/packages/order-watcher) | [data:image/s3,"s3://crabby-images/85826/85826faaa9368ebc55202bbe618fb47587d72c9d" alt="npm"](https://www.npmjs.com/package/@0x/order-watcher) | An order watcher daemon that watches for order validity | -| [`@0x/react-docs`](/packages/react-docs) | [data:image/s3,"s3://crabby-images/7d54e/7d54e190621a29ed533f2ce5cca2ef10545dd979" alt="npm"](https://www.npmjs.com/package/@0x/react-docs) | React documentation component for rendering TypeDoc & Doxity generated JSON | -| [`@0x/react-shared`](/packages/react-shared) | [data:image/s3,"s3://crabby-images/a836e/a836e10f303578ba30a63385cf1dd0f6f9b4b037" alt="npm"](https://www.npmjs.com/package/@0x/react-shared) | 0x shared react components | -| [`@0x/sol-compiler`](/packages/sol-compiler) | [data:image/s3,"s3://crabby-images/07151/07151dd10eaaacda6ea8dcf31b9b6c0729882679" alt="npm"](https://www.npmjs.com/package/@0x/sol-compiler) | A thin wrapper around Solc.js that outputs artifacts, resolves imports, only re-compiles when needed, and other niceties | -| [`@0x/sol-cov`](/packages/sol-cov) | [data:image/s3,"s3://crabby-images/9c3a5/9c3a562d26540c2d7c05e99b682abd0c1d008161" alt="npm"](https://www.npmjs.com/package/@0x/sol-cov) | Solidity test coverage tool | -| [`@0x/sol-doc`](/packages/sol-doc) | [data:image/s3,"s3://crabby-images/65805/658050cb4902fd209d2e136c8b7724192130036a" alt="npm"](https://www.npmjs.com/package/@0x/sol-doc) | Solidity documentation generator | -| [`@0x/sol-resolver`](/packages/sol-resolver) | [data:image/s3,"s3://crabby-images/a9543/a9543605daf17d995201dd72a36a6b76a0803a2c" alt="npm"](https://www.npmjs.com/package/@0x/sol-resolver) | Import resolver for smart contracts dependencies | -| [`@0x/sra-spec`](/packages/sra-spec) | [data:image/s3,"s3://crabby-images/bb5c2/bb5c26f2d2f2e99ed78a4cfd5a121f9bc09f44c3" alt="npm"](https://www.npmjs.com/package/@0x/sra-spec) | OpenAPI specification for the standard relayer API | -| [`@0x/subproviders`](/packages/subproviders) | [data:image/s3,"s3://crabby-images/5f0fd/5f0fd1fe7f3f6296312c87c000db6a569f0f24f1" alt="npm"](https://www.npmjs.com/package/@0x/subproviders) | Useful web3 subproviders (e.g. LedgerSubprovider) | -| [`@0x/tslint-config`](/packages/tslint-config) | [data:image/s3,"s3://crabby-images/8fd32/8fd328048d4494fdf84435f3d7b3aa184f556efa" alt="npm"](https://www.npmjs.com/package/@0x/tslint-config) | Custom 0x development TSLint rules | -| [`@0x/types`](/packages/types) | [data:image/s3,"s3://crabby-images/0e818/0e81857ac3a68dd5319fada709e306e7efee9cba" alt="npm"](https://www.npmjs.com/package/@0x/types) | Shared type declarations | -| [`@0x/typescript-typings`](/packages/typescript-typings) | [data:image/s3,"s3://crabby-images/958df/958dfa194892c907e8647e259af4f409a8d5e9c6" alt="npm"](https://www.npmjs.com/package/@0x/typescript-typings) | Repository of types for external packages | -| [`@0x/utils`](/packages/utils) | [data:image/s3,"s3://crabby-images/23410/2341045baa4c64b56918d50ac880c61039ef1119" alt="npm"](https://www.npmjs.com/package/@0x/utils) | Shared utilities | -| [`@0x/web3-wrapper`](/packages/web3-wrapper) | [data:image/s3,"s3://crabby-images/07848/0784824f86da99c168f767cf5a2ec9048dffa8e2" alt="npm"](https://www.npmjs.com/package/@0x/web3-wrapper) | Web3 wrapper | - -#### Python +## Packages + +Visit our [developer portal](https://0xproject.com/docs/order-utils) for a comprehensive list of core & community maintained packages. All packages maintained with this monorepo are listed below. + +### Python Packages | Package | Version | Description | | --------------------------------------------------- | ----------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------- | | [`0x-order-utils.py`](/python-packages/order_utils) | [data:image/s3,"s3://crabby-images/a269b/a269b917cda3025d79034c051418fa9556e7c499" alt="PyPI"](https://pypi.org/project/0x-order-utils/) | A set of utilities for generating, parsing, signing and validating 0x orders | -### Private Packages - -| Package | Description | -| -------------------------------------------------------- | ---------------------------------------------------------------- | -| [`@0x/contracts`](/packages/contracts) | 0x solidity smart contracts & tests | -| [`@0x/react-docs-example`](/packages/react-docs-example) | Example documentation site created with `@0x/react-docs` | -| [`@0x/testnet-faucets`](/packages/testnet-faucets) | A faucet micro-service that dispenses test ERC20 tokens or Ether | -| [`@0x/website`](/packages/website) | 0x website & Portal DApp | +### Typescript/Javascript Packages + +#### 0x-specific packages + +| Package | Version | Description | +| -------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------- | +| [`0x.js`](/packages/0x.js) | [data:image/s3,"s3://crabby-images/b552e/b552e701b568e3a3d37c34cf06e3528c44f8508d" alt="npm"](https://www.npmjs.com/package/0x.js) | An aggregate package combining many smaller utility packages for interacting with the 0x protocol | +| [`@0x/contract-addresses`](/packages/contract-addresses) | [data:image/s3,"s3://crabby-images/9dbdd/9dbddbe2034fa10f4f69b5ceadbd16c795cf09f9" alt="npm"](https://www.npmjs.com/package/@0x/contract-addresses) | A tiny utility library for getting known deployed contract addresses for a particular network. | +| [`@0x/contract-wrappers`](/packages/contract-wrappers) | [data:image/s3,"s3://crabby-images/df8ae/df8ae94ad179a57c0f71901bfcd36d95b98aef00" alt="npm"](https://www.npmjs.com/package/@0x/contract-wrappers) | JS/TS wrappers for interacting with the 0x smart contracts | +| [`@0x/order-utils`](/packages/order-utils) | [data:image/s3,"s3://crabby-images/e0d44/e0d442f29643fa7bfb4b75b837297ed17b7e3a9f" alt="npm"](https://www.npmjs.com/package/@0x/order-utils) | A set of utilities for generating, parsing, signing and validating 0x orders | +| [`@0x/json-schemas`](/packages/json-schemas) | [data:image/s3,"s3://crabby-images/e26ca/e26cac72953546221f6cdc4d4147bae83c65af0c" alt="npm"](https://www.npmjs.com/package/@0x/json-schemas) | 0x-related JSON schemas | +| [`@0x/order-watcher`](/packages/order-watcher) | [data:image/s3,"s3://crabby-images/85826/85826faaa9368ebc55202bbe618fb47587d72c9d" alt="npm"](https://www.npmjs.com/package/@0x/order-watcher) | An order watcher daemon that watches for order validity | +| [`@0x/migrations`](/packages/migrations) | [data:image/s3,"s3://crabby-images/0890e/0890e82999eb5a8acc25d0c49ccad0dfa1d09608" alt="npm"](https://www.npmjs.com/package/@0x/migrations) | Migration tool for deploying 0x smart contracts on private testnets | +| [`@0x/contract-artifacts`](/packages/contract-artifacts) | [data:image/s3,"s3://crabby-images/85655/85655004733289bde8f70c4e48a620016ac56a73" alt="npm"](https://www.npmjs.com/package/@0x/contract-artifacts) | 0x smart contract compilation artifacts | +| [`@0x/abi-gen-wrappers`](/packages/abi-gen-wrappers) | [data:image/s3,"s3://crabby-images/50fb9/50fb939a6f38ccced2b41436cc4a4e35bfcc7050" alt="npm"](https://www.npmjs.com/package/@0x/abi-gen-wrappers) | Low-level 0x smart contract wrappers generated using `@0x/abi-gen` | +| [`@0x/sra-spec`](/packages/sra-spec) | [data:image/s3,"s3://crabby-images/bb5c2/bb5c26f2d2f2e99ed78a4cfd5a121f9bc09f44c3" alt="npm"](https://www.npmjs.com/package/@0x/sra-spec) | OpenAPI specification for the Standard Relayer API | +| [`@0x/connect`](/packages/connect) | [data:image/s3,"s3://crabby-images/2aaeb/2aaeb07bc77542ede19f7a12f799d3e9a0ad5297" alt="npm"](https://www.npmjs.com/package/@0x/connect) | An HTTP/WS client for interacting with the Standard Relayer API | +| [`@0x/asset-buyer`](/packages/asset-buyer) | [data:image/s3,"s3://crabby-images/f302c/f302c3d5333f0c56fa41fb05eb624126b9d15fef" alt="npm"](https://www.npmjs.com/package/@0x/asset-buyer) | Convenience package for discovering and buying assets with Ether | + +#### Ethereum tooling + +| Package | Version | Description | +| -------------------------------------------- | ----------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`@0x/web3-wrapper`](/packages/web3-wrapper) | [data:image/s3,"s3://crabby-images/07848/0784824f86da99c168f767cf5a2ec9048dffa8e2" alt="npm"](https://www.npmjs.com/package/@0x/web3-wrapper) | An Ethereum JSON RPC client | +| [`@0x/sol-compiler`](/packages/sol-compiler) | [data:image/s3,"s3://crabby-images/07151/07151dd10eaaacda6ea8dcf31b9b6c0729882679" alt="npm"](https://www.npmjs.com/package/@0x/sol-compiler) | A wrapper around solc-js that adds smart re-compilation, ability to compile an entire project, Solidity version specific compilation, standard input description support and much more. | +| [`@0x/sol-cov`](/packages/sol-cov) | [data:image/s3,"s3://crabby-images/9c3a5/9c3a562d26540c2d7c05e99b682abd0c1d008161" alt="npm"](https://www.npmjs.com/package/@0x/sol-cov) | A solidity test coverage tool | +| [`@0x/sol-resolver`](/packages/sol-resolver) | [data:image/s3,"s3://crabby-images/a9543/a9543605daf17d995201dd72a36a6b76a0803a2c" alt="npm"](https://www.npmjs.com/package/@0x/sol-resolver) | Import resolver for smart contracts dependencies | +| [`@0x/subproviders`](/packages/subproviders) | [data:image/s3,"s3://crabby-images/5f0fd/5f0fd1fe7f3f6296312c87c000db6a569f0f24f1" alt="npm"](https://www.npmjs.com/package/@0x/subproviders) | Web3 provider middlewares (e.g. LedgerSubprovider) | +| [`@0x/sol-doc`](/packages/sol-doc) | [data:image/s3,"s3://crabby-images/65805/658050cb4902fd209d2e136c8b7724192130036a" alt="npm"](https://www.npmjs.com/package/@0x/sol-doc) | Solidity documentation generator | + +#### Utilities + +| Package | Version | Description | +| -------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------- | +| [`@0x/abi-gen`](/packages/abi-gen) | [data:image/s3,"s3://crabby-images/e748f/e748f30c74838573b9ec42c562dd6a96867a2436" alt="npm"](https://www.npmjs.com/package/@0x/abi-gen) | Tool to generate TS wrappers from smart contract ABIs | +| [`@0x/tslint-config`](/packages/tslint-config) | [data:image/s3,"s3://crabby-images/8fd32/8fd328048d4494fdf84435f3d7b3aa184f556efa" alt="npm"](https://www.npmjs.com/package/@0x/tslint-config) | Custom TSLint rules used by the 0x core team | +| [`@0x/types`](/packages/types) | [data:image/s3,"s3://crabby-images/0e818/0e81857ac3a68dd5319fada709e306e7efee9cba" alt="npm"](https://www.npmjs.com/package/@0x/types) | Shared type declarations | +| [`@0x/typescript-typings`](/packages/typescript-typings) | [data:image/s3,"s3://crabby-images/958df/958dfa194892c907e8647e259af4f409a8d5e9c6" alt="npm"](https://www.npmjs.com/package/@0x/typescript-typings) | Repository of types for external packages | +| [`@0x/utils`](/packages/utils) | [data:image/s3,"s3://crabby-images/23410/2341045baa4c64b56918d50ac880c61039ef1119" alt="npm"](https://www.npmjs.com/package/@0x/utils) | Shared utilities | +| [`@0x/react-docs`](/packages/react-docs) | [data:image/s3,"s3://crabby-images/7d54e/7d54e190621a29ed533f2ce5cca2ef10545dd979" alt="npm"](https://www.npmjs.com/package/@0x/react-docs) | React documentation component for rendering TypeDoc & sol-doc generated JSON | +| [`@0x/react-shared`](/packages/react-shared) | [data:image/s3,"s3://crabby-images/a836e/a836e10f303578ba30a63385cf1dd0f6f9b4b037" alt="npm"](https://www.npmjs.com/package/@0x/react-shared) | 0x shared react components | +| [`@0x/assert`](/packages/assert) | [data:image/s3,"s3://crabby-images/1dff6/1dff6909ac126bfd43c8aae7d04057871fe4d52f" alt="npm"](https://www.npmjs.com/package/@0x/assert) | Type and schema assertions used by our packages | +| [`@0x/base-contract`](/packages/base-contract) | [data:image/s3,"s3://crabby-images/e52fb/e52fb1567c6353027618980bc9acb5a713556941" alt="npm"](https://www.npmjs.com/package/@0x/base-contract) | BaseContract used by auto-generated `abi-gen` wrapper contracts | +| [`@0x/dev-utils`](/packages/dev-utils) | [data:image/s3,"s3://crabby-images/ae943/ae943c3e93e8b7665875e4120c3d5f017fc970d1" alt="npm"](https://www.npmjs.com/package/@0x/dev-utils) | Dev utils to be shared across 0x packages | +| [`@0x/fill-scenarios`](/packages/fill-scenarios) | [data:image/s3,"s3://crabby-images/1e8a2/1e8a220dd560899cea7a605a36d2c2791e5f3b47" alt="npm"](https://www.npmjs.com/package/@0x/fill-scenarios) | 0x order fill scenario generator | + +#### Private Packages + +| Package | Description | +| -------------------------------------------------- | ---------------------------------------------------------------- | +| [`@0x/contracts`](/packages/contracts) | 0x protocol solidity smart contracts & tests | +| [`@0x/testnet-faucets`](/packages/testnet-faucets) | A faucet micro-service that dispenses test ERC20 tokens or Ether | +| [`@0x/website`](/packages/website) | 0x website | ## Usage -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) -* [Sol Compiler](https://0xproject.com/docs/sol-compiler) -* [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) - Node version >= 6.12 is required. Most of the packages require additional typings for external dependencies. |