@effect/workflow 0.1.0
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.
- package/Activity/package.json +6 -0
- package/DurableClock/package.json +6 -0
- package/DurableDeferred/package.json +6 -0
- package/LICENSE +21 -0
- package/README.md +133 -0
- package/Workflow/package.json +6 -0
- package/WorkflowEngine/package.json +6 -0
- package/dist/cjs/Activity.js +100 -0
- package/dist/cjs/Activity.js.map +1 -0
- package/dist/cjs/DurableClock.js +49 -0
- package/dist/cjs/DurableClock.js.map +1 -0
- package/dist/cjs/DurableDeferred.js +158 -0
- package/dist/cjs/DurableDeferred.js.map +1 -0
- package/dist/cjs/Workflow.js +198 -0
- package/dist/cjs/Workflow.js.map +1 -0
- package/dist/cjs/WorkflowEngine.js +25 -0
- package/dist/cjs/WorkflowEngine.js.map +1 -0
- package/dist/cjs/index.js +18 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/internal/crypto.js +19 -0
- package/dist/cjs/internal/crypto.js.map +1 -0
- package/dist/dts/Activity.d.ts +70 -0
- package/dist/dts/Activity.d.ts.map +1 -0
- package/dist/dts/DurableClock.d.ts +42 -0
- package/dist/dts/DurableClock.d.ts.map +1 -0
- package/dist/dts/DurableDeferred.d.ts +252 -0
- package/dist/dts/DurableDeferred.d.ts.map +1 -0
- package/dist/dts/Workflow.d.ts +211 -0
- package/dist/dts/Workflow.d.ts.map +1 -0
- package/dist/dts/WorkflowEngine.d.ts +91 -0
- package/dist/dts/WorkflowEngine.d.ts.map +1 -0
- package/dist/dts/index.d.ts +21 -0
- package/dist/dts/index.d.ts.map +1 -0
- package/dist/dts/internal/crypto.d.ts +2 -0
- package/dist/dts/internal/crypto.d.ts.map +1 -0
- package/dist/esm/Activity.js +90 -0
- package/dist/esm/Activity.js.map +1 -0
- package/dist/esm/DurableClock.js +40 -0
- package/dist/esm/DurableClock.js.map +1 -0
- package/dist/esm/DurableDeferred.js +155 -0
- package/dist/esm/DurableDeferred.js.map +1 -0
- package/dist/esm/Workflow.js +183 -0
- package/dist/esm/Workflow.js.map +1 -0
- package/dist/esm/WorkflowEngine.js +15 -0
- package/dist/esm/WorkflowEngine.js.map +1 -0
- package/dist/esm/index.js +21 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/internal/crypto.js +11 -0
- package/dist/esm/internal/crypto.js.map +1 -0
- package/dist/esm/package.json +4 -0
- package/package.json +74 -0
- package/src/Activity.ts +177 -0
- package/src/DurableClock.ts +82 -0
- package/src/DurableDeferred.ts +461 -0
- package/src/Workflow.ts +401 -0
- package/src/WorkflowEngine.ts +122 -0
- package/src/index.ts +24 -0
- package/src/internal/crypto.ts +15 -0
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
import * as Context from "effect/Context";
|
|
5
|
+
import * as Effect from "effect/Effect";
|
|
6
|
+
import * as Effectable from "effect/Effectable";
|
|
7
|
+
import { dual } from "effect/Function";
|
|
8
|
+
import * as Schema from "effect/Schema";
|
|
9
|
+
import { makeHashDigest } from "./internal/crypto.js";
|
|
10
|
+
/**
|
|
11
|
+
* @since 1.0.0
|
|
12
|
+
* @category Symbols
|
|
13
|
+
*/
|
|
14
|
+
export const TypeId = /*#__PURE__*/Symbol.for("@effect/workflow/Activity");
|
|
15
|
+
/**
|
|
16
|
+
* @since 1.0.0
|
|
17
|
+
* @category Constructors
|
|
18
|
+
*/
|
|
19
|
+
export const make = options => {
|
|
20
|
+
const successSchema = options.success ?? Schema.Void;
|
|
21
|
+
const errorSchema = options.error ?? Schema.Never;
|
|
22
|
+
// eslint-disable-next-line prefer-const
|
|
23
|
+
let execute;
|
|
24
|
+
const self = {
|
|
25
|
+
...Effectable.CommitPrototype,
|
|
26
|
+
[TypeId]: TypeId,
|
|
27
|
+
name: options.name,
|
|
28
|
+
successSchema,
|
|
29
|
+
errorSchema,
|
|
30
|
+
exitSchema: Schema.ExitFromSelf({
|
|
31
|
+
success: successSchema,
|
|
32
|
+
failure: errorSchema,
|
|
33
|
+
defect: Schema.Defect
|
|
34
|
+
}),
|
|
35
|
+
executeEncoded: Effect.matchEffect(options.execute, {
|
|
36
|
+
onFailure: error => Effect.flatMap(Effect.orDie(Schema.encode(self.errorSchema)(error)), Effect.fail),
|
|
37
|
+
onSuccess: value => Effect.orDie(Schema.encode(self.successSchema)(value))
|
|
38
|
+
}),
|
|
39
|
+
commit() {
|
|
40
|
+
return execute;
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
execute = makeExecute(self);
|
|
44
|
+
return self;
|
|
45
|
+
};
|
|
46
|
+
/**
|
|
47
|
+
* @since 1.0.0
|
|
48
|
+
* @category Error handling
|
|
49
|
+
*/
|
|
50
|
+
export const retry = /*#__PURE__*/dual(2, (effect, options) => Effect.suspend(() => {
|
|
51
|
+
let attempt = 1;
|
|
52
|
+
return Effect.suspend(() => Effect.provideService(effect, CurrentAttempt, attempt++)).pipe(Effect.retry(options));
|
|
53
|
+
}));
|
|
54
|
+
/**
|
|
55
|
+
* @since 1.0.0
|
|
56
|
+
* @category Attempts
|
|
57
|
+
*/
|
|
58
|
+
export class CurrentAttempt extends /*#__PURE__*/Context.Reference()("@effect/workflow/Activity/CurrentAttempt", {
|
|
59
|
+
defaultValue: () => 0
|
|
60
|
+
}) {}
|
|
61
|
+
/**
|
|
62
|
+
* @since 1.0.0
|
|
63
|
+
* @category Execution ID
|
|
64
|
+
*/
|
|
65
|
+
export const executionIdWithAttempt = /*#__PURE__*/Effect.gen(function* () {
|
|
66
|
+
const instance = yield* InstanceTag;
|
|
67
|
+
const attempt = yield* CurrentAttempt;
|
|
68
|
+
return yield* makeHashDigest(`${instance.executionId}-${attempt}`);
|
|
69
|
+
});
|
|
70
|
+
// -----------------------------------------------------------------------------
|
|
71
|
+
// internal
|
|
72
|
+
// -----------------------------------------------------------------------------
|
|
73
|
+
const EngineTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine");
|
|
74
|
+
const InstanceTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine/WorkflowInstance");
|
|
75
|
+
const makeExecute = /*#__PURE__*/Effect.fnUntraced(function* (activity) {
|
|
76
|
+
const engine = yield* EngineTag;
|
|
77
|
+
const instance = yield* InstanceTag;
|
|
78
|
+
const attempt = yield* CurrentAttempt;
|
|
79
|
+
const result = yield* engine.activityExecute({
|
|
80
|
+
activity,
|
|
81
|
+
attempt
|
|
82
|
+
});
|
|
83
|
+
if (result._tag === "Suspended") {
|
|
84
|
+
instance.suspended = true;
|
|
85
|
+
return yield* Effect.interrupt;
|
|
86
|
+
}
|
|
87
|
+
const exit = yield* Effect.orDie(Schema.decode(activity.exitSchema)(result.exit));
|
|
88
|
+
return yield* exit;
|
|
89
|
+
});
|
|
90
|
+
//# sourceMappingURL=Activity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Activity.js","names":["Context","Effect","Effectable","dual","Schema","makeHashDigest","TypeId","Symbol","for","make","options","successSchema","success","Void","errorSchema","error","Never","execute","self","CommitPrototype","name","exitSchema","ExitFromSelf","failure","defect","Defect","executeEncoded","matchEffect","onFailure","flatMap","orDie","encode","fail","onSuccess","value","commit","makeExecute","retry","effect","suspend","attempt","provideService","CurrentAttempt","pipe","Reference","defaultValue","executionIdWithAttempt","gen","instance","InstanceTag","executionId","EngineTag","GenericTag","fnUntraced","activity","engine","result","activityExecute","_tag","suspended","interrupt","exit","decode"],"sources":["../../src/Activity.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
import * as Context from "effect/Context";
|
|
5
|
+
import * as Duration from "effect/Duration";
|
|
6
|
+
import * as Effect from "effect/Effect";
|
|
7
|
+
import * as DurableDeferred from "./DurableDeferred.js";
|
|
8
|
+
/**
|
|
9
|
+
* @since 1.0.0
|
|
10
|
+
* @category Symbols
|
|
11
|
+
*/
|
|
12
|
+
export const TypeId = /*#__PURE__*/Symbol.for("@effect/workflow/DurableClock");
|
|
13
|
+
/**
|
|
14
|
+
* @since 1.0.0
|
|
15
|
+
* @category Constructors
|
|
16
|
+
*/
|
|
17
|
+
export const make = options => ({
|
|
18
|
+
[TypeId]: TypeId,
|
|
19
|
+
name: options.name,
|
|
20
|
+
duration: Duration.decode(options.duration),
|
|
21
|
+
deferred: DurableDeferred.make(`DurableClock/${options.name}`)
|
|
22
|
+
});
|
|
23
|
+
const EngineTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine");
|
|
24
|
+
const InstanceTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine/WorkflowInstance");
|
|
25
|
+
/**
|
|
26
|
+
* @since 1.0.0
|
|
27
|
+
* @category Sleeping
|
|
28
|
+
*/
|
|
29
|
+
export const sleep = /*#__PURE__*/Effect.fnUntraced(function* (options) {
|
|
30
|
+
const engine = yield* EngineTag;
|
|
31
|
+
const instance = yield* InstanceTag;
|
|
32
|
+
const clock = make(options);
|
|
33
|
+
yield* engine.scheduleClock({
|
|
34
|
+
workflow: instance.workflow,
|
|
35
|
+
executionId: instance.executionId,
|
|
36
|
+
clock
|
|
37
|
+
});
|
|
38
|
+
return yield* DurableDeferred.await(clock.deferred);
|
|
39
|
+
});
|
|
40
|
+
//# sourceMappingURL=DurableClock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DurableClock.js","names":["Context","Duration","Effect","DurableDeferred","TypeId","Symbol","for","make","options","name","duration","decode","deferred","EngineTag","GenericTag","InstanceTag","sleep","fnUntraced","engine","instance","clock","scheduleClock","workflow","executionId","await"],"sources":["../../src/DurableClock.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,OAAO,MAAM,gBAAgB;AACzC,OAAO,KAAKC,QAAQ,MAAM,iBAAiB;AAC3C,OAAO,KAAKC,MAAM,MAAM,eAAe;AAEvC,OAAO,KAAKC,eAAe,MAAM,sBAAsB;AAGvD;;;;AAIA,OAAO,MAAMC,MAAM,gBAAkBC,MAAM,CAACC,GAAG,CAAC,+BAA+B,CAAC;AAmBhF;;;;AAIA,OAAO,MAAMC,IAAI,GAAIC,OAGpB,KAAoB;EACnB,CAACJ,MAAM,GAAGA,MAAM;EAChBK,IAAI,EAAED,OAAO,CAACC,IAAI;EAClBC,QAAQ,EAAET,QAAQ,CAACU,MAAM,CAACH,OAAO,CAACE,QAAQ,CAAC;EAC3CE,QAAQ,EAAET,eAAe,CAACI,IAAI,CAAC,gBAAgBC,OAAO,CAACC,IAAI,EAAE;CAC9D,CAAC;AAEF,MAAMI,SAAS,gBAAGb,OAAO,CAACc,UAAU,CAClC,iCAAqE,CACtE;AAED,MAAMC,WAAW,gBAAGf,OAAO,CAACc,UAAU,CACpC,kDAAwF,CACzF;AAED;;;;AAIA,OAAO,MAAME,KAAK,gBASdd,MAAM,CAACe,UAAU,CAAC,WAAUT,OAG/B;EACC,MAAMU,MAAM,GAAG,OAAOL,SAAS;EAC/B,MAAMM,QAAQ,GAAG,OAAOJ,WAAW;EACnC,MAAMK,KAAK,GAAGb,IAAI,CAACC,OAAO,CAAC;EAC3B,OAAOU,MAAM,CAACG,aAAa,CAAC;IAC1BC,QAAQ,EAAEH,QAAQ,CAACG,QAAQ;IAC3BC,WAAW,EAAEJ,QAAQ,CAACI,WAAW;IACjCH;GACD,CAAC;EACF,OAAO,OAAOjB,eAAe,CAACqB,KAAK,CAACJ,KAAK,CAACR,QAAQ,CAAC;AACrD,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import * as Context from "effect/Context";
|
|
2
|
+
import * as Effect from "effect/Effect";
|
|
3
|
+
import * as Encoding from "effect/Encoding";
|
|
4
|
+
import * as Exit from "effect/Exit";
|
|
5
|
+
import { dual } from "effect/Function";
|
|
6
|
+
import * as Option from "effect/Option";
|
|
7
|
+
import * as Schema from "effect/Schema";
|
|
8
|
+
/**
|
|
9
|
+
* @since 1.0.0
|
|
10
|
+
* @category Symbols
|
|
11
|
+
*/
|
|
12
|
+
export const TypeId = /*#__PURE__*/Symbol.for("@effect/workflow/DurableDeferred");
|
|
13
|
+
/**
|
|
14
|
+
* @since 1.0.0
|
|
15
|
+
* @category Constructors
|
|
16
|
+
*/
|
|
17
|
+
export const make = (name, options) => ({
|
|
18
|
+
[TypeId]: TypeId,
|
|
19
|
+
name,
|
|
20
|
+
successSchema: options?.success ?? Schema.Void,
|
|
21
|
+
errorSchema: options?.error ?? Schema.Never,
|
|
22
|
+
exitSchema: Schema.Exit({
|
|
23
|
+
success: options?.success ?? Schema.Void,
|
|
24
|
+
failure: options?.error ?? Schema.Never,
|
|
25
|
+
defect: Schema.Defect
|
|
26
|
+
})
|
|
27
|
+
});
|
|
28
|
+
const EngineTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine");
|
|
29
|
+
const InstanceTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine/WorkflowInstance");
|
|
30
|
+
const await_ = /*#__PURE__*/Effect.fnUntraced(function* (self) {
|
|
31
|
+
const engine = yield* EngineTag;
|
|
32
|
+
const instance = yield* InstanceTag;
|
|
33
|
+
const oexit = yield* engine.deferredResult(self);
|
|
34
|
+
if (Option.isNone(oexit)) {
|
|
35
|
+
instance.suspended = true;
|
|
36
|
+
return yield* Effect.interrupt;
|
|
37
|
+
}
|
|
38
|
+
return yield* Effect.flatten(Effect.orDie(Schema.decodeUnknown(self.exitSchema)(oexit.value)));
|
|
39
|
+
});
|
|
40
|
+
export {
|
|
41
|
+
/**
|
|
42
|
+
* @since 1.0.0
|
|
43
|
+
* @category Combinators
|
|
44
|
+
*/
|
|
45
|
+
await_ as await };
|
|
46
|
+
/**
|
|
47
|
+
* @since 1.0.0
|
|
48
|
+
* @category Token
|
|
49
|
+
*/
|
|
50
|
+
export const TokenTypeId = /*#__PURE__*/Symbol.for("@effect/workflow/DurableDeferred/Token");
|
|
51
|
+
/**
|
|
52
|
+
* @since 1.0.0
|
|
53
|
+
* @category Token
|
|
54
|
+
*/
|
|
55
|
+
export const Token = /*#__PURE__*/Schema.String.pipe(/*#__PURE__*/Schema.brand(TokenTypeId));
|
|
56
|
+
/**
|
|
57
|
+
* @since 1.0.0
|
|
58
|
+
* @category Token
|
|
59
|
+
*/
|
|
60
|
+
export class TokenParsed extends /*#__PURE__*/Schema.Class("@effect/workflow/DurableDeferred/TokenParsed")({
|
|
61
|
+
workflowName: Schema.String,
|
|
62
|
+
executionId: Schema.String,
|
|
63
|
+
deferredName: Schema.String
|
|
64
|
+
}) {
|
|
65
|
+
/**
|
|
66
|
+
* @since 1.0.0
|
|
67
|
+
*/
|
|
68
|
+
get asToken() {
|
|
69
|
+
return Encoding.encodeBase64Url(JSON.stringify([this.workflowName, this.executionId, this.deferredName]));
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* @since 1.0.0
|
|
73
|
+
*/
|
|
74
|
+
static FromString = /*#__PURE__*/Schema.StringFromBase64Url.pipe(/*#__PURE__*/Schema.compose(/*#__PURE__*/Schema.parseJson(/*#__PURE__*/Schema.Tuple(Schema.String, Schema.String, Schema.String))), /*#__PURE__*/Schema.transform(TokenParsed, {
|
|
75
|
+
decode: ([workflowName, executionId, deferredName]) => new TokenParsed({
|
|
76
|
+
workflowName,
|
|
77
|
+
executionId,
|
|
78
|
+
deferredName
|
|
79
|
+
}),
|
|
80
|
+
encode: parsed => [parsed.workflowName, parsed.executionId, parsed.deferredName]
|
|
81
|
+
}));
|
|
82
|
+
/**
|
|
83
|
+
* @since 1.0.0
|
|
84
|
+
*/
|
|
85
|
+
static fromString = /*#__PURE__*/Schema.decodeSync(TokenParsed.FromString);
|
|
86
|
+
/**
|
|
87
|
+
* @since 1.0.0
|
|
88
|
+
*/
|
|
89
|
+
static encode = /*#__PURE__*/Schema.encodeSync(TokenParsed.FromString);
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* @since 1.0.0
|
|
93
|
+
* @category Token
|
|
94
|
+
*/
|
|
95
|
+
export const token = /*#__PURE__*/Effect.fnUntraced(function* (self) {
|
|
96
|
+
const instance = yield* InstanceTag;
|
|
97
|
+
return tokenFromExecutionId(self, instance);
|
|
98
|
+
});
|
|
99
|
+
/**
|
|
100
|
+
* @since 1.0.0
|
|
101
|
+
* @category Token
|
|
102
|
+
*/
|
|
103
|
+
export const tokenFromExecutionId = /*#__PURE__*/dual(2, (self, options) => new TokenParsed({
|
|
104
|
+
workflowName: options.workflow.name,
|
|
105
|
+
executionId: options.executionId,
|
|
106
|
+
deferredName: self.name
|
|
107
|
+
}).asToken);
|
|
108
|
+
/**
|
|
109
|
+
* @since 1.0.0
|
|
110
|
+
* @category Token
|
|
111
|
+
*/
|
|
112
|
+
export const tokenFromPayload = /*#__PURE__*/dual(2, (self, options) => Effect.map(options.workflow.executionId(options.payload), executionId => tokenFromExecutionId(self, {
|
|
113
|
+
workflow: options.workflow,
|
|
114
|
+
executionId
|
|
115
|
+
})));
|
|
116
|
+
/**
|
|
117
|
+
* @since 1.0.0
|
|
118
|
+
* @category Combinators
|
|
119
|
+
*/
|
|
120
|
+
export const done = /*#__PURE__*/dual(2, /*#__PURE__*/Effect.fnUntraced(function* (self, options) {
|
|
121
|
+
const engine = yield* EngineTag;
|
|
122
|
+
const token = TokenParsed.fromString(options.token);
|
|
123
|
+
const exit = yield* Schema.encode(self.exitSchema)(options.exit);
|
|
124
|
+
yield* engine.deferredDone({
|
|
125
|
+
workflowName: token.workflowName,
|
|
126
|
+
executionId: token.executionId,
|
|
127
|
+
deferred: self,
|
|
128
|
+
exit: exit
|
|
129
|
+
});
|
|
130
|
+
}, Effect.orDie));
|
|
131
|
+
/**
|
|
132
|
+
* @since 1.0.0
|
|
133
|
+
* @category Combinators
|
|
134
|
+
*/
|
|
135
|
+
export const succeed = /*#__PURE__*/dual(2, (self, options) => done(self, {
|
|
136
|
+
token: options.token,
|
|
137
|
+
exit: Exit.succeed(options.value)
|
|
138
|
+
}));
|
|
139
|
+
/**
|
|
140
|
+
* @since 1.0.0
|
|
141
|
+
* @category Combinators
|
|
142
|
+
*/
|
|
143
|
+
export const fail = /*#__PURE__*/dual(2, (self, options) => done(self, {
|
|
144
|
+
token: options.token,
|
|
145
|
+
exit: Exit.fail(options.error)
|
|
146
|
+
}));
|
|
147
|
+
/**
|
|
148
|
+
* @since 1.0.0
|
|
149
|
+
* @category Combinators
|
|
150
|
+
*/
|
|
151
|
+
export const failCause = /*#__PURE__*/dual(2, (self, options) => done(self, {
|
|
152
|
+
token: options.token,
|
|
153
|
+
exit: Exit.failCause(options.cause)
|
|
154
|
+
}));
|
|
155
|
+
//# sourceMappingURL=DurableDeferred.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DurableDeferred.js","names":["Context","Effect","Encoding","Exit","dual","Option","Schema","TypeId","Symbol","for","make","name","options","successSchema","success","Void","errorSchema","error","Never","exitSchema","failure","defect","Defect","EngineTag","GenericTag","InstanceTag","await_","fnUntraced","self","engine","instance","oexit","deferredResult","isNone","suspended","interrupt","flatten","orDie","decodeUnknown","value","await","TokenTypeId","Token","String","pipe","brand","TokenParsed","Class","workflowName","executionId","deferredName","asToken","encodeBase64Url","JSON","stringify","FromString","StringFromBase64Url","compose","parseJson","Tuple","transform","decode","encode","parsed","fromString","decodeSync","encodeSync","token","tokenFromExecutionId","workflow","tokenFromPayload","map","payload","done","exit","deferredDone","deferred","succeed","fail","failCause","cause"],"sources":["../../src/DurableDeferred.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
import * as Context from "effect/Context";
|
|
5
|
+
import * as Data from "effect/Data";
|
|
6
|
+
import * as Effect from "effect/Effect";
|
|
7
|
+
import * as Exit from "effect/Exit";
|
|
8
|
+
import * as Layer from "effect/Layer";
|
|
9
|
+
import * as Predicate from "effect/Predicate";
|
|
10
|
+
import * as PrimaryKey from "effect/PrimaryKey";
|
|
11
|
+
import * as Schedule from "effect/Schedule";
|
|
12
|
+
import * as Schema from "effect/Schema";
|
|
13
|
+
import { makeHashDigest } from "./internal/crypto.js";
|
|
14
|
+
/**
|
|
15
|
+
* @since 1.0.0
|
|
16
|
+
* @category Symbols
|
|
17
|
+
*/
|
|
18
|
+
export const TypeId = /*#__PURE__*/Symbol.for("@effect/workflow/Workflow");
|
|
19
|
+
const EngineTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine");
|
|
20
|
+
const InstanceTag = /*#__PURE__*/Context.GenericTag("@effect/workflow/WorkflowEngine/WorkflowInstance");
|
|
21
|
+
/**
|
|
22
|
+
* @since 1.0.0
|
|
23
|
+
* @category Constructors
|
|
24
|
+
*/
|
|
25
|
+
export const make = options => {
|
|
26
|
+
const suspendedRetrySchedule = options.suspendedRetrySchedule ?? defaultRetrySchedule;
|
|
27
|
+
const makeExecutionId = payload => makeHashDigest(`${options.name}-${options.idempotencyKey(payload)}`);
|
|
28
|
+
const self = {
|
|
29
|
+
[TypeId]: TypeId,
|
|
30
|
+
name: options.name,
|
|
31
|
+
payloadSchema: Schema.isSchema(options.payload) ? options.payload : Schema.Struct(options.payload),
|
|
32
|
+
successSchema: options.success ?? Schema.Void,
|
|
33
|
+
errorSchema: options.error ?? Schema.Never,
|
|
34
|
+
execute: Effect.fnUntraced(function* (fields, opts) {
|
|
35
|
+
const payload = self.payloadSchema.make(fields);
|
|
36
|
+
const engine = yield* EngineTag;
|
|
37
|
+
const executionId = yield* makeExecutionId(payload);
|
|
38
|
+
yield* Effect.annotateCurrentSpan({
|
|
39
|
+
executionId
|
|
40
|
+
});
|
|
41
|
+
if (opts?.discard) {
|
|
42
|
+
return yield* engine.execute({
|
|
43
|
+
workflow: self,
|
|
44
|
+
executionId,
|
|
45
|
+
payload,
|
|
46
|
+
discard: true
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
let sleep;
|
|
50
|
+
while (true) {
|
|
51
|
+
const result = yield* engine.execute({
|
|
52
|
+
workflow: self,
|
|
53
|
+
executionId,
|
|
54
|
+
payload,
|
|
55
|
+
discard: false
|
|
56
|
+
});
|
|
57
|
+
if (result._tag === "Complete") {
|
|
58
|
+
return yield* result.exit;
|
|
59
|
+
}
|
|
60
|
+
// @effect-diagnostics effect/floatingEffect:off
|
|
61
|
+
sleep ??= (yield* Schedule.driver(suspendedRetrySchedule)).next(void 0).pipe(Effect.catchAll(() => Effect.dieMessage(`${options.name}.execute: suspendedRetrySchedule exhausted`)));
|
|
62
|
+
yield* sleep;
|
|
63
|
+
}
|
|
64
|
+
}, Effect.withSpan(`${options.name}.execute`, {
|
|
65
|
+
captureStackTrace: false
|
|
66
|
+
})),
|
|
67
|
+
interrupt: Effect.fnUntraced(function* (executionId) {
|
|
68
|
+
const engine = yield* EngineTag;
|
|
69
|
+
yield* engine.interrupt(self, executionId);
|
|
70
|
+
}, (effect, executionId) => Effect.withSpan(effect, `${options.name}.interrupt`, {
|
|
71
|
+
captureStackTrace: false,
|
|
72
|
+
attributes: {
|
|
73
|
+
executionId
|
|
74
|
+
}
|
|
75
|
+
})),
|
|
76
|
+
toLayer: execute => Layer.effectContext(Effect.gen(function* () {
|
|
77
|
+
const context = yield* Effect.context();
|
|
78
|
+
const engine = Context.get(context, EngineTag);
|
|
79
|
+
yield* engine.register(self, (payload, executionId) => execute(payload, executionId).pipe(Effect.provide(context)));
|
|
80
|
+
return EngineTag.context(engine);
|
|
81
|
+
})),
|
|
82
|
+
executionId: payload => makeExecutionId(self.payloadSchema.make(payload))
|
|
83
|
+
};
|
|
84
|
+
return self;
|
|
85
|
+
};
|
|
86
|
+
const defaultRetrySchedule = /*#__PURE__*/Schedule.exponential(200, 1.5).pipe(/*#__PURE__*/Schedule.union(/*#__PURE__*/Schedule.spaced(30000)));
|
|
87
|
+
/**
|
|
88
|
+
* @since 1.0.0
|
|
89
|
+
* @category Constructors
|
|
90
|
+
*/
|
|
91
|
+
export const fromTaggedRequest = (schema, options) => make({
|
|
92
|
+
name: schema._tag,
|
|
93
|
+
payload: schema,
|
|
94
|
+
success: schema.success,
|
|
95
|
+
error: schema.failure,
|
|
96
|
+
idempotencyKey: PrimaryKey.value,
|
|
97
|
+
suspendedRetrySchedule: options?.suspendedRetrySchedule
|
|
98
|
+
});
|
|
99
|
+
/**
|
|
100
|
+
* @since 1.0.0
|
|
101
|
+
* @category Result
|
|
102
|
+
*/
|
|
103
|
+
export const ResultTypeId = /*#__PURE__*/Symbol.for("@effect/workflow/Workflow/Result");
|
|
104
|
+
/**
|
|
105
|
+
* @since 1.0.0
|
|
106
|
+
* @category Result
|
|
107
|
+
*/
|
|
108
|
+
export const isResult = u => Predicate.hasProperty(u, ResultTypeId);
|
|
109
|
+
/**
|
|
110
|
+
* @since 1.0.0
|
|
111
|
+
* @category Result
|
|
112
|
+
*/
|
|
113
|
+
export class Complete extends /*#__PURE__*/Data.TaggedClass("Complete") {
|
|
114
|
+
/**
|
|
115
|
+
* @since 1.0.0
|
|
116
|
+
*/
|
|
117
|
+
[ResultTypeId] = ResultTypeId;
|
|
118
|
+
/**
|
|
119
|
+
* @since 1.0.0
|
|
120
|
+
*/
|
|
121
|
+
static SchemaFromSelf(_options) {
|
|
122
|
+
return Schema.declare(u => isResult(u) && u._tag === "Complete");
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* @since 1.0.0
|
|
126
|
+
*/
|
|
127
|
+
static SchemaEncoded(options) {
|
|
128
|
+
return Schema.Struct({
|
|
129
|
+
_tag: Schema.tag("Complete"),
|
|
130
|
+
exit: Schema.Exit({
|
|
131
|
+
success: options.success,
|
|
132
|
+
failure: options.error,
|
|
133
|
+
defect: Schema.Defect
|
|
134
|
+
})
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* @since 1.0.0
|
|
139
|
+
*/
|
|
140
|
+
static Schema(options) {
|
|
141
|
+
return Schema.transform(this.SchemaEncoded(options), this.SchemaFromSelf(options), {
|
|
142
|
+
decode(fromA) {
|
|
143
|
+
return new Complete({
|
|
144
|
+
exit: fromA.exit
|
|
145
|
+
});
|
|
146
|
+
},
|
|
147
|
+
encode(toI) {
|
|
148
|
+
return toI;
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* @since 1.0.0
|
|
155
|
+
* @category Result
|
|
156
|
+
*/
|
|
157
|
+
export class Suspended extends /*#__PURE__*/Schema.TaggedClass("@effect/workflow/Workflow/Suspended")("Suspended", {}) {
|
|
158
|
+
/**
|
|
159
|
+
* @since 1.0.0
|
|
160
|
+
*/
|
|
161
|
+
[ResultTypeId] = ResultTypeId;
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* @since 1.0.0
|
|
165
|
+
* @category Result
|
|
166
|
+
*/
|
|
167
|
+
export const Result = options => Schema.Union(Complete.Schema(options), Suspended);
|
|
168
|
+
/**
|
|
169
|
+
* @since 1.0.0
|
|
170
|
+
* @category Result
|
|
171
|
+
*/
|
|
172
|
+
export const intoResult = effect => Effect.uninterruptibleMask(restore => Effect.withFiberRuntime(fiber => Effect.matchCause(restore(effect), {
|
|
173
|
+
onSuccess: value => new Complete({
|
|
174
|
+
exit: Exit.succeed(value)
|
|
175
|
+
}),
|
|
176
|
+
onFailure(cause) {
|
|
177
|
+
const instance = Context.unsafeGet(fiber.currentContext, InstanceTag);
|
|
178
|
+
return instance.suspended ? new Suspended() : new Complete({
|
|
179
|
+
exit: Exit.failCause(cause)
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
})));
|
|
183
|
+
//# sourceMappingURL=Workflow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Workflow.js","names":["Context","Data","Effect","Exit","Layer","Predicate","PrimaryKey","Schedule","Schema","makeHashDigest","TypeId","Symbol","for","EngineTag","GenericTag","InstanceTag","make","options","suspendedRetrySchedule","defaultRetrySchedule","makeExecutionId","payload","name","idempotencyKey","self","payloadSchema","isSchema","Struct","successSchema","success","Void","errorSchema","error","Never","execute","fnUntraced","fields","opts","engine","executionId","annotateCurrentSpan","discard","workflow","sleep","result","_tag","exit","driver","next","pipe","catchAll","dieMessage","withSpan","captureStackTrace","interrupt","effect","attributes","toLayer","effectContext","gen","context","get","register","provide","exponential","union","spaced","fromTaggedRequest","schema","failure","value","ResultTypeId","isResult","u","hasProperty","Complete","TaggedClass","SchemaFromSelf","_options","declare","SchemaEncoded","tag","defect","Defect","transform","decode","fromA","encode","toI","Suspended","Result","Union","intoResult","uninterruptibleMask","restore","withFiberRuntime","fiber","matchCause","onSuccess","succeed","onFailure","cause","instance","unsafeGet","currentContext","suspended","failCause"],"sources":["../../src/Workflow.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
import * as Context from "effect/Context";
|
|
5
|
+
/**
|
|
6
|
+
* @since 1.0.0
|
|
7
|
+
* @category Services
|
|
8
|
+
*/
|
|
9
|
+
export class WorkflowEngine extends /*#__PURE__*/Context.Tag("@effect/workflow/WorkflowEngine")() {}
|
|
10
|
+
/**
|
|
11
|
+
* @since 1.0.0
|
|
12
|
+
* @category Services
|
|
13
|
+
*/
|
|
14
|
+
export class WorkflowInstance extends /*#__PURE__*/Context.Tag("@effect/workflow/WorkflowEngine/WorkflowInstance")() {}
|
|
15
|
+
//# sourceMappingURL=WorkflowEngine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkflowEngine.js","names":["Context","WorkflowEngine","Tag","WorkflowInstance"],"sources":["../../src/WorkflowEngine.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,OAAO,MAAM,gBAAgB;AASzC;;;;AAIA,OAAM,MAAOC,cAAe,sBAAQD,OAAO,CAACE,GAAG,CAAC,iCAAiC,CAAC,EAiF/E;AAEH;;;;AAIA,OAAM,MAAOC,gBAAiB,sBAAQH,OAAO,CAACE,GAAG,CAAC,kDAAkD,CAAC,EAkBlG","ignoreList":[]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 1.0.0
|
|
3
|
+
*/
|
|
4
|
+
export * as Activity from "./Activity.js";
|
|
5
|
+
/**
|
|
6
|
+
* @since 1.0.0
|
|
7
|
+
*/
|
|
8
|
+
export * as DurableClock from "./DurableClock.js";
|
|
9
|
+
/**
|
|
10
|
+
* @since 1.0.0
|
|
11
|
+
*/
|
|
12
|
+
export * as DurableDeferred from "./DurableDeferred.js";
|
|
13
|
+
/**
|
|
14
|
+
* @since 1.0.0
|
|
15
|
+
*/
|
|
16
|
+
export * as Workflow from "./Workflow.js";
|
|
17
|
+
/**
|
|
18
|
+
* @since 1.0.0
|
|
19
|
+
*/
|
|
20
|
+
export * as WorkflowEngine from "./WorkflowEngine.js";
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":["Activity","DurableClock","DurableDeferred","Workflow","WorkflowEngine"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,QAAQ,MAAM,eAAe;AAEzC;;;AAGA,OAAO,KAAKC,YAAY,MAAM,mBAAmB;AAEjD;;;AAGA,OAAO,KAAKC,eAAe,MAAM,sBAAsB;AAEvD;;;AAGA,OAAO,KAAKC,QAAQ,MAAM,eAAe;AAEzC;;;AAGA,OAAO,KAAKC,cAAc,MAAM,qBAAqB","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as Effect from "effect/Effect";
|
|
2
|
+
/** @internal */
|
|
3
|
+
export const makeHashDigest = original => Effect.map(Effect.promise(() => crypto.subtle.digest("SHA-256", new TextEncoder().encode(original))), buffer => {
|
|
4
|
+
const data = new Uint8Array(buffer);
|
|
5
|
+
let hexString = "";
|
|
6
|
+
for (let i = 0; i < 16; i++) {
|
|
7
|
+
hexString += data[i].toString(16).padStart(2, "0");
|
|
8
|
+
}
|
|
9
|
+
return hexString;
|
|
10
|
+
});
|
|
11
|
+
//# sourceMappingURL=crypto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crypto.js","names":["Effect","makeHashDigest","original","map","promise","crypto","subtle","digest","TextEncoder","encode","buffer","data","Uint8Array","hexString","i","toString","padStart"],"sources":["../../../src/internal/crypto.ts"],"sourcesContent":[null],"mappings":"AAAA,OAAO,KAAKA,MAAM,MAAM,eAAe;AAEvC;AACA,OAAO,MAAMC,cAAc,GAAIC,QAAgB,IAC7CF,MAAM,CAACG,GAAG,CACRH,MAAM,CAACI,OAAO,CAAC,MAAMC,MAAM,CAACC,MAAM,CAACC,MAAM,CAAC,SAAS,EAAE,IAAIC,WAAW,EAAE,CAACC,MAAM,CAACP,QAAQ,CAAC,CAAC,CAAC,EACxFQ,MAAM,IAAI;EACT,MAAMC,IAAI,GAAG,IAAIC,UAAU,CAACF,MAAM,CAAC;EACnC,IAAIG,SAAS,GAAG,EAAE;EAClB,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG,EAAE,EAAEA,CAAC,EAAE,EAAE;IAC3BD,SAAS,IAAIF,IAAI,CAACG,CAAC,CAAC,CAACC,QAAQ,CAAC,EAAE,CAAC,CAACC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;EACpD;EACA,OAAOH,SAAS;AAClB,CAAC,CACF","ignoreList":[]}
|
package/package.json
ADDED
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@effect/workflow",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Durable workflows for Effect",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"repository": {
|
|
7
|
+
"type": "git",
|
|
8
|
+
"url": "https://github.com/Effect-TS/effect.git",
|
|
9
|
+
"directory": "packages/workflow"
|
|
10
|
+
},
|
|
11
|
+
"sideEffects": [],
|
|
12
|
+
"homepage": "https://effect.website",
|
|
13
|
+
"peerDependencies": {
|
|
14
|
+
"effect": "^3.16.3"
|
|
15
|
+
},
|
|
16
|
+
"publishConfig": {
|
|
17
|
+
"provenance": true
|
|
18
|
+
},
|
|
19
|
+
"main": "./dist/cjs/index.js",
|
|
20
|
+
"module": "./dist/esm/index.js",
|
|
21
|
+
"types": "./dist/dts/index.d.ts",
|
|
22
|
+
"exports": {
|
|
23
|
+
"./package.json": "./package.json",
|
|
24
|
+
".": {
|
|
25
|
+
"types": "./dist/dts/index.d.ts",
|
|
26
|
+
"import": "./dist/esm/index.js",
|
|
27
|
+
"default": "./dist/cjs/index.js"
|
|
28
|
+
},
|
|
29
|
+
"./Activity": {
|
|
30
|
+
"types": "./dist/dts/Activity.d.ts",
|
|
31
|
+
"import": "./dist/esm/Activity.js",
|
|
32
|
+
"default": "./dist/cjs/Activity.js"
|
|
33
|
+
},
|
|
34
|
+
"./DurableClock": {
|
|
35
|
+
"types": "./dist/dts/DurableClock.d.ts",
|
|
36
|
+
"import": "./dist/esm/DurableClock.js",
|
|
37
|
+
"default": "./dist/cjs/DurableClock.js"
|
|
38
|
+
},
|
|
39
|
+
"./DurableDeferred": {
|
|
40
|
+
"types": "./dist/dts/DurableDeferred.d.ts",
|
|
41
|
+
"import": "./dist/esm/DurableDeferred.js",
|
|
42
|
+
"default": "./dist/cjs/DurableDeferred.js"
|
|
43
|
+
},
|
|
44
|
+
"./Workflow": {
|
|
45
|
+
"types": "./dist/dts/Workflow.d.ts",
|
|
46
|
+
"import": "./dist/esm/Workflow.js",
|
|
47
|
+
"default": "./dist/cjs/Workflow.js"
|
|
48
|
+
},
|
|
49
|
+
"./WorkflowEngine": {
|
|
50
|
+
"types": "./dist/dts/WorkflowEngine.d.ts",
|
|
51
|
+
"import": "./dist/esm/WorkflowEngine.js",
|
|
52
|
+
"default": "./dist/cjs/WorkflowEngine.js"
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
"typesVersions": {
|
|
56
|
+
"*": {
|
|
57
|
+
"Activity": [
|
|
58
|
+
"./dist/dts/Activity.d.ts"
|
|
59
|
+
],
|
|
60
|
+
"DurableClock": [
|
|
61
|
+
"./dist/dts/DurableClock.d.ts"
|
|
62
|
+
],
|
|
63
|
+
"DurableDeferred": [
|
|
64
|
+
"./dist/dts/DurableDeferred.d.ts"
|
|
65
|
+
],
|
|
66
|
+
"Workflow": [
|
|
67
|
+
"./dist/dts/Workflow.d.ts"
|
|
68
|
+
],
|
|
69
|
+
"WorkflowEngine": [
|
|
70
|
+
"./dist/dts/WorkflowEngine.d.ts"
|
|
71
|
+
]
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|