0pflow 0.1.0-dev.628bd97 → 0.1.0-dev.67aecec
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/__tests__/discover.integration.test.d.ts +2 -0
- package/dist/__tests__/discover.integration.test.d.ts.map +1 -0
- package/dist/__tests__/discover.integration.test.js +137 -0
- package/dist/__tests__/discover.integration.test.js.map +1 -0
- package/dist/__tests__/factory.test.js +13 -0
- package/dist/__tests__/factory.test.js.map +1 -1
- package/dist/__tests__/integration.e2e.test.js +2 -1
- package/dist/__tests__/integration.e2e.test.js.map +1 -1
- package/dist/__tests__/integration.test.js +87 -82
- package/dist/__tests__/integration.test.js.map +1 -1
- package/dist/agent.d.ts +7 -0
- package/dist/agent.d.ts.map +1 -1
- package/dist/agent.js +75 -10
- package/dist/agent.js.map +1 -1
- package/dist/cli/__tests__/discovery.test.js +1 -1
- package/dist/cli/__tests__/discovery.test.js.map +1 -1
- package/dist/cli/app.d.ts +6 -0
- package/dist/cli/app.d.ts.map +1 -1
- package/dist/cli/app.js +31 -0
- package/dist/cli/app.js.map +1 -1
- package/dist/cli/cloud-dev.d.ts +7 -0
- package/dist/cli/cloud-dev.d.ts.map +1 -0
- package/dist/cli/cloud-dev.js +570 -0
- package/dist/cli/cloud-dev.js.map +1 -0
- package/dist/cli/deploy.d.ts +27 -0
- package/dist/cli/deploy.d.ts.map +1 -0
- package/dist/cli/deploy.js +332 -0
- package/dist/cli/deploy.js.map +1 -0
- package/dist/cli/discovery.d.ts +10 -0
- package/dist/cli/discovery.d.ts.map +1 -1
- package/dist/cli/discovery.js +42 -0
- package/dist/cli/discovery.js.map +1 -1
- package/dist/cli/env.d.ts +3 -1
- package/dist/cli/env.d.ts.map +1 -1
- package/dist/cli/env.js +9 -4
- package/dist/cli/env.js.map +1 -1
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +208 -11
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/install.d.ts +4 -0
- package/dist/cli/install.d.ts.map +1 -1
- package/dist/cli/install.js +63 -32
- package/dist/cli/install.js.map +1 -1
- package/dist/cli/mcp/config.d.ts +0 -1
- package/dist/cli/mcp/config.d.ts.map +1 -1
- package/dist/cli/mcp/config.js +2 -4
- package/dist/cli/mcp/config.js.map +1 -1
- package/dist/cli/mcp/lib/scaffolding.d.ts +33 -0
- package/dist/cli/mcp/lib/scaffolding.d.ts.map +1 -0
- package/dist/cli/mcp/lib/scaffolding.js +234 -0
- package/dist/cli/mcp/lib/scaffolding.js.map +1 -0
- package/dist/cli/mcp/lib/templates.d.ts +1 -0
- package/dist/cli/mcp/lib/templates.d.ts.map +1 -1
- package/dist/cli/mcp/lib/templates.js.map +1 -1
- package/dist/cli/mcp/tools/createApp.d.ts +1 -0
- package/dist/cli/mcp/tools/createApp.d.ts.map +1 -1
- package/dist/cli/mcp/tools/createApp.js +12 -53
- package/dist/cli/mcp/tools/createApp.js.map +1 -1
- package/dist/cli/mcp/tools/createDatabase.d.ts.map +1 -1
- package/dist/cli/mcp/tools/createDatabase.js +2 -41
- package/dist/cli/mcp/tools/createDatabase.js.map +1 -1
- package/dist/cli/mcp/tools/getConnectionInfo.d.ts +19 -0
- package/dist/cli/mcp/tools/getConnectionInfo.d.ts.map +1 -0
- package/dist/cli/mcp/tools/getConnectionInfo.js +111 -0
- package/dist/cli/mcp/tools/getConnectionInfo.js.map +1 -0
- package/dist/cli/mcp/tools/getRun.d.ts +22 -0
- package/dist/cli/mcp/tools/getRun.d.ts.map +1 -0
- package/dist/cli/mcp/tools/getRun.js +80 -0
- package/dist/cli/mcp/tools/getRun.js.map +1 -0
- package/dist/cli/mcp/tools/getTrace.d.ts +32 -0
- package/dist/cli/mcp/tools/getTrace.d.ts.map +1 -0
- package/dist/cli/mcp/tools/getTrace.js +104 -0
- package/dist/cli/mcp/tools/getTrace.js.map +1 -0
- package/dist/cli/mcp/tools/index.d.ts +94 -1
- package/dist/cli/mcp/tools/index.d.ts.map +1 -1
- package/dist/cli/mcp/tools/index.js +16 -0
- package/dist/cli/mcp/tools/index.js.map +1 -1
- package/dist/cli/mcp/tools/listIntegrations.d.ts +14 -0
- package/dist/cli/mcp/tools/listIntegrations.d.ts.map +1 -0
- package/dist/cli/mcp/tools/listIntegrations.js +53 -0
- package/dist/cli/mcp/tools/listIntegrations.js.map +1 -0
- package/dist/cli/mcp/tools/listRuns.d.ts +21 -0
- package/dist/cli/mcp/tools/listRuns.d.ts.map +1 -0
- package/dist/cli/mcp/tools/listRuns.js +72 -0
- package/dist/cli/mcp/tools/listRuns.js.map +1 -0
- package/dist/cli/mcp/tools/listWorkflows.d.ts +15 -0
- package/dist/cli/mcp/tools/listWorkflows.d.ts.map +1 -0
- package/dist/cli/mcp/tools/listWorkflows.js +45 -0
- package/dist/cli/mcp/tools/listWorkflows.js.map +1 -0
- package/dist/cli/mcp/tools/runNode.d.ts +17 -0
- package/dist/cli/mcp/tools/runNode.d.ts.map +1 -0
- package/dist/cli/mcp/tools/runNode.js +74 -0
- package/dist/cli/mcp/tools/runNode.js.map +1 -0
- package/dist/cli/mcp/tools/runWorkflow.d.ts +16 -0
- package/dist/cli/mcp/tools/runWorkflow.d.ts.map +1 -0
- package/dist/cli/mcp/tools/runWorkflow.js +66 -0
- package/dist/cli/mcp/tools/runWorkflow.js.map +1 -0
- package/dist/cli/mcp/tools/setupAppSchema.d.ts +1 -1
- package/dist/cli/mcp/tools/setupAppSchema.d.ts.map +1 -1
- package/dist/cli/mcp/tools/setupAppSchema.js +11 -132
- package/dist/cli/mcp/tools/setupAppSchema.js.map +1 -1
- package/dist/cli/mcp/tools/utils.d.ts +7 -0
- package/dist/cli/mcp/tools/utils.d.ts.map +1 -0
- package/dist/cli/mcp/tools/utils.js +28 -0
- package/dist/cli/mcp/tools/utils.js.map +1 -0
- package/dist/cli/run.d.ts +2 -0
- package/dist/cli/run.d.ts.map +1 -0
- package/dist/cli/run.js +560 -0
- package/dist/cli/run.js.map +1 -0
- package/dist/cli/trace.d.ts +5 -0
- package/dist/cli/trace.d.ts.map +1 -1
- package/dist/cli/trace.js +1 -1
- package/dist/cli/trace.js.map +1 -1
- package/dist/connections/cloud-auth.d.ts +46 -0
- package/dist/connections/cloud-auth.d.ts.map +1 -0
- package/dist/connections/cloud-auth.js +247 -0
- package/dist/connections/cloud-auth.js.map +1 -0
- package/dist/connections/cloud-client.d.ts +25 -0
- package/dist/connections/cloud-client.d.ts.map +1 -0
- package/dist/connections/cloud-client.js +66 -0
- package/dist/connections/cloud-client.js.map +1 -0
- package/dist/connections/cloud-integration-provider.d.ts +22 -0
- package/dist/connections/cloud-integration-provider.d.ts.map +1 -0
- package/dist/connections/cloud-integration-provider.js +42 -0
- package/dist/connections/cloud-integration-provider.js.map +1 -0
- package/dist/connections/connection-labels.d.ts +14 -0
- package/dist/connections/connection-labels.d.ts.map +1 -0
- package/dist/connections/connection-labels.js +46 -0
- package/dist/connections/connection-labels.js.map +1 -0
- package/dist/connections/index.d.ts +12 -0
- package/dist/connections/index.d.ts.map +1 -0
- package/dist/connections/index.js +10 -0
- package/dist/connections/index.js.map +1 -0
- package/dist/connections/integration-provider.d.ts +39 -0
- package/dist/connections/integration-provider.d.ts.map +1 -0
- package/dist/connections/integration-provider.js +20 -0
- package/dist/connections/integration-provider.js.map +1 -0
- package/dist/connections/local-integration-provider.d.ts +29 -0
- package/dist/connections/local-integration-provider.d.ts.map +1 -0
- package/dist/connections/local-integration-provider.js +71 -0
- package/dist/connections/local-integration-provider.js.map +1 -0
- package/dist/connections/nango-client.d.ts +14 -0
- package/dist/connections/nango-client.d.ts.map +1 -0
- package/dist/connections/nango-client.js +51 -0
- package/dist/connections/nango-client.js.map +1 -0
- package/dist/connections/resolver.d.ts +26 -0
- package/dist/connections/resolver.d.ts.map +1 -0
- package/dist/connections/resolver.js +48 -0
- package/dist/connections/resolver.js.map +1 -0
- package/dist/connections/schema.d.ts +8 -0
- package/dist/connections/schema.d.ts.map +1 -0
- package/dist/connections/schema.js +31 -0
- package/dist/connections/schema.js.map +1 -0
- package/dist/context.d.ts.map +1 -1
- package/dist/context.js +4 -0
- package/dist/context.js.map +1 -1
- package/dist/dev-ui/api.d.ts +18 -0
- package/dist/dev-ui/api.d.ts.map +1 -0
- package/dist/dev-ui/api.js +273 -0
- package/dist/dev-ui/api.js.map +1 -0
- package/dist/dev-ui/dag/extractor.d.ts +19 -0
- package/dist/dev-ui/dag/extractor.d.ts.map +1 -0
- package/dist/dev-ui/dag/extractor.js +716 -0
- package/dist/dev-ui/dag/extractor.js.map +1 -0
- package/dist/dev-ui/dag/types.d.ts +42 -0
- package/dist/dev-ui/dag/types.d.ts.map +1 -0
- package/dist/dev-ui/dag/types.js +2 -0
- package/dist/dev-ui/dag/types.js.map +1 -0
- package/dist/dev-ui/deploy-api.d.ts +14 -0
- package/dist/dev-ui/deploy-api.d.ts.map +1 -0
- package/dist/dev-ui/deploy-api.js +112 -0
- package/dist/dev-ui/deploy-api.js.map +1 -0
- package/dist/dev-ui/dev-server.d.ts +18 -0
- package/dist/dev-ui/dev-server.d.ts.map +1 -0
- package/dist/dev-ui/dev-server.js +275 -0
- package/dist/dev-ui/dev-server.js.map +1 -0
- package/dist/dev-ui/index.d.ts +3 -0
- package/dist/dev-ui/index.d.ts.map +1 -0
- package/dist/dev-ui/index.js +2 -0
- package/dist/dev-ui/index.js.map +1 -0
- package/dist/dev-ui/pty.d.ts +16 -0
- package/dist/dev-ui/pty.d.ts.map +1 -0
- package/dist/dev-ui/pty.js +87 -0
- package/dist/dev-ui/pty.js.map +1 -0
- package/dist/dev-ui/watcher.d.ts +12 -0
- package/dist/dev-ui/watcher.d.ts.map +1 -0
- package/dist/dev-ui/watcher.js +166 -0
- package/dist/dev-ui/watcher.js.map +1 -0
- package/dist/dev-ui/ws.d.ts +52 -0
- package/dist/dev-ui/ws.d.ts.map +1 -0
- package/dist/dev-ui/ws.js +32 -0
- package/dist/dev-ui/ws.js.map +1 -0
- package/dist/dev-ui-client/assets/index-CNKqwcCH.css +32 -0
- package/dist/dev-ui-client/assets/index-Ccj-QknZ.js +179 -0
- package/dist/dev-ui-client/assets/index-DAKTQEvj.js +1 -0
- package/dist/dev-ui-client/index.html +13 -0
- package/dist/discover.d.ts +15 -0
- package/dist/discover.d.ts.map +1 -0
- package/dist/discover.js +32 -0
- package/dist/discover.js.map +1 -0
- package/dist/factory.d.ts.map +1 -1
- package/dist/factory.js +37 -13
- package/dist/factory.js.map +1 -1
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -1
- package/dist/node.d.ts +1 -0
- package/dist/node.d.ts.map +1 -1
- package/dist/node.js +1 -0
- package/dist/node.js.map +1 -1
- package/dist/nodes/agent/executor.d.ts +2 -0
- package/dist/nodes/agent/executor.d.ts.map +1 -1
- package/dist/nodes/agent/executor.js +11 -1
- package/dist/nodes/agent/executor.js.map +1 -1
- package/dist/registry-gen.d.ts +6 -0
- package/dist/registry-gen.d.ts.map +1 -0
- package/dist/registry-gen.js +146 -0
- package/dist/registry-gen.js.map +1 -0
- package/dist/types.d.ts +28 -3
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +18 -1
- package/dist/types.js.map +1 -1
- package/dist/workflow.d.ts +22 -0
- package/dist/workflow.d.ts.map +1 -1
- package/dist/workflow.js +113 -3
- package/dist/workflow.js.map +1 -1
- package/package.json +30 -6
- package/templates/app/.dockerignore +6 -0
- package/templates/app/.env.example +13 -0
- package/templates/app/Dockerfile +34 -0
- package/templates/app/README.md +29 -0
- package/templates/app/biome.jsonc +81 -0
- package/templates/app/dbos-config.yaml +6 -0
- package/templates/app/drizzle.config.ts +12 -0
- package/templates/app/generated/registry.ts +8 -0
- package/templates/app/next.config.js +13 -0
- package/templates/app/package.json +57 -0
- package/templates/app/postcss.config.js +5 -0
- package/templates/app/public/favicon.ico +0 -0
- package/templates/app/src/app/_components/.gitkeep +0 -0
- package/templates/app/src/app/api/trpc/[trpc]/route.ts +34 -0
- package/templates/app/src/app/api/workflow/[name]/route.ts +37 -0
- package/templates/app/src/app/layout.tsx +29 -0
- package/templates/app/src/app/page.tsx +18 -0
- package/templates/app/src/env.js +46 -0
- package/templates/app/src/instrumentation.ts +6 -0
- package/templates/app/src/lib/pflow.ts +28 -0
- package/templates/app/src/server/api/root.ts +21 -0
- package/templates/app/src/server/api/routers/.gitkeep +0 -0
- package/templates/app/src/server/api/trpc.ts +106 -0
- package/templates/app/src/server/db/index.ts +18 -0
- package/templates/app/src/server/db/schema.ts +14 -0
- package/templates/app/src/styles/globals.css +6 -0
- package/templates/app/src/styles/globals.css.orange +126 -0
- package/templates/app/src/trpc/query-client.ts +25 -0
- package/templates/app/src/trpc/react.tsx +78 -0
- package/templates/app/src/trpc/server.ts +30 -0
- package/templates/app/tsconfig.check.json +23 -0
- package/templates/app/tsconfig.json +42 -0
- package/templates/app/tsconfig.server.json +5 -0
- package/templates/app/tsconfig.test.json +21 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Auto-detect and create the appropriate IntegrationProvider.
|
|
3
|
+
*
|
|
4
|
+
* - NANGO_SECRET_KEY set → LocalIntegrationProvider (direct Nango)
|
|
5
|
+
* - Otherwise → CloudIntegrationProvider (proxies through 0pflow cloud)
|
|
6
|
+
*
|
|
7
|
+
* Optionally pass a nangoSecretKey to override env detection.
|
|
8
|
+
*/
|
|
9
|
+
export async function createIntegrationProvider(nangoSecretKey) {
|
|
10
|
+
const key = nangoSecretKey ?? process.env.NANGO_SECRET_KEY;
|
|
11
|
+
if (key) {
|
|
12
|
+
const { createLocalIntegrationProvider } = await import("./local-integration-provider.js");
|
|
13
|
+
return createLocalIntegrationProvider(key);
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
const { CloudIntegrationProvider } = await import("./cloud-integration-provider.js");
|
|
17
|
+
return new CloudIntegrationProvider();
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=integration-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"integration-provider.js","sourceRoot":"","sources":["../../src/connections/integration-provider.ts"],"names":[],"mappings":"AAmCA;;;;;;;GAOG;AACH,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAC7C,cAAuB;IAEvB,MAAM,GAAG,GAAG,cAAc,IAAI,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC;IAE3D,IAAI,GAAG,EAAE,CAAC;QACR,MAAM,EAAE,8BAA8B,EAAE,GAAG,MAAM,MAAM,CAAC,iCAAiC,CAAC,CAAC;QAC3F,OAAO,8BAA8B,CAAC,GAAG,CAAC,CAAC;IAC7C,CAAC;SAAM,CAAC;QACN,MAAM,EAAE,wBAAwB,EAAE,GAAG,MAAM,MAAM,CAAC,iCAAiC,CAAC,CAAC;QACrF,OAAO,IAAI,wBAAwB,EAAE,CAAC;IACxC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { IntegrationProvider } from "./integration-provider.js";
|
|
2
|
+
import { ConnectionCredentials } from "../types.js";
|
|
3
|
+
/**
|
|
4
|
+
* IntegrationProvider backed by a direct Nango connection (self-hosted mode).
|
|
5
|
+
* Requires NANGO_SECRET_KEY.
|
|
6
|
+
*/
|
|
7
|
+
export declare class LocalIntegrationProvider implements IntegrationProvider {
|
|
8
|
+
private nango;
|
|
9
|
+
constructor(nangoInstance: any);
|
|
10
|
+
fetchCredentials(integrationId: string, connectionId: string): Promise<ConnectionCredentials>;
|
|
11
|
+
listIntegrations(): Promise<Array<{
|
|
12
|
+
id: string;
|
|
13
|
+
provider: string;
|
|
14
|
+
}>>;
|
|
15
|
+
listConnections(integrationId: string): Promise<Array<{
|
|
16
|
+
connection_id: string;
|
|
17
|
+
provider_config_key: string;
|
|
18
|
+
display_name: string;
|
|
19
|
+
}>>;
|
|
20
|
+
createConnectSession(integrationId: string, endUserId?: string): Promise<{
|
|
21
|
+
token: string;
|
|
22
|
+
}>;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Create a LocalIntegrationProvider from a Nango secret key.
|
|
26
|
+
* Uses dynamic import to avoid hard dependency on @nangohq/node.
|
|
27
|
+
*/
|
|
28
|
+
export declare function createLocalIntegrationProvider(secretKey: string): Promise<LocalIntegrationProvider>;
|
|
29
|
+
//# sourceMappingURL=local-integration-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-integration-provider.d.ts","sourceRoot":"","sources":["../../src/connections/local-integration-provider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAGpD;;;GAGG;AACH,qBAAa,wBAAyB,YAAW,mBAAmB;IAElE,OAAO,CAAC,KAAK,CAAM;gBAGP,aAAa,EAAE,GAAG;IAIxB,gBAAgB,CACpB,aAAa,EAAE,MAAM,EACrB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,qBAAqB,CAAC;IAkB3B,gBAAgB,IAAI,OAAO,CAAC,KAAK,CAAC;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAUpE,eAAe,CACnB,aAAa,EAAE,MAAM,GACpB,OAAO,CAAC,KAAK,CAAC;QAAE,aAAa,EAAE,MAAM,CAAC;QAAC,mBAAmB,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAwBzF,oBAAoB,CACxB,aAAa,EAAE,MAAM,EACrB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;CAO9B;AAED;;;GAGG;AACH,wBAAsB,8BAA8B,CAClD,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,wBAAwB,CAAC,CAInC"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { ConnectionCredentials } from "../types.js";
|
|
2
|
+
import { getConnectionDisplayName } from "./connection-labels.js";
|
|
3
|
+
/**
|
|
4
|
+
* IntegrationProvider backed by a direct Nango connection (self-hosted mode).
|
|
5
|
+
* Requires NANGO_SECRET_KEY.
|
|
6
|
+
*/
|
|
7
|
+
export class LocalIntegrationProvider {
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
9
|
+
nango;
|
|
10
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
11
|
+
constructor(nangoInstance) {
|
|
12
|
+
this.nango = nangoInstance;
|
|
13
|
+
}
|
|
14
|
+
async fetchCredentials(integrationId, connectionId) {
|
|
15
|
+
const connection = await this.nango.getConnection(integrationId, connectionId);
|
|
16
|
+
const creds = connection.credentials ?? {};
|
|
17
|
+
const token = creds.access_token ??
|
|
18
|
+
creds.api_key ??
|
|
19
|
+
creds.apiKey ??
|
|
20
|
+
creds.token ??
|
|
21
|
+
"";
|
|
22
|
+
return new ConnectionCredentials({
|
|
23
|
+
token,
|
|
24
|
+
connectionConfig: connection.connection_config ?? {},
|
|
25
|
+
raw: creds,
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
async listIntegrations() {
|
|
29
|
+
const result = await this.nango.listIntegrations();
|
|
30
|
+
return (result.configs ?? []).map((c) => ({
|
|
31
|
+
id: c.unique_key,
|
|
32
|
+
provider: c.provider,
|
|
33
|
+
}));
|
|
34
|
+
}
|
|
35
|
+
async listConnections(integrationId) {
|
|
36
|
+
const result = await this.nango.listConnections();
|
|
37
|
+
const filtered = (result.connections ?? []).filter((c) => c.provider_config_key === integrationId);
|
|
38
|
+
return Promise.all(filtered.map(async (c) => {
|
|
39
|
+
let displayName = c.connection_id;
|
|
40
|
+
try {
|
|
41
|
+
const conn = await this.nango.getConnection(integrationId, c.connection_id);
|
|
42
|
+
displayName = await getConnectionDisplayName(integrationId, c.connection_id, conn.credentials);
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
// Fall back to connection_id if fetch fails
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
connection_id: c.connection_id,
|
|
49
|
+
provider_config_key: c.provider_config_key,
|
|
50
|
+
display_name: displayName,
|
|
51
|
+
};
|
|
52
|
+
}));
|
|
53
|
+
}
|
|
54
|
+
async createConnectSession(integrationId, endUserId) {
|
|
55
|
+
const session = await this.nango.createConnectSession({
|
|
56
|
+
end_user: { id: endUserId ?? "dev-ui-user" },
|
|
57
|
+
allowed_integrations: [integrationId],
|
|
58
|
+
});
|
|
59
|
+
return { token: session.data.token };
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Create a LocalIntegrationProvider from a Nango secret key.
|
|
64
|
+
* Uses dynamic import to avoid hard dependency on @nangohq/node.
|
|
65
|
+
*/
|
|
66
|
+
export async function createLocalIntegrationProvider(secretKey) {
|
|
67
|
+
const { Nango } = await import("@nangohq/node");
|
|
68
|
+
const nango = new Nango({ secretKey });
|
|
69
|
+
return new LocalIntegrationProvider(nango);
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=local-integration-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-integration-provider.js","sourceRoot":"","sources":["../../src/connections/local-integration-provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ConnectionCredentials } from "../types.js";
|
|
2
|
+
/**
|
|
3
|
+
* Initialize the Nango client singleton.
|
|
4
|
+
*/
|
|
5
|
+
export declare function initNango(secretKey: string): Promise<void>;
|
|
6
|
+
/**
|
|
7
|
+
* Get the Nango client instance, or null if not initialized.
|
|
8
|
+
*/
|
|
9
|
+
export declare function getNango(): any | null;
|
|
10
|
+
/**
|
|
11
|
+
* Fetch credentials for an integration connection from Nango.
|
|
12
|
+
*/
|
|
13
|
+
export declare function fetchCredentials(integrationId: string, connectionId: string): Promise<ConnectionCredentials>;
|
|
14
|
+
//# sourceMappingURL=nango-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nango-client.d.ts","sourceRoot":"","sources":["../../src/connections/nango-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAkBpD;;GAEG;AACH,wBAAsB,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAGhE;AAED;;GAEG;AAEH,wBAAgB,QAAQ,IAAI,GAAG,GAAG,IAAI,CAErC;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,aAAa,EAAE,MAAM,EACrB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,qBAAqB,CAAC,CAwBhC"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { ConnectionCredentials } from "../types.js";
|
|
2
|
+
// Use dynamic import to avoid hard dependency when Nango isn't configured.
|
|
3
|
+
// Stored on globalThis so it's shared across module instances (jiti vs compiled).
|
|
4
|
+
const NANGO_KEY = Symbol.for("opflow.nangoInstance");
|
|
5
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
6
|
+
function getNangoInstance() {
|
|
7
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
8
|
+
return globalThis[NANGO_KEY] ?? null;
|
|
9
|
+
}
|
|
10
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
11
|
+
function setNangoInstance(instance) {
|
|
12
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
13
|
+
globalThis[NANGO_KEY] = instance;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Initialize the Nango client singleton.
|
|
17
|
+
*/
|
|
18
|
+
export async function initNango(secretKey) {
|
|
19
|
+
const { Nango } = await import("@nangohq/node");
|
|
20
|
+
setNangoInstance(new Nango({ secretKey }));
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Get the Nango client instance, or null if not initialized.
|
|
24
|
+
*/
|
|
25
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
26
|
+
export function getNango() {
|
|
27
|
+
return getNangoInstance();
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Fetch credentials for an integration connection from Nango.
|
|
31
|
+
*/
|
|
32
|
+
export async function fetchCredentials(integrationId, connectionId) {
|
|
33
|
+
const nango = getNangoInstance();
|
|
34
|
+
if (!nango) {
|
|
35
|
+
throw new Error("Nango not initialized. Set NANGO_SECRET_KEY environment variable or nangoSecretKey in config.");
|
|
36
|
+
}
|
|
37
|
+
const connection = await nango.getConnection(integrationId, connectionId);
|
|
38
|
+
// Extract token from credentials based on auth type
|
|
39
|
+
const creds = connection.credentials ?? {};
|
|
40
|
+
const token = creds.access_token ??
|
|
41
|
+
creds.api_key ??
|
|
42
|
+
creds.apiKey ??
|
|
43
|
+
creds.token ??
|
|
44
|
+
"";
|
|
45
|
+
return new ConnectionCredentials({
|
|
46
|
+
token,
|
|
47
|
+
connectionConfig: connection.connection_config ?? {},
|
|
48
|
+
raw: creds,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=nango-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nango-client.js","sourceRoot":"","sources":["../../src/connections/nango-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAEpD,2EAA2E;AAC3E,kFAAkF;AAClF,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;AAErD,8DAA8D;AAC9D,SAAS,gBAAgB;IACvB,8DAA8D;IAC9D,OAAQ,UAAkC,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC;AAChE,CAAC;AAED,8DAA8D;AAC9D,SAAS,gBAAgB,CAAC,QAAa;IACrC,8DAA8D;IAC7D,UAAkC,CAAC,SAAS,CAAC,GAAG,QAAQ,CAAC;AAC5D,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,SAAiB;IAC/C,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC,CAAC;IAChD,gBAAgB,CAAC,IAAI,KAAK,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;AAC7C,CAAC;AAED;;GAEG;AACH,8DAA8D;AAC9D,MAAM,UAAU,QAAQ;IACtB,OAAO,gBAAgB,EAAE,CAAC;AAC5B,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,aAAqB,EACrB,YAAoB;IAEpB,MAAM,KAAK,GAAG,gBAAgB,EAAE,CAAC;IACjC,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CACb,+FAA+F,CAChG,CAAC;IACJ,CAAC;IAED,MAAM,UAAU,GAAG,MAAM,KAAK,CAAC,aAAa,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;IAE1E,oDAAoD;IACpD,MAAM,KAAK,GAAG,UAAU,CAAC,WAAW,IAAI,EAAE,CAAC;IAC3C,MAAM,KAAK,GACT,KAAK,CAAC,YAAY;QAClB,KAAK,CAAC,OAAO;QACb,KAAK,CAAC,MAAM;QACZ,KAAK,CAAC,KAAK;QACX,EAAE,CAAC;IAEL,OAAO,IAAI,qBAAqB,CAAC;QAC/B,KAAK;QACL,gBAAgB,EAAE,UAAU,CAAC,iBAAiB,IAAI,EAAE;QACpD,GAAG,EAAE,KAAK;KACX,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import pg from "pg";
|
|
2
|
+
export interface ConnectionMapping {
|
|
3
|
+
workflow_name: string;
|
|
4
|
+
node_name: string;
|
|
5
|
+
integration_id: string;
|
|
6
|
+
connection_id: string;
|
|
7
|
+
updated_at?: Date;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Resolve a connection ID for a given workflow/node/integration.
|
|
11
|
+
* Checks for an exact match first, then falls back to global defaults (* / *).
|
|
12
|
+
*/
|
|
13
|
+
export declare function resolveConnectionId(pool: pg.Pool, workflowName: string, nodeName: string, integrationId: string, schema: string): Promise<string | null>;
|
|
14
|
+
/**
|
|
15
|
+
* Upsert a connection mapping.
|
|
16
|
+
*/
|
|
17
|
+
export declare function upsertConnection(pool: pg.Pool, mapping: Omit<ConnectionMapping, "updated_at">, schema: string): Promise<void>;
|
|
18
|
+
/**
|
|
19
|
+
* List all connection mappings.
|
|
20
|
+
*/
|
|
21
|
+
export declare function listConnections(pool: pg.Pool, schema: string): Promise<ConnectionMapping[]>;
|
|
22
|
+
/**
|
|
23
|
+
* Delete a connection mapping.
|
|
24
|
+
*/
|
|
25
|
+
export declare function deleteConnection(pool: pg.Pool, workflowName: string, nodeName: string, integrationId: string, schema: string): Promise<void>;
|
|
26
|
+
//# sourceMappingURL=resolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolver.d.ts","sourceRoot":"","sources":["../../src/connections/resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;AAEpB,MAAM,WAAW,iBAAiB;IAChC,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,IAAI,CAAC;CACnB;AAOD;;;GAGG;AACH,wBAAsB,mBAAmB,CACvC,IAAI,EAAE,EAAE,CAAC,IAAI,EACb,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAcxB;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,IAAI,EAAE,EAAE,CAAC,IAAI,EACb,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,YAAY,CAAC,EAC9C,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC,CAQf;AAED;;GAEG;AACH,wBAAsB,eAAe,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,EAAE,CAAC,CAOjG;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,IAAI,EAAE,EAAE,CAAC,IAAI,EACb,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC,CAQf"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/** Schema-qualified table reference for opflow_connections */
|
|
2
|
+
function table(schema) {
|
|
3
|
+
return `"${schema}".opflow_connections`;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* Resolve a connection ID for a given workflow/node/integration.
|
|
7
|
+
* Checks for an exact match first, then falls back to global defaults (* / *).
|
|
8
|
+
*/
|
|
9
|
+
export async function resolveConnectionId(pool, workflowName, nodeName, integrationId, schema) {
|
|
10
|
+
const result = await pool.query(`SELECT connection_id FROM ${table(schema)}
|
|
11
|
+
WHERE integration_id = $1
|
|
12
|
+
AND (
|
|
13
|
+
(workflow_name = $2 AND node_name = $3)
|
|
14
|
+
OR (workflow_name = '*' AND node_name = '*')
|
|
15
|
+
)
|
|
16
|
+
ORDER BY
|
|
17
|
+
CASE WHEN workflow_name = '*' AND node_name = '*' THEN 1 ELSE 0 END
|
|
18
|
+
LIMIT 1`, [integrationId, workflowName, nodeName]);
|
|
19
|
+
return result.rows.length > 0 ? result.rows[0].connection_id : null;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Upsert a connection mapping.
|
|
23
|
+
*/
|
|
24
|
+
export async function upsertConnection(pool, mapping, schema) {
|
|
25
|
+
await pool.query(`INSERT INTO ${table(schema)} (workflow_name, node_name, integration_id, connection_id, updated_at)
|
|
26
|
+
VALUES ($1, $2, $3, $4, NOW())
|
|
27
|
+
ON CONFLICT (workflow_name, node_name, integration_id)
|
|
28
|
+
DO UPDATE SET connection_id = EXCLUDED.connection_id, updated_at = NOW()`, [mapping.workflow_name, mapping.node_name, mapping.integration_id, mapping.connection_id]);
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* List all connection mappings.
|
|
32
|
+
*/
|
|
33
|
+
export async function listConnections(pool, schema) {
|
|
34
|
+
const result = await pool.query(`SELECT workflow_name, node_name, integration_id, connection_id, updated_at
|
|
35
|
+
FROM ${table(schema)}
|
|
36
|
+
ORDER BY workflow_name, node_name, integration_id`);
|
|
37
|
+
return result.rows;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Delete a connection mapping.
|
|
41
|
+
*/
|
|
42
|
+
export async function deleteConnection(pool, workflowName, nodeName, integrationId, schema) {
|
|
43
|
+
await pool.query(`DELETE FROM ${table(schema)}
|
|
44
|
+
WHERE workflow_name = $1
|
|
45
|
+
AND node_name = $2
|
|
46
|
+
AND integration_id = $3`, [workflowName, nodeName, integrationId]);
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=resolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolver.js","sourceRoot":"","sources":["../../src/connections/resolver.ts"],"names":[],"mappings":"AAUA,8DAA8D;AAC9D,SAAS,KAAK,CAAC,MAAc;IAC3B,OAAO,IAAI,MAAM,sBAAsB,CAAC;AAC1C,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,IAAa,EACb,YAAoB,EACpB,QAAgB,EAChB,aAAqB,EACrB,MAAc;IAEd,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAC7B,6BAA6B,KAAK,CAAC,MAAM,CAAC;;;;;;;;YAQlC,EACR,CAAC,aAAa,EAAE,YAAY,EAAE,QAAQ,CAAC,CACxC,CAAC;IACF,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,aAAwB,CAAC,CAAC,CAAC,IAAI,CAAC;AAClF,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,IAAa,EACb,OAA8C,EAC9C,MAAc;IAEd,MAAM,IAAI,CAAC,KAAK,CACd,eAAe,KAAK,CAAC,MAAM,CAAC;;;6EAG6C,EACzE,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,cAAc,EAAE,OAAO,CAAC,aAAa,CAAC,CAC1F,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,IAAa,EAAE,MAAc;IACjE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAC7B;WACO,KAAK,CAAC,MAAM,CAAC;sDAC8B,CACnD,CAAC;IACF,OAAO,MAAM,CAAC,IAA2B,CAAC;AAC5C,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,IAAa,EACb,YAAoB,EACpB,QAAgB,EAChB,aAAqB,EACrB,MAAc;IAEd,MAAM,IAAI,CAAC,KAAK,CACd,eAAe,KAAK,CAAC,MAAM,CAAC;;;8BAGF,EAC1B,CAAC,YAAY,EAAE,QAAQ,EAAE,aAAa,CAAC,CACxC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ensure the opflow_connections table exists.
|
|
3
|
+
* Creates a short-lived connection, runs the DDL, then closes it.
|
|
4
|
+
* When schema is provided, the table is created in that schema explicitly
|
|
5
|
+
* (avoids permission issues when a same-named table exists in public).
|
|
6
|
+
*/
|
|
7
|
+
export declare function ensureConnectionsTable(databaseUrl: string, schema: string): Promise<void>;
|
|
8
|
+
//# sourceMappingURL=schema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../src/connections/schema.ts"],"names":[],"mappings":"AAeA;;;;;GAKG;AACH,wBAAsB,sBAAsB,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAS/F"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import pg from "pg";
|
|
2
|
+
function createTableSQL(schema) {
|
|
3
|
+
const table = `"${schema}".opflow_connections`;
|
|
4
|
+
return `
|
|
5
|
+
CREATE TABLE IF NOT EXISTS ${table} (
|
|
6
|
+
workflow_name TEXT NOT NULL,
|
|
7
|
+
node_name TEXT NOT NULL,
|
|
8
|
+
integration_id TEXT NOT NULL,
|
|
9
|
+
connection_id TEXT NOT NULL,
|
|
10
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
11
|
+
PRIMARY KEY (workflow_name, node_name, integration_id)
|
|
12
|
+
)`;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Ensure the opflow_connections table exists.
|
|
16
|
+
* Creates a short-lived connection, runs the DDL, then closes it.
|
|
17
|
+
* When schema is provided, the table is created in that schema explicitly
|
|
18
|
+
* (avoids permission issues when a same-named table exists in public).
|
|
19
|
+
*/
|
|
20
|
+
export async function ensureConnectionsTable(databaseUrl, schema) {
|
|
21
|
+
const client = new pg.Client({ connectionString: databaseUrl });
|
|
22
|
+
try {
|
|
23
|
+
await client.connect();
|
|
24
|
+
await client.query(`CREATE SCHEMA IF NOT EXISTS "${schema}"`);
|
|
25
|
+
await client.query(createTableSQL(schema));
|
|
26
|
+
}
|
|
27
|
+
finally {
|
|
28
|
+
await client.end();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../src/connections/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;AAEpB,SAAS,cAAc,CAAC,MAAc;IACpC,MAAM,KAAK,GAAG,IAAI,MAAM,sBAAsB,CAAC;IAC/C,OAAO;6BACoB,KAAK;;;;;;;EAOhC,CAAC;AACH,CAAC;AAED;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,WAAmB,EAAE,MAAc;IAC9E,MAAM,MAAM,GAAG,IAAI,EAAE,CAAC,MAAM,CAAC,EAAE,gBAAgB,EAAE,WAAW,EAAE,CAAC,CAAC;IAChE,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;QACvB,MAAM,MAAM,CAAC,KAAK,CAAC,gCAAgC,MAAM,GAAG,CAAC,CAAC;QAC9D,MAAM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;IAC7C,CAAC;YAAS,CAAC;QACT,MAAM,MAAM,CAAC,GAAG,EAAE,CAAC;IACrB,CAAC;AACH,CAAC"}
|
package/dist/context.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAc,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAExE,MAAM,WAAW,cAAc;IAC7B,6DAA6D;IAC7D,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,KAAK,IAAI,CAAC;CACrD;AAQD;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,GAAE,cAAmB,GAAG,eAAe,
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAc,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAExE,MAAM,WAAW,cAAc;IAC7B,6DAA6D;IAC7D,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,KAAK,IAAI,CAAC;CACrD;AAQD;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,GAAE,cAAmB,GAAG,eAAe,CA6BnF"}
|
package/dist/context.js
CHANGED
|
@@ -10,12 +10,16 @@ const defaultLogger = (message, level) => {
|
|
|
10
10
|
export function createWorkflowContext(options = {}) {
|
|
11
11
|
const logger = options.logger ?? defaultLogger;
|
|
12
12
|
const ctx = {
|
|
13
|
+
workflowName: "*",
|
|
13
14
|
run: async (executable, inputs) => {
|
|
14
15
|
// Validate inputs against schema
|
|
15
16
|
const validated = executable.inputSchema.parse(inputs);
|
|
16
17
|
// Execute (DBOS wrapping will be added in factory integration)
|
|
17
18
|
return executable.execute(ctx, validated);
|
|
18
19
|
},
|
|
20
|
+
getConnection: async () => {
|
|
21
|
+
throw new Error("getConnection is not available in this context. Use create0pflow() for connection management.");
|
|
22
|
+
},
|
|
19
23
|
log: (message, level = "info") => {
|
|
20
24
|
logger(message, level);
|
|
21
25
|
},
|
package/dist/context.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.js","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":"AAOA,MAAM,aAAa,GAAG,CAAC,OAAe,EAAE,KAAe,EAAE,EAAE;IACzD,OAAO,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CACxC,WAAW,KAAK,KAAK,OAAO,EAAE,CAC/B,CAAC;AACJ,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,UAAU,qBAAqB,CAAC,UAA0B,EAAE;IAChE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,aAAa,CAAC;IAE/C,MAAM,GAAG,GAAoB;QAC3B,GAAG,EAAE,KAAK,EACR,UAAuC,EACvC,MAAc,EACI,EAAE;YACpB,iCAAiC;YACjC,MAAM,SAAS,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAEvD,+DAA+D;YAC/D,OAAO,UAAU,CAAC,OAAO,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAC5C,CAAC;QAED,GAAG,EAAE,CAAC,OAAe,EAAE,QAAkB,MAAM,EAAE,EAAE;YACjD,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACzB,CAAC;KACF,CAAC;IAEF,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":"AAOA,MAAM,aAAa,GAAG,CAAC,OAAe,EAAE,KAAe,EAAE,EAAE;IACzD,OAAO,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CACxC,WAAW,KAAK,KAAK,OAAO,EAAE,CAC/B,CAAC;AACJ,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,UAAU,qBAAqB,CAAC,UAA0B,EAAE;IAChE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,aAAa,CAAC;IAE/C,MAAM,GAAG,GAAoB;QAC3B,YAAY,EAAE,GAAG;QAEjB,GAAG,EAAE,KAAK,EACR,UAAuC,EACvC,MAAc,EACI,EAAE;YACpB,iCAAiC;YACjC,MAAM,SAAS,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAEvD,+DAA+D;YAC/D,OAAO,UAAU,CAAC,OAAO,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAC5C,CAAC;QAED,aAAa,EAAE,KAAK,IAAI,EAAE;YACxB,MAAM,IAAI,KAAK,CACb,+FAA+F,CAChG,CAAC;QACJ,CAAC;QAED,GAAG,EAAE,CAAC,OAAe,EAAE,QAAkB,MAAM,EAAE,EAAE;YACjD,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACzB,CAAC;KACF,CAAC;IAEF,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from "node:http";
|
|
2
|
+
import type pg from "pg";
|
|
3
|
+
import type { IntegrationProvider } from "../connections/integration-provider.js";
|
|
4
|
+
export interface ApiContext {
|
|
5
|
+
pool: pg.Pool;
|
|
6
|
+
integrationProvider: IntegrationProvider;
|
|
7
|
+
/** DBOS system schema (e.g. my_app_dbos) for workflow_status queries */
|
|
8
|
+
schema: string;
|
|
9
|
+
/** App schema where opflow_connections lives (e.g. my_app) */
|
|
10
|
+
appSchema: string;
|
|
11
|
+
/** Project root directory for CLI subprocess execution */
|
|
12
|
+
projectRoot: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Handle API requests. Returns true if the request was handled, false otherwise.
|
|
16
|
+
*/
|
|
17
|
+
export declare function handleApiRequest(req: IncomingMessage, res: ServerResponse, ctx: ApiContext): Promise<boolean>;
|
|
18
|
+
//# sourceMappingURL=api.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../src/dev-ui/api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAGjE,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AAMzB,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAKlF,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC;IACd,mBAAmB,EAAE,mBAAmB,CAAC;IACzC,wEAAwE;IACxE,MAAM,EAAE,MAAM,CAAC;IACf,8DAA8D;IAC9D,SAAS,EAAE,MAAM,CAAC;IAClB,0DAA0D;IAC1D,WAAW,EAAE,MAAM,CAAC;CACrB;AA0BD;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,GAAG,EAAE,eAAe,EACpB,GAAG,EAAE,cAAc,EACnB,GAAG,EAAE,UAAU,GACd,OAAO,CAAC,OAAO,CAAC,CAsRlB"}
|