otp.CallbackBase#
- class CallbackBase[source]#
- Bases: - onetick.query.callback.CallbackBase- Base class for user-defined callback classes for - onetick.py.runcallback mode.- Note - Callbacks are executed sequentially, so make sure they don’t take too much time to execute. - Examples - >>> t = otp.Ticks(A=[1, 2, 3]) >>> class NumTicksCallback(otp.CallbackBase): ... def __init__(self): ... self.num_ticks = 0 ... def process_tick(self, tick, time): ... self.num_ticks += 1 >>> callback = NumTicksCallback() >>> t(callback=callback) >>> callback.num_ticks 3 - See also - Method - __init__()can be used for callback initialization. Can be used to define some variables for future use in callback methods.- replicate()[source]#
- Called to replicate the callback object for each output node. May also be used for internal copying of callback object. - Return type
- By default reference to this callback object 
 
 - process_callback_label(callback_label)[source]#
- Called immediately before - process_symbol_name()to supply label assigned to callback.- Parameters
- callback_label (str) – label assigned to this callback object 
 
 - process_symbol_name(symbol_name)[source]#
- Invoked to supply the name of the security that produces all the ticks that will be delivered to this callback object. If these ticks are provided by several securities, the - symbol_nameparameter is set to empty string.- Parameters
- symbol_name (str) – name of security 
 - Examples - >>> t = otp.Tick(A=1) >>> class SymbolNameCallback(otp.CallbackBase): ... def process_symbol_name(self, symbol_name): ... self.symbol_name = symbol_name >>> callback = SymbolNameCallback() >>> t(callback=callback, symbols='DEMO_L1::X') >>> callback.symbol_name 'DEMO_L1::X' 
 - process_symbol_group_name(symbol_group_name)[source]#
- Called when a named group of securities, i.e. portfolio, is processed. - Parameters
- symbol_group_name (str) – The name of security group. 
 
 - process_tick_type(tick_type)[source]#
- Reports the type of the security ticks which are processed by this callback object. This method is called before any call to - process_tick_descriptor()or- process_tick(). It is called immediately after- process_symbol_name().- Parameters
- tick_type (str) – The name of tick type. 
 - Examples - >>> t = otp.Tick(A=1, symbol='DEMO_L1', tick_type='TT_TT') >>> class TickTypeCallback(otp.CallbackBase): ... def process_tick_type(self, tick_type): ... self.tick_type = tick_type >>> callback = TickTypeCallback() >>> t(callback=callback) >>> callback.tick_type 'DEMO_L1::TT_TT' 
 - process_tick_descriptor(tick_descriptor)[source]#
- This method is is invoked before the first call to - process_tick()and every time before tick structure changes.- Parameters
- tick_descriptor (list of tuple) – First element of each tuple is field’s name and the second one is a dictionary - {'type': string_field_type}.
 - Examples - >>> t = otp.Tick(A=1) >>> class TickDescriptorCallback(otp.CallbackBase): ... def process_tick_descriptor(self, tick_descriptor): ... self.tick_descriptor = tick_descriptor >>> callback = TickDescriptorCallback() >>> t(callback=callback) >>> callback.tick_descriptor [('A', {'type': 'int'})] 
 - process_tick(tick, time)[source]#
- Called to deliver each tick. - Parameters
 - Examples - >>> t = otp.Tick(A=1) >>> class ProcessTickCallback(otp.CallbackBase): ... def process_tick(self, tick, time): ... self.result = (tick, time) >>> callback = ProcessTickCallback() >>> t(callback=callback) >>> callback.result ({'A': 1}, datetime.datetime(2003, 12, 1, 5, 0)) 
 - process_sorting_order(sorted_by_time_flag)[source]#
- Informs whether the ticks that will be submitted to this callback object will be ordered by time. - Parameters
- sorted_by_time_flag (bool) – Indicates whether the incoming ticks will be sorted by time. 
 
 - process_data_quality_change(symbol_name, data_quality, time)[source]#
- Called to report a data quality change, such as collection outage. - Parameters
- symbol_name (str) – Symbol name for each data quality change is propagated. 
- data_quality (int) – - parameter has following meaning: - QUALITY_UNKNOWN = -1, 
- QUALITY_OK, 
- QUALITY_STALE = 1, 
- QUALITY_MISSING = 2, 
- QUALITY_PATCHED = 4, 
- QUALITY_MOUNT_BAD = 9, 
- QUALITY_DISCONNECT = 17, 
- QUALITY_COLLECTOR_FAILURE = 33, 
- QUALITY_DELAY_STITCHING_WITH_RT = 64, 
- QUALITY_OK_STITCHING_WITH_RT = 66 
 
- time (datetime) – Time of the change in GMT timezone. 
 
 
 - process_error(error_code, error_msg)[source]#
- Called to report a per-security error or per-security warning. 
 - done()[source]#
- Invoked when all the raw or computed ticks for a given request were submitted to the callback using the - process_tick()method.- Examples - >>> t = otp.Tick(A=1) >>> class DoneCallback(otp.CallbackBase): ... def done(self): ... self.done = True >>> callback = DoneCallback() >>> t(callback=callback) >>> callback.done True