Metadata-Version: 2.1
Name: python-idex
Version: 3.0.0
Summary: IDEX v3 REST API python implementation
Home-page: https://github.com/sammchardy/python-idex
Author: Sam McHardy
Author-email: 
License: MIT
Keywords: idex exchange rest api ethereum eth eos
Platform: UNKNOWN
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python
Classifier: Topic :: Software Development :: Libraries :: Python Modules
License-File: LICENSE
Requires-Dist: aiohttp
Requires-Dist: requests
Requires-Dist: web3

=============================
Welcome to python-idex v3.0.0
=============================

.. image:: https://img.shields.io/pypi/v/python-idex.svg
    :target: https://pypi.python.org/pypi/python-idex

.. image:: https://img.shields.io/pypi/l/python-idex.svg
    :target: https://pypi.python.org/pypi/python-idex

.. image:: https://img.shields.io/travis/sammchardy/python-idex.svg
    :target: https://app.travis-ci.com/github/sammchardy/python-idex

.. image:: https://img.shields.io/coveralls/sammchardy/python-idex.svg
    :target: https://coveralls.io/github/sammchardy/python-idex

.. image:: https://img.shields.io/pypi/wheel/python-idex.svg
    :target: https://pypi.python.org/pypi/python-idex

.. image:: https://img.shields.io/pypi/pyversions/python-idex.svg
    :target: https://pypi.python.org/pypi/python-idex

This is an unofficial Python wrapper for the `IDEX exchanges REST API v3 <https://api-docs-v3.idex.io/>`_. I am in no way affiliated with IDEX, use at your own risk.

PyPi
  https://pypi.python.org/pypi/python-idex

Source code
  https://github.com/sammchardy/python-idex

Documentation
  https://python-idex.readthedocs.io/en/latest/


Features
--------

- Implementation of all REST endpoints
- Liquidity endpoints
- Deposit from main wallet to exchange wallet
- Sandbox and faucet support
- Async client support
- Response exception handling

Notes
-----

Using an API key increases `rate limits <https://api-docs-v3.idex.io/#rate-limits>`_.

Quick Start
-----------

Register an account with `IDEX v3 <https://exchange.idex.io/r/O5O9RA3B>`_.

.. code:: bash

    pip install python-idex

Synchronous Examples
--------------------

.. code:: python

    # Unauthenticated

    from idex import Client
    client = Client()

    # server time
    time = client.get_server_time()

    # get exchange_info
    exchange_info = client.get_exchange()

    # get assets
    assets = client.get_assets()

    # get markets
    markets = client.get_markets()

    # get market depth
    depth = client.get_order_book(market='ETH-USDC')

    # get liquidity pools
    pools = client.get_liquidity_pools()

    # Authenticated

    api_key = '<api_key>'
    address = '<address_string>'
    private_key = '<wallet_private_key_string>'
    wallet_address = '0x<wallet_address>'
    client = Client(api_key, address, private_key)

    # associate wallet to account
    client.associate_wallet(wallet_address=wallet_address)

    # deposit funds
    client.deposit_funds(asset='MATIC', quantity=1.234)

    # get your balances
    balances = client.get_balances()

    # get your open orders
    orders = client.get_open_orders()

    # create a market order
    order = client.create_market_order(
        market='ETH-USDC',
        order_side=OrderSide.BUY,
        quantity=1000
    )

    # create a limit order
    order = client.create_limit_order(
        market='ETH-USDC',
        order_side=OrderSide.BUY,
        quantity=1000,
        price=2100,
    )


Async Example
-------------

.. code:: python

    from idex import AsyncClient


    async def main():

        # Initialise the client
        client = await AsyncClient.create()

        # get currencies
        currencies = await client.get_currencies()

        # get market depth
        depth = await client.get_order_book('ETH_SENT')

        # get your balances
        balances = await client.get_my_balances()

        # get your open orders
        orders = await client.get_my_open_orders('ETH_SENT')

        # create a limit order
        order = await client.create_order('SENT', 'ETH', '0.001', '10000')

        # Authenticated

        api_key = '<api_key>'
        address = '<address_string>'
        private_key = '<wallet_private_key_string>'
        wallet_address = '0x<wallet_address>'
        client = await AsyncClient.create(api_key, address, private_key)

        # associate wallet to account
        await client.associate_wallet(wallet_address=wallet_address)

        # deposit funds
        await client.deposit_funds(asset='MATIC', quantity=1.234)

        # get your balances
        balances = await client.get_balances()

        # get your open orders
        orders = await client.get_open_orders()

        # create a market order
        order = await client.create_market_order(
            market='ETH-USDC',
            order_side=OrderSide.BUY,
            quantity=1000
        )

        # create a limit order
        order = await client.create_limit_order(
            market='ETH-USDC',
            order_side=OrderSide.BUY,
            quantity=1000,
            price=2100,
        )

    if __name__ == "__main__":
        loop = asyncio.get_event_loop()
        loop.run_until_complete(main())

Wallet
------

The examples above use the wallet private key when creating the Client to specify
which wallet to interact with.

Most functions will have a `wallet_address` parameter to target a different wallet.

If a new wallet is needed for subsequent calls `init_wallet` can be used to change the
internal wallet

... code:python

    private_key = '<old_private_key>'
    client = Client(api_key, address, private_key)
    client.init_wallet(private_key='<new_wallet_private_key>')

    # this will fetch balance of the new wallet
    client.get_balance()

Contract function
-----------------

Functions such as `deposit_funds`, `contract_exit_wallet` and `contract_withdraw_exit` interact
with the Polygon blockchain.

Gas fee and price are attempted to be generated, but may fail. These values can be
overridden by passing a `TransactionOptions` object to the calls.

... code:python

    client = Client(api_key, address, private_key)

    tx_options = TransactionOptions(gas=150000, gas_price=20000000000)

    client.deposit_funds(asset="USD", quantity=1123, tx_options=tx_options)

Sandbox/Testnet
---------------

IDEX v3 supports the Mumbai testnet as a sandbox to test functionality.

Enable it by passing `sandbox=True` when creating the client

... code:python

    client = Client(sandbox=True)

    # or async

    client = await AsyncClient.create(sandbox=True)

Read more about the Sandbox mode in the `IDEX Sandbox docs <https://api-docs-v3.idex.io/#sandbox>`_.

`Search reddit <https://www.reddit.com/r/0xPolygon/search/?q=faucet>`_ for a functioning faucet to receive MATIC.

For other tokens on the sandbox DIL, PIP, IDEX, USD they can be added using a contract function

... code:python

    client = Client(sandbox=True)

    tx_id = client.contract_testnet_faucet(asset='DIL')
    client.wait_for_transaction_receipt(tx_id)

    tx_id = client.contract_testnet_faucet(asset='PIP')
    client.wait_for_transaction_receipt(tx_id)

    tx_id = client.contract_testnet_faucet(asset='IDEX')
    client.wait_for_transaction_receipt(tx_id)

    tx_id = client.contract_testnet_faucet(asset='USD')
    client.wait_for_transaction_receipt(tx_id)


Test Orders
-----------

All order functions allow for test orders to be sent, just set `test=True` when calling a test function

Stake your IDEX
---------------

Earn staking rewards on your idle IDEX tokens from IDEX trade fees while also contributing to the decentralization of
IDEX and robustness of the platform.

Delegate them to `everday-chicken` node in the `IDEX v3 delegate portal <https://exchange.idex.io/rewards/staking/delegate>`_
with one click.

Donate
------

If this library helped you out feel free to donate.

- ETH: 0xD7a7fDdCfA687073d7cC93E9E51829a727f9fE70
- IDEX: 0xD7a7fDdCfA687073d7cC93E9E51829a727f9fE70 (Polygon)
- NEO: AVJB4ZgN7VgSUtArCt94y7ZYT6d5NDfpBo
- LTC: LPC5vw9ajR1YndE1hYVeo3kJ9LdHjcRCUZ
- BTC: 1Dknp6L6oRZrHDECRedihPzx2sSfmvEBys

Other Exchanges
---------------

If you use `Binance <https://www.binance.com/?ref=10099792>`_ check out my `python-binance <https://github.com/sammchardy/python-binance>`_ library.

If you use `Binance Chain <https://testnet.binance.org/>`_ check out my `python-binance-chain <https://github.com/sammchardy/python-binance-chain>`_ library.

If you use `Kucoin <https://www.kucoin.com/?rcode=E42cWB>`_ check out my `python-kucoin <https://github.com/sammchardy/python-kucoin>`_ library.

.. image:: https://analytics-pixel.appspot.com/UA-111417213-1/github/python-idex?pixel


