@motiadev/core 0.14.0-beta.164 → 0.14.0-beta.165-707935
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/index.d.mts +38 -0
- package/dist/index.mjs +30 -0
- package/dist/src/adapters/defaults/cron/in-memory-cron-adapter.d.mts +17 -0
- package/dist/src/adapters/defaults/cron/in-memory-cron-adapter.d.mts.map +1 -0
- package/dist/src/adapters/defaults/cron/in-memory-cron-adapter.mjs +51 -0
- package/dist/src/adapters/defaults/cron/in-memory-cron-adapter.mjs.map +1 -0
- package/dist/src/adapters/defaults/event/in-memory-queue-event-adapter.d.mts +19 -0
- package/dist/src/adapters/defaults/event/in-memory-queue-event-adapter.d.mts.map +1 -0
- package/dist/src/adapters/defaults/event/in-memory-queue-event-adapter.mjs +54 -0
- package/dist/src/adapters/defaults/event/in-memory-queue-event-adapter.mjs.map +1 -0
- package/dist/src/adapters/defaults/index.d.mts +8 -0
- package/dist/src/adapters/defaults/index.mjs +10 -0
- package/dist/src/adapters/defaults/state/file-state-adapter.d.mts +27 -0
- package/dist/src/adapters/defaults/state/file-state-adapter.d.mts.map +1 -0
- package/dist/src/adapters/defaults/state/file-state-adapter.mjs +105 -0
- package/dist/src/adapters/defaults/state/file-state-adapter.mjs.map +1 -0
- package/dist/src/adapters/defaults/state/memory-state-adapter.d.mts +20 -0
- package/dist/src/adapters/defaults/state/memory-state-adapter.d.mts.map +1 -0
- package/dist/src/adapters/defaults/state/memory-state-adapter.mjs +58 -0
- package/dist/src/adapters/defaults/state/memory-state-adapter.mjs.map +1 -0
- package/dist/src/adapters/defaults/state/utils.mjs +40 -0
- package/dist/src/adapters/defaults/state/utils.mjs.map +1 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter-manager.d.mts +13 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter-manager.d.mts.map +1 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter-manager.mjs +16 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter-manager.mjs.map +1 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter.d.mts +24 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter.d.mts.map +1 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter.mjs +84 -0
- package/dist/src/adapters/defaults/stream/file-stream-adapter.mjs.map +1 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter-manager.d.mts +10 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter-manager.d.mts.map +1 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter-manager.mjs +12 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter-manager.mjs.map +1 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter.d.mts +20 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter.d.mts.map +1 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter.mjs +58 -0
- package/dist/src/adapters/defaults/stream/memory-stream-adapter.mjs.map +1 -0
- package/dist/src/adapters/interfaces/cron-adapter.interface.d.mts +32 -0
- package/dist/src/adapters/interfaces/cron-adapter.interface.d.mts.map +1 -0
- package/dist/src/adapters/interfaces/event-adapter.interface.d.mts +19 -0
- package/dist/src/adapters/interfaces/event-adapter.interface.d.mts.map +1 -0
- package/dist/src/adapters/interfaces/observability-adapter.interface.d.mts +27 -0
- package/dist/src/adapters/interfaces/observability-adapter.interface.d.mts.map +1 -0
- package/dist/src/adapters/interfaces/state-adapter.interface.d.mts +28 -0
- package/dist/src/adapters/interfaces/state-adapter.interface.d.mts.map +1 -0
- package/dist/src/adapters/interfaces/stream-adapter-manager.interface.d.mts +10 -0
- package/dist/src/adapters/interfaces/stream-adapter-manager.interface.d.mts.map +1 -0
- package/dist/src/adapters/interfaces/stream-adapter.interface.d.mts +26 -0
- package/dist/src/adapters/interfaces/stream-adapter.interface.d.mts.map +1 -0
- package/dist/src/adapters/interfaces/stream-adapter.interface.mjs +17 -0
- package/dist/src/adapters/interfaces/stream-adapter.interface.mjs.map +1 -0
- package/dist/src/analytics/utils.d.mts +9 -0
- package/dist/src/analytics/utils.d.mts.map +1 -0
- package/dist/src/analytics/utils.mjs +35 -0
- package/dist/src/analytics/utils.mjs.map +1 -0
- package/dist/src/call-step-file.mjs +215 -0
- package/dist/src/call-step-file.mjs.map +1 -0
- package/dist/src/config.d.mts +7 -0
- package/dist/src/config.d.mts.map +1 -0
- package/dist/src/config.mjs +6 -0
- package/dist/src/config.mjs.map +1 -0
- package/dist/src/cron-handler.d.mts +18 -0
- package/dist/src/cron-handler.d.mts.map +1 -0
- package/dist/src/cron-handler.mjs +103 -0
- package/dist/src/cron-handler.mjs.map +1 -0
- package/dist/src/endpoints/analytics-endpoint.mjs +29 -0
- package/dist/src/endpoints/analytics-endpoint.mjs.map +1 -0
- package/dist/src/endpoints/flows-config-endpoint.mjs +38 -0
- package/dist/src/endpoints/flows-config-endpoint.mjs.map +1 -0
- package/dist/src/endpoints/flows-endpoint.mjs +39 -0
- package/dist/src/endpoints/flows-endpoint.mjs.map +1 -0
- package/dist/src/endpoints/step-endpoint.mjs +41 -0
- package/dist/src/endpoints/step-endpoint.mjs.map +1 -0
- package/dist/src/generate-trace-id.mjs +13 -0
- package/dist/src/generate-trace-id.mjs.map +1 -0
- package/dist/src/get-step-config.d.mts +9 -0
- package/dist/src/get-step-config.d.mts.map +1 -0
- package/dist/src/get-step-config.mjs +63 -0
- package/dist/src/get-step-config.mjs.map +1 -0
- package/dist/src/get-step-language.mjs +14 -0
- package/dist/src/get-step-language.mjs.map +1 -0
- package/dist/src/guards.d.mts +10 -0
- package/dist/src/guards.d.mts.map +1 -0
- package/dist/src/guards.mjs +9 -0
- package/dist/src/guards.mjs.map +1 -0
- package/dist/src/helper/flows-helper.mjs +126 -0
- package/dist/src/helper/flows-helper.mjs.map +1 -0
- package/dist/src/infrastructure-validator/defaults.mjs +17 -0
- package/dist/src/infrastructure-validator/defaults.mjs.map +1 -0
- package/dist/src/infrastructure-validator/index.d.mts +3 -0
- package/dist/src/infrastructure-validator/index.mjs +4 -0
- package/dist/src/infrastructure-validator/schemas.d.mts +1 -0
- package/dist/src/infrastructure-validator/schemas.mjs +77 -0
- package/dist/src/infrastructure-validator/schemas.mjs.map +1 -0
- package/dist/src/infrastructure-validator/types.d.mts +14 -0
- package/dist/src/infrastructure-validator/types.d.mts.map +1 -0
- package/dist/src/infrastructure-validator/validations.d.mts +7 -0
- package/dist/src/infrastructure-validator/validations.d.mts.map +1 -0
- package/dist/src/infrastructure-validator/validations.mjs +29 -0
- package/dist/src/infrastructure-validator/validations.mjs.map +1 -0
- package/dist/src/language-runner.mjs +55 -0
- package/dist/src/language-runner.mjs.map +1 -0
- package/dist/src/locked-data.d.mts +81 -0
- package/dist/src/locked-data.d.mts.map +1 -0
- package/dist/src/locked-data.mjs +223 -0
- package/dist/src/locked-data.mjs.map +1 -0
- package/dist/src/logger-factory.d.mts +16 -0
- package/dist/src/logger-factory.d.mts.map +1 -0
- package/dist/src/logger-factory.mjs +33 -0
- package/dist/src/logger-factory.mjs.map +1 -0
- package/dist/src/logger.d.mts +28 -0
- package/dist/src/logger.d.mts.map +1 -0
- package/dist/src/logger.mjs +64 -0
- package/dist/src/logger.mjs.map +1 -0
- package/dist/src/mermaid-generator.d.mts +9 -0
- package/dist/src/mermaid-generator.d.mts.map +1 -0
- package/dist/src/mermaid-generator.mjs +126 -0
- package/dist/src/mermaid-generator.mjs.map +1 -0
- package/dist/src/motia.d.mts +37 -0
- package/dist/src/motia.d.mts.map +1 -0
- package/dist/src/motia.mjs +6 -0
- package/dist/src/motia.mjs.map +1 -0
- package/dist/src/node/can-access.d.mts +1 -0
- package/dist/src/node/can-access.mjs +36 -0
- package/dist/src/node/can-access.mjs.map +1 -0
- package/dist/src/node/get-config.d.mts +1 -0
- package/dist/src/node/get-config.mjs +49 -0
- package/dist/src/node/get-config.mjs.map +1 -0
- package/dist/src/node/logger.mjs +47 -0
- package/dist/src/node/logger.mjs.map +1 -0
- package/dist/src/node/middleware-compose.mjs +10 -0
- package/dist/src/node/middleware-compose.mjs.map +1 -0
- package/dist/src/node/node-runner.d.mts +1 -0
- package/dist/src/node/node-runner.mjs +94 -0
- package/dist/src/node/node-runner.mjs.map +1 -0
- package/dist/src/node/rpc-state-manager.mjs +35 -0
- package/dist/src/node/rpc-state-manager.mjs.map +1 -0
- package/dist/src/node/rpc.mjs +55 -0
- package/dist/src/node/rpc.mjs.map +1 -0
- package/dist/src/observability/create-trace.mjs +26 -0
- package/dist/src/observability/create-trace.mjs.map +1 -0
- package/dist/src/observability/index.d.mts +7 -0
- package/dist/src/observability/index.d.mts.map +1 -0
- package/dist/src/observability/no-tracer.d.mts +15 -0
- package/dist/src/observability/no-tracer.d.mts.map +1 -0
- package/dist/src/observability/no-tracer.mjs +23 -0
- package/dist/src/observability/no-tracer.mjs.map +1 -0
- package/dist/src/observability/redis-trace-stream-adapter.mjs +76 -0
- package/dist/src/observability/redis-trace-stream-adapter.mjs.map +1 -0
- package/dist/src/observability/stream-tracer.mjs +98 -0
- package/dist/src/observability/stream-tracer.mjs.map +1 -0
- package/dist/src/observability/trace-manager.mjs +27 -0
- package/dist/src/observability/trace-manager.mjs.map +1 -0
- package/dist/src/observability/tracer.mjs +88 -0
- package/dist/src/observability/tracer.mjs.map +1 -0
- package/dist/src/observability/types.d.mts +14 -0
- package/dist/src/observability/types.d.mts.map +1 -0
- package/dist/src/pretty-print.mjs +50 -0
- package/dist/src/pretty-print.mjs.map +1 -0
- package/dist/src/printer.d.mts +65 -0
- package/dist/src/printer.d.mts.map +1 -0
- package/dist/src/printer.mjs +147 -0
- package/dist/src/printer.mjs.map +1 -0
- package/dist/src/process-communication/communication-config.mjs +26 -0
- package/dist/src/process-communication/communication-config.mjs.map +1 -0
- package/dist/src/process-communication/process-manager.mjs +67 -0
- package/dist/src/process-communication/process-manager.mjs.map +1 -0
- package/dist/src/queue-manager.d.mts +37 -0
- package/dist/src/queue-manager.d.mts.map +1 -0
- package/dist/src/queue-manager.mjs +209 -0
- package/dist/src/queue-manager.mjs.map +1 -0
- package/dist/src/run-stream-can-access.mjs +59 -0
- package/dist/src/run-stream-can-access.mjs.map +1 -0
- package/dist/src/schema-utils.mjs +30 -0
- package/dist/src/schema-utils.mjs.map +1 -0
- package/dist/src/server.d.mts +40 -0
- package/dist/src/server.d.mts.map +1 -0
- package/dist/src/server.mjs +353 -0
- package/dist/src/server.mjs.map +1 -0
- package/dist/src/socket-server/helpers.mjs +35 -0
- package/dist/src/socket-server/helpers.mjs.map +1 -0
- package/dist/src/socket-server.mjs +127 -0
- package/dist/src/socket-server.mjs.map +1 -0
- package/dist/src/state/create-state-adapter.d.mts +11 -0
- package/dist/src/state/create-state-adapter.d.mts.map +1 -0
- package/dist/src/state/create-state-adapter.mjs +11 -0
- package/dist/src/state/create-state-adapter.mjs.map +1 -0
- package/dist/src/step-handler-rpc-processor.mjs +56 -0
- package/dist/src/step-handler-rpc-processor.mjs.map +1 -0
- package/dist/src/step-handler-rpc-stdin-processor.mjs +71 -0
- package/dist/src/step-handler-rpc-stdin-processor.mjs.map +1 -0
- package/dist/src/step-handlers.d.mts +13 -0
- package/dist/src/step-handlers.d.mts.map +1 -0
- package/dist/src/step-handlers.mjs +93 -0
- package/dist/src/step-handlers.mjs.map +1 -0
- package/dist/src/step-validator.d.mts +15 -0
- package/dist/src/step-validator.d.mts.map +1 -0
- package/dist/src/step-validator.mjs +118 -0
- package/dist/src/step-validator.mjs.map +1 -0
- package/dist/src/steps/emit.step.mjs +20 -0
- package/dist/src/steps/emit.step.mjs.map +1 -0
- package/dist/src/steps/index.mjs +14 -0
- package/dist/src/steps/index.mjs.map +1 -0
- package/dist/src/streams/flows-config-stream.mjs +46 -0
- package/dist/src/streams/flows-config-stream.mjs.map +1 -0
- package/dist/src/streams/flows-stream.mjs +33 -0
- package/dist/src/streams/flows-stream.mjs.map +1 -0
- package/dist/src/streams/redis-logs-stream.d.mts +3 -0
- package/dist/src/streams/redis-logs-stream.mjs +97 -0
- package/dist/src/streams/redis-logs-stream.mjs.map +1 -0
- package/dist/src/streams/stream-factory.d.mts +7 -0
- package/dist/src/streams/stream-factory.d.mts.map +1 -0
- package/dist/src/types/app-config-types.d.mts +49 -0
- package/dist/src/types/app-config-types.d.mts.map +1 -0
- package/dist/src/types/generate-type-from-schema.mjs +30 -0
- package/dist/src/types/generate-type-from-schema.mjs.map +1 -0
- package/dist/src/types/generate-types-from-response.mjs +12 -0
- package/dist/src/types/generate-types-from-response.mjs.map +1 -0
- package/dist/src/types/generate-types.mjs +101 -0
- package/dist/src/types/generate-types.mjs.map +1 -0
- package/dist/src/types/merge-schemas.mjs +102 -0
- package/dist/src/types/merge-schemas.mjs.map +1 -0
- package/dist/src/types/schema.types.d.mts +13 -0
- package/dist/src/types/schema.types.d.mts.map +1 -0
- package/dist/src/types/schema.types.mjs +14 -0
- package/dist/src/types/schema.types.mjs.map +1 -0
- package/dist/src/types-stream.d.mts +46 -0
- package/dist/src/types-stream.d.mts.map +1 -0
- package/dist/src/types.d.mts +194 -0
- package/dist/src/types.d.mts.map +1 -0
- package/dist/src/utils.mjs +13 -0
- package/dist/src/utils.mjs.map +1 -0
- package/dist/src/validate-event-input.mjs +76 -0
- package/dist/src/validate-event-input.mjs.map +1 -0
- package/jest.config.cjs +20 -0
- package/package.json +21 -8
- package/tsdown.config.ts +53 -0
- package/dist/index.d.ts +0 -30
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -72
- package/dist/jest.config.d.ts +0 -8
- package/dist/jest.config.d.ts.map +0 -1
- package/dist/src/adapters/defaults/cron/in-memory-cron-adapter.d.ts +0 -13
- package/dist/src/adapters/defaults/cron/in-memory-cron-adapter.d.ts.map +0 -1
- package/dist/src/adapters/defaults/cron/in-memory-cron-adapter.js +0 -53
- package/dist/src/adapters/defaults/event/in-memory-queue-event-adapter.d.ts +0 -15
- package/dist/src/adapters/defaults/event/in-memory-queue-event-adapter.d.ts.map +0 -1
- package/dist/src/adapters/defaults/event/in-memory-queue-event-adapter.js +0 -49
- package/dist/src/adapters/defaults/index.d.ts +0 -9
- package/dist/src/adapters/defaults/index.d.ts.map +0 -1
- package/dist/src/adapters/defaults/index.js +0 -19
- package/dist/src/adapters/defaults/state/file-state-adapter.d.ts +0 -23
- package/dist/src/adapters/defaults/state/file-state-adapter.d.ts.map +0 -1
- package/dist/src/adapters/defaults/state/file-state-adapter.js +0 -149
- package/dist/src/adapters/defaults/state/memory-state-adapter.d.ts +0 -16
- package/dist/src/adapters/defaults/state/memory-state-adapter.d.ts.map +0 -1
- package/dist/src/adapters/defaults/state/memory-state-adapter.js +0 -69
- package/dist/src/adapters/defaults/state/utils.d.ts +0 -4
- package/dist/src/adapters/defaults/state/utils.d.ts.map +0 -1
- package/dist/src/adapters/defaults/state/utils.js +0 -66
- package/dist/src/adapters/defaults/stream/file-stream-adapter-manager.d.ts +0 -9
- package/dist/src/adapters/defaults/stream/file-stream-adapter-manager.d.ts.map +0 -1
- package/dist/src/adapters/defaults/stream/file-stream-adapter-manager.js +0 -14
- package/dist/src/adapters/defaults/stream/file-stream-adapter.d.ts +0 -22
- package/dist/src/adapters/defaults/stream/file-stream-adapter.d.ts.map +0 -1
- package/dist/src/adapters/defaults/stream/file-stream-adapter.js +0 -125
- package/dist/src/adapters/defaults/stream/index.d.ts +0 -5
- package/dist/src/adapters/defaults/stream/index.d.ts.map +0 -1
- package/dist/src/adapters/defaults/stream/index.js +0 -11
- package/dist/src/adapters/defaults/stream/memory-stream-adapter-manager.d.ts +0 -6
- package/dist/src/adapters/defaults/stream/memory-stream-adapter-manager.d.ts.map +0 -1
- package/dist/src/adapters/defaults/stream/memory-stream-adapter-manager.js +0 -10
- package/dist/src/adapters/defaults/stream/memory-stream-adapter.d.ts +0 -16
- package/dist/src/adapters/defaults/stream/memory-stream-adapter.d.ts.map +0 -1
- package/dist/src/adapters/defaults/stream/memory-stream-adapter.js +0 -55
- package/dist/src/adapters/interfaces/cron-adapter.interface.d.ts +0 -29
- package/dist/src/adapters/interfaces/cron-adapter.interface.d.ts.map +0 -1
- package/dist/src/adapters/interfaces/cron-adapter.interface.js +0 -2
- package/dist/src/adapters/interfaces/event-adapter.interface.d.ts +0 -15
- package/dist/src/adapters/interfaces/event-adapter.interface.d.ts.map +0 -1
- package/dist/src/adapters/interfaces/event-adapter.interface.js +0 -2
- package/dist/src/adapters/interfaces/index.d.ts +0 -7
- package/dist/src/adapters/interfaces/index.d.ts.map +0 -1
- package/dist/src/adapters/interfaces/index.js +0 -5
- package/dist/src/adapters/interfaces/observability-adapter.interface.d.ts +0 -23
- package/dist/src/adapters/interfaces/observability-adapter.interface.d.ts.map +0 -1
- package/dist/src/adapters/interfaces/observability-adapter.interface.js +0 -2
- package/dist/src/adapters/interfaces/state-adapter.interface.d.ts +0 -24
- package/dist/src/adapters/interfaces/state-adapter.interface.d.ts.map +0 -1
- package/dist/src/adapters/interfaces/state-adapter.interface.js +0 -2
- package/dist/src/adapters/interfaces/stream-adapter-manager.interface.d.ts +0 -6
- package/dist/src/adapters/interfaces/stream-adapter-manager.interface.d.ts.map +0 -1
- package/dist/src/adapters/interfaces/stream-adapter-manager.interface.js +0 -2
- package/dist/src/adapters/interfaces/stream-adapter.interface.d.ts +0 -22
- package/dist/src/adapters/interfaces/stream-adapter.interface.d.ts.map +0 -1
- package/dist/src/adapters/interfaces/stream-adapter.interface.js +0 -16
- package/dist/src/analytics/utils.d.ts +0 -6
- package/dist/src/analytics/utils.d.ts.map +0 -1
- package/dist/src/analytics/utils.js +0 -51
- package/dist/src/call-step-file.d.ts +0 -16
- package/dist/src/call-step-file.d.ts.map +0 -1
- package/dist/src/call-step-file.js +0 -198
- package/dist/src/config.d.ts +0 -3
- package/dist/src/config.d.ts.map +0 -1
- package/dist/src/config.js +0 -5
- package/dist/src/config.types.d.ts +0 -17
- package/dist/src/config.types.d.ts.map +0 -1
- package/dist/src/config.types.js +0 -2
- package/dist/src/cron-handler.d.ts +0 -14
- package/dist/src/cron-handler.d.ts.map +0 -1
- package/dist/src/cron-handler.js +0 -132
- package/dist/src/endpoints/analytics-endpoint.d.ts +0 -3
- package/dist/src/endpoints/analytics-endpoint.d.ts.map +0 -1
- package/dist/src/endpoints/analytics-endpoint.js +0 -28
- package/dist/src/endpoints/flows-config-endpoint.d.ts +0 -4
- package/dist/src/endpoints/flows-config-endpoint.d.ts.map +0 -1
- package/dist/src/endpoints/flows-config-endpoint.js +0 -34
- package/dist/src/endpoints/flows-endpoint.d.ts +0 -3
- package/dist/src/endpoints/flows-endpoint.d.ts.map +0 -1
- package/dist/src/endpoints/flows-endpoint.js +0 -29
- package/dist/src/endpoints/step-endpoint.d.ts +0 -4
- package/dist/src/endpoints/step-endpoint.d.ts.map +0 -1
- package/dist/src/endpoints/step-endpoint.js +0 -45
- package/dist/src/generate-trace-id.d.ts +0 -3
- package/dist/src/generate-trace-id.d.ts.map +0 -1
- package/dist/src/generate-trace-id.js +0 -14
- package/dist/src/get-step-config.d.ts +0 -5
- package/dist/src/get-step-config.d.ts.map +0 -1
- package/dist/src/get-step-config.js +0 -68
- package/dist/src/get-step-language.d.ts +0 -2
- package/dist/src/get-step-language.d.ts.map +0 -1
- package/dist/src/get-step-language.js +0 -27
- package/dist/src/guards.d.ts +0 -6
- package/dist/src/guards.d.ts.map +0 -1
- package/dist/src/guards.js +0 -11
- package/dist/src/helper/flows-helper.d.ts +0 -6
- package/dist/src/helper/flows-helper.d.ts.map +0 -1
- package/dist/src/helper/flows-helper.js +0 -143
- package/dist/src/infrastructure-validator/defaults.d.ts +0 -4
- package/dist/src/infrastructure-validator/defaults.d.ts.map +0 -1
- package/dist/src/infrastructure-validator/defaults.js +0 -16
- package/dist/src/infrastructure-validator/index.d.ts +0 -4
- package/dist/src/infrastructure-validator/index.d.ts.map +0 -1
- package/dist/src/infrastructure-validator/index.js +0 -13
- package/dist/src/infrastructure-validator/schemas.d.ts +0 -45
- package/dist/src/infrastructure-validator/schemas.d.ts.map +0 -1
- package/dist/src/infrastructure-validator/schemas.js +0 -100
- package/dist/src/infrastructure-validator/types.d.ts +0 -21
- package/dist/src/infrastructure-validator/types.d.ts.map +0 -1
- package/dist/src/infrastructure-validator/types.js +0 -2
- package/dist/src/infrastructure-validator/validations.d.ts +0 -4
- package/dist/src/infrastructure-validator/validations.d.ts.map +0 -1
- package/dist/src/infrastructure-validator/validations.js +0 -62
- package/dist/src/language-runner.d.ts +0 -15
- package/dist/src/language-runner.d.ts.map +0 -1
- package/dist/src/language-runner.js +0 -31
- package/dist/src/locked-data.d.ts +0 -78
- package/dist/src/locked-data.d.ts.map +0 -1
- package/dist/src/locked-data.js +0 -284
- package/dist/src/logger-factory.d.ts +0 -19
- package/dist/src/logger-factory.d.ts.map +0 -1
- package/dist/src/logger-factory.js +0 -27
- package/dist/src/logger.d.ts +0 -26
- package/dist/src/logger.d.ts.map +0 -1
- package/dist/src/logger.js +0 -60
- package/dist/src/mermaid-generator.d.ts +0 -5
- package/dist/src/mermaid-generator.d.ts.map +0 -1
- package/dist/src/mermaid-generator.js +0 -203
- package/dist/src/motia.d.ts +0 -33
- package/dist/src/motia.d.ts.map +0 -1
- package/dist/src/motia.js +0 -4
- package/dist/src/node/can-access.d.ts +0 -2
- package/dist/src/node/can-access.d.ts.map +0 -1
- package/dist/src/node/can-access.js +0 -44
- package/dist/src/node/get-config.d.ts +0 -2
- package/dist/src/node/get-config.d.ts.map +0 -1
- package/dist/src/node/get-config.js +0 -64
- package/dist/src/node/logger.d.ts +0 -16
- package/dist/src/node/logger.d.ts.map +0 -1
- package/dist/src/node/logger.js +0 -48
- package/dist/src/node/middleware-compose.d.ts +0 -2
- package/dist/src/node/middleware-compose.d.ts.map +0 -1
- package/dist/src/node/middleware-compose.js +0 -10
- package/dist/src/node/node-runner.d.ts +0 -2
- package/dist/src/node/node-runner.d.ts.map +0 -1
- package/dist/src/node/node-runner.js +0 -83
- package/dist/src/node/rpc-state-manager.d.ts +0 -12
- package/dist/src/node/rpc-state-manager.d.ts.map +0 -1
- package/dist/src/node/rpc-state-manager.js +0 -24
- package/dist/src/node/rpc.d.ts +0 -10
- package/dist/src/node/rpc.d.ts.map +0 -1
- package/dist/src/node/rpc.js +0 -50
- package/dist/src/observability/create-trace.d.ts +0 -4
- package/dist/src/observability/create-trace.d.ts.map +0 -1
- package/dist/src/observability/create-trace.js +0 -22
- package/dist/src/observability/index.d.ts +0 -4
- package/dist/src/observability/index.d.ts.map +0 -1
- package/dist/src/observability/index.js +0 -2
- package/dist/src/observability/no-tracer.d.ts +0 -10
- package/dist/src/observability/no-tracer.d.ts.map +0 -1
- package/dist/src/observability/no-tracer.js +0 -22
- package/dist/src/observability/redis-trace-stream-adapter.d.ts +0 -17
- package/dist/src/observability/redis-trace-stream-adapter.d.ts.map +0 -1
- package/dist/src/observability/redis-trace-stream-adapter.js +0 -65
- package/dist/src/observability/stream-tracer.d.ts +0 -23
- package/dist/src/observability/stream-tracer.d.ts.map +0 -1
- package/dist/src/observability/stream-tracer.js +0 -114
- package/dist/src/observability/trace-manager.d.ts +0 -14
- package/dist/src/observability/trace-manager.d.ts.map +0 -1
- package/dist/src/observability/trace-manager.js +0 -26
- package/dist/src/observability/tracer.d.ts +0 -19
- package/dist/src/observability/tracer.d.ts.map +0 -1
- package/dist/src/observability/tracer.js +0 -98
- package/dist/src/observability/types.d.ts +0 -75
- package/dist/src/observability/types.d.ts.map +0 -1
- package/dist/src/observability/types.js +0 -2
- package/dist/src/pretty-print.d.ts +0 -2
- package/dist/src/pretty-print.d.ts.map +0 -1
- package/dist/src/pretty-print.js +0 -63
- package/dist/src/printer.d.ts +0 -61
- package/dist/src/printer.d.ts.map +0 -1
- package/dist/src/printer.js +0 -164
- package/dist/src/process-communication/communication-config.d.ts +0 -8
- package/dist/src/process-communication/communication-config.d.ts.map +0 -1
- package/dist/src/process-communication/communication-config.js +0 -18
- package/dist/src/process-communication/process-manager.d.ts +0 -32
- package/dist/src/process-communication/process-manager.d.ts.map +0 -1
- package/dist/src/process-communication/process-manager.js +0 -88
- package/dist/src/process-communication/rpc-processor-interface.d.ts +0 -10
- package/dist/src/process-communication/rpc-processor-interface.d.ts.map +0 -1
- package/dist/src/process-communication/rpc-processor-interface.js +0 -2
- package/dist/src/queue-manager.d.ts +0 -42
- package/dist/src/queue-manager.d.ts.map +0 -1
- package/dist/src/queue-manager.js +0 -252
- package/dist/src/ruby/get-ruby-config.d.ts +0 -3
- package/dist/src/ruby/get-ruby-config.d.ts.map +0 -1
- package/dist/src/ruby/get-ruby-config.js +0 -34
- package/dist/src/run-stream-can-access.d.ts +0 -10
- package/dist/src/run-stream-can-access.d.ts.map +0 -1
- package/dist/src/run-stream-can-access.js +0 -59
- package/dist/src/schema-utils.d.ts +0 -9
- package/dist/src/schema-utils.d.ts.map +0 -1
- package/dist/src/schema-utils.js +0 -80
- package/dist/src/server.d.ts +0 -37
- package/dist/src/server.d.ts.map +0 -1
- package/dist/src/server.js +0 -344
- package/dist/src/socket-server/helpers.d.ts +0 -53
- package/dist/src/socket-server/helpers.d.ts.map +0 -1
- package/dist/src/socket-server/helpers.js +0 -28
- package/dist/src/socket-server.d.ts +0 -21
- package/dist/src/socket-server.d.ts.map +0 -1
- package/dist/src/socket-server.js +0 -127
- package/dist/src/state/create-state-adapter.d.ts +0 -8
- package/dist/src/state/create-state-adapter.d.ts.map +0 -1
- package/dist/src/state/create-state-adapter.js +0 -8
- package/dist/src/step-handler-rpc-processor.d.ts +0 -22
- package/dist/src/step-handler-rpc-processor.d.ts.map +0 -1
- package/dist/src/step-handler-rpc-processor.js +0 -63
- package/dist/src/step-handler-rpc-stdin-processor.d.ts +0 -23
- package/dist/src/step-handler-rpc-stdin-processor.d.ts.map +0 -1
- package/dist/src/step-handler-rpc-stdin-processor.js +0 -83
- package/dist/src/step-handlers.d.ts +0 -9
- package/dist/src/step-handlers.d.ts.map +0 -1
- package/dist/src/step-handlers.js +0 -77
- package/dist/src/step-validator.d.ts +0 -15
- package/dist/src/step-validator.d.ts.map +0 -1
- package/dist/src/step-validator.js +0 -135
- package/dist/src/steps/emit.step.d.ts +0 -12
- package/dist/src/steps/emit.step.d.ts.map +0 -1
- package/dist/src/steps/emit.step.js +0 -27
- package/dist/src/steps/index.d.ts +0 -3
- package/dist/src/steps/index.d.ts.map +0 -1
- package/dist/src/steps/index.js +0 -16
- package/dist/src/streams/flows-config-stream.d.ts +0 -14
- package/dist/src/streams/flows-config-stream.d.ts.map +0 -1
- package/dist/src/streams/flows-config-stream.js +0 -49
- package/dist/src/streams/flows-stream.d.ts +0 -12
- package/dist/src/streams/flows-stream.d.ts.map +0 -1
- package/dist/src/streams/flows-stream.js +0 -35
- package/dist/src/streams/redis-logs-stream.d.ts +0 -31
- package/dist/src/streams/redis-logs-stream.d.ts.map +0 -1
- package/dist/src/streams/redis-logs-stream.js +0 -84
- package/dist/src/streams/stream-factory.d.ts +0 -3
- package/dist/src/streams/stream-factory.d.ts.map +0 -1
- package/dist/src/streams/stream-factory.js +0 -2
- package/dist/src/types/app-config-types.d.ts +0 -45
- package/dist/src/types/app-config-types.d.ts.map +0 -1
- package/dist/src/types/app-config-types.js +0 -2
- package/dist/src/types/flows-config-types.d.ts +0 -10
- package/dist/src/types/flows-config-types.d.ts.map +0 -1
- package/dist/src/types/flows-config-types.js +0 -2
- package/dist/src/types/flows-types.d.ts +0 -39
- package/dist/src/types/flows-types.d.ts.map +0 -1
- package/dist/src/types/flows-types.js +0 -2
- package/dist/src/types/generate-type-from-schema.d.ts +0 -3
- package/dist/src/types/generate-type-from-schema.d.ts.map +0 -1
- package/dist/src/types/generate-type-from-schema.js +0 -49
- package/dist/src/types/generate-types-from-response.d.ts +0 -3
- package/dist/src/types/generate-types-from-response.d.ts.map +0 -1
- package/dist/src/types/generate-types-from-response.js +0 -13
- package/dist/src/types/generate-types.d.ts +0 -13
- package/dist/src/types/generate-types.d.ts.map +0 -1
- package/dist/src/types/generate-types.js +0 -127
- package/dist/src/types/merge-schemas.d.ts +0 -5
- package/dist/src/types/merge-schemas.d.ts.map +0 -1
- package/dist/src/types/merge-schemas.js +0 -183
- package/dist/src/types/schema.types.d.ts +0 -9
- package/dist/src/types/schema.types.d.ts.map +0 -1
- package/dist/src/types/schema.types.js +0 -14
- package/dist/src/types-stream.d.ts +0 -42
- package/dist/src/types-stream.d.ts.map +0 -1
- package/dist/src/types-stream.js +0 -2
- package/dist/src/types.d.ts +0 -190
- package/dist/src/types.d.ts.map +0 -1
- package/dist/src/types.js +0 -17
- package/dist/src/utils.d.ts +0 -3
- package/dist/src/utils.d.ts.map +0 -1
- package/dist/src/utils.js +0 -12
- package/dist/src/validate-event-input.d.ts +0 -3
- package/dist/src/validate-event-input.d.ts.map +0 -1
- package/dist/src/validate-event-input.js +0 -74
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
import { trackEvent } from "./analytics/utils.mjs";
|
|
2
|
+
import { getLanguageBasedRunner } from "./language-runner.mjs";
|
|
3
|
+
import { ProcessManager } from "./process-communication/process-manager.mjs";
|
|
4
|
+
import { isAllowedToEmit } from "./utils.mjs";
|
|
5
|
+
|
|
6
|
+
//#region src/call-step-file.ts
|
|
7
|
+
const callStepFile = (options, motia) => {
|
|
8
|
+
const { step, traceId, data, tracer, logger, contextInFirstArg = false, infrastructure } = options;
|
|
9
|
+
const flows = step.config.flows;
|
|
10
|
+
return new Promise((resolve, reject) => {
|
|
11
|
+
const streamConfig = motia.lockedData.getStreams();
|
|
12
|
+
const streams = Object.keys(streamConfig).map((name) => ({ name }));
|
|
13
|
+
const jsonData = JSON.stringify({
|
|
14
|
+
data,
|
|
15
|
+
flows,
|
|
16
|
+
traceId,
|
|
17
|
+
contextInFirstArg,
|
|
18
|
+
streams
|
|
19
|
+
});
|
|
20
|
+
const { runner, command, args } = getLanguageBasedRunner(step.filePath);
|
|
21
|
+
let result;
|
|
22
|
+
let timeoutId;
|
|
23
|
+
const processManager = new ProcessManager({
|
|
24
|
+
command,
|
|
25
|
+
args: [
|
|
26
|
+
...args,
|
|
27
|
+
runner,
|
|
28
|
+
step.filePath,
|
|
29
|
+
jsonData
|
|
30
|
+
],
|
|
31
|
+
logger,
|
|
32
|
+
context: "StepExecution",
|
|
33
|
+
projectRoot: motia.lockedData.baseDir
|
|
34
|
+
});
|
|
35
|
+
trackEvent("step_execution_started", {
|
|
36
|
+
stepName: step.config.name,
|
|
37
|
+
language: command,
|
|
38
|
+
type: step.config.type,
|
|
39
|
+
streams: streams.length
|
|
40
|
+
});
|
|
41
|
+
const timeoutSeconds = infrastructure?.handler?.timeout;
|
|
42
|
+
if (timeoutSeconds) timeoutId = setTimeout(async () => {
|
|
43
|
+
processManager.kill();
|
|
44
|
+
const errorMessage = `Step execution timed out after ${timeoutSeconds} seconds`;
|
|
45
|
+
logger.error(errorMessage, {
|
|
46
|
+
step: step.config.name,
|
|
47
|
+
timeout: timeoutSeconds
|
|
48
|
+
});
|
|
49
|
+
await tracer.end({ message: errorMessage });
|
|
50
|
+
trackEvent("step_execution_timeout", {
|
|
51
|
+
stepName: step.config.name,
|
|
52
|
+
traceId,
|
|
53
|
+
timeout: timeoutSeconds
|
|
54
|
+
});
|
|
55
|
+
reject(new Error(errorMessage));
|
|
56
|
+
}, timeoutSeconds * 1e3);
|
|
57
|
+
processManager.spawn().then(() => {
|
|
58
|
+
processManager.handler("close", async (err) => {
|
|
59
|
+
if (err) {
|
|
60
|
+
if (timeoutId) clearTimeout(timeoutId);
|
|
61
|
+
processManager.close();
|
|
62
|
+
trackEvent("step_execution_error", {
|
|
63
|
+
stepName: step.config.name,
|
|
64
|
+
traceId,
|
|
65
|
+
message: err.message
|
|
66
|
+
});
|
|
67
|
+
await tracer.end({
|
|
68
|
+
message: err.message,
|
|
69
|
+
code: err.code,
|
|
70
|
+
stack: err.stack?.replace(/* @__PURE__ */ new RegExp(`${motia.lockedData.baseDir}/`), "")
|
|
71
|
+
});
|
|
72
|
+
reject(err ?? /* @__PURE__ */ new Error("Handler execution failed"));
|
|
73
|
+
} else await tracer.end();
|
|
74
|
+
processManager.kill();
|
|
75
|
+
});
|
|
76
|
+
processManager.handler("log", async (input) => logger.log(input));
|
|
77
|
+
processManager.handler("state.get", async (input) => {
|
|
78
|
+
await tracer.stateOperation("get", input);
|
|
79
|
+
return motia.state.get(input.traceId, input.key);
|
|
80
|
+
});
|
|
81
|
+
processManager.handler("state.set", async (input) => {
|
|
82
|
+
await tracer.stateOperation("set", {
|
|
83
|
+
traceId: input.traceId,
|
|
84
|
+
key: input.key,
|
|
85
|
+
value: input.value
|
|
86
|
+
});
|
|
87
|
+
return motia.state.set(input.traceId, input.key, input.value);
|
|
88
|
+
});
|
|
89
|
+
processManager.handler("state.delete", async (input) => {
|
|
90
|
+
await tracer.stateOperation("delete", input);
|
|
91
|
+
return motia.state.delete(input.traceId, input.key);
|
|
92
|
+
});
|
|
93
|
+
processManager.handler("state.clear", async (input) => {
|
|
94
|
+
await tracer.stateOperation("clear", input);
|
|
95
|
+
return motia.state.clear(input.traceId);
|
|
96
|
+
});
|
|
97
|
+
processManager.handler(`state.getGroup`, async (input) => {
|
|
98
|
+
await tracer.stateOperation("getGroup", input);
|
|
99
|
+
return motia.state.getGroup(input.groupId);
|
|
100
|
+
});
|
|
101
|
+
processManager.handler("result", async (input) => {
|
|
102
|
+
const anyInput = { ...input };
|
|
103
|
+
if (anyInput.body && anyInput.body.type === "Buffer") anyInput.body = Buffer.from(anyInput.body.data);
|
|
104
|
+
result = anyInput;
|
|
105
|
+
});
|
|
106
|
+
processManager.handler("emit", async (input) => {
|
|
107
|
+
const flows$1 = step.config.flows;
|
|
108
|
+
if (!isAllowedToEmit(step, input.topic)) {
|
|
109
|
+
await tracer.emitOperation(input.topic, input.data, false);
|
|
110
|
+
return motia.printer.printInvalidEmit(step, input.topic);
|
|
111
|
+
}
|
|
112
|
+
await tracer.emitOperation(input.topic, input.data, true);
|
|
113
|
+
return motia.eventAdapter.emit({
|
|
114
|
+
...input,
|
|
115
|
+
traceId,
|
|
116
|
+
flows: flows$1,
|
|
117
|
+
logger,
|
|
118
|
+
tracer
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
Object.entries(streamConfig).forEach(([name, streamFactory]) => {
|
|
122
|
+
const stateStream = streamFactory();
|
|
123
|
+
processManager.handler(`streams.${name}.get`, async (input) => {
|
|
124
|
+
await tracer.streamOperation(name, "get", input);
|
|
125
|
+
return stateStream.get(input.groupId, input.id);
|
|
126
|
+
});
|
|
127
|
+
processManager.handler(`streams.${name}.set`, async (input) => {
|
|
128
|
+
await tracer.streamOperation(name, "set", {
|
|
129
|
+
groupId: input.groupId,
|
|
130
|
+
id: input.id,
|
|
131
|
+
data: input.data
|
|
132
|
+
});
|
|
133
|
+
return stateStream.set(input.groupId, input.id, input.data);
|
|
134
|
+
});
|
|
135
|
+
processManager.handler(`streams.${name}.delete`, async (input) => {
|
|
136
|
+
await tracer.streamOperation(name, "delete", input);
|
|
137
|
+
return stateStream.delete(input.groupId, input.id);
|
|
138
|
+
});
|
|
139
|
+
processManager.handler(`streams.${name}.getGroup`, async (input) => {
|
|
140
|
+
await tracer.streamOperation(name, "getGroup", input);
|
|
141
|
+
return stateStream.getGroup(input.groupId);
|
|
142
|
+
});
|
|
143
|
+
processManager.handler(`streams.${name}.send`, async (input) => {
|
|
144
|
+
await tracer.streamOperation(name, "send", input);
|
|
145
|
+
return stateStream.send(input.channel, input.event);
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
processManager.onStdout((data$1) => {
|
|
149
|
+
try {
|
|
150
|
+
const message = JSON.parse(data$1.toString());
|
|
151
|
+
logger.log(message);
|
|
152
|
+
} catch {
|
|
153
|
+
logger.info(Buffer.from(data$1).toString());
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
processManager.onStderr((data$1) => logger.error(Buffer.from(data$1).toString()));
|
|
157
|
+
processManager.onProcessClose(async (code) => {
|
|
158
|
+
if (timeoutId) clearTimeout(timeoutId);
|
|
159
|
+
processManager.close();
|
|
160
|
+
if (code !== 0 && code !== null) {
|
|
161
|
+
const error = {
|
|
162
|
+
message: `Process exited with code ${code}`,
|
|
163
|
+
code
|
|
164
|
+
};
|
|
165
|
+
await tracer.end(error);
|
|
166
|
+
trackEvent("step_execution_error", {
|
|
167
|
+
stepName: step.config.name,
|
|
168
|
+
traceId,
|
|
169
|
+
code
|
|
170
|
+
});
|
|
171
|
+
reject(`Process exited with code ${code}`);
|
|
172
|
+
} else {
|
|
173
|
+
await tracer.end();
|
|
174
|
+
resolve(result);
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
processManager.onProcessError(async (error) => {
|
|
178
|
+
if (timeoutId) clearTimeout(timeoutId);
|
|
179
|
+
processManager.close();
|
|
180
|
+
await tracer.end({
|
|
181
|
+
message: error.message,
|
|
182
|
+
code: error.code,
|
|
183
|
+
stack: error.stack
|
|
184
|
+
});
|
|
185
|
+
if (error.code === "ENOENT") {
|
|
186
|
+
trackEvent("step_execution_error", {
|
|
187
|
+
stepName: step.config.name,
|
|
188
|
+
traceId,
|
|
189
|
+
code: error.code,
|
|
190
|
+
message: error.message
|
|
191
|
+
});
|
|
192
|
+
reject(`Executable ${command} not found`);
|
|
193
|
+
} else reject(error);
|
|
194
|
+
});
|
|
195
|
+
}).catch(async (error) => {
|
|
196
|
+
if (timeoutId) clearTimeout(timeoutId);
|
|
197
|
+
await tracer.end({
|
|
198
|
+
message: error.message,
|
|
199
|
+
code: error.code,
|
|
200
|
+
stack: error.stack
|
|
201
|
+
});
|
|
202
|
+
trackEvent("step_execution_error", {
|
|
203
|
+
stepName: step.config.name,
|
|
204
|
+
traceId,
|
|
205
|
+
code: error.code,
|
|
206
|
+
message: error.message
|
|
207
|
+
});
|
|
208
|
+
reject(`Failed to spawn process: ${error}`);
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
};
|
|
212
|
+
|
|
213
|
+
//#endregion
|
|
214
|
+
export { callStepFile };
|
|
215
|
+
//# sourceMappingURL=call-step-file.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"call-step-file.mjs","names":["result: TData | undefined","timeoutId: NodeJS.Timeout | undefined","anyInput: any","flows","data"],"sources":["../../src/call-step-file.ts"],"sourcesContent":["import { trackEvent } from './analytics/utils'\nimport { getLanguageBasedRunner } from './language-runner'\nimport type { Logger } from './logger'\nimport type { Motia } from './motia'\nimport type { Tracer } from './observability'\nimport type { TraceError } from './observability/types'\nimport { ProcessManager } from './process-communication/process-manager'\nimport type { Event, InfrastructureConfig, Step } from './types'\nimport type { BaseStreamItem, StateStreamEvent, StateStreamEventChannel } from './types-stream'\nimport { isAllowedToEmit } from './utils'\n\ntype StateGetInput = { traceId: string; key: string }\ntype StateSetInput = { traceId: string; key: string; value: unknown }\ntype StateDeleteInput = { traceId: string; key: string }\ntype StateClearInput = { traceId: string }\n\ntype StateStreamGetInput = { groupId: string; id: string }\ntype StateStreamSendInput = { channel: StateStreamEventChannel; event: StateStreamEvent<unknown> }\ntype StateStreamMutateInput = { groupId: string; id: string; data: BaseStreamItem }\n\ntype CallStepFileOptions = {\n step: Step\n traceId: string\n data?: unknown\n contextInFirstArg?: boolean\n logger: Logger\n tracer: Tracer\n infrastructure?: Partial<InfrastructureConfig>\n}\n\nexport const callStepFile = <TData>(options: CallStepFileOptions, motia: Motia): Promise<TData | undefined> => {\n const { step, traceId, data, tracer, logger, contextInFirstArg = false, infrastructure } = options\n\n const flows = step.config.flows\n\n return new Promise((resolve, reject) => {\n const streamConfig = motia.lockedData.getStreams()\n const streams = Object.keys(streamConfig).map((name) => ({ name }))\n const jsonData = JSON.stringify({ data, flows, traceId, contextInFirstArg, streams })\n const { runner, command, args } = getLanguageBasedRunner(step.filePath)\n let result: TData | undefined\n let timeoutId: NodeJS.Timeout | undefined\n\n const processManager = new ProcessManager({\n command,\n args: [...args, runner, step.filePath, jsonData],\n logger,\n context: 'StepExecution',\n projectRoot: motia.lockedData.baseDir,\n })\n\n trackEvent('step_execution_started', {\n stepName: step.config.name,\n language: command,\n type: step.config.type,\n streams: streams.length,\n })\n\n const timeoutSeconds = infrastructure?.handler?.timeout\n if (timeoutSeconds) {\n timeoutId = setTimeout(async () => {\n processManager.kill()\n const errorMessage = `Step execution timed out after ${timeoutSeconds} seconds`\n logger.error(errorMessage, { step: step.config.name, timeout: timeoutSeconds })\n await tracer.end({ message: errorMessage })\n trackEvent('step_execution_timeout', {\n stepName: step.config.name,\n traceId,\n timeout: timeoutSeconds,\n })\n reject(new Error(errorMessage))\n }, timeoutSeconds * 1000)\n }\n\n processManager\n .spawn()\n .then(() => {\n processManager.handler<TraceError | undefined>('close', async (err) => {\n if (err) {\n if (timeoutId) clearTimeout(timeoutId)\n processManager.close()\n\n trackEvent('step_execution_error', {\n stepName: step.config.name,\n traceId,\n message: err.message,\n })\n\n await tracer.end({\n message: err.message,\n code: err.code,\n stack: err.stack?.replace(new RegExp(`${motia.lockedData.baseDir}/`), ''),\n })\n\n const error = err ?? new Error('Handler execution failed')\n\n reject(error)\n } else {\n await tracer.end()\n }\n\n processManager.kill()\n })\n processManager.handler<unknown>('log', async (input: unknown) => logger.log(input))\n\n processManager.handler<StateGetInput, unknown>('state.get', async (input) => {\n await tracer.stateOperation('get', input)\n return motia.state.get(input.traceId, input.key)\n })\n\n processManager.handler<StateSetInput, unknown>('state.set', async (input) => {\n await tracer.stateOperation('set', { traceId: input.traceId, key: input.key, value: input.value })\n return motia.state.set(input.traceId, input.key, input.value)\n })\n\n processManager.handler<StateDeleteInput, unknown>('state.delete', async (input) => {\n await tracer.stateOperation('delete', input)\n return motia.state.delete(input.traceId, input.key)\n })\n\n processManager.handler<StateClearInput, void>('state.clear', async (input) => {\n await tracer.stateOperation('clear', input)\n return motia.state.clear(input.traceId)\n })\n\n processManager.handler<StateStreamGetInput>(`state.getGroup`, async (input) => {\n await tracer.stateOperation('getGroup', input)\n return motia.state.getGroup(input.groupId)\n })\n\n processManager.handler<TData, void>('result', async (input) => {\n const anyInput: any = { ...input }\n\n if (anyInput.body && anyInput.body.type === 'Buffer') {\n anyInput.body = Buffer.from(anyInput.body.data)\n }\n result = anyInput\n })\n\n processManager.handler<Event, unknown>('emit', async (input) => {\n const flows = step.config.flows\n\n if (!isAllowedToEmit(step, input.topic)) {\n await tracer.emitOperation(input.topic, input.data, false)\n return motia.printer.printInvalidEmit(step, input.topic)\n }\n\n await tracer.emitOperation(input.topic, input.data, true)\n return motia.eventAdapter.emit({ ...input, traceId, flows, logger, tracer })\n })\n\n Object.entries(streamConfig).forEach(([name, streamFactory]) => {\n const stateStream = streamFactory()\n\n processManager.handler<StateStreamGetInput>(`streams.${name}.get`, async (input) => {\n await tracer.streamOperation(name, 'get', input)\n return stateStream.get(input.groupId, input.id)\n })\n\n processManager.handler<StateStreamMutateInput>(`streams.${name}.set`, async (input) => {\n await tracer.streamOperation(name, 'set', { groupId: input.groupId, id: input.id, data: input.data })\n return stateStream.set(input.groupId, input.id, input.data)\n })\n\n processManager.handler<StateStreamGetInput>(`streams.${name}.delete`, async (input) => {\n await tracer.streamOperation(name, 'delete', input)\n return stateStream.delete(input.groupId, input.id)\n })\n\n processManager.handler<StateStreamGetInput>(`streams.${name}.getGroup`, async (input) => {\n await tracer.streamOperation(name, 'getGroup', input)\n return stateStream.getGroup(input.groupId)\n })\n\n processManager.handler<StateStreamSendInput>(`streams.${name}.send`, async (input) => {\n await tracer.streamOperation(name, 'send', input)\n return stateStream.send(input.channel, input.event)\n })\n })\n\n processManager.onStdout((data) => {\n try {\n const message = JSON.parse(data.toString())\n logger.log(message)\n } catch {\n logger.info(Buffer.from(data).toString())\n }\n })\n\n processManager.onStderr((data) => logger.error(Buffer.from(data).toString()))\n\n processManager.onProcessClose(async (code) => {\n if (timeoutId) clearTimeout(timeoutId)\n processManager.close()\n\n if (code !== 0 && code !== null) {\n const error = { message: `Process exited with code ${code}`, code }\n await tracer.end(error)\n trackEvent('step_execution_error', { stepName: step.config.name, traceId, code })\n reject(`Process exited with code ${code}`)\n } else {\n await tracer.end()\n resolve(result)\n }\n })\n\n processManager.onProcessError(async (error) => {\n if (timeoutId) clearTimeout(timeoutId)\n processManager.close()\n await tracer.end({\n message: error.message,\n code: error.code,\n stack: error.stack,\n })\n\n if (error.code === 'ENOENT') {\n trackEvent('step_execution_error', {\n stepName: step.config.name,\n traceId,\n code: error.code,\n message: error.message,\n })\n reject(`Executable ${command} not found`)\n } else {\n reject(error)\n }\n })\n })\n .catch(async (error) => {\n if (timeoutId) clearTimeout(timeoutId)\n await tracer.end({\n message: error.message,\n code: error.code,\n stack: error.stack,\n })\n\n trackEvent('step_execution_error', {\n stepName: step.config.name,\n traceId,\n code: error.code,\n message: error.message,\n })\n reject(`Failed to spawn process: ${error}`)\n })\n })\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.mts","names":[],"sources":["../../src/config.ts"],"sourcesContent":[],"mappings":";;;cAEa,iBAAkB,WAAS"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.mjs","names":["config"],"sources":["../../src/config.ts"],"sourcesContent":["import type { Config } from './types/app-config-types'\n\nexport const config = (config: Config): Config => config\n"],"mappings":";AAEA,MAAa,UAAU,aAA2BA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { CronAdapter } from "./adapters/interfaces/cron-adapter.interface.mjs";
|
|
2
|
+
import { Motia } from "./motia.mjs";
|
|
3
|
+
import { CronConfig, Step } from "./types.mjs";
|
|
4
|
+
|
|
5
|
+
//#region src/cron-handler.d.ts
|
|
6
|
+
type CronManager = {
|
|
7
|
+
createCronJob: (step: Step<CronConfig>) => void;
|
|
8
|
+
removeCronJob: (step: Step<CronConfig>) => void;
|
|
9
|
+
close: () => Promise<void>;
|
|
10
|
+
};
|
|
11
|
+
declare const setupCronHandlers: (motia: Motia, cronAdapter?: CronAdapter) => {
|
|
12
|
+
createCronJob: (step: Step<CronConfig>) => void;
|
|
13
|
+
removeCronJob: (step: Step<CronConfig>) => void;
|
|
14
|
+
close: () => Promise<void>;
|
|
15
|
+
};
|
|
16
|
+
//#endregion
|
|
17
|
+
export { CronManager, setupCronHandlers };
|
|
18
|
+
//# sourceMappingURL=cron-handler.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cron-handler.d.mts","names":[],"sources":["../../src/cron-handler.ts"],"sourcesContent":[],"mappings":";;;;;KAQY,WAAA;wBACY,KAAK;EADjB,aAAA,EAAW,CAAA,IAAA,EAEC,IAFD,CAEM,UAFN,CAAA,EAAA,GAAA,IAAA;EACM,KAAA,EAAA,GAAA,GAEd,OAFc,CAAA,IAAA,CAAA;CAAL;AACK,cAIhB,iBAJgB,EAAA,CAAA,KAAA,EAIY,KAJZ,EAAA,WAAA,CAAA,EAIiC,WAJjC,EAAA,GAAA;EAAL,aAAA,EAAA,CAAA,IAAA,EAOO,IAPP,CAOY,UAPZ,CAAA,EAAA,GAAA,IAAA;EACT,aAAA,EAAA,CAAA,IAAA,EAoFgB,IApFhB,CAoFqB,UApFrB,CAAA,EAAA,GAAA,IAAA;EAAO,KAAA,EAAA,GAAA,UAAA,CAAA,IAAA,CAAA;AAGtB,CAAA"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { globalLogger } from "./logger.mjs";
|
|
2
|
+
import { callStepFile } from "./call-step-file.mjs";
|
|
3
|
+
import { generateTraceId } from "./generate-trace-id.mjs";
|
|
4
|
+
import * as cron from "node-cron";
|
|
5
|
+
|
|
6
|
+
//#region src/cron-handler.ts
|
|
7
|
+
const setupCronHandlers = (motia, cronAdapter) => {
|
|
8
|
+
const cronJobs = /* @__PURE__ */ new Map();
|
|
9
|
+
const createCronJob = (step) => {
|
|
10
|
+
const { config, filePath } = step;
|
|
11
|
+
const { cron: cronExpression, name: stepName, flows } = config;
|
|
12
|
+
if (!cron.validate(cronExpression)) {
|
|
13
|
+
globalLogger.error("[cron handler] invalid cron expression", {
|
|
14
|
+
expression: cronExpression,
|
|
15
|
+
step: stepName
|
|
16
|
+
});
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
globalLogger.debug("[cron handler] setting up cron job", {
|
|
20
|
+
filePath,
|
|
21
|
+
step: stepName,
|
|
22
|
+
cron: cronExpression
|
|
23
|
+
});
|
|
24
|
+
const task = cron.schedule(cronExpression, async () => {
|
|
25
|
+
let lock = null;
|
|
26
|
+
if (cronAdapter) try {
|
|
27
|
+
lock = await cronAdapter.acquireLock(stepName, 3e5);
|
|
28
|
+
if (!lock) {
|
|
29
|
+
globalLogger.debug("[cron handler] failed to acquire lock, skipping execution", { step: stepName });
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
globalLogger.debug("[cron handler] acquired lock for cron job", {
|
|
33
|
+
step: stepName,
|
|
34
|
+
lockId: lock.lockId,
|
|
35
|
+
instanceId: lock.instanceId
|
|
36
|
+
});
|
|
37
|
+
} catch (error) {
|
|
38
|
+
globalLogger.error("[cron handler] error acquiring lock", {
|
|
39
|
+
error: error.message,
|
|
40
|
+
step: stepName
|
|
41
|
+
});
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
const traceId = generateTraceId();
|
|
45
|
+
const logger = motia.loggerFactory.create({
|
|
46
|
+
traceId,
|
|
47
|
+
flows,
|
|
48
|
+
stepName
|
|
49
|
+
});
|
|
50
|
+
const tracer = await motia.tracerFactory.createTracer(traceId, step, logger);
|
|
51
|
+
try {
|
|
52
|
+
await callStepFile({
|
|
53
|
+
contextInFirstArg: true,
|
|
54
|
+
step,
|
|
55
|
+
traceId,
|
|
56
|
+
tracer,
|
|
57
|
+
logger
|
|
58
|
+
}, motia);
|
|
59
|
+
} catch (error) {
|
|
60
|
+
logger.error("[cron handler] error executing cron job", {
|
|
61
|
+
error: error.message,
|
|
62
|
+
step: step.config.name
|
|
63
|
+
});
|
|
64
|
+
} finally {
|
|
65
|
+
if (lock && cronAdapter) try {
|
|
66
|
+
await cronAdapter.releaseLock(lock);
|
|
67
|
+
globalLogger.debug("[cron handler] released lock for cron job", {
|
|
68
|
+
step: stepName,
|
|
69
|
+
lockId: lock.lockId
|
|
70
|
+
});
|
|
71
|
+
} catch (error) {
|
|
72
|
+
globalLogger.error("[cron handler] error releasing lock", {
|
|
73
|
+
error: error.message,
|
|
74
|
+
step: stepName
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
cronJobs.set(step.filePath, task);
|
|
80
|
+
};
|
|
81
|
+
const removeCronJob = (step) => {
|
|
82
|
+
const task = cronJobs.get(step.filePath);
|
|
83
|
+
if (task) {
|
|
84
|
+
task.stop();
|
|
85
|
+
cronJobs.delete(step.filePath);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
const close = async () => {
|
|
89
|
+
cronJobs.forEach((task) => task.stop());
|
|
90
|
+
cronJobs.clear();
|
|
91
|
+
if (cronAdapter) await cronAdapter.shutdown();
|
|
92
|
+
};
|
|
93
|
+
motia.lockedData.cronSteps().forEach(createCronJob);
|
|
94
|
+
return {
|
|
95
|
+
createCronJob,
|
|
96
|
+
removeCronJob,
|
|
97
|
+
close
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
//#endregion
|
|
102
|
+
export { setupCronHandlers };
|
|
103
|
+
//# sourceMappingURL=cron-handler.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cron-handler.mjs","names":["lock: CronLock | null","error: any"],"sources":["../../src/cron-handler.ts"],"sourcesContent":["import * as cron from 'node-cron'\nimport type { CronAdapter, CronLock } from './adapters/interfaces/cron-adapter.interface'\nimport { callStepFile } from './call-step-file'\nimport { generateTraceId } from './generate-trace-id'\nimport { globalLogger } from './logger'\nimport type { Motia } from './motia'\nimport type { CronConfig, Step } from './types'\n\nexport type CronManager = {\n createCronJob: (step: Step<CronConfig>) => void\n removeCronJob: (step: Step<CronConfig>) => void\n close: () => Promise<void>\n}\n\nexport const setupCronHandlers = (motia: Motia, cronAdapter?: CronAdapter) => {\n const cronJobs = new Map<string, cron.ScheduledTask>()\n\n const createCronJob = (step: Step<CronConfig>) => {\n const { config, filePath } = step\n const { cron: cronExpression, name: stepName, flows } = config\n\n if (!cron.validate(cronExpression)) {\n globalLogger.error('[cron handler] invalid cron expression', {\n expression: cronExpression,\n step: stepName,\n })\n return\n }\n\n globalLogger.debug('[cron handler] setting up cron job', {\n filePath,\n step: stepName,\n cron: cronExpression,\n })\n\n const task = cron.schedule(cronExpression, async () => {\n let lock: CronLock | null = null\n\n if (cronAdapter) {\n try {\n lock = await cronAdapter.acquireLock(stepName, 300000)\n\n if (!lock) {\n globalLogger.debug('[cron handler] failed to acquire lock, skipping execution', {\n step: stepName,\n })\n return\n }\n\n globalLogger.debug('[cron handler] acquired lock for cron job', {\n step: stepName,\n lockId: lock.lockId,\n instanceId: lock.instanceId,\n })\n } catch (error: any) {\n globalLogger.error('[cron handler] error acquiring lock', {\n error: error.message,\n step: stepName,\n })\n return\n }\n }\n\n const traceId = generateTraceId()\n const logger = motia.loggerFactory.create({ traceId, flows, stepName })\n const tracer = await motia.tracerFactory.createTracer(traceId, step, logger)\n\n try {\n await callStepFile({ contextInFirstArg: true, step, traceId, tracer, logger }, motia)\n } catch (error: any) {\n logger.error('[cron handler] error executing cron job', {\n error: error.message,\n step: step.config.name,\n })\n } finally {\n if (lock && cronAdapter) {\n try {\n await cronAdapter.releaseLock(lock)\n globalLogger.debug('[cron handler] released lock for cron job', {\n step: stepName,\n lockId: lock.lockId,\n })\n } catch (error: any) {\n globalLogger.error('[cron handler] error releasing lock', {\n error: error.message,\n step: stepName,\n })\n }\n }\n }\n })\n\n cronJobs.set(step.filePath, task)\n }\n\n const removeCronJob = (step: Step<CronConfig>) => {\n const task = cronJobs.get(step.filePath)\n\n if (task) {\n task.stop()\n cronJobs.delete(step.filePath)\n }\n }\n\n const close = async () => {\n cronJobs.forEach((task) => task.stop())\n cronJobs.clear()\n\n if (cronAdapter) {\n await cronAdapter.shutdown()\n }\n }\n\n motia.lockedData.cronSteps().forEach(createCronJob)\n\n return { createCronJob, removeCronJob, close }\n}\n"],"mappings":";;;;;;AAcA,MAAa,qBAAqB,OAAc,gBAA8B;CAC5E,MAAM,2BAAW,IAAI,KAAiC;CAEtD,MAAM,iBAAiB,SAA2B;EAChD,MAAM,EAAE,QAAQ,aAAa;EAC7B,MAAM,EAAE,MAAM,gBAAgB,MAAM,UAAU,UAAU;AAExD,MAAI,CAAC,KAAK,SAAS,eAAe,EAAE;AAClC,gBAAa,MAAM,0CAA0C;IAC3D,YAAY;IACZ,MAAM;IACP,CAAC;AACF;;AAGF,eAAa,MAAM,sCAAsC;GACvD;GACA,MAAM;GACN,MAAM;GACP,CAAC;EAEF,MAAM,OAAO,KAAK,SAAS,gBAAgB,YAAY;GACrD,IAAIA,OAAwB;AAE5B,OAAI,YACF,KAAI;AACF,WAAO,MAAM,YAAY,YAAY,UAAU,IAAO;AAEtD,QAAI,CAAC,MAAM;AACT,kBAAa,MAAM,6DAA6D,EAC9E,MAAM,UACP,CAAC;AACF;;AAGF,iBAAa,MAAM,6CAA6C;KAC9D,MAAM;KACN,QAAQ,KAAK;KACb,YAAY,KAAK;KAClB,CAAC;YACKC,OAAY;AACnB,iBAAa,MAAM,uCAAuC;KACxD,OAAO,MAAM;KACb,MAAM;KACP,CAAC;AACF;;GAIJ,MAAM,UAAU,iBAAiB;GACjC,MAAM,SAAS,MAAM,cAAc,OAAO;IAAE;IAAS;IAAO;IAAU,CAAC;GACvE,MAAM,SAAS,MAAM,MAAM,cAAc,aAAa,SAAS,MAAM,OAAO;AAE5E,OAAI;AACF,UAAM,aAAa;KAAE,mBAAmB;KAAM;KAAM;KAAS;KAAQ;KAAQ,EAAE,MAAM;YAC9EA,OAAY;AACnB,WAAO,MAAM,2CAA2C;KACtD,OAAO,MAAM;KACb,MAAM,KAAK,OAAO;KACnB,CAAC;aACM;AACR,QAAI,QAAQ,YACV,KAAI;AACF,WAAM,YAAY,YAAY,KAAK;AACnC,kBAAa,MAAM,6CAA6C;MAC9D,MAAM;MACN,QAAQ,KAAK;MACd,CAAC;aACKA,OAAY;AACnB,kBAAa,MAAM,uCAAuC;MACxD,OAAO,MAAM;MACb,MAAM;MACP,CAAC;;;IAIR;AAEF,WAAS,IAAI,KAAK,UAAU,KAAK;;CAGnC,MAAM,iBAAiB,SAA2B;EAChD,MAAM,OAAO,SAAS,IAAI,KAAK,SAAS;AAExC,MAAI,MAAM;AACR,QAAK,MAAM;AACX,YAAS,OAAO,KAAK,SAAS;;;CAIlC,MAAM,QAAQ,YAAY;AACxB,WAAS,SAAS,SAAS,KAAK,MAAM,CAAC;AACvC,WAAS,OAAO;AAEhB,MAAI,YACF,OAAM,YAAY,UAAU;;AAIhC,OAAM,WAAW,WAAW,CAAC,QAAQ,cAAc;AAEnD,QAAO;EAAE;EAAe;EAAe;EAAO"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { getProjectIdentifier, getUserIdentifier, isAnalyticsEnabled } from "../analytics/utils.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/endpoints/analytics-endpoint.ts
|
|
4
|
+
const analyticsEndpoint = (app, baseDir) => {
|
|
5
|
+
app.get("/motia/analytics/user", (_req, res) => {
|
|
6
|
+
if (!isAnalyticsEnabled()) {
|
|
7
|
+
res.json({
|
|
8
|
+
userId: null,
|
|
9
|
+
projectId: null,
|
|
10
|
+
motiaVersion: null,
|
|
11
|
+
analyticsEnabled: false
|
|
12
|
+
});
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
res.json({
|
|
16
|
+
userId: getUserIdentifier(),
|
|
17
|
+
projectId: getProjectIdentifier(baseDir),
|
|
18
|
+
motiaVersion: process.env.npm_package_dependencies_motia || "unknown",
|
|
19
|
+
analyticsEnabled: true
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
app.get("/motia/analytics/status", (_req, res) => {
|
|
23
|
+
res.json({ analyticsEnabled: isAnalyticsEnabled() });
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
//#endregion
|
|
28
|
+
export { analyticsEndpoint };
|
|
29
|
+
//# sourceMappingURL=analytics-endpoint.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"analytics-endpoint.mjs","names":[],"sources":["../../../src/endpoints/analytics-endpoint.ts"],"sourcesContent":["import type { Express } from 'express'\nimport { getProjectIdentifier, getUserIdentifier, isAnalyticsEnabled } from '../analytics/utils'\n\nexport const analyticsEndpoint = (app: Express, baseDir: string) => {\n app.get('/motia/analytics/user', (_req, res) => {\n const analyticsEnabled = isAnalyticsEnabled()\n\n if (!analyticsEnabled) {\n res.json({\n userId: null,\n projectId: null,\n motiaVersion: null,\n analyticsEnabled: false,\n })\n return\n }\n\n res.json({\n userId: getUserIdentifier(),\n projectId: getProjectIdentifier(baseDir),\n motiaVersion: process.env.npm_package_dependencies_motia || 'unknown',\n analyticsEnabled: true,\n })\n })\n\n app.get('/motia/analytics/status', (_req, res) => {\n res.json({ analyticsEnabled: isAnalyticsEnabled() })\n })\n}\n"],"mappings":";;;AAGA,MAAa,qBAAqB,KAAc,YAAoB;AAClE,KAAI,IAAI,0BAA0B,MAAM,QAAQ;AAG9C,MAAI,CAFqB,oBAAoB,EAEtB;AACrB,OAAI,KAAK;IACP,QAAQ;IACR,WAAW;IACX,cAAc;IACd,kBAAkB;IACnB,CAAC;AACF;;AAGF,MAAI,KAAK;GACP,QAAQ,mBAAmB;GAC3B,WAAW,qBAAqB,QAAQ;GACxC,cAAc,QAAQ,IAAI,kCAAkC;GAC5D,kBAAkB;GACnB,CAAC;GACF;AAEF,KAAI,IAAI,4BAA4B,MAAM,QAAQ;AAChD,MAAI,KAAK,EAAE,kBAAkB,oBAAoB,EAAE,CAAC;GACpD"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { FlowsConfigStream } from "../streams/flows-config-stream.mjs";
|
|
2
|
+
import path from "path";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
|
|
5
|
+
//#region src/endpoints/flows-config-endpoint.ts
|
|
6
|
+
const flowsConfigEndpoint = (app, baseDir, lockedData) => {
|
|
7
|
+
const stream = new FlowsConfigStream(path.join(baseDir, "motia-workbench.json"));
|
|
8
|
+
lockedData.createStream({
|
|
9
|
+
filePath: "__motia.flowsConfig",
|
|
10
|
+
hidden: true,
|
|
11
|
+
config: {
|
|
12
|
+
name: "__motia.flowsConfig",
|
|
13
|
+
schema: z.object({
|
|
14
|
+
name: z.string(),
|
|
15
|
+
steps: z.any(),
|
|
16
|
+
edges: z.any()
|
|
17
|
+
}),
|
|
18
|
+
baseConfig: {
|
|
19
|
+
storageType: "custom",
|
|
20
|
+
factory: () => stream
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}, { disableTypeCreation: true })();
|
|
24
|
+
app.post("/__motia/flows/:id/config", async (req, res) => {
|
|
25
|
+
const newFlowConfig = req.body;
|
|
26
|
+
try {
|
|
27
|
+
await stream.set("default", newFlowConfig.id, newFlowConfig);
|
|
28
|
+
res.status(200).send({ message: "Flow config saved successfully" });
|
|
29
|
+
} catch (error) {
|
|
30
|
+
console.error("Error saving flow config:", error.message);
|
|
31
|
+
res.status(500).json({ error: "Failed to save flow config" });
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
//#endregion
|
|
37
|
+
export { flowsConfigEndpoint };
|
|
38
|
+
//# sourceMappingURL=flows-config-endpoint.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flows-config-endpoint.mjs","names":["newFlowConfig: FlowConfig"],"sources":["../../../src/endpoints/flows-config-endpoint.ts"],"sourcesContent":["import type { Express, Request, Response } from 'express'\nimport path from 'path'\nimport { z } from 'zod'\nimport type { LockedData } from '../locked-data'\nimport { FlowsConfigStream } from '../streams/flows-config-stream'\nimport type { FlowConfig } from '../types/flows-config-types'\n\ninterface ParamId {\n id: string\n}\n\nexport const flowsConfigEndpoint = (app: Express, baseDir: string, lockedData: LockedData) => {\n const configPath = path.join(baseDir, 'motia-workbench.json')\n const stream = new FlowsConfigStream(configPath)\n\n lockedData.createStream(\n {\n filePath: '__motia.flowsConfig',\n hidden: true,\n config: {\n name: '__motia.flowsConfig',\n schema: z.object({ name: z.string(), steps: z.any(), edges: z.any() }),\n baseConfig: { storageType: 'custom', factory: () => stream },\n },\n },\n { disableTypeCreation: true },\n )()\n\n app.post('/__motia/flows/:id/config', async (req: Request<ParamId>, res: Response) => {\n const newFlowConfig: FlowConfig = req.body\n try {\n await stream.set('default', newFlowConfig.id, newFlowConfig)\n res.status(200).send({ message: 'Flow config saved successfully' })\n } catch (error) {\n console.error('Error saving flow config:', (error as Error).message)\n res.status(500).json({ error: 'Failed to save flow config' })\n }\n })\n}\n"],"mappings":";;;;;AAWA,MAAa,uBAAuB,KAAc,SAAiB,eAA2B;CAE5F,MAAM,SAAS,IAAI,kBADA,KAAK,KAAK,SAAS,uBAAuB,CACb;AAEhD,YAAW,aACT;EACE,UAAU;EACV,QAAQ;EACR,QAAQ;GACN,MAAM;GACN,QAAQ,EAAE,OAAO;IAAE,MAAM,EAAE,QAAQ;IAAE,OAAO,EAAE,KAAK;IAAE,OAAO,EAAE,KAAK;IAAE,CAAC;GACtE,YAAY;IAAE,aAAa;IAAU,eAAe;IAAQ;GAC7D;EACF,EACD,EAAE,qBAAqB,MAAM,CAC9B,EAAE;AAEH,KAAI,KAAK,6BAA6B,OAAO,KAAuB,QAAkB;EACpF,MAAMA,gBAA4B,IAAI;AACtC,MAAI;AACF,SAAM,OAAO,IAAI,WAAW,cAAc,IAAI,cAAc;AAC5D,OAAI,OAAO,IAAI,CAAC,KAAK,EAAE,SAAS,kCAAkC,CAAC;WAC5D,OAAO;AACd,WAAQ,MAAM,6BAA8B,MAAgB,QAAQ;AACpE,OAAI,OAAO,IAAI,CAAC,KAAK,EAAE,OAAO,8BAA8B,CAAC;;GAE/D"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { generateFlow } from "../helper/flows-helper.mjs";
|
|
2
|
+
import { FlowsStream } from "../streams/flows-stream.mjs";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
|
|
5
|
+
//#region src/endpoints/flows-endpoint.ts
|
|
6
|
+
const flowsEndpoint = (lockedData) => {
|
|
7
|
+
const flowsStream = lockedData.createStream({
|
|
8
|
+
filePath: "__motia.flows",
|
|
9
|
+
hidden: true,
|
|
10
|
+
config: {
|
|
11
|
+
name: "__motia.flows",
|
|
12
|
+
schema: z.object({
|
|
13
|
+
id: z.string(),
|
|
14
|
+
name: z.string(),
|
|
15
|
+
steps: z.any(),
|
|
16
|
+
edges: z.any()
|
|
17
|
+
}),
|
|
18
|
+
baseConfig: {
|
|
19
|
+
storageType: "custom",
|
|
20
|
+
factory: () => new FlowsStream(lockedData)
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}, { disableTypeCreation: true })();
|
|
24
|
+
lockedData.on("flow-created", (flowId) => {
|
|
25
|
+
const flow = lockedData.flows[flowId];
|
|
26
|
+
const response = generateFlow(flowId, flow.steps);
|
|
27
|
+
flowsStream.set("default", flowId, response);
|
|
28
|
+
});
|
|
29
|
+
lockedData.on("flow-updated", (flowId) => {
|
|
30
|
+
const flow = lockedData.flows[flowId];
|
|
31
|
+
const response = generateFlow(flowId, flow.steps);
|
|
32
|
+
flowsStream.set("default", flowId, response);
|
|
33
|
+
});
|
|
34
|
+
lockedData.on("flow-removed", (flowId) => flowsStream.delete("default", flowId));
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
//#endregion
|
|
38
|
+
export { flowsEndpoint };
|
|
39
|
+
//# sourceMappingURL=flows-endpoint.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flows-endpoint.mjs","names":[],"sources":["../../../src/endpoints/flows-endpoint.ts"],"sourcesContent":["import { z } from 'zod'\nimport { generateFlow } from '../helper/flows-helper'\nimport type { LockedData } from '../locked-data'\nimport { FlowsStream } from '../streams/flows-stream'\n\nexport const flowsEndpoint = (lockedData: LockedData) => {\n const flowsStream = lockedData.createStream(\n {\n filePath: '__motia.flows',\n hidden: true,\n config: {\n name: '__motia.flows',\n schema: z.object({ id: z.string(), name: z.string(), steps: z.any(), edges: z.any() }),\n baseConfig: { storageType: 'custom', factory: () => new FlowsStream(lockedData) },\n },\n },\n { disableTypeCreation: true },\n )()\n\n lockedData.on('flow-created', (flowId) => {\n const flow = lockedData.flows[flowId]\n const response = generateFlow(flowId, flow.steps)\n flowsStream.set('default', flowId, response)\n })\n\n lockedData.on('flow-updated', (flowId) => {\n const flow = lockedData.flows[flowId]\n const response = generateFlow(flowId, flow.steps)\n flowsStream.set('default', flowId, response)\n })\n\n lockedData.on('flow-removed', (flowId) => flowsStream.delete('default', flowId))\n}\n"],"mappings":";;;;;AAKA,MAAa,iBAAiB,eAA2B;CACvD,MAAM,cAAc,WAAW,aAC7B;EACE,UAAU;EACV,QAAQ;EACR,QAAQ;GACN,MAAM;GACN,QAAQ,EAAE,OAAO;IAAE,IAAI,EAAE,QAAQ;IAAE,MAAM,EAAE,QAAQ;IAAE,OAAO,EAAE,KAAK;IAAE,OAAO,EAAE,KAAK;IAAE,CAAC;GACtF,YAAY;IAAE,aAAa;IAAU,eAAe,IAAI,YAAY,WAAW;IAAE;GAClF;EACF,EACD,EAAE,qBAAqB,MAAM,CAC9B,EAAE;AAEH,YAAW,GAAG,iBAAiB,WAAW;EACxC,MAAM,OAAO,WAAW,MAAM;EAC9B,MAAM,WAAW,aAAa,QAAQ,KAAK,MAAM;AACjD,cAAY,IAAI,WAAW,QAAQ,SAAS;GAC5C;AAEF,YAAW,GAAG,iBAAiB,WAAW;EACxC,MAAM,OAAO,WAAW,MAAM;EAC9B,MAAM,WAAW,aAAa,QAAQ,KAAK,MAAM;AACjD,cAAY,IAAI,WAAW,QAAQ,SAAS;GAC5C;AAEF,YAAW,GAAG,iBAAiB,WAAW,YAAY,OAAO,WAAW,OAAO,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { generateStepId } from "../helper/flows-helper.mjs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import fs from "fs/promises";
|
|
4
|
+
|
|
5
|
+
//#region src/endpoints/step-endpoint.ts
|
|
6
|
+
const getFeatures = async (filePath) => {
|
|
7
|
+
const stat = await fs.stat(`${filePath}-features.json`).catch(() => null);
|
|
8
|
+
if (!stat || stat.isDirectory()) return [];
|
|
9
|
+
try {
|
|
10
|
+
const content = await fs.readFile(`${filePath}-features.json`, "utf8");
|
|
11
|
+
return JSON.parse(content);
|
|
12
|
+
} catch {
|
|
13
|
+
return [];
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
const stepEndpoint = (app, lockedData) => {
|
|
17
|
+
app.get("/__motia/step/:stepId", async (req, res) => {
|
|
18
|
+
const id = req.params.stepId;
|
|
19
|
+
const step = [...lockedData.activeSteps, ...lockedData.devSteps].find((step$1) => generateStepId(step$1.filePath) === id);
|
|
20
|
+
if (!step) {
|
|
21
|
+
res.status(404).send({ error: "Step not found" });
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
try {
|
|
25
|
+
const content = await fs.readFile(step.filePath, "utf8");
|
|
26
|
+
const features = await getFeatures(step.filePath.replace(`${path.sep}steps${path.sep}`, `${path.sep}tutorial${path.sep}`));
|
|
27
|
+
res.status(200).send({
|
|
28
|
+
id,
|
|
29
|
+
content,
|
|
30
|
+
features
|
|
31
|
+
});
|
|
32
|
+
} catch (error) {
|
|
33
|
+
console.error("Error reading step file:", error);
|
|
34
|
+
res.status(500).send({ error: "Failed to read step file" });
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
//#endregion
|
|
40
|
+
export { stepEndpoint };
|
|
41
|
+
//# sourceMappingURL=step-endpoint.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"step-endpoint.mjs","names":["step"],"sources":["../../../src/endpoints/step-endpoint.ts"],"sourcesContent":["import path from 'node:path'\nimport type { Express } from 'express'\nimport fs from 'fs/promises'\nimport { generateStepId } from '../helper/flows-helper'\nimport type { LockedData } from '../locked-data'\n\nconst getFeatures = async (filePath: string) => {\n const stat = await fs.stat(`${filePath}-features.json`).catch(() => null)\n\n if (!stat || stat.isDirectory()) {\n return []\n }\n\n try {\n const content = await fs.readFile(`${filePath}-features.json`, 'utf8')\n return JSON.parse(content)\n } catch {\n return []\n }\n}\n\nexport const stepEndpoint = (app: Express, lockedData: LockedData) => {\n app.get('/__motia/step/:stepId', async (req, res) => {\n const id = req.params.stepId\n\n const allSteps = [...lockedData.activeSteps, ...lockedData.devSteps]\n const step = allSteps.find((step) => generateStepId(step.filePath) === id)\n\n if (!step) {\n res.status(404).send({ error: 'Step not found' })\n return\n }\n\n try {\n const content = await fs.readFile(step.filePath, 'utf8')\n const features = await getFeatures(\n step.filePath.replace(`${path.sep}steps${path.sep}`, `${path.sep}tutorial${path.sep}`),\n )\n\n res.status(200).send({ id, content, features })\n } catch (error) {\n console.error('Error reading step file:', error)\n res.status(500).send({\n error: 'Failed to read step file',\n })\n }\n })\n}\n"],"mappings":";;;;;AAMA,MAAM,cAAc,OAAO,aAAqB;CAC9C,MAAM,OAAO,MAAM,GAAG,KAAK,GAAG,SAAS,gBAAgB,CAAC,YAAY,KAAK;AAEzE,KAAI,CAAC,QAAQ,KAAK,aAAa,CAC7B,QAAO,EAAE;AAGX,KAAI;EACF,MAAM,UAAU,MAAM,GAAG,SAAS,GAAG,SAAS,iBAAiB,OAAO;AACtE,SAAO,KAAK,MAAM,QAAQ;SACpB;AACN,SAAO,EAAE;;;AAIb,MAAa,gBAAgB,KAAc,eAA2B;AACpE,KAAI,IAAI,yBAAyB,OAAO,KAAK,QAAQ;EACnD,MAAM,KAAK,IAAI,OAAO;EAGtB,MAAM,OADW,CAAC,GAAG,WAAW,aAAa,GAAG,WAAW,SAAS,CAC9C,MAAM,WAAS,eAAeA,OAAK,SAAS,KAAK,GAAG;AAE1E,MAAI,CAAC,MAAM;AACT,OAAI,OAAO,IAAI,CAAC,KAAK,EAAE,OAAO,kBAAkB,CAAC;AACjD;;AAGF,MAAI;GACF,MAAM,UAAU,MAAM,GAAG,SAAS,KAAK,UAAU,OAAO;GACxD,MAAM,WAAW,MAAM,YACrB,KAAK,SAAS,QAAQ,GAAG,KAAK,IAAI,OAAO,KAAK,OAAO,GAAG,KAAK,IAAI,UAAU,KAAK,MAAM,CACvF;AAED,OAAI,OAAO,IAAI,CAAC,KAAK;IAAE;IAAI;IAAS;IAAU,CAAC;WACxC,OAAO;AACd,WAAQ,MAAM,4BAA4B,MAAM;AAChD,OAAI,OAAO,IAAI,CAAC,KAAK,EACnB,OAAO,4BACR,CAAC;;GAEJ"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
//#region src/generate-trace-id.ts
|
|
2
|
+
const generateCode = (length = 6) => {
|
|
3
|
+
const chars = "ABCDEFGHJKMNPQRSTUVWXYZ123456789";
|
|
4
|
+
return Array.from({ length }, () => chars[Math.floor(Math.random() * 32)]).join("");
|
|
5
|
+
};
|
|
6
|
+
const generateTraceId = () => {
|
|
7
|
+
const datePart = String(Date.now()).slice(6);
|
|
8
|
+
return `${generateCode(5)}-${datePart}`;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
//#endregion
|
|
12
|
+
export { generateTraceId };
|
|
13
|
+
//# sourceMappingURL=generate-trace-id.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-trace-id.mjs","names":[],"sources":["../../src/generate-trace-id.ts"],"sourcesContent":["export const generateCode = (length = 6) => {\n const chars = 'ABCDEFGHJKMNPQRSTUVWXYZ123456789'\n return Array.from({ length }, () => chars[Math.floor(Math.random() * chars.length)]).join('')\n}\n\nexport const generateTraceId = () => {\n const datePart = String(Date.now()).slice(6)\n const randomPart = generateCode(5)\n return `${randomPart}-${datePart}`\n}\n"],"mappings":";AAAA,MAAa,gBAAgB,SAAS,MAAM;CAC1C,MAAM,QAAQ;AACd,QAAO,MAAM,KAAK,EAAE,QAAQ,QAAQ,MAAM,KAAK,MAAM,KAAK,QAAQ,GAAG,GAAa,EAAE,CAAC,KAAK,GAAG;;AAG/F,MAAa,wBAAwB;CACnC,MAAM,WAAW,OAAO,KAAK,KAAK,CAAC,CAAC,MAAM,EAAE;AAE5C,QAAO,GADY,aAAa,EAAE,CACb,GAAG"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { StreamConfig } from "./types-stream.mjs";
|
|
2
|
+
import { StepConfig } from "./types.mjs";
|
|
3
|
+
|
|
4
|
+
//#region src/get-step-config.d.ts
|
|
5
|
+
declare const getStepConfig: (file: string, projectRoot?: string) => Promise<StepConfig | null>;
|
|
6
|
+
declare const getStreamConfig: (file: string, projectRoot?: string) => Promise<StreamConfig | null>;
|
|
7
|
+
//#endregion
|
|
8
|
+
export { getStepConfig, getStreamConfig };
|
|
9
|
+
//# sourceMappingURL=get-step-config.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-step-config.d.mts","names":[],"sources":["../../src/get-step-config.ts"],"sourcesContent":[],"mappings":";;;;cA+Da,uDAAsD,QAAQ;cAI9D,yDAAwD,QAAQ"}
|