osbot-utils 1.59.0__py3-none-any.whl → 1.61.0__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.
@@ -0,0 +1,13 @@
1
+ from osbot_utils.utils.Misc import timestamp_now
2
+
3
+ class Timestamp_Now(int):
4
+ def __new__(cls, value=None):
5
+ if value is None:
6
+ value = timestamp_now()
7
+ return int.__new__(cls, value)
8
+
9
+ def __init__(self, value=None):
10
+ self.value = value if value is not None else timestamp_now()
11
+
12
+ def __str__(self):
13
+ return str(self.value)
@@ -2,17 +2,17 @@ import asyncio
2
2
  import logging
3
3
  import typing
4
4
 
5
- from osbot_utils.helpers.Dependency_Manager import Dependency_Manager
6
-
7
- from osbot_utils.base_classes.Type_Safe import Type_Safe
8
- from osbot_utils.helpers.CFormat import CFormat, f_dark_grey, f_magenta, f_bold
9
- from osbot_utils.helpers.flows.models.Flow__Config import Flow__Config
10
- from osbot_utils.helpers.flows.Flow__Events import flow_events
11
- from osbot_utils.testing.Stdout import Stdout
12
- from osbot_utils.utils.Misc import random_id, lower
13
- from osbot_utils.utils.Python_Logger import Python_Logger
14
- from osbot_utils.utils.Str import ansis_to_texts
15
- from osbot_utils.utils.Threads import invoke_in_new_event_loop
5
+ from osbot_utils.helpers.Dependency_Manager import Dependency_Manager
6
+ from osbot_utils.base_classes.Type_Safe import Type_Safe
7
+ from osbot_utils.helpers.CFormat import CFormat, f_dark_grey, f_magenta, f_bold
8
+ from osbot_utils.helpers.flows.models.Flow_Run__Config import Flow_Run__Config
9
+ from osbot_utils.helpers.flows.Flow__Events import flow_events
10
+ from osbot_utils.helpers.flows.models.Flow_Run__Event_Data import Flow_Run__Event_Data
11
+ from osbot_utils.testing.Stdout import Stdout
12
+ from osbot_utils.utils.Misc import random_id, lower
13
+ from osbot_utils.utils.Python_Logger import Python_Logger
14
+ from osbot_utils.utils.Str import ansis_to_texts
15
+ from osbot_utils.utils.Threads import invoke_in_new_event_loop
16
16
 
17
17
  FLOW__RANDOM_ID__PREFIX = 'flow_id__'
18
18
  FLOW__RANDOM_NAME__PREFIX = 'flow_name__'
@@ -26,32 +26,35 @@ class Flow(Type_Safe):
26
26
  data : dict # dict available to the tasks to add and collect data
27
27
  flow_id : str
28
28
  flow_name : str
29
- flow_config : Flow__Config
29
+ flow_config : Flow_Run__Config
30
30
  flow_error : Exception = None
31
31
  flow_target : callable
32
32
  flow_args : tuple
33
33
  flow_kwargs : dict
34
34
  flow_return_value : typing.Any
35
+ flow_run_params : dict
35
36
  logger : Python_Logger
36
37
  cformat : CFormat
37
38
  executed_tasks : typing.List
38
39
  resolved_args : tuple
39
40
  resolved_kwargs : dict
40
41
 
41
- def add_flow_artifact(self, description=None, key=None, data=None, artifact_type=None): # todo: figure out how to make this work since at the moment most are showing an unknown type
42
- result_data = dict(flow_run_id = self.flow_id,
43
- description = description or 'description' ,
44
- key = key or 'an-artifact-key' ,
45
- data = data or {"link": "https://www.google.com", "link_text": "link to Google"}, # test data to see if it worksw
46
- type = artifact_type or "link" ) # type clashed with built-in type
42
+ def add_flow_artifact(self, description=None, key=None, data=None, artifact_type=None): # todo: figure out how to make this work since at the moment most are showing an unknown type
43
+ event_data = Flow_Run__Event_Data()
44
+ event_data.data= dict(artifact_data = dict(description = description or 'description',
45
+ key = key or 'an-artifact-key',
46
+ data = data or {"link": "https://www.google.com", "link_text": "link to Google"}, # test data to see if it worksw
47
+ type = artifact_type or "link")) # type clashed with built-in type
48
+ event_data.flow_run_id = self.flow_id
49
+ flow_events.on__new_artifact(event_data)
47
50
 
48
- flow_events.on__new_artifact(self, result_data )
49
51
 
50
52
  def add_flow_result(self, key, description):
51
- result_data = dict(flow_run_id = self.flow_id,
52
- key = key ,
53
- description = description )
54
- flow_events.on__new_result(self, result_data )
53
+ event_data = Flow_Run__Event_Data()
54
+ event_data.flow_run_id = self.flow_id
55
+ event_data.data = dict(result_data = dict(key = key ,
56
+ description = description ))
57
+ flow_events.on__new_result(event_data)
55
58
 
56
59
  def config_logger(self):
57
60
  with self.logger as _:
@@ -60,15 +63,14 @@ class Flow(Type_Safe):
60
63
  if self.flow_config.log_to_console:
61
64
  _.add_console_logger()
62
65
 
63
- def create_flow(self):
64
- self.set_flow_name()
65
- self.log_debug(f"Created flow run '{self.f__flow_id()}' for flow '{self.f__flow_name()}'")
66
-
67
66
  def execute(self):
68
67
  return self.execute_flow()
69
68
 
70
- def execute_flow(self):
71
- flow_events.on__flow__start(self)
69
+ def execute_flow(self, flow_run_params=None): # todo: see if it makes more sense to call this start_flow_run
70
+ flow_events.on__flow__start(self.flow_event_data())
71
+ self.log_debug(f"Created flow run '{self.f__flow_id()}' for flow '{self.f__flow_name()}'")
72
+ self.set_flow_run_params(flow_run_params)
73
+
72
74
  if self.flow_config.log_to_memory:
73
75
  self.logger.add_memory_logger() # todo: move to method that does pre-execute tasks
74
76
 
@@ -90,7 +92,7 @@ class Flow(Type_Safe):
90
92
  self.logger.remove_memory_logger() # todo: move to method that does post-execute tasks
91
93
  if self.flow_return_value:
92
94
  self.add_flow_result(key = 'flow-return-value', description=f'{self.flow_return_value}')
93
- flow_events.on__flow__stop(self)
95
+ flow_events.on__flow__stop(self.flow_event_data())
94
96
  return self
95
97
 
96
98
  def captured_logs(self):
@@ -113,6 +115,11 @@ class Flow(Type_Safe):
113
115
  def f__flow_name(self):
114
116
  return self.cformat.blue(self.flow_name)
115
117
 
118
+ def flow_event_data(self):
119
+ kwargs = dict(flow_name = self.flow_name ,
120
+ #flow_id = self.flow_id , # todo: add support for actually sending the flow_id value (not the flow_run_id)
121
+ flow_run_id = self.flow_id )
122
+ return Flow_Run__Event_Data(**kwargs)
116
123
 
117
124
  def log_captured_stdout(self, stdout):
118
125
  for line in stdout.value().splitlines():
@@ -139,7 +146,7 @@ class Flow(Type_Safe):
139
146
  message = message ,
140
147
  flow_run_id = self.flow_id,
141
148
  task_run_id = task_run_id )
142
- flow_events.on__flow_run__message(self, **kwargs)
149
+ flow_events.on__flow_run__message(**kwargs)
143
150
  if log_level == logging.DEBUG:
144
151
  self.logger.debug(message)
145
152
  elif log_level == logging.ERROR:
@@ -206,11 +213,20 @@ class Flow(Type_Safe):
206
213
  self.flow_name = self.flow_target.__name__
207
214
  else:
208
215
  self.flow_name = self.random_flow_name()
209
- def setup(self):
216
+
217
+ def set_flow_run_params(self, flow_run_params=None):
218
+ if flow_run_params:
219
+ self.flow_run_params = flow_run_params
220
+ self.log_info(f"flow_run_params: {flow_run_params}")
221
+ self.add_flow_artifact(description="Data received via FastAPI's request.json()", key='post-data', data=flow_run_params)
222
+
223
+ def setup(self, target, *args, **kwargs):
210
224
  with self as _:
211
225
  _.cformat.auto_bold = True
212
- _.config_logger()
213
- _.setup_flow_run()
226
+ _.set_flow_target (target, *args, **kwargs)
227
+ _.config_logger ()
228
+ _.setup_flow_run ()
229
+ _.set_flow_name ()
214
230
  return self
215
231
 
216
232
  def setup_flow_run(self):
@@ -1,46 +1,45 @@
1
- from osbot_utils.utils.Str import ansis_to_texts, ansi_to_text
2
-
3
- from osbot_utils.utils.Dev import pprint
4
-
5
- from osbot_utils.base_classes.Type_Safe import Type_Safe
6
- from osbot_utils.helpers.flows.models.Flow__Event import Flow__Event
7
- from osbot_utils.helpers.flows.models.Flow__Event_Type import Flow__Event_Type
1
+ from osbot_utils.helpers.flows.models.Flow_Run__Event_Data import Flow_Run__Event_Data
2
+ from osbot_utils.utils.Str import ansi_to_text
3
+ from osbot_utils.base_classes.Type_Safe import Type_Safe
4
+ from osbot_utils.helpers.flows.models.Flow_Run__Event import Flow_Run__Event
5
+ from osbot_utils.helpers.flows.models.Flow_Run__Event_Type import Flow_Run__Event_Type
8
6
 
9
7
 
10
8
  class Flow_Events(Type_Safe):
11
9
  event_listeners : list
12
10
 
13
- def on__flow__start(self, flow):
14
- flow_event = Flow__Event(event_type=Flow__Event_Type.FLOW_START, event_source=flow)
11
+ def on__flow__start(self, event_data: Flow_Run__Event_Data):
12
+ flow_event = Flow_Run__Event(event_type=Flow_Run__Event_Type.FLOW_START, event_data=event_data)
15
13
  self.raise_event(flow_event)
16
14
 
17
- def on__flow__stop(self, flow): # todo: see of flow_ended or flow_completed are better names
18
- flow_event = Flow__Event(event_type=Flow__Event_Type.FLOW_STOP , event_source=flow)
15
+ def on__flow__stop(self, event_data: Flow_Run__Event_Data): # todo: see of flow_ended or flow_completed are better names
16
+ flow_event = Flow_Run__Event(event_type=Flow_Run__Event_Type.FLOW_STOP , event_data=event_data)
19
17
  self.raise_event(flow_event)
20
18
 
21
- def on__flow_run__message(self, flow, log_level, flow_run_id, task_run_id, message):
22
- event_data = dict(flow_run_id = flow_run_id ,
23
- log_level = log_level ,
24
- message = message ,
25
- message_text = ansi_to_text(message) ,
26
- task_run_id = task_run_id )
27
- flow_event = Flow__Event(event_type=Flow__Event_Type.FLOW_MESSAGE, event_source=flow, event_data=event_data)
19
+ def on__flow_run__message(self, log_level, flow_run_id, task_run_id, message):
20
+ event_data = Flow_Run__Event_Data()
21
+ event_data.flow_run_id = flow_run_id
22
+ event_data.task_run_id = task_run_id
23
+ event_data.data = dict(message_data = dict(log_level = log_level ,
24
+ message = message ,
25
+ message_text = ansi_to_text(message) ))
26
+ flow_event = Flow_Run__Event(event_type=Flow_Run__Event_Type.FLOW_MESSAGE, event_data=event_data)
28
27
  self.raise_event(flow_event)
29
28
 
30
- def on__new_artifact(self, flow, result_data):
31
- flow_event = Flow__Event(event_type=Flow__Event_Type.NEW_ARTIFACT , event_source=flow, event_data=result_data)
29
+ def on__new_artifact(self, event_data: Flow_Run__Event_Data):
30
+ flow_event = Flow_Run__Event(event_type=Flow_Run__Event_Type.NEW_ARTIFACT, event_data=event_data)
32
31
  self.raise_event(flow_event)
33
32
 
34
- def on__new_result(self, flow, result_data):
35
- flow_event = Flow__Event(event_type=Flow__Event_Type.NEW_RESULT , event_source=flow, event_data=result_data)
33
+ def on__new_result(self, event_data: Flow_Run__Event_Data):
34
+ flow_event = Flow_Run__Event(event_type=Flow_Run__Event_Type.NEW_RESULT, event_data=event_data)
36
35
  self.raise_event(flow_event)
37
36
 
38
- def on__task__start(self, task):
39
- flow_event = Flow__Event(event_type=Flow__Event_Type.TASK_START, event_source=task)
37
+ def on__task__start(self, event_data: Flow_Run__Event_Data):
38
+ flow_event = Flow_Run__Event(event_type=Flow_Run__Event_Type.TASK_START, event_data=event_data)
40
39
  self.raise_event(flow_event)
41
40
 
42
- def on__task__stop(self, task): # todo: see of flow_ended or flow_completed are better names
43
- flow_event = Flow__Event(event_type=Flow__Event_Type.TASK_STOP , event_source=task)
41
+ def on__task__stop(self, event_data: Flow_Run__Event_Data): # todo: see of flow_ended or flow_completed are better names
42
+ flow_event = Flow_Run__Event(event_type=Flow_Run__Event_Type.TASK_STOP , event_data=event_data)
44
43
  self.raise_event(flow_event)
45
44
 
46
45
  def raise_event(self, flow_event):
@@ -2,6 +2,7 @@ import asyncio
2
2
  import inspect
3
3
  import typing
4
4
 
5
+ from osbot_utils.helpers.flows.models.Flow_Run__Event_Data import Flow_Run__Event_Data
5
6
  from osbot_utils.utils.Misc import random_id, lower
6
7
  from osbot_utils.helpers.Dependency_Manager import Dependency_Manager
7
8
  from osbot_utils.helpers.flows.Flow__Events import flow_events
@@ -57,12 +58,19 @@ class Task(Type_Safe):
57
58
  if not self.task_id:
58
59
  self.task_id = self.random_task_id()
59
60
 
60
- flow_events.on__task__start(self)
61
+ flow_events.on__task__start(self.task_event_data())
61
62
 
62
63
  self.task_flow.executed_tasks.append(self)
63
64
  self.log_debug(f"Executing task '{f_blue(self.task_name)}'")
64
65
  self.resolve_args_and_kwargs()
65
66
 
67
+ def task_event_data(self):
68
+ kwargs = dict(flow_name = self.task_flow.flow_name,
69
+ flow_run_id = self.task_flow.flow_id ,
70
+ task_name = self.task_name ,
71
+ task_run_id = self.task_id )
72
+ return Flow_Run__Event_Data(**kwargs)
73
+
66
74
  def resolve_args_and_kwargs(self):
67
75
  dependency_manager = Dependency_Manager()
68
76
  dependency_manager.add_dependency('this_task', self )
@@ -97,7 +105,7 @@ class Task(Type_Safe):
97
105
 
98
106
  self.print_task_finished_message()
99
107
 
100
- flow_events.on__task__stop(self)
108
+ flow_events.on__task__stop(self.task_event_data())
101
109
  return self.task_return_value
102
110
 
103
111
 
@@ -10,9 +10,7 @@ def flow(**flow_kwargs):
10
10
  @wraps(function)
11
11
  def wrapper(*args: Any, **kwargs: Any) -> Flow:
12
12
  with Flow(**flow_kwargs) as _:
13
- _.set_flow_target(function, *args, **kwargs)
14
- _.setup()
15
- _.create_flow()
13
+ _.setup(function, *args, **kwargs)
16
14
  return _
17
15
  return wrapper
18
16
  return decorator
@@ -1,7 +1,7 @@
1
1
  from osbot_utils.base_classes.Type_Safe import Type_Safe
2
2
 
3
3
 
4
- class Flow__Config(Type_Safe):
4
+ class Flow_Run__Config(Type_Safe):
5
5
  add_task_to_self : bool = True
6
6
  log_to_console : bool = False
7
7
  log_to_memory : bool = True
@@ -0,0 +1,15 @@
1
+ from osbot_utils.helpers.Random_Guid import Random_Guid
2
+
3
+ from osbot_utils.base_classes.Type_Safe import Type_Safe
4
+ from osbot_utils.helpers.Timestamp_Now import Timestamp_Now
5
+ from osbot_utils.helpers.flows.models.Flow_Run__Event_Data import Flow_Run__Event_Data
6
+ from osbot_utils.helpers.flows.models.Flow_Run__Event_Type import Flow_Run__Event_Type
7
+
8
+
9
+
10
+ class Flow_Run__Event(Type_Safe):
11
+ event_id : Random_Guid
12
+ event_type : Flow_Run__Event_Type
13
+ event_data : Flow_Run__Event_Data
14
+ timestamp : Timestamp_Now
15
+
@@ -0,0 +1,14 @@
1
+ import logging
2
+
3
+ from osbot_utils.base_classes.Type_Safe import Type_Safe
4
+
5
+
6
+ class Flow_Run__Event_Data(Type_Safe):
7
+ data : dict
8
+ event_source: str
9
+ flow_id : str = None
10
+ flow_name : str = None
11
+ flow_run_id : str = None
12
+ log_level : int = logging.INFO
13
+ task_name : str = None
14
+ task_run_id : str = None
@@ -1,6 +1,8 @@
1
+ from enum import Enum
2
+
1
3
  from osbot_utils.base_classes.Type_Safe import Type_Safe
2
4
 
3
- class Flow__Event_Type(Type_Safe):
5
+ class Flow_Run__Event_Type(Enum):
4
6
  FLOW_MESSAGE: str = 'flow_message'
5
7
  FLOW_START : str = 'flow_start'
6
8
  FLOW_STOP : str = 'flow_stop'
osbot_utils/utils/Json.py CHANGED
@@ -1,9 +1,9 @@
1
1
  import json
2
2
  import os
3
3
 
4
- from osbot_utils.utils.Misc import str_lines, str_md5, str_sha256
4
+ from osbot_utils.utils.Misc import str_lines, str_md5, str_sha256
5
5
  from osbot_utils.utils.Files import file_create_gz, file_create, load_file_gz, file_contents, file_lines, file_lines_gz
6
- from osbot_utils.utils.Zip import str_to_gz, gz_to_str
6
+ from osbot_utils.utils.Zip import str_to_gz, gz_to_str
7
7
 
8
8
 
9
9
  def json_dumps(python_object, indent=4, pretty=True, sort_keys=False, default=str, raise_exception=False):
osbot_utils/utils/Misc.py CHANGED
@@ -131,6 +131,8 @@ def date_today():
131
131
  def list_set(target: object) -> object:
132
132
  if hasattr(target, '__iter__'):
133
133
  return sorted(list(set(target)))
134
+ if hasattr(target, '__dict__'):
135
+ return list_set(target.__dict__)
134
136
  return []
135
137
 
136
138
  def time_str_milliseconds(datetime_str, datetime_format, milliseconds_numbers=0):
@@ -511,5 +513,6 @@ random_guid = random_uuid
511
513
  random_value = random_string
512
514
 
513
515
  time_utc = time_now
516
+ timestamp_now = timestamp_utc_now
514
517
  wait_for = wait
515
518
 
@@ -1,5 +1,6 @@
1
1
  # todo add tests
2
2
  import inspect
3
+ import json
3
4
  import pickle
4
5
  import sys
5
6
  import types
@@ -151,6 +152,9 @@ def obj_to_dict(target):
151
152
  return {obj_to_dict(item) for item in target}
152
153
  return target # Return non-object types as is
153
154
 
155
+ def str_to_obj(target):
156
+ return dict_to_obj(json.loads(target))
157
+
154
158
  def enum_from_value(enum_type, value):
155
159
  try:
156
160
  return enum_type[value] # Attempt to convert the value to an Enum member by name
@@ -390,6 +394,8 @@ def value_type_matches_obj_annotation_for_attr(target, attr_name, value):
390
394
  base_types = base_classes
391
395
  bytes_to_obj = pickle_load_from_bytes
392
396
 
397
+ json_to_obj = str_to_obj
398
+
393
399
  full_type_name = class_full_name
394
400
 
395
401
  obj_list_set = obj_keys
osbot_utils/version CHANGED
@@ -1 +1 @@
1
- v1.59.0
1
+ v1.61.0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: osbot_utils
3
- Version: 1.59.0
3
+ Version: 1.61.0
4
4
  Summary: OWASP Security Bot - Utils
5
5
  Home-page: https://github.com/owasp-sbot/OSBot-Utils
6
6
  License: MIT
@@ -15,6 +15,7 @@ Classifier: Programming Language :: Python :: 3.9
15
15
  Classifier: Programming Language :: Python :: 3.10
16
16
  Classifier: Programming Language :: Python :: 3.11
17
17
  Classifier: Programming Language :: Python :: 3.12
18
+ Classifier: Programming Language :: Python :: 3.13
18
19
  Project-URL: Repository, https://github.com/owasp-sbot/OSBot-Utils
19
20
  Description-Content-Type: text/markdown
20
21
 
@@ -22,7 +23,7 @@ Description-Content-Type: text/markdown
22
23
 
23
24
  Powerful Python util methods and classes that simplify common apis and tasks.
24
25
 
25
- ![Current Release](https://img.shields.io/badge/release-v1.59.0-blue)
26
+ ![Current Release](https://img.shields.io/badge/release-v1.61.0-blue)
26
27
  [![codecov](https://codecov.io/gh/owasp-sbot/OSBot-Utils/graph/badge.svg?token=GNVW0COX1N)](https://codecov.io/gh/owasp-sbot/OSBot-Utils)
27
28
 
28
29
 
@@ -67,6 +67,7 @@ osbot_utils/helpers/Print_Table.py,sha256=LEXbyqGg_6WSraI4cob4bNNSu18ddqvALp1zGK
67
67
  osbot_utils/helpers/Python_Audit.py,sha256=shpZlluJwqJBAlad6xN01FkgC1TsQ48RLvR5ZjmrKa4,1539
68
68
  osbot_utils/helpers/Random_Guid.py,sha256=_wlyM17SIr-FeYESwnVt4cfkEtRRf-dbYh_lTnrKVG0,379
69
69
  osbot_utils/helpers/Random_Seed.py,sha256=14btja8LDN9cMGWaz4fCNcMRU_eyx49gas-_PQvHgy4,634
70
+ osbot_utils/helpers/Timestamp_Now.py,sha256=Vmdsm-pgvxkkQ_Qj_9Watr8rXXSvc-aBxWMPFGQx8Z0,371
70
71
  osbot_utils/helpers/Type_Registry.py,sha256=Ajk3SyMSKDi2g9SJYUtTgg7PZkAgydaHcpbGuEN3S94,311
71
72
  osbot_utils/helpers/Zip_Bytes.py,sha256=d5hYXNOJkOaYa7h2CJ0Y3ojEuGTOvCxPuSic2quwMY4,4236
72
73
  osbot_utils/helpers/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -154,16 +155,17 @@ osbot_utils/helpers/cache_requests/Cache__Requests__Row.py,sha256=h-yc7NkpScbHww
154
155
  osbot_utils/helpers/cache_requests/Cache__Requests__Table.py,sha256=RgxAYhm-FIrXXteQRtD91pOLq8JXhSzxb51Jb6MTUdY,391
155
156
  osbot_utils/helpers/cache_requests/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
156
157
  osbot_utils/helpers/cache_requests/flows/flow__Cache__Requests.py,sha256=xgx_oExxkcvRwQN1UCobimECIMUKGoIX5oGdCmp8Nyw,243
157
- osbot_utils/helpers/flows/Flow.py,sha256=m5j9OxR_xDgMh2z9u2FVQN_cQTQV_juJjbbNiNS8BuI,9645
158
- osbot_utils/helpers/flows/Flow__Events.py,sha256=u9GzVNd08Hr49ZRIpoRDhwJnAHUFB-XzFzmNw-r3_Q0,2535
159
- osbot_utils/helpers/flows/Task.py,sha256=ifPm0aqUG4sWAUTaYwT7ig-7Y9JmG9YTiNyC3dOX5sw,4887
158
+ osbot_utils/helpers/flows/Flow.py,sha256=2oUlvX5wyTZT1K5hkNn8owwCLb84nTUXelpRH1E0IPE,10812
159
+ osbot_utils/helpers/flows/Flow__Events.py,sha256=_BHXh9v1GfvTI7hGx7eJDkCGeo9VjqDoCTMDeL09Ujc,2843
160
+ osbot_utils/helpers/flows/Task.py,sha256=3PiU1GCWhnDcgYxYRldo0CWcCcnQDvWvU2cXPCmpSTc,5336
160
161
  osbot_utils/helpers/flows/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
161
162
  osbot_utils/helpers/flows/decorators/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
162
- osbot_utils/helpers/flows/decorators/flow.py,sha256=LUL7bHjZ_lC3QoTNh-KsDZHzjE2u4mU-5EpZnfsEGuc,738
163
+ osbot_utils/helpers/flows/decorators/flow.py,sha256=7wj5TtUO_ffbACnagZtZ6LfFgclmbQSfn2lKkMMrnJI,670
163
164
  osbot_utils/helpers/flows/decorators/task.py,sha256=9bhQBPJU1dO-J4FAsFkmxqQMBNtay4FT_b1BdpHJ9sA,734
164
- osbot_utils/helpers/flows/models/Flow__Config.py,sha256=NLIfT0S8zxbig6Q1p9KeoyE2qRVWorHxk-JXCv9Yx-U,382
165
- osbot_utils/helpers/flows/models/Flow__Event.py,sha256=O2SNmDG8FTsQQqm5tWmbomQsC_usA7EqMQhTWIFl4KM,157
166
- osbot_utils/helpers/flows/models/Flow__Event_Type.py,sha256=vPDW-7D96Sjn0X6-V1Xgp4ytQ58SgSbX0kyflXNwmK4,353
165
+ osbot_utils/helpers/flows/models/Flow_Run__Config.py,sha256=3JSPSG3vjM7mdnI-3wgLCc7Nc_3Xjqxn34_A6yUp-4Q,386
166
+ osbot_utils/helpers/flows/models/Flow_Run__Event.py,sha256=-F_H_Tq119qa9tk8IoX5U36h_f8AE1VueL0olhjH24g,569
167
+ osbot_utils/helpers/flows/models/Flow_Run__Event_Data.py,sha256=FlL1MifonjzHnHYtiVTMeZWu2WxjCNU5-D9VrF18Ces,340
168
+ osbot_utils/helpers/flows/models/Flow_Run__Event_Type.py,sha256=-iHKNQ-Ar2UfiCraFYQNHdBQ9fNcTTRoh3kRpXRS_Gc,375
167
169
  osbot_utils/helpers/flows/models/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
168
170
  osbot_utils/helpers/html/Dict_To_Css.py,sha256=u6B4Mx7PXr-gDrTrs1hgknnvsZVK4Fic5LqedKjo-lk,1097
169
171
  osbot_utils/helpers/html/Dict_To_Html.py,sha256=OlRSaDGOeseBNTxRB2ho5whqEacMXeAXWOfeVSEYqC4,3355
@@ -286,11 +288,11 @@ osbot_utils/utils/Files.py,sha256=7fdqbfFyo6Ow5Repi_dZAzHqGb0XYh6tDALYAy42pBY,22
286
288
  osbot_utils/utils/Functions.py,sha256=0E6alPJ0fJpBiJgFOWooCOi265wSRyxxXAJ5CELBnso,3498
287
289
  osbot_utils/utils/Http.py,sha256=vFvD-xLkkXLTJvmYGourMLoUOfkZx_KBSLmo1RX73jM,7043
288
290
  osbot_utils/utils/Int.py,sha256=PmlUdU4lSwf4gJdmTVdqclulkEp7KPCVUDO6AcISMF4,116
289
- osbot_utils/utils/Json.py,sha256=7COxBlZRnpxtpNqpmzMPYkcKTnCok-s686nT27oiKEQ,6489
291
+ osbot_utils/utils/Json.py,sha256=yIT2hUI23gYd24Uf3LCjqPNV67zS46rYZftcCM3jw-Q,6492
290
292
  osbot_utils/utils/Json_Cache.py,sha256=mLPkkDZN-3ZVJiDvV1KBJXILtKkTZ4OepzOsDoBPhWg,2006
291
293
  osbot_utils/utils/Lists.py,sha256=tPz5x5s3sRO97WZ_nsxREBPC5cwaHrhgaYBhsrffTT8,5599
292
- osbot_utils/utils/Misc.py,sha256=nODZT6p44B4xYiIiqfEeKYEErQiKR9SGthhGtZWGhkI,16804
293
- osbot_utils/utils/Objects.py,sha256=0XKssf_aGarfWI-2Gl-XXUb2tYglTfCBkiKa5zTF0O4,17498
294
+ osbot_utils/utils/Misc.py,sha256=Z362HW7nUiGd7mj0QKW7ifNR1opUYNlQM7YmEyz_qHw,16921
295
+ osbot_utils/utils/Objects.py,sha256=_BWr7KA8Xzzxu6fyxHSqDqDM1Pkyr5IZUFo_hMf7oTo,17612
294
296
  osbot_utils/utils/Png.py,sha256=V1juGp6wkpPigMJ8HcxrPDIP4bSwu51oNkLI8YqP76Y,1172
295
297
  osbot_utils/utils/Process.py,sha256=lr3CTiEkN3EiBx3ZmzYmTKlQoPdkgZBRjPulMxG-zdo,2357
296
298
  osbot_utils/utils/Python_Logger.py,sha256=tx8N6wRKL3RDHboDRKZn8SirSJdSAE9cACyJkxrThZ8,12792
@@ -302,8 +304,8 @@ osbot_utils/utils/Toml.py,sha256=SD6IA4-mrtoBXcI0dIGKV9POMQNd6WYKvmDQq7GQ6ZQ,143
302
304
  osbot_utils/utils/Version.py,sha256=Ww6ChwTxqp1QAcxOnztkTicShlcx6fbNsWX5xausHrg,422
303
305
  osbot_utils/utils/Zip.py,sha256=G6Hk_hDcm9yvWzhTKzhT0R_6f0NBIAchHqMxGb3kfh4,14037
304
306
  osbot_utils/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
305
- osbot_utils/version,sha256=EhXG92o5KIntEa30a4LpsRMDYwjYTabNawYRJaxsOiI,8
306
- osbot_utils-1.59.0.dist-info/LICENSE,sha256=xx0jnfkXJvxRnG63LTGOxlggYnIysveWIZ6H3PNdCrQ,11357
307
- osbot_utils-1.59.0.dist-info/METADATA,sha256=DdvKFldlZVnDRyR4XMvON5CIAjR_-MNMAKm2e4XeDHY,1266
308
- osbot_utils-1.59.0.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
309
- osbot_utils-1.59.0.dist-info/RECORD,,
307
+ osbot_utils/version,sha256=AxhppEeDw-7cq3HMr0l7OrPCdy5R5eZ7MF-27O2MVqs,8
308
+ osbot_utils-1.61.0.dist-info/LICENSE,sha256=xx0jnfkXJvxRnG63LTGOxlggYnIysveWIZ6H3PNdCrQ,11357
309
+ osbot_utils-1.61.0.dist-info/METADATA,sha256=yiavdHaHNU9h8VejBNAUqWYEl8itBbWeIfWhRIFngRU,1317
310
+ osbot_utils-1.61.0.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
311
+ osbot_utils-1.61.0.dist-info/RECORD,,
@@ -1,4 +1,4 @@
1
1
  Wheel-Version: 1.0
2
- Generator: poetry-core 1.9.0
2
+ Generator: poetry-core 1.9.1
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any
@@ -1,6 +0,0 @@
1
- from osbot_utils.base_classes.Type_Safe import Type_Safe
2
-
3
- class Flow__Event(Type_Safe):
4
- event_type : str
5
- event_source: object
6
- event_data : dict