forked from lth-elm/TradingView-Webhook-Trading-Bot
-
Notifications
You must be signed in to change notification settings - Fork 1
/
orderapi.py
127 lines (102 loc) · 3.46 KB
/
orderapi.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
import logbot
import json, os, config
from ftxapi import Ftx
from bybitapi import ByBit
exchange = 'SUBACCOUNT_NAME'
leverage = 1.0
risk = 1.0 / 100
api_key = 'API_KEY'
api_secret = 'API_SECRET'
# ================== SET GLOBAL VARIABLES ==================
def global_var(payload):
global exchange
global leverage
global risk
global api_key
global api_secret
exchange = payload['exchange']
leverage = os.environ.get('LEVERAGE', config.LEVERAGE)
leverage = float(leverage)
risk = os.environ.get('RISK', config.RISK)
risk = float(risk) / 100
if exchange == 'BYBIT':
api_key = os.environ.get('BYBIT_API_KEY', config.BYBIT_API_KEY)
api_secret = os.environ.get('BYBIT_API_SECRET', config.BYBIT_API_SECRET)
else:
logbot.logs(">>> Exchange name not found!", True)
return {
"success": False,
"error": "subaccount name not found"
}
return {
"success": True
}
# ================== MAIN ==================
def order(payload: dict):
# DEFINE GLOBAL VARIABLE
glob = global_var(payload)
if not glob['success']:
return glob
init_var = {
#'exchange': exchange,
'leverage': leverage,
'risk': risk,
'api_key': api_key,
'api_secret': api_secret
}
exchange = payload['exchange']
# SET EXCHANGE CLASS
exchange_api = None
try:
if exchange.upper() == 'FTX':
exchange_api = Ftx(init_var)
elif exchange.upper() == 'BYBIT':
exchange_api = ByBit(init_var)
except Exception as e:
logbot.logs('>>> /!\ An exception occured : {}'.format(e), True)
return {
"success": False,
"error": str(e)
}
logbot.logs('>>> Exchange : {}'.format(exchange))
logbot.logs('>>> Subaccount : {}'.format(exchange))
# FIND THE APPROPRIATE TICKER IN DICTIONNARY
ticker = ""
if exchange.upper() == 'BYBIT':
ticker = payload['ticker']
else:
with open('tickers.json') as json_file:
tickers = json.load(json_file)
try:
ticker = tickers[exchange.lower()][payload['ticker']]
except Exception as e:
logbot.logs('>>> /!\ An exception occured : {}'.format(e), True)
return {
"success": False,
"error": str(e)
}
logbot.logs(">>> Ticker '{}' found".format(ticker))
# ALERT MESSAGE CONDITIONS
if payload['message'] == 'entry':
logbot.logs(">>> Order message : 'entry'")
exchange_api.exit_position(ticker)
orders = exchange_api.entry_position(payload, ticker)
return orders
elif payload['message'] == 'exit':
logbot.logs(">>> Order message : 'exit'")
exit_res = exchange_api.exit_position(ticker)
return exit_res
elif payload['message'][-9:] == 'breakeven':
logbot.logs(">>> Order message : 'breakeven'")
breakeven_res = exchange_api.breakeven(payload, ticker)
return breakeven_res
elif payload['message']== 'pivot':
logbot.logs(">>> Order message : 'pivot'")
#exchange_api.exit_position(ticker)
pivot_res = exchange_api.entry_spot_position(ticker, payload['side'])
return pivot_res
else:
logbot.logs(f">>> Order message : '{payload['message']}'")
return {
"message": payload['message']
}