Merge pull request #239 from Davi0kProgramsThings/v3.0.0

Merge branch ` Davi0kProgramsThings:v3.0.0` into branch `bitfinexcom:master`.
This commit is contained in:
Dario Moceri
2024-04-07 19:41:18 +02:00
committed by GitHub
5 changed files with 22 additions and 34 deletions

View File

@@ -1,12 +1,7 @@
# bitfinex-api-py (v3-beta)
# bitfinex-api-py
Official implementation of the [Bitfinex APIs (V2)](https://docs.bitfinex.com/docs) for `Python 3.8+`.
> **DISCLAIMER:** \
Production use of v3.0.0b1 (and all future beta versions) is HIGHLY discouraged. \
Beta versions should not be used in applications which require user authentication. \
Provide your API-KEY/API-SECRET, and manage your account and funds at your own risk.
### Features
* Support for 75+ REST endpoints (a list of available endpoints can be found [here](https://docs.bitfinex.com/reference))
@@ -20,13 +15,6 @@ Provide your API-KEY/API-SECRET, and manage your account and funds at your own r
python3 -m pip install --pre bitfinex-api-py
```
### Selecting and installing a specific beta version
It's also possible to select and install a specific beta version:
```console
python3 -m pip install bitfinex-api-py==3.0.0b1
```
---
# Quickstart
@@ -305,7 +293,7 @@ All contributions are welcome! :D
A guide on how to install and set up `bitfinex-api-py`'s source code can be found [here](#installation-and-setup). \
Before opening any pull requests, please have a look at [Before Opening a PR](#before-opening-a-pr). \
Contributors must uphold the [Contributor Covenant code of conduct](https://github.com/bitfinexcom/bitfinex-api-py/blob/v3-beta/CODE_OF_CONDUCT.md).
Contributors must uphold the [Contributor Covenant code of conduct](https://github.com/bitfinexcom/bitfinex-api-py/blob/master/CODE_OF_CONDUCT.md).
### Index
@@ -323,10 +311,8 @@ A brief guide on how to install and set up the project in your Python 3.8+ envir
### Cloning the repository
The following command will only clone the `v3-beta` branch (excluding all others):
```console
git clone --branch v3-beta --single-branch https://github.com/bitfinexcom/bitfinex-api-py.git
git clone https://github.com/bitfinexcom/bitfinex-api-py.git
```
### Installing the dependencies

View File

@@ -1 +1 @@
__version__ = "3.0.0b5"
__version__ = "3.0.0"

View File

@@ -3,14 +3,14 @@ import hmac
import json
from datetime import datetime
from enum import IntEnum
from typing import TYPE_CHECKING, Any, List, Optional
from typing import TYPE_CHECKING, Any, List, NoReturn, Optional
import requests
from bfxapi._utils.json_decoder import JSONDecoder
from bfxapi._utils.json_encoder import JSONEncoder
from bfxapi.exceptions import InvalidCredentialError
from bfxapi.rest.exceptions import RequestParametersError, UnknownGenericError
from bfxapi.rest.exceptions import GenericError, RequestParameterError
if TYPE_CHECKING:
from requests.sessions import _Params
@@ -86,28 +86,30 @@ class Middleware:
return data
def __handle_error(self, error: List[Any]) -> None:
def __handle_error(self, error: List[Any]) -> NoReturn:
if error[1] == _Error.ERR_PARAMS:
raise RequestParametersError(
raise RequestParameterError(
"The request was rejected with the following parameter "
f"error: <{error[2]}>"
f"error: <{error[2]}>."
)
if error[1] == _Error.ERR_AUTH_FAIL:
raise InvalidCredentialError(
"Cannot authenticate with given API-KEY and API-SECRET."
"Can't authenticate with given API-KEY and API-SECRET."
)
if not error[1] or error[1] == _Error.ERR_UNK or error[1] == _Error.ERR_GENERIC:
raise UnknownGenericError(
"The server replied to the request with a generic error with "
f"the following message: <{error[2]}>."
raise GenericError(
"The request was rejected with the following generic "
f"error: <{error[2]}>."
)
raise RuntimeError(
f"The request was rejected with an unexpected error: <{error}>."
)
def __get_authentication_headers(self, endpoint: str, data: Optional[str] = None):
assert (
self.__api_key and self.__api_secret
), "API-KEY and API-SECRET must be strings."
assert self.__api_key and self.__api_secret
nonce = str(round(datetime.now().timestamp() * 1_000_000))

View File

@@ -1,9 +1,9 @@
from bfxapi.exceptions import BfxBaseException
class RequestParametersError(BfxBaseException):
class RequestParameterError(BfxBaseException):
pass
class UnknownGenericError(BfxBaseException):
class GenericError(BfxBaseException):
pass

View File

@@ -16,7 +16,7 @@ setup(
author_email="support@bitfinex.com",
license="Apache-2.0",
classifiers=[
"Development Status :: 4 - Beta",
"Development Status :: 5 - Production/Stable",
"Intended Audience :: Developers",
"Topic :: Software Development :: Build Tools",
"License :: OSI Approved :: Apache Software License",