Skip to main content

SDK of CoinGate API for Python 3+

Project description

# CoinGate API SDK (API v2)

The repo contains Python 3 SDK for [CoinGate API v2](https://developer.coingate.com/docs/api-overview).
This is open source library is provided by [SociumNET](https://socium.net) team and it is used in some internal
projects.

## Installation

You can install the library using PIP:

`$ pip install coingate_api`

## Quick start

Try it:
```python
from coingate_api import CoingateAPI


api = CoingateAPI(auth_token='your-auth-token', environment='sandbox')
print(api.ping())
```

Only replace "your-auth-token" to your token from CoinGate of CoinGate sandbox

## How to

Default behavior of API uses retries for requests:

* 3 retries
* with back-off factor 0.2
* http statuses of response for retries: 500, 502, 504

You can change all these params by initialization of API client:
```python
from coingate_api import CoingateAPI
api = CoingateAPI(auth_token='your-auth-token', environment='sandbox',
retries=5, backoff_factor=0.5, status_forcelist=(500, 502, 504, 505))

```

#### Methods of API:

* `api.test_connection()` - tests authentication. Should return simple "OK"
* `api.ping()` - tests connection to server. Should return "pong"
* `api.exchange_rate(from_='EUR', to='USD')` - check documentation of API
* `api.exchange_rates()` - check documentation of API
* `api.ip_addresses()` - check documentation of API
* `api.orders(per_page=100, page=1, sort='created_at_desc', **kwargs)` - check documentation of API.
Values of kwargs can contain also `created_at_from` and `created_at_to`
* `api.checkout(order_id, pay_currency='BTC')` - check documentation of API
* `api.create_order(price_amount, price_currency, receive_currency, **kwargs)` - check documentation of API.
Values of kwargs can contain also `order_id`, `title`, `description`, `callback_url`, `cancel_url`, `success_url`, `token`


#### Exceptions

```python
from coingate_api import CoingateAPI, api_error

api = CoingateAPI(auth_token='your-auth-token', environment='sandbox')

try:
print(api.test_connection())
except api_error.APIError as e:
print(e)

```

Exceptions hierarchy:

* `APIError`
* `Unauthorized`
* `BadCredentials`
* `BadAuthToken`
* `AccountBlocked`
* `IPAddressIsNotAllowed`
* `NotFound`
* `PageNotFound`
* `RecordNotFound`
* `OrderNotFound`
* `UnprocessableEntity`
* `OrderIsNotValid`
* `RateLimitError`
* `InternalServerError` - notice that client will do retries for this error by default


## Contribution

You can be free to contribute in the project. You should only create PR with a short description what it is for and
what the problem can be solved by your PR.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

coingate_api-0.1.2.tar.gz (4.2 kB view details)

Uploaded Source

File details

Details for the file coingate_api-0.1.2.tar.gz.

File metadata

  • Download URL: coingate_api-0.1.2.tar.gz
  • Upload date:
  • Size: 4.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/39.1.0 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.7.0

File hashes

Hashes for coingate_api-0.1.2.tar.gz
Algorithm Hash digest
SHA256 9faef236378bad7d34ede1e3ad5f957b045ca0f9e0f6b352b6e99b75d89abe89
MD5 f2b49c10e2e157188dc55389b0b6e9e1
BLAKE2b-256 5fff676df4cd2770891f0b31b0a244836b5c5295740d40f06e35347529ceef99

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page