Skip to content

Commit 1ce41c2

Browse files
committed
pushback
1 parent c72738d commit 1ce41c2

File tree

288 files changed

+64750
-2
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

288 files changed

+64750
-2
lines changed

README.md

Lines changed: 294 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,294 @@
1+
# woofipro-python
2+
Python SDK (sync and async) for Woofipro cryptocurrency exchange with Rest and WS capabilities.
3+
4+
- You can check the SDK docs here: [SDK](https://docs.ccxt.com/#/exchanges/woofipro)
5+
- You can check Woofipro's docs here: [Docs](https://www.google.com/search?q=google+woofipro+cryptocurrency+exchange+api+docs)
6+
- Github repo: https://github.com/ccxt/woofipro-python
7+
- Pypi package: https://pypi.org/project/woofipro-api
8+
9+
10+
## Installation
11+
12+
```
13+
pip install woofipro-api
14+
```
15+
16+
## Usage
17+
18+
### Sync
19+
20+
```Python
21+
from woofipro import WoofiproSync
22+
23+
def main():
24+
instance = WoofiproSync({})
25+
ob = instance.fetch_order_book("BTC/USDC")
26+
print(ob)
27+
#
28+
# balance = instance.fetch_balance()
29+
# order = instance.create_order("BTC/USDC", "limit", "buy", 1, 100000)
30+
31+
main()
32+
```
33+
34+
### Async
35+
36+
```Python
37+
import sys
38+
import asyncio
39+
from woofipro import WoofiproAsync
40+
41+
### on Windows, uncomment below:
42+
# if sys.platform == 'win32':
43+
# asyncio.set_event_loop_policy(asyncio.WindowsSelectorEventLoopPolicy())
44+
45+
async def main():
46+
instance = WoofiproAsync({})
47+
ob = await instance.fetch_order_book("BTC/USDC")
48+
print(ob)
49+
#
50+
# balance = await instance.fetch_balance()
51+
# order = await instance.create_order("BTC/USDC", "limit", "buy", 1, 100000)
52+
53+
# once you are done with the exchange
54+
await instance.close()
55+
56+
asyncio.run(main())
57+
```
58+
59+
60+
61+
### Websockets
62+
63+
```Python
64+
import sys
65+
from woofipro import WoofiproWs
66+
67+
### on Windows, uncomment below:
68+
# if sys.platform == 'win32':
69+
# asyncio.set_event_loop_policy(asyncio.WindowsSelectorEventLoopPolicy())
70+
71+
async def main():
72+
instance = WoofiproWs({})
73+
while True:
74+
ob = await instance.watch_order_book("BTC/USDC")
75+
print(ob)
76+
# orders = await instance.watch_orders("BTC/USDC")
77+
78+
# once you are done with the exchange
79+
await instance.close()
80+
81+
asyncio.run(main())
82+
```
83+
84+
85+
86+
87+
88+
#### Raw call
89+
90+
You can also construct custom requests to available "implicit" endpoints
91+
92+
```Python
93+
request = {
94+
'type': 'candleSnapshot',
95+
'req': {
96+
'coin': coin,
97+
'interval': tf,
98+
'startTime': since,
99+
'endTime': until,
100+
},
101+
}
102+
response = await instance.public_post_info(request)
103+
```
104+
105+
106+
## Available methods
107+
108+
### REST Unified
109+
110+
- `create_order_request(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={})`
111+
- `create_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={})`
112+
- `create_orders(self, orders: List[OrderRequest], params={})`
113+
- `fetch_balance(self, params={})`
114+
- `fetch_closed_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
115+
- `fetch_currencies(self, params={})`
116+
- `fetch_deposits_withdrawals(self, code: Str = None, since: Int = None, limit: Int = None, params={})`
117+
- `fetch_deposits(self, code: Str = None, since: Int = None, limit: Int = None, params={})`
118+
- `fetch_funding_history(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
119+
- `fetch_funding_interval(self, symbol: str, params={})`
120+
- `fetch_funding_rate_history(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
121+
- `fetch_funding_rate(self, symbol: str, params={})`
122+
- `fetch_funding_rates(self, symbols: Strings = None, params={})`
123+
- `fetch_ledger(self, code: Str = None, since: Int = None, limit: Int = None, params={})`
124+
- `fetch_leverage(self, symbol: str, params={})`
125+
- `fetch_markets(self, params={})`
126+
- `fetch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
127+
- `fetch_ohlcv(self, symbol: str, timeframe='1m', since: Int = None, limit: Int = None, params={})`
128+
- `fetch_open_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
129+
- `fetch_order_book(self, symbol: str, limit: Int = None, params={})`
130+
- `fetch_order_trades(self, id: str, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
131+
- `fetch_order(self, id: str, symbol: Str = None, params={})`
132+
- `fetch_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
133+
- `fetch_position(self, symbol: Str, params={})`
134+
- `fetch_positions(self, symbols: Strings = None, params={})`
135+
- `fetch_status(self, params={})`
136+
- `fetch_time(self, params={})`
137+
- `fetch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={})`
138+
- `fetch_trading_fees(self, params={})`
139+
- `fetch_withdrawals(self, code: Str = None, since: Int = None, limit: Int = None, params={})`
140+
- `cancel_all_orders(self, symbol: Str = None, params={})`
141+
- `cancel_order(self, id: str, symbol: Str = None, params={})`
142+
- `cancel_orders(self, ids: List[str], symbol: Str = None, params={})`
143+
- `describe(self)`
144+
- `edit_order(self, id: str, symbol: str, type: OrderType, side: OrderSide, amount: Num = None, price: Num = None, params={})`
145+
- `get_asset_history_rows(self, code: Str = None, since: Int = None, limit: Int = None, params={})`
146+
- `get_withdraw_nonce(self, params={})`
147+
- `hash_message(self, message)`
148+
- `nonce(self)`
149+
- `set_leverage(self, leverage: int, symbol: Str = None, params={})`
150+
- `set_sandbox_mode(self, enable: bool)`
151+
- `withdraw(self, code: str, amount: float, address: str, tag: Str = None, params={})`
152+
153+
### REST Raw
154+
155+
- `v1_public_get_public_volume_stats(request)`
156+
- `v1_public_get_public_broker_name(request)`
157+
- `v1_public_get_public_chain_info_broker_id(request)`
158+
- `v1_public_get_public_system_info(request)`
159+
- `v1_public_get_public_vault_balance(request)`
160+
- `v1_public_get_public_insurancefund(request)`
161+
- `v1_public_get_public_chain_info(request)`
162+
- `v1_public_get_faucet_usdc(request)`
163+
- `v1_public_get_public_account(request)`
164+
- `v1_public_get_get_account(request)`
165+
- `v1_public_get_registration_nonce(request)`
166+
- `v1_public_get_get_orderly_key(request)`
167+
- `v1_public_get_public_liquidation(request)`
168+
- `v1_public_get_public_liquidated_positions(request)`
169+
- `v1_public_get_public_config(request)`
170+
- `v1_public_get_public_campaign_ranking(request)`
171+
- `v1_public_get_public_campaign_stats(request)`
172+
- `v1_public_get_public_campaign_user(request)`
173+
- `v1_public_get_public_campaign_stats_details(request)`
174+
- `v1_public_get_public_campaigns(request)`
175+
- `v1_public_get_public_points_leaderboard(request)`
176+
- `v1_public_get_client_points(request)`
177+
- `v1_public_get_public_points_epoch(request)`
178+
- `v1_public_get_public_points_epoch_dates(request)`
179+
- `v1_public_get_public_referral_check_ref_code(request)`
180+
- `v1_public_get_public_referral_verify_ref_code(request)`
181+
- `v1_public_get_referral_admin_info(request)`
182+
- `v1_public_get_referral_info(request)`
183+
- `v1_public_get_referral_referee_info(request)`
184+
- `v1_public_get_referral_referee_rebate_summary(request)`
185+
- `v1_public_get_referral_referee_history(request)`
186+
- `v1_public_get_referral_referral_history(request)`
187+
- `v1_public_get_referral_rebate_summary(request)`
188+
- `v1_public_get_client_distribution_history(request)`
189+
- `v1_public_get_tv_config(request)`
190+
- `v1_public_get_tv_history(request)`
191+
- `v1_public_get_tv_symbol_info(request)`
192+
- `v1_public_get_public_funding_rate_history(request)`
193+
- `v1_public_get_public_funding_rate_symbol(request)`
194+
- `v1_public_get_public_funding_rates(request)`
195+
- `v1_public_get_public_info(request)`
196+
- `v1_public_get_public_info_symbol(request)`
197+
- `v1_public_get_public_market_trades(request)`
198+
- `v1_public_get_public_token(request)`
199+
- `v1_public_get_public_futures(request)`
200+
- `v1_public_get_public_futures_symbol(request)`
201+
- `v1_public_post_register_account(request)`
202+
- `v1_private_get_client_key_info(request)`
203+
- `v1_private_get_client_orderly_key_ip_restriction(request)`
204+
- `v1_private_get_order_oid(request)`
205+
- `v1_private_get_client_order_client_order_id(request)`
206+
- `v1_private_get_algo_order_oid(request)`
207+
- `v1_private_get_algo_client_order_client_order_id(request)`
208+
- `v1_private_get_orders(request)`
209+
- `v1_private_get_algo_orders(request)`
210+
- `v1_private_get_trade_tid(request)`
211+
- `v1_private_get_trades(request)`
212+
- `v1_private_get_order_oid_trades(request)`
213+
- `v1_private_get_client_liquidator_liquidations(request)`
214+
- `v1_private_get_liquidations(request)`
215+
- `v1_private_get_asset_history(request)`
216+
- `v1_private_get_client_holding(request)`
217+
- `v1_private_get_withdraw_nonce(request)`
218+
- `v1_private_get_settle_nonce(request)`
219+
- `v1_private_get_pnl_settlement_history(request)`
220+
- `v1_private_get_volume_user_daily(request)`
221+
- `v1_private_get_volume_user_stats(request)`
222+
- `v1_private_get_client_statistics(request)`
223+
- `v1_private_get_client_info(request)`
224+
- `v1_private_get_client_statistics_daily(request)`
225+
- `v1_private_get_positions(request)`
226+
- `v1_private_get_position_symbol(request)`
227+
- `v1_private_get_funding_fee_history(request)`
228+
- `v1_private_get_notification_inbox_notifications(request)`
229+
- `v1_private_get_notification_inbox_unread(request)`
230+
- `v1_private_get_volume_broker_daily(request)`
231+
- `v1_private_get_broker_fee_rate_default(request)`
232+
- `v1_private_get_broker_user_info(request)`
233+
- `v1_private_get_orderbook_symbol(request)`
234+
- `v1_private_get_kline(request)`
235+
- `v1_private_post_orderly_key(request)`
236+
- `v1_private_post_client_set_orderly_key_ip_restriction(request)`
237+
- `v1_private_post_client_reset_orderly_key_ip_restriction(request)`
238+
- `v1_private_post_order(request)`
239+
- `v1_private_post_batch_order(request)`
240+
- `v1_private_post_algo_order(request)`
241+
- `v1_private_post_liquidation(request)`
242+
- `v1_private_post_claim_insurance_fund(request)`
243+
- `v1_private_post_withdraw_request(request)`
244+
- `v1_private_post_settle_pnl(request)`
245+
- `v1_private_post_notification_inbox_mark_read(request)`
246+
- `v1_private_post_notification_inbox_mark_read_all(request)`
247+
- `v1_private_post_client_leverage(request)`
248+
- `v1_private_post_client_maintenance_config(request)`
249+
- `v1_private_post_delegate_signer(request)`
250+
- `v1_private_post_delegate_orderly_key(request)`
251+
- `v1_private_post_delegate_settle_pnl(request)`
252+
- `v1_private_post_delegate_withdraw_request(request)`
253+
- `v1_private_post_broker_fee_rate_set(request)`
254+
- `v1_private_post_broker_fee_rate_set_default(request)`
255+
- `v1_private_post_broker_fee_rate_default(request)`
256+
- `v1_private_post_referral_create(request)`
257+
- `v1_private_post_referral_update(request)`
258+
- `v1_private_post_referral_bind(request)`
259+
- `v1_private_post_referral_edit_split(request)`
260+
- `v1_private_put_order(request)`
261+
- `v1_private_put_algo_order(request)`
262+
- `v1_private_delete_order(request)`
263+
- `v1_private_delete_algo_order(request)`
264+
- `v1_private_delete_client_order(request)`
265+
- `v1_private_delete_algo_client_order(request)`
266+
- `v1_private_delete_algo_orders(request)`
267+
- `v1_private_delete_orders(request)`
268+
- `v1_private_delete_batch_order(request)`
269+
- `v1_private_delete_client_batch_order(request)`
270+
271+
### WS Unified
272+
273+
- `describe(self)`
274+
- `watch_public(self, messageHash, message)`
275+
- `watch_order_book(self, symbol: str, limit: Int = None, params={})`
276+
- `watch_ticker(self, symbol: str, params={})`
277+
- `watch_tickers(self, symbols: Strings = None, params={})`
278+
- `watch_bids_asks(self, symbols: Strings = None, params={})`
279+
- `watch_ohlcv(self, symbol: str, timeframe='1m', since: Int = None, limit: Int = None, params={})`
280+
- `watch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={})`
281+
- `authenticate(self, params={})`
282+
- `watch_private(self, messageHash, message, params={})`
283+
- `watch_private_multiple(self, messageHashes, message, params={})`
284+
- `watch_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
285+
- `watch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`
286+
- `watch_positions(self, symbols: Strings = None, since: Int = None, limit: Int = None, params={})`
287+
- `set_positions_cache(self, client: Client, type, symbols: Strings = None)`
288+
- `load_positions_snapshot(self, client, messageHash)`
289+
- `watch_balance(self, params={})`
290+
291+
## Contribution
292+
- Give us a star :star:
293+
- Fork and Clone! Awesome
294+
- Select existing issues or create a new issue.

build/package.json

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,6 @@
66
"scripts": {
77
"build-single-exchange": "tsx build.ts",
88
"pypi-packager": "tsx pypi-packager.ts",
9-
109
"sample-generate": "cd ../.github/scripts/ && bash generate-exchange-skeleton.sh ../../../tmp_folder kucoin",
1110
"sample-build": "cd ../../tmp_folder/build && npm run build-single-exchange",
1211
"sample-pypi": "cd ../../tmp_folder/build && npm run pypi-packager",
@@ -17,7 +16,8 @@
1716
"dependencies": {
1817
"fs": "*",
1918
"path": "*",
20-
"semver": "^7.7.1"
19+
"semver": "^7.7.1",
20+
"typescript": "^5.9.3"
2121
},
2222
"devDependencies": {
2323
"tsx": "^4.19.3"

examples/async.py

Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
import os
2+
import sys
3+
import asyncio
4+
5+
# if CCXT is included locally
6+
# sys.path.append(os.path.dirname(os.path.dirname((os.path.abspath(__file__)))) + '/')
7+
8+
from woofipro import WoofiproAsync
9+
10+
if sys.platform == 'win32':
11+
asyncio.set_event_loop_policy(asyncio.WindowsSelectorEventLoopPolicy())
12+
13+
async def main():
14+
instance = WoofiproAsync({})
15+
await instance.load_markets()
16+
symbol = "BTC/USDC"
17+
18+
# fetch ticker
19+
ticker = await instance.fetch_ticker(symbol)
20+
print(ticker)
21+
22+
# create order
23+
order = await instance.create_order("BTC/USDC", "limit", "buy", 1, 123456.789)
24+
print(order)
25+
26+
# close after you finish
27+
await instance.close()
28+
29+
asyncio.run(main())
30+

examples/sync.py

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
import os
2+
import sys
3+
4+
root = os.path.dirname(os.path.dirname((os.path.abspath(__file__))))
5+
sys.path.append(root + '/')
6+
7+
from woofipro import WoofiproSync
8+
9+
10+
def main():
11+
instance = WoofiproSync({})
12+
instance.load_markets()
13+
symbol = "BTC/USDC"
14+
15+
# fetch ticker
16+
ticker = instance.fetch_ticker(symbol)
17+
print(ticker)
18+
19+
# create order
20+
order = instance.create_order("BTC/USDC", "limit", "buy", 1, 123456.789)
21+
print(order)
22+
23+
main()
24+

0 commit comments

Comments
 (0)