siglab-py 0.3.9__py3-none-any.whl → 0.3.11__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.

@@ -452,6 +452,8 @@ async def execute_one_position(
452
452
  'reduceOnly': slice.reduce_only
453
453
  }
454
454
  if position.order_type=='limit':
455
+ order_params['postOnly'] = True
456
+
455
457
  if not param['dry_run']:
456
458
  executed_order = await exchange.create_order( # type: ignore
457
459
  symbol = position.ticker,
@@ -19,6 +19,7 @@ from yahoofinancials import YahooFinancials
19
19
  # yfinance allows intervals '1m', '5m', '15m', '1h', '1d', '1wk', '1mo'. yahoofinancials not as flexible
20
20
  import yfinance as yf
21
21
 
22
+ from siglab_py.util.retry_util import retry
22
23
  from siglab_py.exchanges.futubull import Futubull
23
24
  from siglab_py.exchanges.any_exchange import AnyExchange
24
25
 
@@ -516,55 +517,57 @@ def _fetch_candles_ccxt(
516
517
  candle_size : str,
517
518
  num_candles_limit : int = 100
518
519
  ) -> Dict[str, Union[pd.DataFrame, None]]:
519
- ticker = normalized_symbols[0]
520
+ rsp = {}
520
521
 
521
- def _fetch_ohlcv(exchange, symbol, timeframe, since, limit, params) -> Union[List, NoReturn]:
522
- one_timeframe = f"1{timeframe[-1]}"
523
- candles = exchange.fetch_ohlcv(symbol=symbol, timeframe=one_timeframe, since=since, limit=limit, params=params)
524
- if candles and len(candles)>0:
525
- candles.sort(key=lambda x : x[0], reverse=False)
522
+ for ticker in normalized_symbols:
523
+ @retry(num_attempts=3, pause_between_retries_ms=1000)
524
+ def _fetch_ohlcv(exchange, symbol, timeframe, since, limit, params) -> Union[List, NoReturn]:
525
+ one_timeframe = f"1{timeframe[-1]}"
526
+ candles = exchange.fetch_ohlcv(symbol=symbol, timeframe=one_timeframe, since=since, limit=limit, params=params)
527
+ if candles and len(candles)>0:
528
+ candles.sort(key=lambda x : x[0], reverse=False)
526
529
 
527
- return candles
528
-
529
- def _calc_increment(candle_size):
530
- increment = 1
531
- num_intervals = int(candle_size[0])
532
- interval_type = candle_size[-1]
533
- if interval_type == "m":
534
- increment = 60
535
- elif interval_type == "h":
536
- increment = 60*60
537
- elif interval_type == "d":
538
- increment = 60*60*24
539
- else:
540
- raise ValueError(f"Invalid candle_size {candle_size}")
541
- return num_intervals * increment
542
-
543
- all_candles = []
544
- params = {}
545
- this_cutoff = start_ts
546
- while this_cutoff<end_ts:
547
- candles = _fetch_ohlcv(exchange=exchange, symbol=ticker, timeframe=candle_size, since=int(this_cutoff * 1000), limit=num_candles_limit, params=params)
548
- if candles and len(candles)>0:
549
- all_candles = all_candles + [[ int(x[0]), float(x[1]), float(x[2]), float(x[3]), float(x[4]), float(x[5]) ] for x in candles if x[1] and x[2] and x[3] and x[4] and x[5] ]
550
-
551
- record_ts = max([int(record[0]) for record in candles])
552
- record_ts_str : str = str(record_ts)
553
- if len(record_ts_str)==13:
554
- record_ts = int(int(record_ts_str)/1000) # Convert from milli-seconds to seconds
530
+ return candles
555
531
 
556
- this_cutoff = record_ts + _calc_increment(candle_size)
557
- else:
558
- this_cutoff += _calc_increment(candle_size)
532
+ def _calc_increment(candle_size):
533
+ increment = 1
534
+ num_intervals = int(candle_size[0])
535
+ interval_type = candle_size[-1]
536
+ if interval_type == "m":
537
+ increment = 60
538
+ elif interval_type == "h":
539
+ increment = 60*60
540
+ elif interval_type == "d":
541
+ increment = 60*60*24
542
+ else:
543
+ raise ValueError(f"Invalid candle_size {candle_size}")
544
+ return num_intervals * increment
545
+
546
+ all_candles = []
547
+ params = {}
548
+ this_cutoff = start_ts
549
+ while this_cutoff<end_ts:
550
+ candles = _fetch_ohlcv(exchange=exchange, symbol=ticker, timeframe=candle_size, since=int(this_cutoff * 1000), limit=num_candles_limit, params=params)
551
+ if candles and len(candles)>0:
552
+ all_candles = all_candles + [[ int(x[0]), float(x[1]), float(x[2]), float(x[3]), float(x[4]), float(x[5]) ] for x in candles if x[1] and x[2] and x[3] and x[4] and x[5] ]
553
+
554
+ record_ts = max([int(record[0]) for record in candles])
555
+ record_ts_str : str = str(record_ts)
556
+ if len(record_ts_str)==13:
557
+ record_ts = int(int(record_ts_str)/1000) # Convert from milli-seconds to seconds
558
+
559
+ this_cutoff = record_ts + _calc_increment(candle_size)
560
+ else:
561
+ this_cutoff += _calc_increment(candle_size)
559
562
 
560
- columns = ['exchange', 'symbol', 'timestamp_ms', 'open', 'high', 'low', 'close', 'volume']
561
- pd_all_candles = pd.DataFrame([ [ exchange.name, ticker, x[0], x[1], x[2], x[3], x[4], x[5] ] for x in all_candles], columns=columns)
562
- fix_column_types(pd_all_candles)
563
- pd_all_candles['pct_chg_on_close'] = pd_all_candles['close'].pct_change()
563
+ columns = ['exchange', 'symbol', 'timestamp_ms', 'open', 'high', 'low', 'close', 'volume']
564
+ pd_all_candles = pd.DataFrame([ [ exchange.name, ticker, x[0], x[1], x[2], x[3], x[4], x[5] ] for x in all_candles], columns=columns)
565
+ fix_column_types(pd_all_candles)
566
+ pd_all_candles['pct_chg_on_close'] = pd_all_candles['close'].pct_change()
564
567
 
565
- return {
566
- ticker : pd_all_candles
567
- }
568
+ rsp[ticker] = pd_all_candles
569
+
570
+ return rsp
568
571
 
569
572
  def fetch_deribit_btc_option_expiries(
570
573
  market: str = 'BTC'
@@ -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.9
3
+ Version: 0.3.11
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=uMJRDGoYrqHZCfkv5ye-tmsJ8nYawIzy9_ehXa3Kk8M,42166
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=GSEpGG3wpR7kaM8Ou4lzy8MHqbbRp-tvSGZhNJymALc,29100
30
+ siglab_py/util/market_data_util.py,sha256=ogkuj8grE2sVI_-K2wPeyE7pdY04UpsVsoePQXjub7k,29387
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.9.dist-info/METADATA,sha256=5s95ToohGOXArDateCWXBCMSybFtxkxb3P2hVMlB2M0,979
36
- siglab_py-0.3.9.dist-info/WHEEL,sha256=yQN5g4mg4AybRjkgi-9yy4iQEFibGQmlz78Pik5Or-A,92
37
- siglab_py-0.3.9.dist-info/top_level.txt,sha256=AbD4VR9OqmMOGlMJLkAVPGQMtUPIQv0t1BF5xmcLJSk,10
38
- siglab_py-0.3.9.dist-info/RECORD,,
35
+ siglab_py-0.3.11.dist-info/METADATA,sha256=HkAJasuTZTqIP16RrphAhj4Yyvqu4u4GOq6h5wD_lsc,980
36
+ siglab_py-0.3.11.dist-info/WHEEL,sha256=yQN5g4mg4AybRjkgi-9yy4iQEFibGQmlz78Pik5Or-A,92
37
+ siglab_py-0.3.11.dist-info/top_level.txt,sha256=AbD4VR9OqmMOGlMJLkAVPGQMtUPIQv0t1BF5xmcLJSk,10
38
+ siglab_py-0.3.11.dist-info/RECORD,,