@pikku/cli 0.11.0 → 0.11.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/.pikku/channel/pikku-channel-types.gen.ts +11 -12
- package/.pikku/channel/pikku-channels-map.gen.d.ts +9 -9
- package/.pikku/channel/pikku-channels-meta.gen.ts +1 -1
- package/.pikku/channel/pikku-channels.gen.ts +1 -1
- package/.pikku/cli/pikku-cli-channel.ts +92 -0
- package/.pikku/cli/pikku-cli-client.gen.ts +54 -0
- package/.pikku/cli/pikku-cli-types.gen.ts +3 -3
- package/.pikku/cli/pikku-cli-wirings-meta.gen.json +146 -0
- package/.pikku/cli/pikku-cli-wirings-meta.gen.ts +4 -34
- package/.pikku/cli/pikku-cli-wirings.gen.ts +2 -1
- package/.pikku/cli/pikku-cli.gen.ts +41 -0
- package/.pikku/function/pikku-function-types.gen.ts +49 -63
- package/.pikku/function/pikku-functions-meta.gen.json +988 -0
- package/.pikku/function/pikku-functions-meta.gen.ts +4 -970
- package/.pikku/function/pikku-functions-meta.min.gen.json +212 -0
- package/.pikku/function/pikku-functions-meta.min.gen.ts +4 -209
- package/.pikku/http/pikku-http-types.gen.ts +2 -2
- package/.pikku/http/pikku-http-wirings-map.gen.d.ts +9 -9
- package/.pikku/http/pikku-http-wirings-meta.gen.ts +1 -1
- package/.pikku/http/pikku-http-wirings.gen.ts +1 -1
- package/.pikku/mcp/pikku-mcp-types.gen.ts +13 -13
- package/.pikku/mcp/pikku-mcp-wirings-meta.gen.json +5 -0
- package/.pikku/mcp/pikku-mcp-wirings-meta.gen.ts +6 -4
- package/.pikku/mcp/pikku-mcp-wirings.gen.ts +1 -1
- package/.pikku/pikku-bootstrap.gen.ts +1 -4
- package/.pikku/pikku-services.gen.ts +6 -8
- package/.pikku/pikku-types.gen.ts +1 -1
- package/.pikku/pikku-websocket.gen.ts +1 -1
- package/.pikku/queue/pikku-queue-types.gen.ts +2 -2
- package/.pikku/queue/pikku-queue-workers-wirings-map.gen.d.ts +9 -9
- package/.pikku/queue/pikku-queue-workers-wirings-meta.gen.json +1 -0
- package/.pikku/queue/pikku-queue-workers-wirings-meta.gen.ts +5 -7
- package/.pikku/queue/pikku-queue-workers-wirings.gen.ts +1 -1
- package/.pikku/rpc/pikku-remote-rpc-workers.gen.ts +2 -2
- package/.pikku/rpc/pikku-rpc-wirings-map.gen.d.ts +9 -9
- package/.pikku/rpc/pikku-rpc-wirings-map.internal.gen.d.ts +41 -40
- package/.pikku/scheduler/pikku-scheduler-types.gen.ts +2 -2
- package/.pikku/scheduler/pikku-schedulers-wirings-meta.gen.json +1 -0
- package/.pikku/scheduler/pikku-schedulers-wirings-meta.gen.ts +5 -2
- package/.pikku/scheduler/pikku-schedulers-wirings.gen.ts +1 -1
- package/.pikku/schemas/register.gen.ts +27 -27
- package/.pikku/schemas/schemas/PikkuCLIConfig.schema.json +1 -1
- package/.pikku/schemas/schemas/PikkuChannelsOutput.schema.json +1 -1
- package/.pikku/schemas/schemas/PikkuSchemasOutput.schema.json +1 -1
- package/.pikku/services/config.gen.json +99 -0
- package/.pikku/services/getInspectorState.gen.json +10 -0
- package/.pikku/services/jwt.gen.json +13 -0
- package/.pikku/services/logger.gen.json +25 -0
- package/.pikku/services/queueService.gen.json +14 -0
- package/.pikku/services/schedulerService.gen.json +17 -0
- package/.pikku/services/schema.gen.json +14 -0
- package/.pikku/services/variables.gen.json +13 -0
- package/.pikku/services/workflowService.gen.json +31 -0
- package/.pikku/workflow/pikku-workflow-map.gen.d.ts +9 -9
- package/.pikku/workflow/pikku-workflow-types.gen.ts +36 -31
- package/.pikku/workflow/pikku-workflow-wirings-meta.gen.json +1 -0
- package/.pikku/workflow/pikku-workflow-wirings-meta.gen.ts +5 -2
- package/.pikku/workflow/pikku-workflow-wirings.gen.ts +6 -2
- package/CHANGELOG.md +27 -1
- package/bin/pikku.ts +6 -32
- package/build.sh +53 -31
- package/cli.schema.json +1 -1
- package/dist/.pikku/channel/pikku-channel-types.gen.d.ts +6 -7
- package/dist/.pikku/channel/pikku-channel-types.gen.js +1 -1
- package/dist/.pikku/channel/pikku-channels-meta.gen.js +1 -1
- package/dist/.pikku/channel/pikku-channels.gen.d.ts +1 -1
- package/dist/.pikku/channel/pikku-channels.gen.js +1 -1
- package/dist/.pikku/cli/pikku-cli-channel.js +91 -0
- package/dist/.pikku/cli/pikku-cli-client.gen.d.ts +10 -0
- package/dist/.pikku/cli/pikku-cli-client.gen.js +44 -0
- package/dist/.pikku/cli/pikku-cli-types.gen.d.ts +3 -3
- package/dist/.pikku/cli/pikku-cli-types.gen.js +1 -1
- package/dist/.pikku/cli/pikku-cli-wirings-meta.gen.js +3 -34
- package/dist/.pikku/cli/pikku-cli-wirings-meta.gen.json +146 -0
- package/dist/.pikku/cli/pikku-cli-wirings.gen.d.ts +2 -1
- package/dist/.pikku/cli/pikku-cli-wirings.gen.js +2 -1
- package/dist/.pikku/cli/pikku-cli.gen.d.ts +10 -0
- package/dist/.pikku/cli/pikku-cli.gen.js +38 -0
- package/dist/.pikku/function/pikku-function-types.gen.d.ts +29 -79
- package/dist/.pikku/function/pikku-function-types.gen.js +19 -15
- package/dist/.pikku/function/pikku-functions-meta.gen.js +3 -969
- package/dist/.pikku/function/pikku-functions-meta.gen.json +988 -0
- package/dist/.pikku/function/pikku-functions-meta.min.gen.js +3 -208
- package/dist/.pikku/function/pikku-functions-meta.min.gen.json +212 -0
- package/dist/.pikku/http/pikku-http-types.gen.d.ts +2 -2
- package/dist/.pikku/http/pikku-http-types.gen.js +1 -1
- package/dist/.pikku/http/pikku-http-wirings-meta.gen.js +1 -1
- package/dist/.pikku/http/pikku-http-wirings.gen.d.ts +1 -1
- package/dist/.pikku/http/pikku-http-wirings.gen.js +1 -1
- package/dist/.pikku/mcp/pikku-mcp-types.gen.d.ts +13 -13
- package/dist/.pikku/mcp/pikku-mcp-types.gen.js +1 -1
- package/dist/.pikku/mcp/pikku-mcp-wirings-meta.gen.js +5 -4
- package/dist/.pikku/mcp/pikku-mcp-wirings-meta.gen.json +5 -0
- package/dist/.pikku/mcp/pikku-mcp-wirings.gen.d.ts +1 -1
- package/dist/.pikku/mcp/pikku-mcp-wirings.gen.js +1 -1
- package/dist/.pikku/pikku-bootstrap.gen.d.ts +1 -4
- package/dist/.pikku/pikku-bootstrap.gen.js +1 -4
- package/dist/.pikku/pikku-services.gen.d.ts +5 -8
- package/dist/.pikku/pikku-services.gen.js +3 -6
- package/dist/.pikku/pikku-types.gen.d.ts +1 -1
- package/dist/.pikku/pikku-types.gen.js +1 -1
- package/dist/.pikku/pikku-websocket.gen.d.ts +1 -1
- package/dist/.pikku/pikku-websocket.gen.js +1 -1
- package/dist/.pikku/queue/pikku-queue-types.gen.d.ts +2 -2
- package/dist/.pikku/queue/pikku-queue-types.gen.js +1 -1
- package/dist/.pikku/queue/pikku-queue-workers-wirings-meta.gen.js +3 -7
- package/dist/.pikku/queue/pikku-queue-workers-wirings-meta.gen.json +1 -0
- package/dist/.pikku/queue/pikku-queue-workers-wirings.gen.d.ts +1 -1
- package/dist/.pikku/queue/pikku-queue-workers-wirings.gen.js +1 -1
- package/dist/.pikku/rpc/pikku-remote-rpc-workers.gen.d.ts +6 -9
- package/dist/.pikku/rpc/pikku-remote-rpc-workers.gen.js +2 -2
- package/dist/.pikku/scheduler/pikku-scheduler-types.gen.d.ts +2 -2
- package/dist/.pikku/scheduler/pikku-scheduler-types.gen.js +1 -1
- package/dist/.pikku/scheduler/pikku-schedulers-wirings-meta.gen.js +3 -2
- package/dist/.pikku/scheduler/pikku-schedulers-wirings-meta.gen.json +1 -0
- package/dist/.pikku/scheduler/pikku-schedulers-wirings.gen.d.ts +1 -1
- package/dist/.pikku/scheduler/pikku-schedulers-wirings.gen.js +1 -1
- package/dist/.pikku/schemas/register.gen.js +17 -17
- package/dist/.pikku/schemas/schemas/PikkuCLIConfig.schema.json +1 -1
- package/dist/.pikku/schemas/schemas/PikkuChannelsOutput.schema.json +1 -1
- package/dist/.pikku/schemas/schemas/PikkuSchemasOutput.schema.json +1 -1
- package/dist/.pikku/workflow/pikku-workflow-types.gen.d.ts +29 -25
- package/dist/.pikku/workflow/pikku-workflow-types.gen.js +22 -8
- package/dist/.pikku/workflow/pikku-workflow-wirings-meta.gen.js +3 -2
- package/dist/.pikku/workflow/pikku-workflow-wirings-meta.gen.json +1 -0
- package/dist/.pikku/workflow/pikku-workflow-wirings.gen.d.ts +6 -2
- package/dist/.pikku/workflow/pikku-workflow-wirings.gen.js +6 -3
- package/dist/bin/pikku.js +5 -28
- package/dist/src/cli.wiring.js +108 -106
- package/dist/src/functions/commands/all.js +82 -42
- package/dist/src/functions/commands/bootstrap.js +22 -10
- package/dist/src/functions/commands/watch.js +6 -3
- package/dist/src/functions/runtimes/nextjs/pikku-command-nextjs.js +12 -7
- package/dist/src/functions/runtimes/nextjs/serialize-nextjs-backend-wrapper.d.ts +1 -1
- package/dist/src/functions/runtimes/nextjs/serialize-nextjs-backend-wrapper.js +42 -4
- package/dist/src/functions/runtimes/nextjs/serialize-nextjs-http-wrapper.d.ts +1 -1
- package/dist/src/functions/runtimes/nextjs/serialize-nextjs-http-wrapper.js +40 -2
- package/dist/src/functions/wirings/channels/pikku-channels.js +9 -2
- package/dist/src/functions/wirings/channels/serialize-channel-types.js +10 -11
- package/dist/src/functions/wirings/cli/pikku-command-cli-entry.js +4 -4
- package/dist/src/functions/wirings/cli/pikku-command-cli-types.js +1 -1
- package/dist/src/functions/wirings/cli/pikku-command-cli.js +9 -3
- package/dist/src/functions/wirings/cli/serialize-channel-cli.js +1 -1
- package/dist/src/functions/wirings/cli/serialize-cli-types.js +2 -2
- package/dist/src/functions/wirings/cli/serialize-local-cli-bootstrap.d.ts +1 -1
- package/dist/src/functions/wirings/cli/serialize-local-cli-bootstrap.js +4 -4
- package/dist/src/functions/wirings/functions/pikku-command-function-types-split.js +4 -4
- package/dist/src/functions/wirings/functions/pikku-command-functions.js +15 -5
- package/dist/src/functions/wirings/functions/pikku-command-services.d.ts +1 -1
- package/dist/src/functions/wirings/functions/pikku-command-services.js +23 -23
- package/dist/src/functions/wirings/functions/schemas.js +1 -1
- package/dist/src/functions/wirings/functions/serialize-function-types.d.ts +1 -1
- package/dist/src/functions/wirings/functions/serialize-function-types.js +50 -64
- package/dist/src/functions/wirings/http/openapi-spec-generator.js +4 -4
- package/dist/src/functions/wirings/http/pikku-http-routes.js +9 -2
- package/dist/src/functions/wirings/http/serialize-http-types.js +1 -1
- package/dist/src/functions/wirings/mcp/pikku-command-mcp.js +18 -4
- package/dist/src/functions/wirings/mcp/serialize-mcp-types.js +12 -12
- package/dist/src/functions/wirings/middleware/pikku-command-middleware.js +26 -2
- package/dist/src/functions/wirings/middleware/serialize-middleware-groups-meta.d.ts +5 -2
- package/dist/src/functions/wirings/middleware/serialize-middleware-groups-meta.js +5 -13
- package/dist/src/functions/wirings/queue/pikku-command-queue.js +9 -3
- package/dist/src/functions/wirings/queue/pikku-queue.js +9 -3
- package/dist/src/functions/wirings/queue/serialize-queue-meta.d.ts +2 -1
- package/dist/src/functions/wirings/queue/serialize-queue-meta.js +10 -1
- package/dist/src/functions/wirings/queue/serialize-queue-types.js +1 -1
- package/dist/src/functions/wirings/rpc/pikku-command-rpc.js +9 -2
- package/dist/src/functions/wirings/rpc/serialize-public-rpc.js +11 -4
- package/dist/src/functions/wirings/rpc/serialize-remote-rpc.js +1 -1
- package/dist/src/functions/wirings/rpc/serialize-rpc-wrapper.js +3 -3
- package/dist/src/functions/wirings/scheduler/pikku-command-scheduler.js +6 -3
- package/dist/src/functions/wirings/scheduler/serialize-scheduler-meta.d.ts +2 -1
- package/dist/src/functions/wirings/scheduler/serialize-scheduler-meta.js +11 -1
- package/dist/src/functions/wirings/scheduler/serialize-scheduler-types.js +1 -1
- package/dist/src/functions/wirings/services/pikku-command-service-metadata.d.ts +1 -0
- package/dist/src/functions/wirings/services/pikku-command-service-metadata.js +22 -0
- package/dist/src/functions/wirings/workflow/pikku-command-workflow-types.js +3 -1
- package/dist/src/functions/wirings/workflow/pikku-command-workflow.js +12 -8
- package/dist/src/functions/wirings/workflow/serialize-workflow-meta.d.ts +2 -1
- package/dist/src/functions/wirings/workflow/serialize-workflow-meta.js +11 -1
- package/dist/src/functions/wirings/workflow/serialize-workflow-types.d.ts +1 -1
- package/dist/src/functions/wirings/workflow/serialize-workflow-types.js +36 -31
- package/dist/src/functions/wirings/workflow/serialize-workflow-wirings.d.ts +8 -0
- package/dist/src/functions/wirings/workflow/serialize-workflow-wirings.js +30 -0
- package/dist/src/functions/wirings/workflow/serialize-workflow-workers.js +2 -2
- package/dist/src/middleware/log-command-info-and-time.d.ts +2 -2
- package/dist/src/middleware/log-command-info-and-time.js +1 -4
- package/dist/src/services/cli-logger-forwarder.service.d.ts +3 -0
- package/dist/src/services/cli-logger-forwarder.service.js +9 -2
- package/dist/src/services.d.ts +2 -7
- package/dist/src/services.js +14 -12
- package/dist/src/utils/check-required-types.d.ts +2 -2
- package/dist/src/utils/check-required-types.js +2 -3
- package/dist/src/utils/pikku-cli-config.js +35 -2
- package/dist/src/utils/pikku-files-and-methods.d.ts +2 -2
- package/dist/src/utils/pikku-files-and-methods.js +4 -4
- package/dist/src/utils/schema-generator.d.ts +1 -1
- package/dist/src/utils/schema-generator.js +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -8
- package/src/cli.wiring.ts +110 -105
- package/src/functions/commands/all.ts +94 -45
- package/src/functions/commands/bootstrap.ts +25 -10
- package/src/functions/commands/watch.ts +6 -3
- package/src/functions/runtimes/nextjs/pikku-command-nextjs.ts +26 -5
- package/src/functions/runtimes/nextjs/serialize-nextjs-backend-wrapper.ts +43 -4
- package/src/functions/runtimes/nextjs/serialize-nextjs-http-wrapper.ts +40 -1
- package/src/functions/wirings/channels/pikku-channels.ts +27 -3
- package/src/functions/wirings/channels/serialize-channel-types.ts +10 -11
- package/src/functions/wirings/cli/pikku-command-cli-entry.ts +4 -4
- package/src/functions/wirings/cli/pikku-command-cli-types.ts +1 -1
- package/src/functions/wirings/cli/pikku-command-cli.ts +26 -3
- package/src/functions/wirings/cli/serialize-channel-cli.ts +1 -1
- package/src/functions/wirings/cli/serialize-cli-types.ts +2 -2
- package/src/functions/wirings/cli/serialize-local-cli-bootstrap.ts +5 -5
- package/src/functions/wirings/functions/pikku-command-function-types-split.ts +6 -6
- package/src/functions/wirings/functions/pikku-command-functions.ts +39 -4
- package/src/functions/wirings/functions/pikku-command-services.ts +25 -25
- package/src/functions/wirings/functions/schemas.ts +2 -2
- package/src/functions/wirings/functions/serialize-function-types.ts +51 -65
- package/src/functions/wirings/http/openapi-spec-generator.ts +14 -5
- package/src/functions/wirings/http/pikku-http-routes.ts +28 -2
- package/src/functions/wirings/http/serialize-http-types.ts +1 -1
- package/src/functions/wirings/mcp/pikku-command-mcp.ts +30 -4
- package/src/functions/wirings/mcp/serialize-mcp-types.ts +12 -12
- package/src/functions/wirings/middleware/pikku-command-middleware.ts +35 -2
- package/src/functions/wirings/middleware/serialize-middleware-groups-meta.ts +4 -19
- package/src/functions/wirings/permissions/pikku-command-permissions.ts +2 -2
- package/src/functions/wirings/queue/pikku-command-queue.ts +27 -2
- package/src/functions/wirings/queue/pikku-queue.ts +27 -2
- package/src/functions/wirings/queue/serialize-queue-meta.ts +15 -1
- package/src/functions/wirings/queue/serialize-queue-types.ts +1 -1
- package/src/functions/wirings/rpc/pikku-command-rpc.ts +25 -2
- package/src/functions/wirings/rpc/serialize-public-rpc.ts +11 -4
- package/src/functions/wirings/rpc/serialize-remote-rpc.ts +1 -1
- package/src/functions/wirings/rpc/serialize-rpc-wrapper.ts +3 -3
- package/src/functions/wirings/scheduler/pikku-command-scheduler.ts +30 -4
- package/src/functions/wirings/scheduler/serialize-scheduler-meta.ts +20 -1
- package/src/functions/wirings/scheduler/serialize-scheduler-types.ts +1 -1
- package/src/functions/wirings/services/pikku-command-service-metadata.ts +25 -0
- package/src/functions/wirings/workflow/pikku-command-workflow-types.ts +8 -1
- package/src/functions/wirings/workflow/pikku-command-workflow.ts +36 -8
- package/src/functions/wirings/workflow/serialize-workflow-meta.ts +18 -1
- package/src/functions/wirings/workflow/serialize-workflow-types.ts +39 -31
- package/src/functions/wirings/workflow/serialize-workflow-wirings.ts +47 -0
- package/src/functions/wirings/workflow/serialize-workflow-workers.ts +2 -2
- package/src/middleware/log-command-info-and-time.ts +3 -6
- package/src/services/cli-logger-forwarder.service.ts +11 -2
- package/src/services.ts +15 -15
- package/src/utils/check-required-types.ts +4 -7
- package/src/utils/pikku-cli-config.ts +69 -2
- package/src/utils/pikku-files-and-methods.ts +10 -13
- package/src/utils/schema-generator.ts +2 -2
- package/types/application-types.d.ts +1 -1
- package/types/config.d.ts +12 -1
- package/.pikku/function/pikku-functions.gen.ts +0 -84
- package/.pikku/rpc/pikku-rpc-wirings-meta.internal.gen.ts +0 -47
- package/dist/.pikku/function/pikku-functions.gen.js +0 -83
- package/dist/.pikku/rpc/pikku-rpc-wirings-meta.internal.gen.d.ts +0 -1
- package/dist/.pikku/rpc/pikku-rpc-wirings-meta.internal.gen.js +0 -47
- package/dist/.pikku/schemas/schemas/PikkuRemoteInternalRPCInput.schema.json +0 -1
- /package/dist/.pikku/{function/pikku-functions.gen.d.ts → cli/pikku-cli-channel.d.ts} +0 -0
|
@@ -15,7 +15,7 @@ import type { PikkuFunctionConfig } from '${functionTypesImportPath}'
|
|
|
15
15
|
* @template In - Input type for the queue job
|
|
16
16
|
* @template Out - Output type for the queue job
|
|
17
17
|
*/
|
|
18
|
-
type QueueWiring<In, Out> = CoreQueueWorker<PikkuFunctionConfig<In, Out>>
|
|
18
|
+
type QueueWiring<In, Out> = CoreQueueWorker<PikkuFunctionConfig<In, Out, 'session' | 'rpc'>>
|
|
19
19
|
|
|
20
20
|
/**
|
|
21
21
|
* Registers a queue worker with the Pikku framework.
|
|
@@ -1,12 +1,19 @@
|
|
|
1
1
|
import { pikkuSessionlessFunc } from '../../../../.pikku/pikku-types.gen.js';
|
|
2
2
|
import { writeFileInDir } from '../../../utils/file-writer.js';
|
|
3
3
|
import { logCommandInfoAndTime } from '../../../middleware/log-command-info-and-time.js';
|
|
4
|
+
import { getFileImportRelativePath } from '../../../utils/file-import-path.js';
|
|
4
5
|
export const pikkuRPC = pikkuSessionlessFunc({
|
|
5
6
|
func: async ({ logger, config, getInspectorState }) => {
|
|
6
7
|
const { rpc } = await getInspectorState();
|
|
7
|
-
const { rpcInternalWiringMetaFile } = config;
|
|
8
|
+
const { rpcInternalWiringMetaFile, rpcInternalWiringMetaJsonFile, packageMappings, schema, } = config;
|
|
8
9
|
if (rpc.internalFiles.size > 0) {
|
|
9
|
-
await writeFileInDir(logger,
|
|
10
|
+
await writeFileInDir(logger, rpcInternalWiringMetaJsonFile, JSON.stringify(rpc.internalMeta, null, 2));
|
|
11
|
+
const jsonImportPath = getFileImportRelativePath(rpcInternalWiringMetaFile, rpcInternalWiringMetaJsonFile, packageMappings);
|
|
12
|
+
const supportsImportAttributes = schema?.supportsImportAttributes ?? false;
|
|
13
|
+
const importStatement = supportsImportAttributes
|
|
14
|
+
? `import metaData from '${jsonImportPath}' with { type: 'json' }`
|
|
15
|
+
: `import metaData from '${jsonImportPath}'`;
|
|
16
|
+
await writeFileInDir(logger, rpcInternalWiringMetaFile, `import { pikkuState } from '@pikku/core'\n${importStatement}\npikkuState('rpc', 'meta', metaData as Record<string, string>)`);
|
|
10
17
|
return true;
|
|
11
18
|
}
|
|
12
19
|
return false;
|
|
@@ -13,16 +13,23 @@ import { pikkuSessionlessFunc, wireHTTP } from '${pathToPikkuTypes}'
|
|
|
13
13
|
* This is used for public HTTP access to exposed server functions
|
|
14
14
|
*/
|
|
15
15
|
export const rpcCaller = pikkuSessionlessFunc<
|
|
16
|
-
{
|
|
16
|
+
{ rpcName: string, data?: any },
|
|
17
17
|
any
|
|
18
18
|
>({
|
|
19
|
-
func: async ({
|
|
20
|
-
return await (rpc.invokeExposed as any)(
|
|
19
|
+
func: async (services, { rpcName, data }, { rpc }) => {
|
|
20
|
+
return await (rpc.invokeExposed as any)(rpcName, data)
|
|
21
21
|
},
|
|
22
22
|
})
|
|
23
23
|
|
|
24
24
|
wireHTTP({
|
|
25
|
-
route:
|
|
25
|
+
route: "/rpc/:rpcName",
|
|
26
|
+
method: "options",
|
|
27
|
+
auth: false,
|
|
28
|
+
func: pikkuSessionlessFunc<{ rpcName: string }>(async () => void 0),
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
wireHTTP({
|
|
32
|
+
route: '/rpc/:rpcName',
|
|
26
33
|
method: 'post',
|
|
27
34
|
func: rpcCaller,
|
|
28
35
|
})
|
|
@@ -16,7 +16,7 @@ export const pikkuRemoteInternalRPC = pikkuSessionlessFunc<
|
|
|
16
16
|
{ rpcName: string, data?: any },
|
|
17
17
|
any
|
|
18
18
|
>({
|
|
19
|
-
func: async (
|
|
19
|
+
func: async (_services, { rpcName, data }, { rpc }) => {
|
|
20
20
|
return await (rpc.invoke as any)(rpcName, data)
|
|
21
21
|
},
|
|
22
22
|
internal: true,
|
|
@@ -54,12 +54,12 @@ export class PikkuRPC {
|
|
|
54
54
|
* This is a generic method that routes to the appropriate server function
|
|
55
55
|
* based on the function name and passes the provided data.
|
|
56
56
|
*
|
|
57
|
-
* @param
|
|
57
|
+
* @param rpcName - The name of the server function to invoke
|
|
58
58
|
* @param data - The data to pass to the server function
|
|
59
59
|
* @returns A promise that resolves with the function's return value
|
|
60
60
|
*/
|
|
61
|
-
invoke: RPCInvoke = async (
|
|
62
|
-
return await this.pikkuFetch.post(
|
|
61
|
+
invoke: RPCInvoke = async (rpcName, data) => {
|
|
62
|
+
return await this.pikkuFetch.post(\`/rpc/\${rpcName}\` as any, { rpcName, data }) as any
|
|
63
63
|
}
|
|
64
64
|
}
|
|
65
65
|
|
|
@@ -2,13 +2,16 @@ import { pikkuSessionlessFunc } from '../../../../.pikku/pikku-types.gen.js';
|
|
|
2
2
|
import { serializeFileImports } from '../../../utils/file-imports-serializer.js';
|
|
3
3
|
import { writeFileInDir } from '../../../utils/file-writer.js';
|
|
4
4
|
import { logCommandInfoAndTime } from '../../../middleware/log-command-info-and-time.js';
|
|
5
|
-
import { serializeSchedulerMeta } from './serialize-scheduler-meta.js';
|
|
5
|
+
import { serializeSchedulerMeta, serializeSchedulerMetaTS, } from './serialize-scheduler-meta.js';
|
|
6
|
+
import { getFileImportRelativePath } from '../../../utils/file-import-path.js';
|
|
6
7
|
export const pikkuScheduler = pikkuSessionlessFunc({
|
|
7
8
|
func: async ({ logger, config, getInspectorState }) => {
|
|
8
9
|
const visitState = await getInspectorState();
|
|
9
|
-
const { schedulersWiringFile, schedulersWiringMetaFile, packageMappings } = config;
|
|
10
|
+
const { schedulersWiringFile, schedulersWiringMetaFile, schedulersWiringMetaJsonFile, packageMappings, schema, } = config;
|
|
10
11
|
const { scheduledTasks } = visitState;
|
|
11
|
-
await writeFileInDir(logger,
|
|
12
|
+
await writeFileInDir(logger, schedulersWiringMetaJsonFile, JSON.stringify(serializeSchedulerMeta(scheduledTasks.meta), null, 2));
|
|
13
|
+
const jsonImportPath = getFileImportRelativePath(schedulersWiringMetaFile, schedulersWiringMetaJsonFile, packageMappings);
|
|
14
|
+
await writeFileInDir(logger, schedulersWiringMetaFile, serializeSchedulerMetaTS(scheduledTasks.meta, jsonImportPath, schema?.supportsImportAttributes ?? false));
|
|
12
15
|
await writeFileInDir(logger, schedulersWiringFile, serializeFileImports('addScheduledTasks', schedulersWiringFile, scheduledTasks.files, packageMappings));
|
|
13
16
|
return true;
|
|
14
17
|
},
|
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { ScheduledTasksMeta } from '@pikku/core/scheduler';
|
|
2
|
-
export declare const serializeSchedulerMeta: (scheduledTasksMeta: ScheduledTasksMeta) =>
|
|
2
|
+
export declare const serializeSchedulerMeta: (scheduledTasksMeta: ScheduledTasksMeta) => ScheduledTasksMeta;
|
|
3
|
+
export declare const serializeSchedulerMetaTS: (scheduledTasksMeta: ScheduledTasksMeta, jsonImportPath: string, supportsImportAttributes: any) => string;
|
|
@@ -1,7 +1,17 @@
|
|
|
1
1
|
export const serializeSchedulerMeta = (scheduledTasksMeta) => {
|
|
2
|
+
return scheduledTasksMeta;
|
|
3
|
+
};
|
|
4
|
+
export const serializeSchedulerMetaTS = (scheduledTasksMeta, jsonImportPath, supportsImportAttributes) => {
|
|
5
|
+
const importStatement = supportsImportAttributes
|
|
6
|
+
? `import metaData from '${jsonImportPath}' with { type: 'json' }`
|
|
7
|
+
: `import metaData from '${jsonImportPath}'`;
|
|
2
8
|
const serializedOutput = [];
|
|
3
9
|
serializedOutput.push("import { pikkuState } from '@pikku/core'");
|
|
4
|
-
serializedOutput.push(
|
|
10
|
+
serializedOutput.push("import { ScheduledTasksMeta } from '@pikku/core/scheduler'");
|
|
11
|
+
serializedOutput.push(importStatement);
|
|
12
|
+
serializedOutput.push('');
|
|
13
|
+
serializedOutput.push("pikkuState('scheduler', 'meta', metaData as ScheduledTasksMeta)");
|
|
14
|
+
serializedOutput.push('');
|
|
5
15
|
const scheduledTasksMetaValues = Object.values(scheduledTasksMeta);
|
|
6
16
|
if (scheduledTasksMetaValues.length > 0) {
|
|
7
17
|
serializedOutput.push(`export type ScheduledTaskNames = '${scheduledTasksMetaValues.map((s) => s.name).join("' | '")}'`);
|
|
@@ -13,7 +13,7 @@ import type { PikkuFunctionConfig, PikkuMiddleware } from '${functionTypesImport
|
|
|
13
13
|
* Type definition for scheduled tasks that run at specified intervals.
|
|
14
14
|
* These are sessionless functions that execute based on cron expressions.
|
|
15
15
|
*/
|
|
16
|
-
type SchedulerWiring = CoreScheduledTask<PikkuFunctionConfig<void, void>, PikkuMiddleware>
|
|
16
|
+
type SchedulerWiring = CoreScheduledTask<PikkuFunctionConfig<void, void, 'session' | 'rpc'>, PikkuMiddleware>
|
|
17
17
|
|
|
18
18
|
/**
|
|
19
19
|
* Registers a scheduled task with the Pikku framework.
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const pikkuServiceMetadata: any;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { pikkuSessionlessFunc } from '../../../../.pikku/pikku-types.gen.js';
|
|
2
|
+
import { logCommandInfoAndTime } from '../../../middleware/log-command-info-and-time.js';
|
|
3
|
+
import { writeAllServiceMetadata } from '@pikku/inspector';
|
|
4
|
+
export const pikkuServiceMetadata = pikkuSessionlessFunc({
|
|
5
|
+
func: async ({ logger, config, getInspectorState }) => {
|
|
6
|
+
const state = await getInspectorState();
|
|
7
|
+
// Only write service metadata if there are services to document
|
|
8
|
+
if (state.serviceMetadata && state.serviceMetadata.length > 0) {
|
|
9
|
+
writeAllServiceMetadata(state.serviceMetadata, config.outDir);
|
|
10
|
+
logger.debug(`• Wrote ${state.serviceMetadata.length} service metadata files`);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
logger.debug('• No service metadata to write');
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
middleware: [
|
|
17
|
+
logCommandInfoAndTime({
|
|
18
|
+
commandStart: 'Generating service metadata',
|
|
19
|
+
commandEnd: 'Generated service metadata',
|
|
20
|
+
}),
|
|
21
|
+
],
|
|
22
|
+
});
|
|
@@ -6,6 +6,8 @@ export const pikkuWorkflowTypes = pikkuSessionlessFunc({
|
|
|
6
6
|
func: async ({ logger, config }) => {
|
|
7
7
|
const { workflowTypesFile, functionTypesFile, packageMappings } = config;
|
|
8
8
|
const functionTypesImportPath = getFileImportRelativePath(workflowTypesFile, functionTypesFile, packageMappings);
|
|
9
|
-
|
|
9
|
+
// Get RPC map import path
|
|
10
|
+
const rpcMapImportPath = getFileImportRelativePath(workflowTypesFile, config.rpcInternalMapDeclarationFile, packageMappings);
|
|
11
|
+
await writeFileInDir(logger, workflowTypesFile, serializeWorkflowTypes(functionTypesImportPath, rpcMapImportPath));
|
|
10
12
|
},
|
|
11
13
|
});
|
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import { pikkuSessionlessFunc } from '../../../../.pikku/pikku-types.gen.js';
|
|
2
2
|
import { ErrorCode } from '@pikku/inspector';
|
|
3
|
-
import { serializeFileImports } from '../../../utils/file-imports-serializer.js';
|
|
4
3
|
import { writeFileInDir } from '../../../utils/file-writer.js';
|
|
5
4
|
import { logCommandInfoAndTime } from '../../../middleware/log-command-info-and-time.js';
|
|
6
|
-
import { serializeWorkflowMeta } from './serialize-workflow-meta.js';
|
|
5
|
+
import { serializeWorkflowMeta, serializeWorkflowMetaTS, } from './serialize-workflow-meta.js';
|
|
7
6
|
import { serializeWorkflowTypes } from './serialize-workflow-types.js';
|
|
8
7
|
import { serializeWorkflowMap } from './serialize-workflow-map.js';
|
|
9
8
|
import { serializeWorkflowWorkers } from './serialize-workflow-workers.js';
|
|
9
|
+
import { serializeWorkflowWirings } from './serialize-workflow-wirings.js';
|
|
10
10
|
import { getFileImportRelativePath } from '../../../utils/file-import-path.js';
|
|
11
11
|
import { join } from 'path';
|
|
12
12
|
export const pikkuWorkflow = pikkuSessionlessFunc({
|
|
13
13
|
func: async ({ logger, config, getInspectorState }) => {
|
|
14
14
|
const visitState = await getInspectorState();
|
|
15
|
-
const { workflowsWiringFile, workflowsWiringMetaFile, workflowMapDeclarationFile, workflowTypesFile, functionTypesFile, typesDeclarationFile, packageMappings, } = config;
|
|
15
|
+
const { workflowsWiringFile, workflowsWiringMetaFile, workflowsWiringMetaJsonFile, workflowMapDeclarationFile, workflowTypesFile, functionTypesFile, typesDeclarationFile, packageMappings, schema, } = config;
|
|
16
16
|
const { workflows, functions: functionState } = visitState;
|
|
17
17
|
const { typesMap } = functionState;
|
|
18
18
|
// Validate that workflowService service is configured if workflows are defined
|
|
@@ -24,13 +24,17 @@ export const pikkuWorkflow = pikkuSessionlessFunc({
|
|
|
24
24
|
throw new Error('WorkflowState service not configured but workflows are defined');
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
// Write workflow
|
|
30
|
-
await writeFileInDir(logger,
|
|
27
|
+
await writeFileInDir(logger, workflowsWiringMetaJsonFile, JSON.stringify(serializeWorkflowMeta(workflows.meta), null, 2));
|
|
28
|
+
const jsonImportPath = getFileImportRelativePath(workflowsWiringMetaFile, workflowsWiringMetaJsonFile, packageMappings);
|
|
29
|
+
// Write workflow metadata TypeScript file that imports JSON
|
|
30
|
+
await writeFileInDir(logger, workflowsWiringMetaFile, serializeWorkflowMetaTS(workflows.meta, jsonImportPath, schema?.supportsImportAttributes ?? false));
|
|
31
|
+
// Write workflow wirings (imports and addWorkflow calls)
|
|
32
|
+
await writeFileInDir(logger, workflowsWiringFile, serializeWorkflowWirings(workflowsWiringFile, workflows.files, packageMappings));
|
|
31
33
|
// Write workflow types
|
|
32
34
|
const functionTypesImportPath = getFileImportRelativePath(workflowTypesFile, functionTypesFile, packageMappings);
|
|
33
|
-
|
|
35
|
+
// Get RPC map import path
|
|
36
|
+
const rpcMapImportPath = getFileImportRelativePath(workflowTypesFile, config.rpcInternalMapDeclarationFile, packageMappings);
|
|
37
|
+
await writeFileInDir(logger, workflowTypesFile, serializeWorkflowTypes(functionTypesImportPath, rpcMapImportPath));
|
|
34
38
|
// Write workflow map (type-safe client API)
|
|
35
39
|
await writeFileInDir(logger, workflowMapDeclarationFile, serializeWorkflowMap(workflowMapDeclarationFile, packageMappings, typesMap, functionState.meta, workflows.meta));
|
|
36
40
|
if (config.workflows) {
|
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { WorkflowsMeta } from '@pikku/core/workflow';
|
|
2
|
-
export declare const serializeWorkflowMeta: (workflowsMeta: WorkflowsMeta) =>
|
|
2
|
+
export declare const serializeWorkflowMeta: (workflowsMeta: WorkflowsMeta) => WorkflowsMeta;
|
|
3
|
+
export declare const serializeWorkflowMetaTS: (workflowsMeta: WorkflowsMeta, jsonImportPath: string, supportsImportAttributes: boolean) => string;
|
|
@@ -1,7 +1,17 @@
|
|
|
1
1
|
export const serializeWorkflowMeta = (workflowsMeta) => {
|
|
2
|
+
return workflowsMeta;
|
|
3
|
+
};
|
|
4
|
+
export const serializeWorkflowMetaTS = (workflowsMeta, jsonImportPath, supportsImportAttributes) => {
|
|
5
|
+
const importStatement = supportsImportAttributes
|
|
6
|
+
? `import metaData from '${jsonImportPath}' with { type: 'json' }`
|
|
7
|
+
: `import metaData from '${jsonImportPath}'`;
|
|
2
8
|
const serializedOutput = [];
|
|
3
9
|
serializedOutput.push("import { pikkuState } from '@pikku/core'");
|
|
4
|
-
serializedOutput.push(
|
|
10
|
+
serializedOutput.push("import { WorkflowsMeta } from '@pikku/core/workflow'");
|
|
11
|
+
serializedOutput.push(importStatement);
|
|
12
|
+
serializedOutput.push('');
|
|
13
|
+
serializedOutput.push("pikkuState('workflows', 'meta', metaData as WorkflowsMeta)");
|
|
14
|
+
serializedOutput.push('');
|
|
5
15
|
const workflowsMetaValues = Object.values(workflowsMeta);
|
|
6
16
|
if (workflowsMetaValues.length > 0) {
|
|
7
17
|
serializedOutput.push(`export type WorkflowNames = '${workflowsMetaValues.map((w) => w.workflowName).join("' | '")}'`);
|
|
@@ -1,30 +1,20 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Generates type definitions for workflow wirings
|
|
3
3
|
*/
|
|
4
|
-
export const serializeWorkflowTypes = (functionTypesImportPath) => {
|
|
4
|
+
export const serializeWorkflowTypes = (functionTypesImportPath, rpcMapImportPath) => {
|
|
5
5
|
return `/**
|
|
6
6
|
* Workflow-specific type definitions for tree-shaking optimization
|
|
7
7
|
*/
|
|
8
8
|
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import type {
|
|
12
|
-
import type { UserSession, SingletonServices } from '../../types/application-types.d.js'
|
|
13
|
-
import type { TypedPikkuRPC, RPCMap } from '../rpc/pikku-rpc-wirings-map.internal.gen.d.js'
|
|
9
|
+
import { PikkuWorkflowWire, WorkflowStepOptions } from '@pikku/core/workflow'
|
|
10
|
+
import type { PikkuFunctionSessionless, PikkuFunctionConfig } from '${functionTypesImportPath}'
|
|
11
|
+
import type { RPCMap } from '${rpcMapImportPath}'
|
|
14
12
|
|
|
15
13
|
/**
|
|
16
|
-
*
|
|
17
|
-
* Workflows support both inline and remote execution modes with step caching.
|
|
18
|
-
*/
|
|
19
|
-
type WorkflowWiring = CoreWorkflow<
|
|
20
|
-
CorePikkuFunctionConfig<PikkuFunctionWorkflow<any, any>, PikkuPermission<any>, PikkuMiddleware>
|
|
21
|
-
>
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Typed workflow interaction with RPC awareness
|
|
14
|
+
* Typed workflow wire with RPC awareness
|
|
25
15
|
* Provides type-safe workflow.do() for RPC steps
|
|
26
16
|
*/
|
|
27
|
-
export interface TypedWorkflow extends
|
|
17
|
+
export interface TypedWorkflow extends PikkuWorkflowWire {
|
|
28
18
|
/**
|
|
29
19
|
* Execute a workflow step with RPC invocation (typed based on available RPCs)
|
|
30
20
|
* @template K - RPC name from the RPC map
|
|
@@ -49,25 +39,23 @@ export interface TypedWorkflow extends PikkuWorkflowInteraction {
|
|
|
49
39
|
|
|
50
40
|
/**
|
|
51
41
|
* Workflow function type with typed workflow service
|
|
52
|
-
* Includes the workflow
|
|
42
|
+
* Includes the workflow wire object with typed RPC methods
|
|
53
43
|
*/
|
|
54
44
|
export type PikkuFunctionWorkflow<
|
|
55
45
|
In = unknown,
|
|
56
46
|
Out = never
|
|
57
|
-
> =
|
|
47
|
+
> = PikkuFunctionSessionless<
|
|
58
48
|
In,
|
|
59
49
|
Out,
|
|
60
|
-
|
|
61
|
-
SingletonServices & {
|
|
62
|
-
rpc: TypedPikkuRPC
|
|
63
|
-
workflow: TypedWorkflow
|
|
64
|
-
},
|
|
65
|
-
UserSession
|
|
50
|
+
'workflow'
|
|
66
51
|
>
|
|
67
52
|
|
|
68
53
|
/**
|
|
69
54
|
* Creates a workflow function with typed input and output.
|
|
70
|
-
* Workflow functions have access to the workflow
|
|
55
|
+
* Workflow functions have access to the workflow wire object for step execution.
|
|
56
|
+
*
|
|
57
|
+
* This is the permissive mode - workflows that don't conform to simple DSL will fall back
|
|
58
|
+
* to basic extraction with a warning.
|
|
71
59
|
*
|
|
72
60
|
* @template In - Input type for the workflow
|
|
73
61
|
* @template Out - Output type for the workflow
|
|
@@ -77,19 +65,36 @@ export type PikkuFunctionWorkflow<
|
|
|
77
65
|
export const pikkuWorkflowFunc = <In, Out = unknown>(
|
|
78
66
|
func:
|
|
79
67
|
| PikkuFunctionWorkflow<In, Out>
|
|
80
|
-
|
|
|
68
|
+
| PikkuFunctionConfig<In, Out, 'workflow', PikkuFunctionWorkflow<In, Out>>
|
|
81
69
|
) => {
|
|
82
70
|
return typeof func === 'function' ? { func } : func
|
|
83
71
|
}
|
|
84
72
|
|
|
85
73
|
/**
|
|
86
|
-
*
|
|
87
|
-
*
|
|
74
|
+
* Creates a simple workflow function with typed input and output.
|
|
75
|
+
* Simple workflows must conform to the restricted DSL for static analysis.
|
|
76
|
+
*
|
|
77
|
+
* This is the strict mode - workflows that don't conform to simple DSL will cause
|
|
78
|
+
* a critical error during inspection.
|
|
88
79
|
*
|
|
89
|
-
*
|
|
80
|
+
* Constraints:
|
|
81
|
+
* - Must use only workflow.do() with RPC form (no inline functions)
|
|
82
|
+
* - Only if/else, for..of, and Promise.all(array.map()) control flow allowed
|
|
83
|
+
* - Step names must be unique (except across mutually exclusive branches)
|
|
84
|
+
* - All workflow calls must be awaited
|
|
85
|
+
*
|
|
86
|
+
* @template In - Input type for the workflow
|
|
87
|
+
* @template Out - Output type for the workflow
|
|
88
|
+
* @param func - Function definition, either direct function or configuration object
|
|
89
|
+
* @returns The normalized configuration object
|
|
90
90
|
*/
|
|
91
|
-
export const
|
|
92
|
-
|
|
91
|
+
export const pikkuSimpleWorkflowFunc = <In, Out = unknown>(
|
|
92
|
+
func:
|
|
93
|
+
| PikkuFunctionWorkflow<In, Out>
|
|
94
|
+
| PikkuFunctionConfig<In, Out, 'workflow', PikkuFunctionWorkflow<In, Out>>
|
|
95
|
+
) => {
|
|
96
|
+
return typeof func === 'function' ? { func } : func
|
|
93
97
|
}
|
|
98
|
+
|
|
94
99
|
`;
|
|
95
100
|
};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generate workflow registration wirings
|
|
3
|
+
* Imports all workflow functions and calls addWorkflow for each
|
|
4
|
+
*/
|
|
5
|
+
export declare const serializeWorkflowWirings: (outputPath: string, workflowFiles: Map<string, {
|
|
6
|
+
path: string;
|
|
7
|
+
exportedName: string;
|
|
8
|
+
}>, packageMappings?: Record<string, string>) => string;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { getFileImportRelativePath } from '../../../utils/file-import-path.js';
|
|
2
|
+
/**
|
|
3
|
+
* Generate workflow registration wirings
|
|
4
|
+
* Imports all workflow functions and calls addWorkflow for each
|
|
5
|
+
*/
|
|
6
|
+
export const serializeWorkflowWirings = (outputPath, workflowFiles, packageMappings = {}) => {
|
|
7
|
+
const imports = [];
|
|
8
|
+
const registrations = [];
|
|
9
|
+
// Sort by pikkuFuncName for consistent output
|
|
10
|
+
const sortedWorkflows = Array.from(workflowFiles.entries()).sort((a, b) => a[0].localeCompare(b[0]));
|
|
11
|
+
// Generate imports
|
|
12
|
+
for (const [, { path, exportedName }] of sortedWorkflows) {
|
|
13
|
+
const importPath = getFileImportRelativePath(outputPath, path, packageMappings);
|
|
14
|
+
imports.push(`import { ${exportedName} } from '${importPath}'`);
|
|
15
|
+
}
|
|
16
|
+
// Generate addWorkflow calls
|
|
17
|
+
for (const [pikkuFuncName, { exportedName }] of sortedWorkflows) {
|
|
18
|
+
registrations.push(`addWorkflow('${pikkuFuncName}', ${exportedName})`);
|
|
19
|
+
}
|
|
20
|
+
// Only import addWorkflow if there are workflows to register
|
|
21
|
+
const addWorkflowImport = sortedWorkflows.length > 0
|
|
22
|
+
? `import { addWorkflow } from '@pikku/core/workflow'\n\n`
|
|
23
|
+
: '';
|
|
24
|
+
return `/**
|
|
25
|
+
* Auto-generated workflow registrations
|
|
26
|
+
* Do not edit manually - regenerate with 'npx pikku'
|
|
27
|
+
*/
|
|
28
|
+
${addWorkflowImport}${imports.join('\n')}${imports.length > 0 ? '\n\n' : ''}${registrations.join('\n')}
|
|
29
|
+
`;
|
|
30
|
+
};
|
|
@@ -22,7 +22,7 @@ export const pikkuWorkflowWorker = pikkuSessionlessFunc<
|
|
|
22
22
|
WorkflowStepInput,
|
|
23
23
|
void
|
|
24
24
|
>({
|
|
25
|
-
func: async ({ workflowService
|
|
25
|
+
func: async ({ workflowService }, { runId, stepName, rpcName, data }, { rpc }) => {
|
|
26
26
|
await workflowService!.executeWorkflowStep(runId, stepName, rpcName, data, rpc)
|
|
27
27
|
}
|
|
28
28
|
})
|
|
@@ -31,7 +31,7 @@ export const pikkuWorkflowOrchestrator = pikkuSessionlessFunc<
|
|
|
31
31
|
{ runId: string },
|
|
32
32
|
void
|
|
33
33
|
>({
|
|
34
|
-
func: async ({ workflowService,
|
|
34
|
+
func: async ({ workflowService }, { runId }, { rpc }) => {
|
|
35
35
|
await workflowService!.orchestrateWorkflow(runId, rpc)
|
|
36
36
|
}
|
|
37
37
|
})
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { Services } from '../../types/application-types.js';
|
|
2
|
-
import type {
|
|
3
|
-
type PikkuMiddleware = (services: Services,
|
|
2
|
+
import type { PikkuWire } from '@pikku/core';
|
|
3
|
+
type PikkuMiddleware = (services: Services, wire: PikkuWire, next: () => Promise<void>) => Promise<void>;
|
|
4
4
|
export interface LogCommandInfoOptions {
|
|
5
5
|
commandStart: string;
|
|
6
6
|
commandEnd: string;
|
|
@@ -3,13 +3,10 @@
|
|
|
3
3
|
* Uses debug level so it only shows with --verbose flag
|
|
4
4
|
*/
|
|
5
5
|
export const logCommandInfoAndTime = ({ commandStart, commandEnd, }) => {
|
|
6
|
-
return async ({ logger },
|
|
7
|
-
// Log start (debug level - only shows with --verbose)
|
|
6
|
+
return async ({ logger }, _wire, next) => {
|
|
8
7
|
const start = Date.now();
|
|
9
8
|
logger.debug(`• ${commandStart}...`);
|
|
10
|
-
// Execute the function
|
|
11
9
|
await next();
|
|
12
|
-
// Log completion (debug level - only shows with --verbose)
|
|
13
10
|
logger.debug({
|
|
14
11
|
type: 'success',
|
|
15
12
|
message: `✓ ${commandEnd} in ${Date.now() - start}ms.`,
|
|
@@ -17,8 +17,11 @@ export declare class CLILoggerForwarder implements Logger {
|
|
|
17
17
|
private logger;
|
|
18
18
|
private channel;
|
|
19
19
|
private level;
|
|
20
|
+
private silent;
|
|
20
21
|
constructor(logger: Logger, channel: PikkuChannel<unknown, any>);
|
|
21
22
|
setLevel(level: LogLevel): void;
|
|
23
|
+
setSilent(silent: boolean): void;
|
|
24
|
+
isSilent(): boolean;
|
|
22
25
|
private log;
|
|
23
26
|
info(messageOrObj: string | Record<string, any>, ..._meta: any[]): void;
|
|
24
27
|
error(messageOrObj: string | Record<string, any> | Error, ..._meta: any[]): void;
|
|
@@ -7,6 +7,7 @@ export class CLILoggerForwarder {
|
|
|
7
7
|
logger;
|
|
8
8
|
channel;
|
|
9
9
|
level = LogLevel.info;
|
|
10
|
+
silent = false;
|
|
10
11
|
constructor(logger, channel) {
|
|
11
12
|
this.logger = logger;
|
|
12
13
|
this.channel = channel;
|
|
@@ -14,12 +15,18 @@ export class CLILoggerForwarder {
|
|
|
14
15
|
setLevel(level) {
|
|
15
16
|
this.level = level;
|
|
16
17
|
}
|
|
18
|
+
setSilent(silent) {
|
|
19
|
+
this.silent = silent;
|
|
20
|
+
}
|
|
21
|
+
isSilent() {
|
|
22
|
+
return this.silent;
|
|
23
|
+
}
|
|
17
24
|
log(level, logLevel, messageOrObj, type) {
|
|
18
|
-
if (this.level > logLevel)
|
|
25
|
+
if (this.level > logLevel || this.silent)
|
|
19
26
|
return;
|
|
20
27
|
let message;
|
|
21
28
|
if (messageOrObj instanceof Error) {
|
|
22
|
-
this.logger.error(messageOrObj);
|
|
29
|
+
this.logger.error(messageOrObj.toString());
|
|
23
30
|
message = messageOrObj.message;
|
|
24
31
|
}
|
|
25
32
|
else if (typeof messageOrObj === 'object') {
|
package/dist/src/services.d.ts
CHANGED
|
@@ -1,20 +1,15 @@
|
|
|
1
1
|
import type { Config, Services, SingletonServices, UserSession } from '../types/application-types.js';
|
|
2
|
-
import { CreateConfig,
|
|
2
|
+
import { CreateConfig, CreateWireServices, CreateSingletonServices } from '@pikku/core';
|
|
3
3
|
import { PikkuCLIConfig } from '../types/config.js';
|
|
4
4
|
import { ForwardedLogMessage } from './services/cli-logger-forwarder.service.js';
|
|
5
5
|
/**
|
|
6
6
|
* Default CLI renderer that logs output using the logger
|
|
7
7
|
*/
|
|
8
8
|
export declare const defaultCLIRenderer: import("@pikku/core").CorePikkuCLIRender<ForwardedLogMessage, SingletonServices, import("@pikku/core").CoreUserSession>;
|
|
9
|
-
/**
|
|
10
|
-
* Client-safe CLI renderer that outputs to console (no service dependencies)
|
|
11
|
-
* This renderer can be used in CLI-over-channel clients
|
|
12
|
-
*/
|
|
13
|
-
export declare const clientCLIRenderer: import("@pikku/core").CorePikkuCLIRender<ForwardedLogMessage, import("@pikku/core").CoreServices, import("@pikku/core").CoreUserSession>;
|
|
14
9
|
export declare const createConfig: CreateConfig<Config, [PikkuCLIConfig]>;
|
|
15
10
|
/**
|
|
16
11
|
* Singleton services factory for the Pikku CLI
|
|
17
12
|
* This function creates the singleton services used by the CLI and is created once on start.
|
|
18
13
|
*/
|
|
19
14
|
export declare const createSingletonServices: CreateSingletonServices<Config, SingletonServices>;
|
|
20
|
-
export declare const
|
|
15
|
+
export declare const createWireServices: CreateWireServices<SingletonServices, Services, UserSession>;
|
package/dist/src/services.js
CHANGED
|
@@ -70,15 +70,17 @@ export const defaultCLIRenderer = pikkuCLIRender(({ logger }, data) => {
|
|
|
70
70
|
logger[data.level]({ message: data.message, type: data.type });
|
|
71
71
|
}
|
|
72
72
|
});
|
|
73
|
-
/**
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
export const clientCLIRenderer = pikkuCLIRender(
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
}
|
|
73
|
+
// /**
|
|
74
|
+
// * Client-safe CLI renderer that outputs to console (no service dependencies)
|
|
75
|
+
// * This renderer can be used in CLI-over-channel clients
|
|
76
|
+
// */
|
|
77
|
+
// export const clientCLIRenderer = pikkuCLIRender<ForwardedLogMessage>(
|
|
78
|
+
// ({ logger }, data) => {
|
|
79
|
+
// if (data) {
|
|
80
|
+
// logger[data.level]?.({ message: data.message, type: data.type } as any)
|
|
81
|
+
// }
|
|
82
|
+
// }
|
|
83
|
+
// )
|
|
82
84
|
export const createConfig = async (_variablesService, data) => {
|
|
83
85
|
// Determine log level based on CLI flags with precedence:
|
|
84
86
|
// --silent > --loglevel > --verbose > --info > default (warn)
|
|
@@ -155,7 +157,7 @@ export const createSingletonServices = async (config) => {
|
|
|
155
157
|
type: 'CoreUserSession',
|
|
156
158
|
typePath: corePackagePath,
|
|
157
159
|
},
|
|
158
|
-
|
|
160
|
+
wireServicesType: {
|
|
159
161
|
file: corePackagePath,
|
|
160
162
|
variable: 'CoreServices',
|
|
161
163
|
type: 'CoreServices',
|
|
@@ -188,7 +190,7 @@ export const createSingletonServices = async (config) => {
|
|
|
188
190
|
configFileType: config.configFile,
|
|
189
191
|
userSessionType: config.userSessionType,
|
|
190
192
|
singletonServicesFactoryType: config.singletonServicesFactoryType,
|
|
191
|
-
|
|
193
|
+
wireServicesFactoryType: config.wireServicesFactoryType,
|
|
192
194
|
},
|
|
193
195
|
});
|
|
194
196
|
// Save unfiltered inspector state to file if stateOutput is provided
|
|
@@ -216,7 +218,7 @@ export const createSingletonServices = async (config) => {
|
|
|
216
218
|
getInspectorState,
|
|
217
219
|
};
|
|
218
220
|
};
|
|
219
|
-
export const
|
|
221
|
+
export const createWireServices = async ({ logger }, { cli, channel }) => {
|
|
220
222
|
const vChannel = cli ? cli.channel : channel;
|
|
221
223
|
if (!vChannel) {
|
|
222
224
|
throw new Error('No channel provided for CLI services');
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { FilesAndMethodsErrors } from '@pikku/inspector';
|
|
2
2
|
export type RequiredTypes = Partial<{
|
|
3
3
|
config: boolean;
|
|
4
|
-
|
|
4
|
+
wireServiceType: boolean;
|
|
5
5
|
singletonServicesType: boolean;
|
|
6
6
|
userSessionType: boolean;
|
|
7
7
|
singletonServicesFactory: boolean;
|
|
8
|
-
|
|
8
|
+
wireServicesFactory: boolean;
|
|
9
9
|
}>;
|
|
10
10
|
export declare const checkRequiredTypes: (errors: FilesAndMethodsErrors, requires?: RequiredTypes) => void;
|
|
@@ -13,7 +13,7 @@ export const checkRequiredTypes = (errors, requires = {}) => {
|
|
|
13
13
|
}
|
|
14
14
|
if (requires.config && message.includes('CoreConfig'))
|
|
15
15
|
return true;
|
|
16
|
-
if (requires.
|
|
16
|
+
if (requires.wireServiceType && message.includes('CoreServices'))
|
|
17
17
|
return true;
|
|
18
18
|
if (requires.singletonServicesType &&
|
|
19
19
|
message.includes('CoreSingletonServices'))
|
|
@@ -23,8 +23,7 @@ export const checkRequiredTypes = (errors, requires = {}) => {
|
|
|
23
23
|
if (requires.singletonServicesFactory &&
|
|
24
24
|
message.includes('CreateSingletonServices'))
|
|
25
25
|
return true;
|
|
26
|
-
if (requires.
|
|
27
|
-
message.includes('CreateSessionServices'))
|
|
26
|
+
if (requires.wireServicesFactory && message.includes('CreateWireServices'))
|
|
28
27
|
return true;
|
|
29
28
|
return false;
|
|
30
29
|
});
|