siglab-py 0.3.10__py3-none-any.whl → 0.3.12__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of siglab-py might be problematic. Click here for more details.

@@ -34,17 +34,21 @@ current_filename = os.path.basename(__file__)
34
34
  '''
35
35
  Usage:
36
36
  set PYTHONPATH=%PYTHONPATH%;D:\dev\siglab\siglab_py
37
- python gateway.py --gateway_id hyperliquid_01 --default_type linear --rate_limit_ms 100
37
+ python gateway.py --gateway_id hyperliquid_01 --default_type linear --rate_limit_ms 100 --encrypt_decrypt_with_aws_kms Y --aws_kms_key_id xxx --apikey xxx --secret xxxx --slack_info_url=https://hooks.slack.com/services/xxx --slack_critial_url=https://hooks.slack.com/services/xxx --slack_alert_url=https://hooks.slack.com/services/xxx
38
38
 
39
39
  --default_type defaults to linear
40
40
  --rate_limit_ms defaults to 100
41
-
41
+ --encrypt_decrypt_with_aws_kms If you encrypt apikey and secret using AMS KMS, then set to Y. If apikey and secret in unencrypted plain text, set to N.
42
+ --passphrase is optional, this depends on the exchange.
43
+ --gateway_id contains two parts separated by underscore. Gateway.py will parse 'hyperliquid_01' into two parts: 'hyperliquid' (Exchange name) and '01' (Use this for your sub account ID). Exchange name need be spelt exactly. Please have a look at market_data_util async_instantiate_exchange.
42
44
  --slack_info_url, --slack_critical_url and --slack_alert_url are if you want gateway to dispatch Slack notification on events.
43
45
  How to get Slack webhook urls? https://medium.com/@natalia_assad/how-send-a-table-to-slack-using-python-d1a20b08abe0
44
46
 
45
47
  Another example:
46
48
  python gateway.py --gateway_id hyperliquid_01 --default_type linear --rate_limit_ms 100 --slack_info_url=https://hooks.slack.com/services/xxx --slack_critial_url=https://hooks.slack.com/services/yyy --slack_alert_url=https://hooks.slack.com/services/zzz
47
49
 
50
+ gateway.py takes outgoing orders from redis and publish executions back to redis when done. Redis configuration in param['mds']['redis']. Start redis before starting gateway.py.
51
+
48
52
  This script is pypy compatible:
49
53
  pypy gateway.py --gateway_id bybit_01 --default_type linear --rate_limit_ms 100
50
54
 
@@ -452,6 +456,8 @@ async def execute_one_position(
452
456
  'reduceOnly': slice.reduce_only
453
457
  }
454
458
  if position.order_type=='limit':
459
+ order_params['postOnly'] = True
460
+
455
461
  if not param['dry_run']:
456
462
  executed_order = await exchange.create_order( # type: ignore
457
463
  symbol = position.ticker,
@@ -1,3 +1,4 @@
1
+ import logging
1
2
  import incremental
2
3
  import tzlocal
3
4
  from datetime import datetime, timezone
@@ -19,6 +20,7 @@ from yahoofinancials import YahooFinancials
19
20
  # yfinance allows intervals '1m', '5m', '15m', '1h', '1d', '1wk', '1mo'. yahoofinancials not as flexible
20
21
  import yfinance as yf
21
22
 
23
+ from siglab_py.util.retry_util import retry
22
24
  from siglab_py.exchanges.futubull import Futubull
23
25
  from siglab_py.exchanges.any_exchange import AnyExchange
24
26
 
@@ -115,6 +117,8 @@ async def async_instantiate_exchange(
115
117
  # spot, swap, future
116
118
  # https://github.com/ccxt/ccxt/blob/master/python/ccxt/deribit.py#L360
117
119
  exchange = ccxtpro.deribit(exchange_params) # type: ignore
120
+ elif exchange_name=='kraken':
121
+ exchange = ccxtpro.kraken(exchange_params) # type: ignore
118
122
  elif exchange_name=='hyperliquid':
119
123
  '''
120
124
  https://app.hyperliquid.xyz/API
@@ -516,9 +520,12 @@ def _fetch_candles_ccxt(
516
520
  candle_size : str,
517
521
  num_candles_limit : int = 100
518
522
  ) -> Dict[str, Union[pd.DataFrame, None]]:
523
+ logger = logging.getLogger()
524
+
519
525
  rsp = {}
520
526
 
521
527
  for ticker in normalized_symbols:
528
+ @retry(num_attempts=3, pause_between_retries_ms=1000)
522
529
  def _fetch_ohlcv(exchange, symbol, timeframe, since, limit, params) -> Union[List, NoReturn]:
523
530
  one_timeframe = f"1{timeframe[-1]}"
524
531
  candles = exchange.fetch_ohlcv(symbol=symbol, timeframe=one_timeframe, since=since, limit=limit, params=params)
@@ -541,6 +548,8 @@ def _fetch_candles_ccxt(
541
548
  raise ValueError(f"Invalid candle_size {candle_size}")
542
549
  return num_intervals * increment
543
550
 
551
+ logger.info(f"Fetching {candle_size} candles for {ticker}.")
552
+
544
553
  all_candles = []
545
554
  params = {}
546
555
  this_cutoff = start_ts
@@ -1,15 +1,23 @@
1
- def retry(num_attempts : int = 1):
1
+ import time
2
+
3
+ def retry(
4
+ num_attempts : int = 1,
5
+ pause_between_retries_ms : int = 1000
6
+ ):
2
7
  def decorator(method):
3
8
  def wrapper(*args, **kw):
4
9
  for i in range(num_attempts):
5
10
  try:
6
11
  result = method(*args, **kw)
7
12
  if i>0:
8
- print(f"retry_gizmo.retry succeeded: {method.__name__} on #{i+1} invocation. {args} {kw}")
13
+ print(f"retry_util.retry done {method.__name__} on #{i+1} call. {args} {kw}")
9
14
  return result
10
15
  except Exception as retry_error:
11
16
  if i==(num_attempts-1):
12
- err_msg = f"retry_gizmo.retry failed: {method.__name__} after {num_attempts} invocations. {args} {kw}. {retry_error}"
17
+ err_msg = f"retry_util.retry gave up {method.__name__} after {num_attempts} calls. {args} {kw}. {retry_error}"
13
18
  raise Exception(err_msg) from retry_error
19
+ finally:
20
+ time.sleep(int(pause_between_retries_ms/1000))
21
+
14
22
  return wrapper
15
23
  return decorator
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: siglab-py
3
- Version: 0.3.10
3
+ Version: 0.3.12
4
4
  Summary: Market data fetches, TA calculations and generic order gateway.
5
5
  Author: r0bbarh00d
6
6
  Author-email: r0bbarh00d <r0bbarh00d@gmail.com>
@@ -15,7 +15,7 @@ siglab_py/market_data_providers/test_provider.py,sha256=wBLCgcWjs7FGZJXWsNyn30lk
15
15
  siglab_py/ordergateway/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
16
16
  siglab_py/ordergateway/client.py,sha256=LvtrYirrdFOcKgTkvuqwdEN7r3nurjX320ESnk7tHE0,15095
17
17
  siglab_py/ordergateway/encrypt_keys_util.py,sha256=-qi87db8To8Yf1WS1Q_Cp2Ya7ZqgWlRqSHfNXCM7wE4,1339
18
- siglab_py/ordergateway/gateway.py,sha256=a0Ys_dr2mDk_9nb1sQMwXpv8g8DoaHipYdTDMi4r1IA,42091
18
+ siglab_py/ordergateway/gateway.py,sha256=5whFTlBLiIMPZ2YyedEIuLclPIdUzC67AZqw56C9o-Y,43087
19
19
  siglab_py/ordergateway/test_ordergateway.py,sha256=4PE2flp_soGcD3DrI7zJOzZndjkb6I5XaDrFNNq4Huo,4009
20
20
  siglab_py/tests/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
21
21
  siglab_py/tests/integration/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -27,12 +27,12 @@ siglab_py/tests/unit/trading_util_tests.py,sha256=tyefqOTQOoXSlemSDonqmdHp61-1nu
27
27
  siglab_py/util/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
28
28
  siglab_py/util/analytic_util.py,sha256=blFJ1kY_aSJeuzzk28vdB4nhLgmosz0L8IJaJCZy9OM,47272
29
29
  siglab_py/util/aws_util.py,sha256=KGmjHrr1rpnnxr33nXHNzTul4tvyyxl9p6gpwNv0Ygc,2557
30
- siglab_py/util/market_data_util.py,sha256=ND2uBpfsYkzDEf8i2jf6ZFYyBGDDdYDqCI6NJrW9DqY,29279
30
+ siglab_py/util/market_data_util.py,sha256=SGroJXt5PHDw6TnXwIFocKCYZ5uW-kZtregljkU2cdU,29613
31
31
  siglab_py/util/notification_util.py,sha256=vySgHjpHgwFDLW0tHSi_AGh9JBbPc25IUgvWxmjAeT8,2658
32
- siglab_py/util/retry_util.py,sha256=mxYuRFZRZoaQQjENcwPmxhxixtd1TFvbxIdPx4RwfRc,743
32
+ siglab_py/util/retry_util.py,sha256=g-UU6pkPouWZZRZEqP99R2Z0lX5xzckYkzjwqqSDpVQ,922
33
33
  siglab_py/util/slack_notification_util.py,sha256=G27n-adbT3Q6oaHSMvu_Nom794rrda5PprSF-zvmzkM,1912
34
34
  siglab_py/util/trading_util.py,sha256=FmqsamuPhMjZUkz4lCyuE8MHFapXn6yNl8Isy7peQEs,3047
35
- siglab_py-0.3.10.dist-info/METADATA,sha256=FzjfNoVztgaAR3Wmw9Jlamc49HEPBF99Az01i3yJtig,980
36
- siglab_py-0.3.10.dist-info/WHEEL,sha256=yQN5g4mg4AybRjkgi-9yy4iQEFibGQmlz78Pik5Or-A,92
37
- siglab_py-0.3.10.dist-info/top_level.txt,sha256=AbD4VR9OqmMOGlMJLkAVPGQMtUPIQv0t1BF5xmcLJSk,10
38
- siglab_py-0.3.10.dist-info/RECORD,,
35
+ siglab_py-0.3.12.dist-info/METADATA,sha256=MySFov9YH_zivfe1Cvbl8Eut7MJ_16JU55CAn0_DTwY,980
36
+ siglab_py-0.3.12.dist-info/WHEEL,sha256=yQN5g4mg4AybRjkgi-9yy4iQEFibGQmlz78Pik5Or-A,92
37
+ siglab_py-0.3.12.dist-info/top_level.txt,sha256=AbD4VR9OqmMOGlMJLkAVPGQMtUPIQv0t1BF5xmcLJSk,10
38
+ siglab_py-0.3.12.dist-info/RECORD,,