dbos 2.0.0__py3-none-any.whl → 2.1.0a2__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.
- dbos/_core.py +16 -13
- dbos/_debouncer.py +5 -1
- dbos/_sys_db.py +34 -15
- {dbos-2.0.0.dist-info → dbos-2.1.0a2.dist-info}/METADATA +1 -1
- {dbos-2.0.0.dist-info → dbos-2.1.0a2.dist-info}/RECORD +8 -8
- {dbos-2.0.0.dist-info → dbos-2.1.0a2.dist-info}/WHEEL +0 -0
- {dbos-2.0.0.dist-info → dbos-2.1.0a2.dist-info}/entry_points.txt +0 -0
- {dbos-2.0.0.dist-info → dbos-2.1.0a2.dist-info}/licenses/LICENSE +0 -0
dbos/_core.py
CHANGED
@@ -1278,21 +1278,24 @@ def recv(dbos: "DBOS", topic: Optional[str] = None, timeout_seconds: float = 60)
|
|
1278
1278
|
def set_event(dbos: "DBOS", key: str, value: Any) -> None:
|
1279
1279
|
cur_ctx = get_local_dbos_context()
|
1280
1280
|
if cur_ctx is not None:
|
1281
|
-
|
1282
|
-
|
1283
|
-
|
1284
|
-
|
1285
|
-
|
1286
|
-
|
1287
|
-
|
1288
|
-
|
1289
|
-
|
1290
|
-
|
1291
|
-
|
1281
|
+
if cur_ctx.is_workflow():
|
1282
|
+
# If called from a workflow function, run as a step
|
1283
|
+
attributes: TracedAttributes = {
|
1284
|
+
"name": "set_event",
|
1285
|
+
}
|
1286
|
+
with EnterDBOSStep(attributes):
|
1287
|
+
ctx = assert_current_dbos_context()
|
1288
|
+
dbos._sys_db.set_event_from_workflow(
|
1289
|
+
ctx.workflow_id, ctx.curr_step_function_id, key, value
|
1290
|
+
)
|
1291
|
+
elif cur_ctx.is_step():
|
1292
|
+
dbos._sys_db.set_event_from_step(cur_ctx.workflow_id, key, value)
|
1293
|
+
else:
|
1294
|
+
raise DBOSException(
|
1295
|
+
"set_event() must be called from within a workflow or step"
|
1292
1296
|
)
|
1293
1297
|
else:
|
1294
|
-
|
1295
|
-
raise DBOSException("set_event() must be called from within a workflow")
|
1298
|
+
raise DBOSException("set_event() must be called from within a workflow or step")
|
1296
1299
|
|
1297
1300
|
|
1298
1301
|
def get_event(
|
dbos/_debouncer.py
CHANGED
@@ -86,6 +86,7 @@ def debouncer_workflow(
|
|
86
86
|
dbos = _get_dbos_instance()
|
87
87
|
|
88
88
|
workflow_inputs: WorkflowInputs = {"args": args, "kwargs": kwargs}
|
89
|
+
|
89
90
|
# Every time the debounced workflow is called, a message is sent to this workflow.
|
90
91
|
# It waits until debounce_period_sec have passed since the last message or until
|
91
92
|
# debounce_timeout_sec has elapsed.
|
@@ -95,7 +96,10 @@ def debouncer_workflow(
|
|
95
96
|
if options["debounce_timeout_sec"]
|
96
97
|
else math.inf
|
97
98
|
)
|
98
|
-
|
99
|
+
|
100
|
+
debounce_deadline_epoch_sec = dbos._sys_db.call_function_as_step(
|
101
|
+
get_debounce_deadline_epoch_sec, "get_debounce_deadline_epoch_sec"
|
102
|
+
)
|
99
103
|
debounce_period_sec = initial_debounce_period_sec
|
100
104
|
while time.time() < debounce_deadline_epoch_sec:
|
101
105
|
time_until_deadline = max(debounce_deadline_epoch_sec - time.time(), 0)
|
dbos/_sys_db.py
CHANGED
@@ -1077,24 +1077,23 @@ class SystemDatabase(ABC):
|
|
1077
1077
|
SystemSchema.operation_outputs.c.child_workflow_id,
|
1078
1078
|
).where(SystemSchema.operation_outputs.c.workflow_uuid == workflow_id)
|
1079
1079
|
).fetchall()
|
1080
|
-
|
1081
|
-
|
1080
|
+
steps = []
|
1081
|
+
for row in rows:
|
1082
|
+
_, output, exception = _serialization.safe_deserialize(
|
1083
|
+
workflow_id,
|
1084
|
+
serialized_input=None,
|
1085
|
+
serialized_output=row[2],
|
1086
|
+
serialized_exception=row[3],
|
1087
|
+
)
|
1088
|
+
step = StepInfo(
|
1082
1089
|
function_id=row[0],
|
1083
1090
|
function_name=row[1],
|
1084
|
-
output=
|
1085
|
-
|
1086
|
-
if row[2] is not None
|
1087
|
-
else row[2]
|
1088
|
-
),
|
1089
|
-
error=(
|
1090
|
-
_serialization.deserialize_exception(row[3])
|
1091
|
-
if row[3] is not None
|
1092
|
-
else row[3]
|
1093
|
-
),
|
1091
|
+
output=output,
|
1092
|
+
error=exception,
|
1094
1093
|
child_workflow_id=row[4],
|
1095
1094
|
)
|
1096
|
-
|
1097
|
-
|
1095
|
+
steps.append(step)
|
1096
|
+
return steps
|
1098
1097
|
|
1099
1098
|
def _record_operation_result_txn(
|
1100
1099
|
self, result: OperationResultInternal, conn: sa.Connection
|
@@ -1525,7 +1524,7 @@ class SystemDatabase(ABC):
|
|
1525
1524
|
return duration
|
1526
1525
|
|
1527
1526
|
@db_retry()
|
1528
|
-
def
|
1527
|
+
def set_event_from_workflow(
|
1529
1528
|
self,
|
1530
1529
|
workflow_uuid: str,
|
1531
1530
|
function_id: int,
|
@@ -1567,6 +1566,26 @@ class SystemDatabase(ABC):
|
|
1567
1566
|
}
|
1568
1567
|
self._record_operation_result_txn(output, conn=c)
|
1569
1568
|
|
1569
|
+
def set_event_from_step(
|
1570
|
+
self,
|
1571
|
+
workflow_uuid: str,
|
1572
|
+
key: str,
|
1573
|
+
message: Any,
|
1574
|
+
) -> None:
|
1575
|
+
with self.engine.begin() as c:
|
1576
|
+
c.execute(
|
1577
|
+
self.dialect.insert(SystemSchema.workflow_events)
|
1578
|
+
.values(
|
1579
|
+
workflow_uuid=workflow_uuid,
|
1580
|
+
key=key,
|
1581
|
+
value=_serialization.serialize(message),
|
1582
|
+
)
|
1583
|
+
.on_conflict_do_update(
|
1584
|
+
index_elements=["workflow_uuid", "key"],
|
1585
|
+
set_={"value": _serialization.serialize(message)},
|
1586
|
+
)
|
1587
|
+
)
|
1588
|
+
|
1570
1589
|
def get_all_events(self, workflow_id: str) -> Dict[str, Any]:
|
1571
1590
|
"""
|
1572
1591
|
Get all events currently present for a workflow ID.
|
@@ -1,7 +1,7 @@
|
|
1
|
-
dbos-2.
|
2
|
-
dbos-2.
|
3
|
-
dbos-2.
|
4
|
-
dbos-2.
|
1
|
+
dbos-2.1.0a2.dist-info/METADATA,sha256=cjLi7rpM1wJUcKQxa6jFruCxYOhGVfEmGCogTXEa7HA,14532
|
2
|
+
dbos-2.1.0a2.dist-info/WHEEL,sha256=9P2ygRxDrTJz3gsagc0Z96ukrxjr-LFBGOgv3AuKlCA,90
|
3
|
+
dbos-2.1.0a2.dist-info/entry_points.txt,sha256=_QOQ3tVfEjtjBlr1jS4sHqHya9lI2aIEIWkz8dqYp14,58
|
4
|
+
dbos-2.1.0a2.dist-info/licenses/LICENSE,sha256=VGZit_a5-kdw9WT6fY5jxAWVwGQzgLFyPWrcVVUhVNU,1067
|
5
5
|
dbos/__init__.py,sha256=pT4BuNLDCrIQX27vQG8NlfxX6PZRU7r9miq4thJTszU,982
|
6
6
|
dbos/__main__.py,sha256=G7Exn-MhGrVJVDbgNlpzhfh8WMX_72t3_oJaFT9Lmt8,653
|
7
7
|
dbos/_admin_server.py,sha256=hubQJw5T8zGKCPNS6FQTXy8jQ8GTJxoYQaDTMlICl9k,16267
|
@@ -11,11 +11,11 @@ dbos/_client.py,sha256=ppkO3bJ_qpBzWjYf9BkGfy8yF76e91UuhoLMtbIwXnU,18933
|
|
11
11
|
dbos/_conductor/conductor.py,sha256=3E_hL3c9g9yWqKZkvI6KA0-ZzPMPRo06TOzT1esMiek,24114
|
12
12
|
dbos/_conductor/protocol.py,sha256=q3rgLxINFtWFigdOONc-4gX4vn66UmMlJQD6Kj8LnL4,7420
|
13
13
|
dbos/_context.py,sha256=cJDxVbswTLXKE5MV4Hmg6gpIX3Dd5mBTG-4lmofWP9E,27668
|
14
|
-
dbos/_core.py,sha256=
|
14
|
+
dbos/_core.py,sha256=x0kGmYD2RAPsM6NCOW9b64FKo6xHaQEail8ld2nDWzc,50685
|
15
15
|
dbos/_croniter.py,sha256=XHAyUyibs_59sJQfSNWkP7rqQY6_XrlfuuCxk4jYqek,47559
|
16
16
|
dbos/_dbos.py,sha256=lkOnSZrEPkqURBJatBhnslHO0OKgmrS8rqLowEn5Rr0,58441
|
17
17
|
dbos/_dbos_config.py,sha256=4vgPyy4NiojAOiw3BnjWwiwT1_Ju3ZhXqJQOKDXhsE4,25148
|
18
|
-
dbos/_debouncer.py,sha256=
|
18
|
+
dbos/_debouncer.py,sha256=qNjIVmWqTPp64M2cEbLnpgGmlKVdCaAKysD1BPJgWh4,15297
|
19
19
|
dbos/_debug.py,sha256=0MfgNqutCUhI4PEmmra9x7f3DiFE_0nscfUCHdLimEY,1415
|
20
20
|
dbos/_docker_pg_helper.py,sha256=xySum4hTA8TVMBODoG19u4cXQAB1vCock-jwM2pnmSI,7791
|
21
21
|
dbos/_error.py,sha256=GwO0Ng4d4iB52brY09-Ss6Cz_V28Xc0D0cRCzZ6XmNM,8688
|
@@ -36,7 +36,7 @@ dbos/_schemas/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
36
36
|
dbos/_schemas/application_database.py,sha256=SypAS9l9EsaBHFn9FR8jmnqt01M74d9AF1AMa4m2hhI,1040
|
37
37
|
dbos/_schemas/system_database.py,sha256=aEkjRQDh9xjdke0d9uFx_20-c9UjQtvuLtHZ24aOypA,5497
|
38
38
|
dbos/_serialization.py,sha256=GLgWLtHpvk7nSHyXukVQLE1ASNA3CJBtfF8w6iflBDw,3590
|
39
|
-
dbos/_sys_db.py,sha256=
|
39
|
+
dbos/_sys_db.py,sha256=kvssT1I6-vW6eGKmbDqr4L-HO-2xbwkePO0TwVxRTM8,85203
|
40
40
|
dbos/_sys_db_postgres.py,sha256=GuyGVyZZD_Wl7LjRSkHnOuZ-hOROlO4Xs2UeDhKq10E,6963
|
41
41
|
dbos/_sys_db_sqlite.py,sha256=ifjKdy-Z9vlVIBf5L6XnSaNjiBdvqPE73asVHim4A5Q,6998
|
42
42
|
dbos/_templates/dbos-db-starter/README.md,sha256=GhxhBj42wjTt1fWEtwNriHbJuKb66Vzu89G4pxNHw2g,930
|
@@ -56,4 +56,4 @@ dbos/cli/migration.py,sha256=zJnDPUBnil5XZXFxc01EbZ0Radw_y8wtDGZExgelAxc,3633
|
|
56
56
|
dbos/dbos-config.schema.json,sha256=47wofTZ5jlFynec7bG0L369tAXbRQQ2euBxBXvg4m9c,1730
|
57
57
|
dbos/py.typed,sha256=QfzXT1Ktfk3Rj84akygc7_42z0lRpCq0Ilh8OXI6Zas,44
|
58
58
|
version/__init__.py,sha256=L4sNxecRuqdtSFdpUGX3TtBi9KL3k7YsZVIvv-fv9-A,1678
|
59
|
-
dbos-2.
|
59
|
+
dbos-2.1.0a2.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|