@t4h.framework/cli 0.4.0 → 0.4.2
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/dist/bin/bin.d.ts +2 -0
- package/dist/bin/bin.js +2 -0
- package/dist/bin/bin.js.map +1 -1
- package/dist/commands/build/build.d.ts +6 -0
- package/dist/commands/build/build.js +1 -5
- package/dist/commands/build/build.js.map +1 -1
- package/dist/commands/dev/dev.d.ts +7 -0
- package/dist/commands/dev/dev.js +7 -14
- package/dist/commands/dev/dev.js.map +1 -1
- package/dist/commands/dev-server-up-app-process.d.ts +2 -0
- package/dist/commands/dev-server-up-app-process.js +9 -63
- package/dist/commands/dev-server-up-app-process.js.map +1 -1
- package/dist/commands/publish/publish.d.ts +11 -0
- package/dist/commands/skills/prompts/get-destination-root-path.js +34 -0
- package/dist/commands/skills/prompts/get-destination-root-path.js.map +1 -0
- package/dist/commands/skills/skills.js +90 -0
- package/dist/commands/skills/skills.js.map +1 -0
- package/dist/commands/skills/target-options.js +33 -0
- package/dist/commands/skills/target-options.js.map +1 -0
- package/dist/commands/skills/tools/copy.js +6 -0
- package/dist/commands/skills/tools/copy.js.map +1 -0
- package/dist/commands/skills/tools/create-directory-snapshot.js +29 -0
- package/dist/commands/skills/tools/create-directory-snapshot.js.map +1 -0
- package/dist/commands/skills/tools/discover-packages.js +16 -0
- package/dist/commands/skills/tools/discover-packages.js.map +1 -0
- package/dist/commands/skills/tools/find-nearest-package-json-path.js +18 -0
- package/dist/commands/skills/tools/find-nearest-package-json-path.js.map +1 -0
- package/dist/commands/skills/tools/get-package-path.js +18 -0
- package/dist/commands/skills/tools/get-package-path.js.map +1 -0
- package/dist/commands/skills/tools/get-skill-sources.js +44 -0
- package/dist/commands/skills/tools/get-skill-sources.js.map +1 -0
- package/dist/commands/skills/tools/is-directory-equal.js +14 -0
- package/dist/commands/skills/tools/is-directory-equal.js.map +1 -0
- package/dist/commands/skills/tools/is-directory.js +8 -0
- package/dist/commands/skills/tools/is-directory.js.map +1 -0
- package/dist/commands/skills/tools/path-exists.js +8 -0
- package/dist/commands/skills/tools/path-exists.js.map +1 -0
- package/dist/dev-runtime/__tests__/fixtures.d.ts +57 -0
- package/dist/dev-runtime/__tests__/fixtures.js +31 -0
- package/dist/dev-runtime/__tests__/fixtures.js.map +1 -0
- package/dist/dev-runtime/bootstrap.js +51 -0
- package/dist/dev-runtime/bootstrap.js.map +1 -0
- package/dist/dev-runtime/claims.d.ts +24 -0
- package/dist/dev-runtime/claims.js +62 -0
- package/dist/dev-runtime/claims.js.map +1 -0
- package/dist/dev-runtime/models/DevServerCacheClaim.d.ts +6 -0
- package/dist/dev-runtime/models/DevServerCacheClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerFileBinary.d.ts +15 -0
- package/dist/dev-runtime/models/DevServerFileBinary.js.map +1 -0
- package/dist/dev-runtime/models/DevServerFileSystemClaim.d.ts +7 -0
- package/dist/dev-runtime/models/DevServerFileSystemClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerGetActivityUniqueIdentifierClaim.d.ts +7 -0
- package/dist/dev-runtime/models/DevServerGetActivityUniqueIdentifierClaim.js +31 -0
- package/dist/dev-runtime/models/DevServerGetActivityUniqueIdentifierClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerGetProjectUniqueIdentifierClaim.d.ts +6 -0
- package/dist/dev-runtime/models/DevServerGetProjectUniqueIdentifierClaim.js +13 -0
- package/dist/dev-runtime/models/DevServerGetProjectUniqueIdentifierClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerGetProjectVersionUniqueIdentifierClaim.d.ts +6 -0
- package/dist/dev-runtime/models/DevServerGetProjectVersionUniqueIdentifierClaim.js +13 -0
- package/dist/dev-runtime/models/DevServerGetProjectVersionUniqueIdentifierClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerGetProjectVersionWorkflowUniqueIdentifierClaim.d.ts +7 -0
- package/dist/dev-runtime/models/DevServerGetProjectVersionWorkflowUniqueIdentifierClaim.js +31 -0
- package/dist/dev-runtime/models/DevServerGetProjectVersionWorkflowUniqueIdentifierClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerGetWorkflowUniqueIdentifierClaim.d.ts +7 -0
- package/dist/dev-runtime/models/DevServerGetWorkflowUniqueIdentifierClaim.js +31 -0
- package/dist/dev-runtime/models/DevServerGetWorkflowUniqueIdentifierClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerHttpClientRequestClaim.d.ts +5 -0
- package/dist/dev-runtime/models/DevServerHttpClientRequestClaim.js +39 -0
- package/dist/dev-runtime/models/DevServerHttpClientRequestClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerORMClaim.d.ts +8 -0
- package/dist/{models → dev-runtime/models}/DevServerORMClaim.js +2 -2
- package/dist/dev-runtime/models/DevServerORMClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerSmtpSendEmailClaim.d.ts +6 -0
- package/dist/dev-runtime/models/DevServerSmtpSendEmailClaim.js.map +1 -0
- package/dist/dev-runtime/models/DevServerWorkflowClaim.d.ts +7 -0
- package/dist/dev-runtime/models/DevServerWorkflowClaim.js +38 -0
- package/dist/dev-runtime/models/DevServerWorkflowClaim.js.map +1 -0
- package/dist/dev-runtime/models/WorkflowRun.d.ts +18 -0
- package/dist/dev-runtime/models/WorkflowRun.js +19 -0
- package/dist/dev-runtime/models/WorkflowRun.js.map +1 -0
- package/dist/dev-runtime/models/WorkflowRunActivity.d.ts +40 -0
- package/dist/dev-runtime/models/WorkflowRunActivity.js +52 -0
- package/dist/dev-runtime/models/WorkflowRunActivity.js.map +1 -0
- package/dist/dev-runtime/repositories/WorkflowRun.repository.d.ts +8 -0
- package/dist/dev-runtime/repositories/WorkflowRun.repository.js +27 -0
- package/dist/dev-runtime/repositories/WorkflowRun.repository.js.map +1 -0
- package/dist/dev-runtime/repositories/WorkflowRunActivity.repository.d.ts +8 -0
- package/dist/dev-runtime/repositories/WorkflowRunActivity.repository.js +36 -0
- package/dist/dev-runtime/repositories/WorkflowRunActivity.repository.js.map +1 -0
- package/dist/dev-runtime/services/BuildWorkflowRunResult.service.d.ts +8 -0
- package/dist/dev-runtime/services/BuildWorkflowRunResult.service.js +49 -0
- package/dist/dev-runtime/services/BuildWorkflowRunResult.service.js.map +1 -0
- package/dist/dev-runtime/services/RuntimeContext.service.d.ts +10 -0
- package/dist/dev-runtime/services/RuntimeContext.service.js +22 -0
- package/dist/dev-runtime/services/RuntimeContext.service.js.map +1 -0
- package/dist/dev-runtime/services/TimeoutScheduler.service.d.ts +5 -0
- package/dist/dev-runtime/services/TimeoutScheduler.service.js +33 -0
- package/dist/dev-runtime/services/TimeoutScheduler.service.js.map +1 -0
- package/dist/dev-runtime/services/WorkflowRunAsyncActivityFacade.service.d.ts +20 -0
- package/dist/dev-runtime/services/WorkflowRunAsyncActivityFacade.service.js +54 -0
- package/dist/dev-runtime/services/WorkflowRunAsyncActivityFacade.service.js.map +1 -0
- package/dist/dev-runtime/services/WorkflowRunFacade.service.d.ts +13 -0
- package/dist/dev-runtime/services/WorkflowRunFacade.service.js +40 -0
- package/dist/dev-runtime/services/WorkflowRunFacade.service.js.map +1 -0
- package/dist/dev-runtime/services/WorkflowRunSyncActivityFacade.service.d.ts +7 -0
- package/dist/dev-runtime/services/WorkflowRunSyncActivityFacade.service.js +26 -0
- package/dist/dev-runtime/services/WorkflowRunSyncActivityFacade.service.js.map +1 -0
- package/dist/dev-runtime/tools/find-claim-by-constructor.d.ts +1 -0
- package/dist/dev-runtime/tools/find-claim-by-constructor.js +5 -0
- package/dist/dev-runtime/tools/find-claim-by-constructor.js.map +1 -0
- package/dist/dev-runtime/transport/DevServerJsonRpc.d.ts +2 -0
- package/dist/dev-runtime/transport/DevServerJsonRpc.js +42 -0
- package/dist/dev-runtime/transport/DevServerJsonRpc.js.map +1 -0
- package/dist/dev-runtime/use-cases/CallbackWorkflowRunAsyncActivity.usecase.d.ts +14 -0
- package/dist/dev-runtime/use-cases/CallbackWorkflowRunAsyncActivity.usecase.js +64 -0
- package/dist/dev-runtime/use-cases/CallbackWorkflowRunAsyncActivity.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/CreateWorkflowRun.usecase.d.ts +14 -0
- package/dist/dev-runtime/use-cases/CreateWorkflowRun.usecase.js +43 -0
- package/dist/dev-runtime/use-cases/CreateWorkflowRun.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/CreateWorkflowRunAsyncActivity.usecase.d.ts +9 -0
- package/dist/dev-runtime/use-cases/CreateWorkflowRunAsyncActivity.usecase.js +68 -0
- package/dist/dev-runtime/use-cases/CreateWorkflowRunAsyncActivity.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/NextTickWorkflowRun.usecase.d.ts +20 -0
- package/dist/dev-runtime/use-cases/NextTickWorkflowRun.usecase.js +150 -0
- package/dist/dev-runtime/use-cases/NextTickWorkflowRun.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/TimeoutWorkflowRunAsyncActivity.usecase.d.ts +8 -0
- package/dist/dev-runtime/use-cases/TimeoutWorkflowRunAsyncActivity.usecase.js +38 -0
- package/dist/dev-runtime/use-cases/TimeoutWorkflowRunAsyncActivity.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/WorkflowRunAsyncActivity.usecase.d.ts +7 -0
- package/dist/dev-runtime/use-cases/WorkflowRunAsyncActivity.usecase.js +44 -0
- package/dist/dev-runtime/use-cases/WorkflowRunAsyncActivity.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/WorkflowRunAsyncActivityAdvance.usecase.d.ts +10 -0
- package/dist/dev-runtime/use-cases/WorkflowRunAsyncActivityAdvance.usecase.js +57 -0
- package/dist/dev-runtime/use-cases/WorkflowRunAsyncActivityAdvance.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/WorkflowRunBuildHistory.usecase.d.ts +8 -0
- package/dist/dev-runtime/use-cases/WorkflowRunBuildHistory.usecase.js +41 -0
- package/dist/dev-runtime/use-cases/WorkflowRunBuildHistory.usecase.js.map +1 -0
- package/dist/dev-runtime/use-cases/WorkflowRunSyncActivity.usecase.d.ts +4 -0
- package/dist/dev-runtime/use-cases/WorkflowRunSyncActivity.usecase.js +26 -0
- package/dist/dev-runtime/use-cases/WorkflowRunSyncActivity.usecase.js.map +1 -0
- package/dist/models/DevServer.d.ts +24 -0
- package/dist/models/DevServer.js +6 -6
- package/dist/models/DevServer.js.map +1 -1
- package/dist/models/InMemoryDatabase.d.ts +20 -0
- package/dist/models/JSONCodec.d.ts +30 -0
- package/dist/models/JSONCodecKindFrameworkSerializableClass.d.ts +8 -0
- package/dist/models/JSONRPCClient.d.ts +11 -0
- package/dist/models/JSONRPCServer.d.ts +63 -0
- package/dist/tools/is-workflow-waiting.d.ts +4 -0
- package/dist/tools/json-codec.d.ts +8 -0
- package/dist/tools/json-codec.js +1 -1
- package/dist/tools/json-codec.js.map +1 -1
- package/dist/tools/json-schema-to-inquirer-question.d.ts +11 -0
- package/dist/tools/mkdir-out-dir-project-from-ts-config-path-and-json-package-path.d.ts +1 -0
- package/dist/tools/resolve-package-json-path.d.ts +1 -0
- package/dist/tools/resolve-tsconfig-path-from-package-json-path.d.ts +1 -0
- package/dist/tools/ts-build-watch.d.ts +12 -0
- package/dist/tools/ts-build.d.ts +6 -0
- package/dist/tools/up-app.d.ts +2 -0
- package/package.json +5 -21
- package/dist/helpers/advance-async-activity.js +0 -48
- package/dist/helpers/advance-async-activity.js.map +0 -1
- package/dist/helpers/repository.js +0 -9
- package/dist/helpers/repository.js.map +0 -1
- package/dist/helpers/workflow-run.js +0 -128
- package/dist/helpers/workflow-run.js.map +0 -1
- package/dist/models/DevServerCacheClaim.js.map +0 -1
- package/dist/models/DevServerFileBinary.js.map +0 -1
- package/dist/models/DevServerFileSystemClaim.js.map +0 -1
- package/dist/models/DevServerHttpClientRequestClaim.js +0 -21
- package/dist/models/DevServerHttpClientRequestClaim.js.map +0 -1
- package/dist/models/DevServerORMClaim.js.map +0 -1
- package/dist/models/DevServerSmtpSendEmailClaim.js.map +0 -1
- package/dist/models/DevServerWorkflowClaim.js +0 -24
- package/dist/models/DevServerWorkflowClaim.js.map +0 -1
- /package/dist/{models → dev-runtime/models}/DevServerCacheClaim.js +0 -0
- /package/dist/{models → dev-runtime/models}/DevServerFileBinary.js +0 -0
- /package/dist/{models → dev-runtime/models}/DevServerFileSystemClaim.js +0 -0
- /package/dist/{models → dev-runtime/models}/DevServerSmtpSendEmailClaim.js +0 -0
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
8
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
9
|
+
};
|
|
10
|
+
import { Inject, Injectable } from 'pleroma';
|
|
11
|
+
import { WorkflowRunSyncActivity } from '../use-cases/WorkflowRunSyncActivity.usecase.js';
|
|
12
|
+
let WorkflowRunSyncActivityFacade = class WorkflowRunSyncActivityFacade {
|
|
13
|
+
workflowRunSyncActivity;
|
|
14
|
+
constructor(workflowRunSyncActivity) {
|
|
15
|
+
this.workflowRunSyncActivity = workflowRunSyncActivity;
|
|
16
|
+
}
|
|
17
|
+
async run(activity, input) {
|
|
18
|
+
return this.workflowRunSyncActivity.run(activity, input);
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
WorkflowRunSyncActivityFacade = __decorate([
|
|
22
|
+
Injectable(),
|
|
23
|
+
__param(0, Inject(() => WorkflowRunSyncActivity))
|
|
24
|
+
], WorkflowRunSyncActivityFacade);
|
|
25
|
+
export { WorkflowRunSyncActivityFacade };
|
|
26
|
+
//# sourceMappingURL=WorkflowRunSyncActivityFacade.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkflowRunSyncActivityFacade.service.js","sourceRoot":"","sources":["../../../src/dev-runtime/services/WorkflowRunSyncActivityFacade.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAG5C,OAAO,EAAE,uBAAuB,EAAE,MAAM,iDAAiD,CAAA;AAGlF,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IAGrB;IAFnB,YAEmB,uBAAgD;QAAhD,4BAAuB,GAAvB,uBAAuB,CAAyB;IAChE,CAAC;IAEG,KAAK,CAAC,GAAG,CAAC,QAA6B,EAAE,KAAc;QAC5D,OAAO,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;IAC1D,CAAC;CACF,CAAA;AATY,6BAA6B;IADzC,UAAU,EAAE;IAGR,WAAA,MAAM,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC,CAAA;GAF7B,6BAA6B,CASzC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function findClaimByConstructor<T>(constructor: new () => T): T;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-claim-by-constructor.js","sourceRoot":"","sources":["../../../src/dev-runtime/tools/find-claim-by-constructor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAErC,MAAM,UAAU,sBAAsB,CAAI,WAAwB;IAChE,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,KAAK,WAAW,CAAE,CAAC,KAAK,CAAA;AACvE,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { container } from 'pleroma';
|
|
2
|
+
import Type from 'typebox';
|
|
3
|
+
import { JSONRPCServerMethod } from '../../models/JSONRPCServer.js';
|
|
4
|
+
import { WorkflowRunActivityRepository } from '../repositories/WorkflowRunActivity.repository.js';
|
|
5
|
+
import { BuildWorkflowRunResultService } from '../services/BuildWorkflowRunResult.service.js';
|
|
6
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
7
|
+
import { WorkflowRunFacade } from '../services/WorkflowRunFacade.service.js';
|
|
8
|
+
export const handlers = new Set();
|
|
9
|
+
handlers.add(() => {
|
|
10
|
+
return new JSONRPCServerMethod('workflow.run', { schema: [Type.String(), Type.Any()] }, async (workflowId, input) => {
|
|
11
|
+
const workflowRun = container.resolve(WorkflowRunFacade);
|
|
12
|
+
const buildWorkflowRunResultService = container.resolve(BuildWorkflowRunResultService);
|
|
13
|
+
const run = workflowRun.create(workflowId, input);
|
|
14
|
+
await workflowRun.nextTick(run.id);
|
|
15
|
+
return buildWorkflowRunResultService.build(run);
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
handlers.add(() => {
|
|
19
|
+
return new JSONRPCServerMethod('workflow.async-activities.advance', { schema: [Type.String(), Type.Any()] }, async (id, payload) => container.resolve(WorkflowRunAsyncActivityFacade).advance(id, payload));
|
|
20
|
+
});
|
|
21
|
+
handlers.add(() => {
|
|
22
|
+
return new JSONRPCServerMethod('workflow.async-activities.waiting.list', { schema: [] }, () => {
|
|
23
|
+
const pendingActivities = container
|
|
24
|
+
.resolve(WorkflowRunActivityRepository)
|
|
25
|
+
.findBy(activity => activity.asyncActivity?.status === 'pending');
|
|
26
|
+
return pendingActivities.map(pending => {
|
|
27
|
+
const run = pending.run;
|
|
28
|
+
return {
|
|
29
|
+
id: pending.id,
|
|
30
|
+
workflowId: run.workflow,
|
|
31
|
+
schema: pending.asyncActivity?.lastPendingAsyncActivity?.schema,
|
|
32
|
+
};
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
handlers.add(env => {
|
|
37
|
+
return new JSONRPCServerMethod('env.set', { schema: [Type.String(), Type.String()] }, (name, value) => env.set(name, value));
|
|
38
|
+
});
|
|
39
|
+
handlers.add(env => {
|
|
40
|
+
return new JSONRPCServerMethod('env.list', () => Object.fromEntries(env));
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=DevServerJsonRpc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DevServerJsonRpc.js","sourceRoot":"","sources":["../../../src/dev-runtime/transport/DevServerJsonRpc.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { type AsyncActivityResult } from '@t4h.framework/core';
|
|
2
|
+
import { WorkflowRunAsyncActivityPending } from '../models/WorkflowRunActivity.js';
|
|
3
|
+
import type { WorkflowRunActivity } from '../models/WorkflowRunActivity.js';
|
|
4
|
+
import { TimeoutSchedulerService } from '../services/TimeoutScheduler.service.js';
|
|
5
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
6
|
+
import { WorkflowRunFacade } from '../services/WorkflowRunFacade.service.js';
|
|
7
|
+
export declare class CallbackWorkflowRunAsyncActivity {
|
|
8
|
+
private readonly timeoutScheduler;
|
|
9
|
+
private readonly workflowRunAsyncActivity;
|
|
10
|
+
private readonly workflowRun;
|
|
11
|
+
constructor(timeoutScheduler: TimeoutSchedulerService, workflowRunAsyncActivity: WorkflowRunAsyncActivityFacade, workflowRun: WorkflowRunFacade);
|
|
12
|
+
callback(pending: WorkflowRunAsyncActivityPending, activity: WorkflowRunActivity, result: AsyncActivityResult<any, any, any>): Promise<void>;
|
|
13
|
+
private chainNextPending;
|
|
14
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
8
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
9
|
+
};
|
|
10
|
+
import { AsyncActivityResultFulfilled, AsyncActivityResultPending, AsyncActivityResultRejected, } from '@t4h.framework/core';
|
|
11
|
+
import { Inject, Injectable } from 'pleroma';
|
|
12
|
+
import { WorkflowRunAsyncActivityPending } from '../models/WorkflowRunActivity.js';
|
|
13
|
+
import { TimeoutSchedulerService } from '../services/TimeoutScheduler.service.js';
|
|
14
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
15
|
+
import { WorkflowRunFacade } from '../services/WorkflowRunFacade.service.js';
|
|
16
|
+
let CallbackWorkflowRunAsyncActivity = class CallbackWorkflowRunAsyncActivity {
|
|
17
|
+
timeoutScheduler;
|
|
18
|
+
workflowRunAsyncActivity;
|
|
19
|
+
workflowRun;
|
|
20
|
+
constructor(timeoutScheduler, workflowRunAsyncActivity, workflowRun) {
|
|
21
|
+
this.timeoutScheduler = timeoutScheduler;
|
|
22
|
+
this.workflowRunAsyncActivity = workflowRunAsyncActivity;
|
|
23
|
+
this.workflowRun = workflowRun;
|
|
24
|
+
}
|
|
25
|
+
async callback(pending, activity, result) {
|
|
26
|
+
this.timeoutScheduler.cancel(pending.id);
|
|
27
|
+
if (result instanceof AsyncActivityResultPending)
|
|
28
|
+
return this.chainNextPending(pending, result);
|
|
29
|
+
const isFulfilled = result instanceof AsyncActivityResultFulfilled;
|
|
30
|
+
const isRejected = result instanceof AsyncActivityResultRejected;
|
|
31
|
+
if (!isFulfilled && !isRejected)
|
|
32
|
+
throw new Error('Unexpected async activity advance result', {
|
|
33
|
+
cause: result,
|
|
34
|
+
});
|
|
35
|
+
pending.status = isFulfilled ? 'fulfilled' : 'rejected';
|
|
36
|
+
if (activity.asyncActivity)
|
|
37
|
+
activity.asyncActivity.status = pending.status;
|
|
38
|
+
if (result.payload !== undefined)
|
|
39
|
+
activity.output = result.payload;
|
|
40
|
+
await this.workflowRun.nextTick(activity.run.id);
|
|
41
|
+
}
|
|
42
|
+
chainNextPending(previous, result) {
|
|
43
|
+
previous.status = 'fulfilled';
|
|
44
|
+
const asyncActivity = previous.asyncActivity;
|
|
45
|
+
const pending = new WorkflowRunAsyncActivityPending(asyncActivity, {
|
|
46
|
+
previous,
|
|
47
|
+
status: 'pending',
|
|
48
|
+
schema: result.schema,
|
|
49
|
+
timeoutAt: result.timeoutAt,
|
|
50
|
+
bootstrap: result,
|
|
51
|
+
});
|
|
52
|
+
asyncActivity.pendingAsyncActivities.push(pending);
|
|
53
|
+
if (result.timeoutAt)
|
|
54
|
+
this.timeoutScheduler.schedule(pending.id, result.timeoutAt, () => this.workflowRunAsyncActivity.timeout(previous.asyncActivity, pending));
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
CallbackWorkflowRunAsyncActivity = __decorate([
|
|
58
|
+
Injectable(),
|
|
59
|
+
__param(0, Inject(() => TimeoutSchedulerService)),
|
|
60
|
+
__param(1, Inject(() => WorkflowRunAsyncActivityFacade)),
|
|
61
|
+
__param(2, Inject(() => WorkflowRunFacade))
|
|
62
|
+
], CallbackWorkflowRunAsyncActivity);
|
|
63
|
+
export { CallbackWorkflowRunAsyncActivity };
|
|
64
|
+
//# sourceMappingURL=CallbackWorkflowRunAsyncActivity.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CallbackWorkflowRunAsyncActivity.usecase.js","sourceRoot":"","sources":["../../../src/dev-runtime/use-cases/CallbackWorkflowRunAsyncActivity.usecase.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EACL,4BAA4B,EAC5B,0BAA0B,EAC1B,2BAA2B,GAE5B,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAE5C,OAAO,EAAE,+BAA+B,EAAE,MAAM,kCAAkC,CAAA;AAElF,OAAO,EAAE,uBAAuB,EAAE,MAAM,yCAAyC,CAAA;AACjF,OAAO,EAAE,8BAA8B,EAAE,MAAM,uDAAuD,CAAA;AACtG,OAAO,EAAE,iBAAiB,EAAE,MAAM,0CAA0C,CAAA;AAGrE,IAAM,gCAAgC,GAAtC,MAAM,gCAAgC;IAGxB;IAGA;IAGA;IARnB,YAEmB,gBAAyC,EAGzC,wBAAwD,EAGxD,WAA8B;QAN9B,qBAAgB,GAAhB,gBAAgB,CAAyB;QAGzC,6BAAwB,GAAxB,wBAAwB,CAAgC;QAGxD,gBAAW,GAAX,WAAW,CAAmB;IAC9C,CAAC;IAEG,KAAK,CAAC,QAAQ,CACnB,OAAwC,EACxC,QAA6B,EAC7B,MAA0C;QAE1C,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;QAExC,IAAI,MAAM,YAAY,0BAA0B;YAC9C,OAAO,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;QAE/C,MAAM,WAAW,GAAG,MAAM,YAAY,4BAA4B,CAAA;QAClE,MAAM,UAAU,GAAG,MAAM,YAAY,2BAA2B,CAAA;QAEhE,IAAI,CAAC,WAAW,IAAI,CAAC,UAAU;YAC7B,MAAM,IAAI,KAAK,CAAC,0CAA0C,EAAE;gBAC1D,KAAK,EAAE,MAAM;aACd,CAAC,CAAA;QAEJ,OAAO,CAAC,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAA;QAEvD,IAAI,QAAQ,CAAC,aAAa;YAAE,QAAQ,CAAC,aAAa,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAA;QAE1E,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS;YAAE,QAAQ,CAAC,MAAM,GAAG,MAAM,CAAC,OAAO,CAAA;QAElE,MAAM,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAClD,CAAC;IAEO,gBAAgB,CACtB,QAAyC,EACzC,MAAkC;QAElC,QAAQ,CAAC,MAAM,GAAG,WAAW,CAAA;QAE7B,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAA;QAE5C,MAAM,OAAO,GAAG,IAAI,+BAA+B,CAAC,aAAa,EAAE;YACjE,QAAQ;YACR,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,SAAS,EAAE,MAAM;SAClB,CAAC,CAAA;QAEF,aAAa,CAAC,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAElD,IAAI,MAAM,CAAC,SAAS;YAClB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,MAAM,CAAC,SAAS,EAAE,GAAG,EAAE,CAChE,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,QAAQ,CAAC,aAAa,EAAE,OAAO,CAAC,CACvE,CAAA;IACL,CAAC;CACF,CAAA;AA9DY,gCAAgC;IAD5C,UAAU,EAAE;IAGR,WAAA,MAAM,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC,CAAA;IAGrC,WAAA,MAAM,CAAC,GAAG,EAAE,CAAC,8BAA8B,CAAC,CAAA;IAG5C,WAAA,MAAM,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,CAAA;GARvB,gCAAgC,CA8D5C"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { WorkflowRun } from '../models/WorkflowRun.js';
|
|
2
|
+
import { WorkflowRunRepository } from '../repositories/WorkflowRun.repository.js';
|
|
3
|
+
import { WorkflowRunActivityRepository } from '../repositories/WorkflowRunActivity.repository.js';
|
|
4
|
+
export interface CreateWorkflowRunOptions {
|
|
5
|
+
id?: string;
|
|
6
|
+
parentWorkflowRunId?: string;
|
|
7
|
+
parentWorkflowRunActivityId?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class CreateWorkflowRun {
|
|
10
|
+
private readonly workflowRunRepository;
|
|
11
|
+
private readonly workflowRunActivityRepository;
|
|
12
|
+
constructor(workflowRunRepository: WorkflowRunRepository, workflowRunActivityRepository: WorkflowRunActivityRepository);
|
|
13
|
+
create(workflowId: string, input: unknown, options?: CreateWorkflowRunOptions): WorkflowRun;
|
|
14
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
8
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
9
|
+
};
|
|
10
|
+
import { Inject, Injectable } from 'pleroma';
|
|
11
|
+
import { WorkflowRun } from '../models/WorkflowRun.js';
|
|
12
|
+
import { WorkflowRunRepository } from '../repositories/WorkflowRun.repository.js';
|
|
13
|
+
import { WorkflowRunActivityRepository } from '../repositories/WorkflowRunActivity.repository.js';
|
|
14
|
+
let CreateWorkflowRun = class CreateWorkflowRun {
|
|
15
|
+
workflowRunRepository;
|
|
16
|
+
workflowRunActivityRepository;
|
|
17
|
+
constructor(workflowRunRepository, workflowRunActivityRepository) {
|
|
18
|
+
this.workflowRunRepository = workflowRunRepository;
|
|
19
|
+
this.workflowRunActivityRepository = workflowRunActivityRepository;
|
|
20
|
+
}
|
|
21
|
+
create(workflowId, input, options) {
|
|
22
|
+
const run = new WorkflowRun(workflowId, input, options?.id);
|
|
23
|
+
if (options?.parentWorkflowRunId) {
|
|
24
|
+
const parentRun = this.workflowRunRepository.findById(options.parentWorkflowRunId);
|
|
25
|
+
if (parentRun)
|
|
26
|
+
run.parent = parentRun;
|
|
27
|
+
}
|
|
28
|
+
if (options?.parentWorkflowRunActivityId) {
|
|
29
|
+
const parentActivity = this.workflowRunActivityRepository.findById(options.parentWorkflowRunActivityId);
|
|
30
|
+
if (parentActivity)
|
|
31
|
+
run.parentActivity = parentActivity;
|
|
32
|
+
}
|
|
33
|
+
this.workflowRunRepository.save(run);
|
|
34
|
+
return run;
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
CreateWorkflowRun = __decorate([
|
|
38
|
+
Injectable(),
|
|
39
|
+
__param(0, Inject(() => WorkflowRunRepository)),
|
|
40
|
+
__param(1, Inject(() => WorkflowRunActivityRepository))
|
|
41
|
+
], CreateWorkflowRun);
|
|
42
|
+
export { CreateWorkflowRun };
|
|
43
|
+
//# sourceMappingURL=CreateWorkflowRun.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CreateWorkflowRun.usecase.js","sourceRoot":"","sources":["../../../src/dev-runtime/use-cases/CreateWorkflowRun.usecase.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAE5C,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AACtD,OAAO,EAAE,qBAAqB,EAAE,MAAM,2CAA2C,CAAA;AACjF,OAAO,EAAE,6BAA6B,EAAE,MAAM,mDAAmD,CAAA;AAS1F,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAGT;IAGA;IALnB,YAEmB,qBAA4C,EAG5C,6BAA4D;QAH5D,0BAAqB,GAArB,qBAAqB,CAAuB;QAG5C,kCAA6B,GAA7B,6BAA6B,CAA+B;IAC5E,CAAC;IAEG,MAAM,CACX,UAAkB,EAClB,KAAc,EACd,OAAkC;QAElC,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,UAAU,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,CAAA;QAE3D,IAAI,OAAO,EAAE,mBAAmB,EAAE,CAAC;YACjC,MAAM,SAAS,GAAG,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CACnD,OAAO,CAAC,mBAAmB,CAC5B,CAAA;YAED,IAAI,SAAS;gBAAE,GAAG,CAAC,MAAM,GAAG,SAAS,CAAA;QACvC,CAAC;QAED,IAAI,OAAO,EAAE,2BAA2B,EAAE,CAAC;YACzC,MAAM,cAAc,GAAG,IAAI,CAAC,6BAA6B,CAAC,QAAQ,CAChE,OAAO,CAAC,2BAA2B,CACpC,CAAA;YAED,IAAI,cAAc;gBAAE,GAAG,CAAC,cAAc,GAAG,cAAc,CAAA;QACzD,CAAC;QAED,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAEpC,OAAO,GAAG,CAAA;IACZ,CAAC;CACF,CAAA;AApCY,iBAAiB;IAD7B,UAAU,EAAE;IAGR,WAAA,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,CAAA;IAGnC,WAAA,MAAM,CAAC,GAAG,EAAE,CAAC,6BAA6B,CAAC,CAAA;GALnC,iBAAiB,CAoC7B"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { WorkflowRunActivity } from '../models/WorkflowRunActivity.js';
|
|
2
|
+
import { TimeoutSchedulerService } from '../services/TimeoutScheduler.service.js';
|
|
3
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
4
|
+
export declare class CreateWorkflowRunAsyncActivity {
|
|
5
|
+
private readonly timeoutScheduler;
|
|
6
|
+
private readonly workflowRunAsyncActivity;
|
|
7
|
+
constructor(timeoutScheduler: TimeoutSchedulerService, workflowRunAsyncActivity: WorkflowRunAsyncActivityFacade);
|
|
8
|
+
create(activity: WorkflowRunActivity, input: unknown): Promise<unknown>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
8
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
9
|
+
};
|
|
10
|
+
import { AsyncActivity, AsyncActivityResultFulfilled, AsyncActivityResultPending, AsyncActivityResultRejected, Internals, } from '@t4h.framework/core';
|
|
11
|
+
import { Inject, Injectable } from 'pleroma';
|
|
12
|
+
import { env } from '../../commands/dev-server-up-app-process.js';
|
|
13
|
+
import { claims } from '../bootstrap.js';
|
|
14
|
+
import { WorkflowRunActivity, WorkflowRunAsyncActivityPending, } from '../models/WorkflowRunActivity.js';
|
|
15
|
+
import { TimeoutSchedulerService } from '../services/TimeoutScheduler.service.js';
|
|
16
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
17
|
+
let CreateWorkflowRunAsyncActivity = class CreateWorkflowRunAsyncActivity {
|
|
18
|
+
timeoutScheduler;
|
|
19
|
+
workflowRunAsyncActivity;
|
|
20
|
+
constructor(timeoutScheduler, workflowRunAsyncActivity) {
|
|
21
|
+
this.timeoutScheduler = timeoutScheduler;
|
|
22
|
+
this.workflowRunAsyncActivity = workflowRunAsyncActivity;
|
|
23
|
+
}
|
|
24
|
+
async create(activity, input) {
|
|
25
|
+
if (!activity.asyncActivity)
|
|
26
|
+
throw new Error(`Activity is not an async activity: ${activity.id}`);
|
|
27
|
+
const Activity = activity.constructable;
|
|
28
|
+
const bootstrap = await Internals.runActivity(Activity, { claims, env }, async (activity) => {
|
|
29
|
+
if (!(activity instanceof AsyncActivity))
|
|
30
|
+
throw new Error(`Activity is not an async activity: ${activity.constructor.name}`);
|
|
31
|
+
return activity.bootstrap(input);
|
|
32
|
+
});
|
|
33
|
+
const asyncActivity = activity.asyncActivity;
|
|
34
|
+
const pending = new WorkflowRunAsyncActivityPending(asyncActivity);
|
|
35
|
+
if (bootstrap instanceof AsyncActivityResultPending) {
|
|
36
|
+
Object.assign(pending, {
|
|
37
|
+
status: 'pending',
|
|
38
|
+
schema: bootstrap.schema,
|
|
39
|
+
timeoutAt: bootstrap.timeoutAt,
|
|
40
|
+
bootstrap,
|
|
41
|
+
});
|
|
42
|
+
asyncActivity.pendingAsyncActivities.push(pending);
|
|
43
|
+
if (bootstrap.timeoutAt)
|
|
44
|
+
this.timeoutScheduler.schedule(pending.id, bootstrap.timeoutAt, () => this.workflowRunAsyncActivity.timeout(asyncActivity, pending));
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
const isFulfilled = bootstrap instanceof AsyncActivityResultFulfilled;
|
|
48
|
+
const isRejected = bootstrap instanceof AsyncActivityResultRejected;
|
|
49
|
+
if (!isFulfilled && !isRejected)
|
|
50
|
+
throw new Error('Unexpected bootstrap result', { cause: bootstrap });
|
|
51
|
+
const status = isFulfilled ? 'fulfilled' : 'rejected';
|
|
52
|
+
Object.assign(pending, {
|
|
53
|
+
status,
|
|
54
|
+
bootstrap: new AsyncActivityResultPending(),
|
|
55
|
+
});
|
|
56
|
+
asyncActivity.pendingAsyncActivities.push(pending);
|
|
57
|
+
asyncActivity.status = status;
|
|
58
|
+
activity.output = bootstrap.payload;
|
|
59
|
+
return activity.output;
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
CreateWorkflowRunAsyncActivity = __decorate([
|
|
63
|
+
Injectable(),
|
|
64
|
+
__param(0, Inject(() => TimeoutSchedulerService)),
|
|
65
|
+
__param(1, Inject(() => WorkflowRunAsyncActivityFacade))
|
|
66
|
+
], CreateWorkflowRunAsyncActivity);
|
|
67
|
+
export { CreateWorkflowRunAsyncActivity };
|
|
68
|
+
//# sourceMappingURL=CreateWorkflowRunAsyncActivity.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CreateWorkflowRunAsyncActivity.usecase.js","sourceRoot":"","sources":["../../../src/dev-runtime/use-cases/CreateWorkflowRunAsyncActivity.usecase.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { WorkflowRunRepository } from '../repositories/WorkflowRun.repository.js';
|
|
2
|
+
import { WorkflowRunActivityRepository } from '../repositories/WorkflowRunActivity.repository.js';
|
|
3
|
+
import { RuntimeContextService } from '../services/RuntimeContext.service.js';
|
|
4
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
5
|
+
import { WorkflowRunFacade } from '../services/WorkflowRunFacade.service.js';
|
|
6
|
+
import { WorkflowRunSyncActivityFacade } from '../services/WorkflowRunSyncActivityFacade.service.js';
|
|
7
|
+
export declare class NextTickWorkflowRun {
|
|
8
|
+
private readonly workflowRunRepository;
|
|
9
|
+
private readonly workflowRunActivityRepository;
|
|
10
|
+
private readonly workflowRun;
|
|
11
|
+
private readonly workflowRunSyncActivity;
|
|
12
|
+
private readonly workflowRunAsyncActivity;
|
|
13
|
+
private readonly context;
|
|
14
|
+
constructor(workflowRunRepository: WorkflowRunRepository, workflowRunActivityRepository: WorkflowRunActivityRepository, workflowRun: WorkflowRunFacade, workflowRunSyncActivity: WorkflowRunSyncActivityFacade, workflowRunAsyncActivity: WorkflowRunAsyncActivityFacade, context: RuntimeContextService);
|
|
15
|
+
nextTick(runId: string): Promise<void>;
|
|
16
|
+
private run;
|
|
17
|
+
private findWorkflow;
|
|
18
|
+
private startPendingChildWorkflows;
|
|
19
|
+
private notifyParentWorkflowRun;
|
|
20
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
8
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
9
|
+
};
|
|
10
|
+
import { randomUUID } from 'node:crypto';
|
|
11
|
+
import { App, AsyncActivity, Internals, PushActivity, PushWaitAsyncActivity, SyncActivity, } from '@t4h.framework/core';
|
|
12
|
+
import { Inject, Injectable } from 'pleroma';
|
|
13
|
+
import { app, env } from '../../commands/dev-server-up-app-process.js';
|
|
14
|
+
import { claims } from '../bootstrap.js';
|
|
15
|
+
import { WorkflowRunActivity } from '../models/WorkflowRunActivity.js';
|
|
16
|
+
import { WorkflowRunRepository } from '../repositories/WorkflowRun.repository.js';
|
|
17
|
+
import { WorkflowRunActivityRepository } from '../repositories/WorkflowRunActivity.repository.js';
|
|
18
|
+
import { RuntimeContextService } from '../services/RuntimeContext.service.js';
|
|
19
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
20
|
+
import { WorkflowRunFacade } from '../services/WorkflowRunFacade.service.js';
|
|
21
|
+
import { WorkflowRunSyncActivityFacade } from '../services/WorkflowRunSyncActivityFacade.service.js';
|
|
22
|
+
let NextTickWorkflowRun = class NextTickWorkflowRun {
|
|
23
|
+
workflowRunRepository;
|
|
24
|
+
workflowRunActivityRepository;
|
|
25
|
+
workflowRun;
|
|
26
|
+
workflowRunSyncActivity;
|
|
27
|
+
workflowRunAsyncActivity;
|
|
28
|
+
context;
|
|
29
|
+
constructor(workflowRunRepository, workflowRunActivityRepository, workflowRun, workflowRunSyncActivity, workflowRunAsyncActivity, context) {
|
|
30
|
+
this.workflowRunRepository = workflowRunRepository;
|
|
31
|
+
this.workflowRunActivityRepository = workflowRunActivityRepository;
|
|
32
|
+
this.workflowRun = workflowRun;
|
|
33
|
+
this.workflowRunSyncActivity = workflowRunSyncActivity;
|
|
34
|
+
this.workflowRunAsyncActivity = workflowRunAsyncActivity;
|
|
35
|
+
this.context = context;
|
|
36
|
+
}
|
|
37
|
+
async nextTick(runId) {
|
|
38
|
+
const run = this.workflowRunRepository.findById(runId);
|
|
39
|
+
if (!run)
|
|
40
|
+
throw new Error(`Unknown workflow run: ${runId}`);
|
|
41
|
+
if (run.status !== 'running')
|
|
42
|
+
return;
|
|
43
|
+
const activityId = randomUUID();
|
|
44
|
+
await this.context.run({ runId, workflowId: run.workflow, activityId }, () => this.run(run, activityId));
|
|
45
|
+
}
|
|
46
|
+
async run(run, activityId) {
|
|
47
|
+
if (!app)
|
|
48
|
+
throw new Error('App not initialized');
|
|
49
|
+
const workflow = this.findWorkflow(app, run.workflow);
|
|
50
|
+
if (!workflow)
|
|
51
|
+
return { kind: 'rejected', error: new Error('Workflow not found') };
|
|
52
|
+
const history = this.workflowRun.getHistory(run);
|
|
53
|
+
try {
|
|
54
|
+
const output = await Internals.runWorkflow(workflow, {
|
|
55
|
+
claims,
|
|
56
|
+
env,
|
|
57
|
+
history,
|
|
58
|
+
input: run.input,
|
|
59
|
+
});
|
|
60
|
+
Object.assign(run, { status: 'fulfilled', output });
|
|
61
|
+
await this.notifyParentWorkflowRun(run, 'fulfilled', output);
|
|
62
|
+
return output;
|
|
63
|
+
}
|
|
64
|
+
catch (pushActivityOrError) {
|
|
65
|
+
if (pushActivityOrError instanceof PushWaitAsyncActivity)
|
|
66
|
+
return;
|
|
67
|
+
if (pushActivityOrError instanceof PushActivity) {
|
|
68
|
+
const activity = new WorkflowRunActivity(run, pushActivityOrError.activity.constructor, activityId);
|
|
69
|
+
this.workflowRunActivityRepository.save(activity);
|
|
70
|
+
if (pushActivityOrError.activity instanceof SyncActivity) {
|
|
71
|
+
await this.workflowRunSyncActivity.run(activity, pushActivityOrError.input);
|
|
72
|
+
await this.startPendingChildWorkflows(activityId);
|
|
73
|
+
await this.nextTick(run.id);
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
if (pushActivityOrError.activity instanceof AsyncActivity) {
|
|
77
|
+
const output = await this.workflowRunAsyncActivity.create(activity, pushActivityOrError.input);
|
|
78
|
+
await this.startPendingChildWorkflows(activityId);
|
|
79
|
+
if (!output)
|
|
80
|
+
return;
|
|
81
|
+
await this.nextTick(run.id);
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
const reason = pushActivityOrError instanceof Error
|
|
86
|
+
? {
|
|
87
|
+
message: pushActivityOrError.message,
|
|
88
|
+
stack: pushActivityOrError.stack,
|
|
89
|
+
}
|
|
90
|
+
: { message: String(pushActivityOrError) };
|
|
91
|
+
Object.assign(run, { status: 'rejected', rejectedReason: reason });
|
|
92
|
+
console.error(pushActivityOrError);
|
|
93
|
+
await this.notifyParentWorkflowRun(run, 'rejected', reason);
|
|
94
|
+
throw pushActivityOrError;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
findWorkflow(app, workflowId) {
|
|
98
|
+
const workflow = app.workflows.find(workflow => workflow.id === workflowId);
|
|
99
|
+
if (workflow)
|
|
100
|
+
return workflow;
|
|
101
|
+
if (!workflowId.startsWith(':'))
|
|
102
|
+
return;
|
|
103
|
+
const index = parseInt(workflowId.slice(1));
|
|
104
|
+
return app.workflows[index];
|
|
105
|
+
}
|
|
106
|
+
async startPendingChildWorkflows(parentActivityId) {
|
|
107
|
+
const runs = this.workflowRunRepository.findBy(run => {
|
|
108
|
+
if (run.parentActivity?.id !== parentActivityId)
|
|
109
|
+
return false;
|
|
110
|
+
if (run.status !== 'running')
|
|
111
|
+
return false;
|
|
112
|
+
const activities = this.workflowRunActivityRepository.findByRunId(run.id);
|
|
113
|
+
if (activities.length > 0)
|
|
114
|
+
return false;
|
|
115
|
+
return true;
|
|
116
|
+
});
|
|
117
|
+
for (const run of runs) {
|
|
118
|
+
await this.nextTick(run.id);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
async notifyParentWorkflowRun(child, status, output) {
|
|
122
|
+
if (!child.parent)
|
|
123
|
+
return;
|
|
124
|
+
if (!child.parentActivity)
|
|
125
|
+
return;
|
|
126
|
+
const parentAsyncActivity = child.parentActivity.asyncActivity;
|
|
127
|
+
if (!parentAsyncActivity)
|
|
128
|
+
return;
|
|
129
|
+
const lastPending = parentAsyncActivity.lastPendingAsyncActivity;
|
|
130
|
+
if (!lastPending)
|
|
131
|
+
return;
|
|
132
|
+
if (lastPending.status !== 'pending')
|
|
133
|
+
return;
|
|
134
|
+
await this.workflowRunAsyncActivity.advance(child.parentActivity.id, {
|
|
135
|
+
status,
|
|
136
|
+
output,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
NextTickWorkflowRun = __decorate([
|
|
141
|
+
Injectable(),
|
|
142
|
+
__param(0, Inject(() => WorkflowRunRepository)),
|
|
143
|
+
__param(1, Inject(() => WorkflowRunActivityRepository)),
|
|
144
|
+
__param(2, Inject(() => WorkflowRunFacade)),
|
|
145
|
+
__param(3, Inject(() => WorkflowRunSyncActivityFacade)),
|
|
146
|
+
__param(4, Inject(() => WorkflowRunAsyncActivityFacade)),
|
|
147
|
+
__param(5, Inject(() => RuntimeContextService))
|
|
148
|
+
], NextTickWorkflowRun);
|
|
149
|
+
export { NextTickWorkflowRun };
|
|
150
|
+
//# sourceMappingURL=NextTickWorkflowRun.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NextTickWorkflowRun.usecase.js","sourceRoot":"","sources":["../../../src/dev-runtime/use-cases/NextTickWorkflowRun.usecase.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { CallbackWorkflowRunAsyncActivity } from './CallbackWorkflowRunAsyncActivity.usecase.js';
|
|
2
|
+
import { WorkflowRunAsyncActivityPending } from '../models/WorkflowRunActivity.js';
|
|
3
|
+
import type { WorkflowRunAsyncActivity } from '../models/WorkflowRunActivity.js';
|
|
4
|
+
export declare class TimeoutWorkflowRunAsyncActivity {
|
|
5
|
+
private readonly workflowRunAsyncActivityHandler;
|
|
6
|
+
constructor(workflowRunAsyncActivityHandler: CallbackWorkflowRunAsyncActivity);
|
|
7
|
+
timeout(asyncActivity: WorkflowRunAsyncActivity, pending: WorkflowRunAsyncActivityPending): Promise<void>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
8
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
9
|
+
};
|
|
10
|
+
import { AsyncActivity, AsyncActivityResultRejected, Internals, } from '@t4h.framework/core';
|
|
11
|
+
import { Inject, Injectable } from 'pleroma';
|
|
12
|
+
import { CallbackWorkflowRunAsyncActivity } from './CallbackWorkflowRunAsyncActivity.usecase.js';
|
|
13
|
+
import { env } from '../../commands/dev-server-up-app-process.js';
|
|
14
|
+
import { claims } from '../bootstrap.js';
|
|
15
|
+
import { WorkflowRunAsyncActivityPending } from '../models/WorkflowRunActivity.js';
|
|
16
|
+
let TimeoutWorkflowRunAsyncActivity = class TimeoutWorkflowRunAsyncActivity {
|
|
17
|
+
workflowRunAsyncActivityHandler;
|
|
18
|
+
constructor(workflowRunAsyncActivityHandler) {
|
|
19
|
+
this.workflowRunAsyncActivityHandler = workflowRunAsyncActivityHandler;
|
|
20
|
+
}
|
|
21
|
+
async timeout(asyncActivity, pending) {
|
|
22
|
+
const Activity = asyncActivity.activity.constructable;
|
|
23
|
+
const result = await Internals.runActivity(new Activity(), { claims, env }, async (activity) => {
|
|
24
|
+
if (!(activity instanceof AsyncActivity))
|
|
25
|
+
throw new Error(`Activity is not an async activity: ${activity.constructor.name}`);
|
|
26
|
+
if (!activity.onTimeout)
|
|
27
|
+
return new AsyncActivityResultRejected({ reason: 'timeout' });
|
|
28
|
+
return activity.onTimeout(pending.bootstrap);
|
|
29
|
+
});
|
|
30
|
+
await this.workflowRunAsyncActivityHandler.callback(pending, asyncActivity.activity, result);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
TimeoutWorkflowRunAsyncActivity = __decorate([
|
|
34
|
+
Injectable(),
|
|
35
|
+
__param(0, Inject(() => CallbackWorkflowRunAsyncActivity))
|
|
36
|
+
], TimeoutWorkflowRunAsyncActivity);
|
|
37
|
+
export { TimeoutWorkflowRunAsyncActivity };
|
|
38
|
+
//# sourceMappingURL=TimeoutWorkflowRunAsyncActivity.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TimeoutWorkflowRunAsyncActivity.usecase.js","sourceRoot":"","sources":["../../../src/dev-runtime/use-cases/TimeoutWorkflowRunAsyncActivity.usecase.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EACL,aAAa,EACb,2BAA2B,EAC3B,SAAS,GACV,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAE5C,OAAO,EAAE,gCAAgC,EAAE,MAAM,+CAA+C,CAAA;AAChG,OAAO,EAAE,GAAG,EAAE,MAAM,6CAA6C,CAAA;AACjE,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,EAAE,+BAA+B,EAAE,MAAM,kCAAkC,CAAA;AAI3E,IAAM,+BAA+B,GAArC,MAAM,+BAA+B;IAGvB;IAFnB,YAEmB,+BAAiE;QAAjE,oCAA+B,GAA/B,+BAA+B,CAAkC;IACjF,CAAC;IAEG,KAAK,CAAC,OAAO,CAClB,aAAuC,EACvC,OAAwC;QAExC,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAA;QAErD,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,WAAW,CACxC,IAAI,QAAQ,EAAE,EACd,EAAE,MAAM,EAAE,GAAG,EAAE,EACf,KAAK,EAAC,QAAQ,EAAC,EAAE;YACf,IAAI,CAAC,CAAC,QAAQ,YAAY,aAAa,CAAC;gBACtC,MAAM,IAAI,KAAK,CACb,sCAAsC,QAAQ,CAAC,WAAW,CAAC,IAAI,EAAE,CAClE,CAAA;YAEH,IAAI,CAAC,QAAQ,CAAC,SAAS;gBACrB,OAAO,IAAI,2BAA2B,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAA;YAE/D,OAAO,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,CAAA;QAC9C,CAAC,CACF,CAAA;QAED,MAAM,IAAI,CAAC,+BAA+B,CAAC,QAAQ,CACjD,OAAO,EACP,aAAa,CAAC,QAAQ,EACtB,MAAM,CACP,CAAA;IACH,CAAC;CACF,CAAA;AAlCY,+BAA+B;IAD3C,UAAU,EAAE;IAGR,WAAA,MAAM,CAAC,GAAG,EAAE,CAAC,gCAAgC,CAAC,CAAA;GAFtC,+BAA+B,CAkC3C"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { WorkflowRunActivity } from '../models/WorkflowRunActivity.js';
|
|
2
|
+
import { WorkflowRunAsyncActivityFacade } from '../services/WorkflowRunAsyncActivityFacade.service.js';
|
|
3
|
+
export declare class WorkflowRunAsyncActivity {
|
|
4
|
+
private readonly workflowRunAsyncActivity;
|
|
5
|
+
constructor(workflowRunAsyncActivity: WorkflowRunAsyncActivityFacade);
|
|
6
|
+
run(activity: WorkflowRunActivity): Promise<void>;
|
|
7
|
+
}
|