Skip to main content

Official Bybit P2P API integration library written in Python.

Project description

bybit_p2p

Bybit P2P API integration library written in Python

pip package

bybit_p2p is the official Python SDK for Bybit's P2P API, enabling seamless integration of your software solutions with Bybit's P2P trading platform.

  • No need to implement signature (HMAC, RSA) logic yourself
  • Easy & quick to work with
  • Actively developed and maintained

originally developed by kolya5544

Features

bybit_p2p currently implements all methods available for P2P API. The library is in active development, so any newly released features will be added almost immediately. Here is a short list of what the library can do:

  • Create, edit, delete, activate advertisements
  • Get pending orders, mark orders as paid, release assets to the buyer
  • Get and send text messages, upload files and send files to the chat
  • Get all public advertisements for tokens
  • ...and so much else! 🌟

All features are usually one method call away and do not require advanced API understanding to interact with.

Tech

bybit_p2p uses a number of projects and technologies to work:

  • requests & requests_toolbelt for HTTP request creation and processing, as well as multiform data requests
  • PyCrypto for HMAC and RSA operations

Installation

bybit_p2p was tested on Python 3.11, but should work on all higher versions as well. The module can be installed manually or via PyPI with pip:

pip install bybit-p2p

Usage

Upon installation, you can use bybit_p2p by importing it in your code:

from bybit_p2p import P2P

Here is a quickstart example to get some info from the exchange:

from bybit_p2p import P2P

api = P2P(
    testnet=True,
    api_key="x",
    api_secret="x"
)

# 1. Get current balance
print(api.get_current_balance(accountType="UNIFIED"))

# 2. Get account information
print(api.get_account_information())

# 3. Get ads list
print(api.get_ads_list())

P2P() class is used for P2P API interactions. Here, testnet refers to environment. For Mainnet (https://bybit.com/), you shall use testnet=False. For Testnet (https://testnet.bybit.com/), use testnet=True instead.

RSA users should also set rsa=True in the constructor. TR/KZ/NL/etc. users can manipulate domain and tld parameters, like tld="kz".

You can find the complete Quickstart example here: bybit_p2p quickstart.

Documentation

bybit_p2p library currently consists of just one module, which is used for direct REST API requests to Bybit P2P API.

You can access P2P API documentation using this link: Not Available at this moment in time

Here is a breakdown of how API methods correspond to appropriate bybit_p2p methods:

Advertisements:

bybit_p2p method name P2P API method name P2P API endpoint path
get_online_ads() Get Market Online Ads list /v5/p2p/item/online
post_new_ad() Post New Ad /v5/p2p/item/create
remove_ad() Remove ad /v5/p2p/item/cancel
update_ad() Update / Relist My Ad /v5/p2p/item/update
get_ads_list() Get ads list /v5/p2p/item/personal/list
get_ad_details() Get ad detail /v5/p2p/item/info

Orders:

bybit_p2p method name P2P API method name P2P API endpoint path
get_orders() Get All Orders /v5/p2p/order/simplifyList
get_order_details() Get Order Details /v5/p2p/order/info
get_pending_orders() Get Pending Orders /v5/p2p/order/pending/simplifyList
mark_as_paid() Mark Order As Paid /v5/p2p/order/pay
release_assets() Release Digital Asset /v5/p2p/order/finish
send_chat_message() Send chat message /v5/p2p/order/message/send
upload_chat_file() Upload chat file /v5/p2p/oss/upload_file
get_chat_messages() Get Chat Message /v5/p2p/order/message/listpage

User:

bybit_p2p method name P2P API method name P2P API endpoint path
get_account_information() Get Account Information /v5/p2p/user/personal/info
get_counterparty_info() Get Counterparty User Info /v5/p2p/user/order/personal/info
get_user_payment_types() Get User Payment /v5/p2p/user/payment/list

Misc:

bybit_p2p method name P2P API method name P2P API endpoint path
get_current_balance() Get Coin Balance /v5/asset/transfer/query-account-coins-balance

More methods will come soon, allowing for more advanced operations.

Development

All contributions are welcome.

License

MIT

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

bybit_p2p-1.1.0.tar.gz (11.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bybit_p2p-1.1.0-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file bybit_p2p-1.1.0.tar.gz.

File metadata

  • Download URL: bybit_p2p-1.1.0.tar.gz
  • Upload date:
  • Size: 11.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for bybit_p2p-1.1.0.tar.gz
Algorithm Hash digest
SHA256 3396f77be419369061aed07e46f786a7823e1280a696121838f690c2c158c6b4
MD5 51ebb067b2c10382af5a9bf56449a01c
BLAKE2b-256 eafa8c5551798733da8028314373d5333153d057d7df5127f04c5d6b83249ca0

See more details on using hashes here.

File details

Details for the file bybit_p2p-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: bybit_p2p-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 11.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for bybit_p2p-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4eab8a792383c84f7989e380271ed7a70a2dabcacb6ad9014359075385a54c8b
MD5 cda12cad36771a6cf1a627a1dc0ab882
BLAKE2b-256 a55c537ac241291fb54317bb53d86e99fd1923354c89a11862fe05a1e63d0de5

See more details on using hashes here.

Supported by

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