lorenz 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/NOTICE +13 -0
- package/README.md +774 -0
- package/RELEASE-MANIFEST.json +211 -0
- package/apps/cli/bin/lorenz.js +25 -0
- package/apps/cli/dist/bin/cli.d.ts +3 -0
- package/apps/cli/dist/bin/cli.d.ts.map +1 -0
- package/apps/cli/dist/bin/cli.js +4 -0
- package/apps/cli/dist/bin/cli.js.map +1 -0
- package/apps/cli/dist/daemon.d.ts +76 -0
- package/apps/cli/dist/daemon.d.ts.map +1 -0
- package/apps/cli/dist/daemon.js +189 -0
- package/apps/cli/dist/daemon.js.map +1 -0
- package/apps/cli/dist/doctor.d.ts +40 -0
- package/apps/cli/dist/doctor.d.ts.map +1 -0
- package/apps/cli/dist/doctor.js +590 -0
- package/apps/cli/dist/doctor.js.map +1 -0
- package/apps/cli/dist/index.d.ts +32 -0
- package/apps/cli/dist/index.d.ts.map +1 -0
- package/apps/cli/dist/index.js +26 -0
- package/apps/cli/dist/index.js.map +1 -0
- package/apps/cli/dist/main.d.ts +40 -0
- package/apps/cli/dist/main.d.ts.map +1 -0
- package/apps/cli/dist/main.js +259 -0
- package/apps/cli/dist/main.js.map +1 -0
- package/apps/cli/dist/runs.d.ts +31 -0
- package/apps/cli/dist/runs.d.ts.map +1 -0
- package/apps/cli/dist/runs.js +281 -0
- package/apps/cli/dist/runs.js.map +1 -0
- package/apps/cli/dist/workerDriverLoader.d.ts +64 -0
- package/apps/cli/dist/workerDriverLoader.d.ts.map +1 -0
- package/apps/cli/dist/workerDriverLoader.js +211 -0
- package/apps/cli/dist/workerDriverLoader.js.map +1 -0
- package/apps/cli/package.json +57 -0
- package/apps/symphony-dashboard/dist/assets/index-B3owF3jd.css +1 -0
- package/apps/symphony-dashboard/dist/assets/index-DQ6XlL0d.js +227 -0
- package/apps/symphony-dashboard/dist/index.html +18 -0
- package/bin/lorenz +16 -0
- package/extensions/docker-worker/dist/index.d.ts +92 -0
- package/extensions/docker-worker/dist/index.d.ts.map +1 -0
- package/extensions/docker-worker/dist/index.js +283 -0
- package/extensions/docker-worker/dist/index.js.map +1 -0
- package/extensions/docker-worker/package.json +14 -0
- package/extensions/jira-tracker/dist/client.d.ts +50 -0
- package/extensions/jira-tracker/dist/client.d.ts.map +1 -0
- package/extensions/jira-tracker/dist/client.js +619 -0
- package/extensions/jira-tracker/dist/client.js.map +1 -0
- package/extensions/jira-tracker/dist/index.d.ts +5 -0
- package/extensions/jira-tracker/dist/index.d.ts.map +1 -0
- package/extensions/jira-tracker/dist/index.js +5 -0
- package/extensions/jira-tracker/dist/index.js.map +1 -0
- package/extensions/jira-tracker/dist/options.d.ts +38 -0
- package/extensions/jira-tracker/dist/options.d.ts.map +1 -0
- package/extensions/jira-tracker/dist/options.js +61 -0
- package/extensions/jira-tracker/dist/options.js.map +1 -0
- package/extensions/jira-tracker/dist/provider.d.ts +6 -0
- package/extensions/jira-tracker/dist/provider.d.ts.map +1 -0
- package/extensions/jira-tracker/dist/provider.js +178 -0
- package/extensions/jira-tracker/dist/provider.js.map +1 -0
- package/extensions/jira-tracker/dist/register.d.ts +10 -0
- package/extensions/jira-tracker/dist/register.d.ts.map +1 -0
- package/extensions/jira-tracker/dist/register.js +15 -0
- package/extensions/jira-tracker/dist/register.js.map +1 -0
- package/extensions/jira-tracker/package.json +16 -0
- package/extensions/linear-tracker/dist/client.d.ts +82 -0
- package/extensions/linear-tracker/dist/client.d.ts.map +1 -0
- package/extensions/linear-tracker/dist/client.js +622 -0
- package/extensions/linear-tracker/dist/client.js.map +1 -0
- package/extensions/linear-tracker/dist/index.d.ts +8 -0
- package/extensions/linear-tracker/dist/index.d.ts.map +1 -0
- package/extensions/linear-tracker/dist/index.js +7 -0
- package/extensions/linear-tracker/dist/index.js.map +1 -0
- package/extensions/linear-tracker/dist/options.d.ts +32 -0
- package/extensions/linear-tracker/dist/options.d.ts.map +1 -0
- package/extensions/linear-tracker/dist/options.js +59 -0
- package/extensions/linear-tracker/dist/options.js.map +1 -0
- package/extensions/linear-tracker/dist/provider.d.ts +4 -0
- package/extensions/linear-tracker/dist/provider.d.ts.map +1 -0
- package/extensions/linear-tracker/dist/provider.js +58 -0
- package/extensions/linear-tracker/dist/provider.js.map +1 -0
- package/extensions/linear-tracker/dist/register.d.ts +11 -0
- package/extensions/linear-tracker/dist/register.d.ts.map +1 -0
- package/extensions/linear-tracker/dist/register.js +19 -0
- package/extensions/linear-tracker/dist/register.js.map +1 -0
- package/extensions/linear-tracker/dist/toolOps.d.ts +8 -0
- package/extensions/linear-tracker/dist/toolOps.d.ts.map +1 -0
- package/extensions/linear-tracker/dist/toolOps.js +160 -0
- package/extensions/linear-tracker/dist/toolOps.js.map +1 -0
- package/extensions/linear-tracker/dist/tools.d.ts +7 -0
- package/extensions/linear-tracker/dist/tools.d.ts.map +1 -0
- package/extensions/linear-tracker/dist/tools.js +210 -0
- package/extensions/linear-tracker/dist/tools.js.map +1 -0
- package/extensions/linear-tracker/package.json +18 -0
- package/extensions/local-tracker/dist/boardStore.d.ts +116 -0
- package/extensions/local-tracker/dist/boardStore.d.ts.map +1 -0
- package/extensions/local-tracker/dist/boardStore.js +475 -0
- package/extensions/local-tracker/dist/boardStore.js.map +1 -0
- package/extensions/local-tracker/dist/client.d.ts +14 -0
- package/extensions/local-tracker/dist/client.d.ts.map +1 -0
- package/extensions/local-tracker/dist/client.js +27 -0
- package/extensions/local-tracker/dist/client.js.map +1 -0
- package/extensions/local-tracker/dist/index.d.ts +7 -0
- package/extensions/local-tracker/dist/index.d.ts.map +1 -0
- package/extensions/local-tracker/dist/index.js +7 -0
- package/extensions/local-tracker/dist/index.js.map +1 -0
- package/extensions/local-tracker/dist/options.d.ts +31 -0
- package/extensions/local-tracker/dist/options.d.ts.map +1 -0
- package/extensions/local-tracker/dist/options.js +69 -0
- package/extensions/local-tracker/dist/options.js.map +1 -0
- package/extensions/local-tracker/dist/provider.d.ts +9 -0
- package/extensions/local-tracker/dist/provider.d.ts.map +1 -0
- package/extensions/local-tracker/dist/provider.js +35 -0
- package/extensions/local-tracker/dist/provider.js.map +1 -0
- package/extensions/local-tracker/dist/register.d.ts +11 -0
- package/extensions/local-tracker/dist/register.d.ts.map +1 -0
- package/extensions/local-tracker/dist/register.js +19 -0
- package/extensions/local-tracker/dist/register.js.map +1 -0
- package/extensions/local-tracker/dist/resolveBoardDir.d.ts +24 -0
- package/extensions/local-tracker/dist/resolveBoardDir.d.ts.map +1 -0
- package/extensions/local-tracker/dist/resolveBoardDir.js +39 -0
- package/extensions/local-tracker/dist/resolveBoardDir.js.map +1 -0
- package/extensions/local-tracker/dist/toolOps.d.ts +9 -0
- package/extensions/local-tracker/dist/toolOps.d.ts.map +1 -0
- package/extensions/local-tracker/dist/toolOps.js +86 -0
- package/extensions/local-tracker/dist/toolOps.js.map +1 -0
- package/extensions/local-tracker/dist/tools.d.ts +7 -0
- package/extensions/local-tracker/dist/tools.d.ts.map +1 -0
- package/extensions/local-tracker/dist/tools.js +170 -0
- package/extensions/local-tracker/dist/tools.js.map +1 -0
- package/extensions/local-tracker/package.json +18 -0
- package/extensions/memory-tracker/dist/index.d.ts +24 -0
- package/extensions/memory-tracker/dist/index.d.ts.map +1 -0
- package/extensions/memory-tracker/dist/index.js +110 -0
- package/extensions/memory-tracker/dist/index.js.map +1 -0
- package/extensions/memory-tracker/package.json +16 -0
- package/extensions/slack-tracker/dist/client.d.ts +88 -0
- package/extensions/slack-tracker/dist/client.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/client.js +246 -0
- package/extensions/slack-tracker/dist/client.js.map +1 -0
- package/extensions/slack-tracker/dist/inMemoryTransport.d.ts +42 -0
- package/extensions/slack-tracker/dist/inMemoryTransport.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/inMemoryTransport.js +104 -0
- package/extensions/slack-tracker/dist/inMemoryTransport.js.map +1 -0
- package/extensions/slack-tracker/dist/index.d.ts +15 -0
- package/extensions/slack-tracker/dist/index.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/index.js +11 -0
- package/extensions/slack-tracker/dist/index.js.map +1 -0
- package/extensions/slack-tracker/dist/mapping.d.ts +27 -0
- package/extensions/slack-tracker/dist/mapping.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/mapping.js +109 -0
- package/extensions/slack-tracker/dist/mapping.js.map +1 -0
- package/extensions/slack-tracker/dist/operations.d.ts +41 -0
- package/extensions/slack-tracker/dist/operations.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/operations.js +97 -0
- package/extensions/slack-tracker/dist/operations.js.map +1 -0
- package/extensions/slack-tracker/dist/options.d.ts +30 -0
- package/extensions/slack-tracker/dist/options.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/options.js +49 -0
- package/extensions/slack-tracker/dist/options.js.map +1 -0
- package/extensions/slack-tracker/dist/provider.d.ts +9 -0
- package/extensions/slack-tracker/dist/provider.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/provider.js +74 -0
- package/extensions/slack-tracker/dist/provider.js.map +1 -0
- package/extensions/slack-tracker/dist/register.d.ts +11 -0
- package/extensions/slack-tracker/dist/register.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/register.js +19 -0
- package/extensions/slack-tracker/dist/register.js.map +1 -0
- package/extensions/slack-tracker/dist/threadState.d.ts +52 -0
- package/extensions/slack-tracker/dist/threadState.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/threadState.js +192 -0
- package/extensions/slack-tracker/dist/threadState.js.map +1 -0
- package/extensions/slack-tracker/dist/toolOps.d.ts +13 -0
- package/extensions/slack-tracker/dist/toolOps.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/toolOps.js +76 -0
- package/extensions/slack-tracker/dist/toolOps.js.map +1 -0
- package/extensions/slack-tracker/dist/tools.d.ts +8 -0
- package/extensions/slack-tracker/dist/tools.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/tools.js +266 -0
- package/extensions/slack-tracker/dist/tools.js.map +1 -0
- package/extensions/slack-tracker/dist/transport.d.ts +63 -0
- package/extensions/slack-tracker/dist/transport.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/transport.js +2 -0
- package/extensions/slack-tracker/dist/transport.js.map +1 -0
- package/extensions/slack-tracker/dist/webTransport.d.ts +44 -0
- package/extensions/slack-tracker/dist/webTransport.d.ts.map +1 -0
- package/extensions/slack-tracker/dist/webTransport.js +402 -0
- package/extensions/slack-tracker/dist/webTransport.js.map +1 -0
- package/extensions/slack-tracker/package.json +17 -0
- package/package.json +89 -0
- package/packages/acp/dist/childProcess.d.ts +4 -0
- package/packages/acp/dist/childProcess.d.ts.map +1 -0
- package/packages/acp/dist/childProcess.js +33 -0
- package/packages/acp/dist/childProcess.js.map +1 -0
- package/packages/acp/dist/index.d.ts +70 -0
- package/packages/acp/dist/index.d.ts.map +1 -0
- package/packages/acp/dist/index.js +701 -0
- package/packages/acp/dist/index.js.map +1 -0
- package/packages/acp/dist/options.d.ts +24 -0
- package/packages/acp/dist/options.d.ts.map +1 -0
- package/packages/acp/dist/options.js +92 -0
- package/packages/acp/dist/options.js.map +1 -0
- package/packages/acp/dist/toml.d.ts +2 -0
- package/packages/acp/dist/toml.d.ts.map +1 -0
- package/packages/acp/dist/toml.js +51 -0
- package/packages/acp/dist/toml.js.map +1 -0
- package/packages/acp/package.json +24 -0
- package/packages/agent-runner/dist/index.d.ts +58 -0
- package/packages/agent-runner/dist/index.d.ts.map +1 -0
- package/packages/agent-runner/dist/index.js +288 -0
- package/packages/agent-runner/dist/index.js.map +1 -0
- package/packages/agent-runner/package.json +19 -0
- package/packages/agent-sdk/dist/index.d.ts +2 -0
- package/packages/agent-sdk/dist/index.d.ts.map +1 -0
- package/packages/agent-sdk/dist/index.js +2 -0
- package/packages/agent-sdk/dist/index.js.map +1 -0
- package/packages/agent-sdk/dist/provider.d.ts +66 -0
- package/packages/agent-sdk/dist/provider.d.ts.map +1 -0
- package/packages/agent-sdk/dist/provider.js +38 -0
- package/packages/agent-sdk/dist/provider.js.map +1 -0
- package/packages/agent-sdk/package.json +14 -0
- package/packages/cli-kit/dist/index.d.ts +20 -0
- package/packages/cli-kit/dist/index.d.ts.map +1 -0
- package/packages/cli-kit/dist/index.js +72 -0
- package/packages/cli-kit/dist/index.js.map +1 -0
- package/packages/cli-kit/package.json +14 -0
- package/packages/config/dist/aliases.d.ts +10 -0
- package/packages/config/dist/aliases.d.ts.map +1 -0
- package/packages/config/dist/aliases.js +153 -0
- package/packages/config/dist/aliases.js.map +1 -0
- package/packages/config/dist/defaults.d.ts +12 -0
- package/packages/config/dist/defaults.d.ts.map +1 -0
- package/packages/config/dist/defaults.js +78 -0
- package/packages/config/dist/defaults.js.map +1 -0
- package/packages/config/dist/errors.d.ts +3 -0
- package/packages/config/dist/errors.d.ts.map +1 -0
- package/packages/config/dist/errors.js +56 -0
- package/packages/config/dist/errors.js.map +1 -0
- package/packages/config/dist/index.d.ts +5 -0
- package/packages/config/dist/index.d.ts.map +1 -0
- package/packages/config/dist/index.js +4 -0
- package/packages/config/dist/index.js.map +1 -0
- package/packages/config/dist/leaf-utils.d.ts +3 -0
- package/packages/config/dist/leaf-utils.d.ts.map +1 -0
- package/packages/config/dist/leaf-utils.js +9 -0
- package/packages/config/dist/leaf-utils.js.map +1 -0
- package/packages/config/dist/parse.d.ts +11 -0
- package/packages/config/dist/parse.d.ts.map +1 -0
- package/packages/config/dist/parse.js +821 -0
- package/packages/config/dist/parse.js.map +1 -0
- package/packages/config/dist/schemas.d.ts +214 -0
- package/packages/config/dist/schemas.d.ts.map +1 -0
- package/packages/config/dist/schemas.js +248 -0
- package/packages/config/dist/schemas.js.map +1 -0
- package/packages/config/package.json +19 -0
- package/packages/dispatch/dist/index.d.ts +22 -0
- package/packages/dispatch/dist/index.d.ts.map +1 -0
- package/packages/dispatch/dist/index.js +117 -0
- package/packages/dispatch/dist/index.js.map +1 -0
- package/packages/dispatch/package.json +16 -0
- package/packages/dispatch-coordinator/dist/coordinator.d.ts +158 -0
- package/packages/dispatch-coordinator/dist/coordinator.d.ts.map +1 -0
- package/packages/dispatch-coordinator/dist/coordinator.js +529 -0
- package/packages/dispatch-coordinator/dist/coordinator.js.map +1 -0
- package/packages/dispatch-coordinator/dist/gate.d.ts +24 -0
- package/packages/dispatch-coordinator/dist/gate.d.ts.map +1 -0
- package/packages/dispatch-coordinator/dist/gate.js +47 -0
- package/packages/dispatch-coordinator/dist/gate.js.map +1 -0
- package/packages/dispatch-coordinator/dist/index.d.ts +6 -0
- package/packages/dispatch-coordinator/dist/index.d.ts.map +1 -0
- package/packages/dispatch-coordinator/dist/index.js +16 -0
- package/packages/dispatch-coordinator/dist/index.js.map +1 -0
- package/packages/dispatch-coordinator/dist/mcpEndpointManager.d.ts +28 -0
- package/packages/dispatch-coordinator/dist/mcpEndpointManager.d.ts.map +1 -0
- package/packages/dispatch-coordinator/dist/mcpEndpointManager.js +54 -0
- package/packages/dispatch-coordinator/dist/mcpEndpointManager.js.map +1 -0
- package/packages/dispatch-coordinator/dist/nullEndpointManager.d.ts +18 -0
- package/packages/dispatch-coordinator/dist/nullEndpointManager.d.ts.map +1 -0
- package/packages/dispatch-coordinator/dist/nullEndpointManager.js +40 -0
- package/packages/dispatch-coordinator/dist/nullEndpointManager.js.map +1 -0
- package/packages/dispatch-coordinator/dist/types.d.ts +119 -0
- package/packages/dispatch-coordinator/dist/types.d.ts.map +1 -0
- package/packages/dispatch-coordinator/dist/types.js +17 -0
- package/packages/dispatch-coordinator/dist/types.js.map +1 -0
- package/packages/dispatch-coordinator/package.json +16 -0
- package/packages/domain/dist/index.d.ts +775 -0
- package/packages/domain/dist/index.d.ts.map +1 -0
- package/packages/domain/dist/index.js +124 -0
- package/packages/domain/dist/index.js.map +1 -0
- package/packages/domain/package.json +14 -0
- package/packages/humanize/dist/index.d.ts +4 -0
- package/packages/humanize/dist/index.d.ts.map +1 -0
- package/packages/humanize/dist/index.js +347 -0
- package/packages/humanize/dist/index.js.map +1 -0
- package/packages/humanize/package.json +11 -0
- package/packages/issue/dist/index.d.ts +7 -0
- package/packages/issue/dist/index.d.ts.map +1 -0
- package/packages/issue/dist/index.js +147 -0
- package/packages/issue/dist/index.js.map +1 -0
- package/packages/issue/package.json +14 -0
- package/packages/log-file/dist/index.d.ts +10 -0
- package/packages/log-file/dist/index.d.ts.map +1 -0
- package/packages/log-file/dist/index.js +200 -0
- package/packages/log-file/dist/index.js.map +1 -0
- package/packages/log-file/package.json +15 -0
- package/packages/mcp/dist/agentEndpoint.d.ts +31 -0
- package/packages/mcp/dist/agentEndpoint.d.ts.map +1 -0
- package/packages/mcp/dist/agentEndpoint.js +270 -0
- package/packages/mcp/dist/agentEndpoint.js.map +1 -0
- package/packages/mcp/dist/auth.d.ts +7 -0
- package/packages/mcp/dist/auth.d.ts.map +1 -0
- package/packages/mcp/dist/auth.js +48 -0
- package/packages/mcp/dist/auth.js.map +1 -0
- package/packages/mcp/dist/filter.d.ts +70 -0
- package/packages/mcp/dist/filter.d.ts.map +1 -0
- package/packages/mcp/dist/filter.js +231 -0
- package/packages/mcp/dist/filter.js.map +1 -0
- package/packages/mcp/dist/index.d.ts +7 -0
- package/packages/mcp/dist/index.d.ts.map +1 -0
- package/packages/mcp/dist/index.js +5 -0
- package/packages/mcp/dist/index.js.map +1 -0
- package/packages/mcp/dist/server.d.ts +31 -0
- package/packages/mcp/dist/server.d.ts.map +1 -0
- package/packages/mcp/dist/server.js +176 -0
- package/packages/mcp/dist/server.js.map +1 -0
- package/packages/mcp/dist/tools/linear.d.ts +5 -0
- package/packages/mcp/dist/tools/linear.d.ts.map +1 -0
- package/packages/mcp/dist/tools/linear.js +192 -0
- package/packages/mcp/dist/tools/linear.js.map +1 -0
- package/packages/mcp/dist/tools/local.d.ts +5 -0
- package/packages/mcp/dist/tools/local.d.ts.map +1 -0
- package/packages/mcp/dist/tools/local.js +161 -0
- package/packages/mcp/dist/tools/local.js.map +1 -0
- package/packages/mcp/dist/tools/result.d.ts +5 -0
- package/packages/mcp/dist/tools/result.d.ts.map +1 -0
- package/packages/mcp/dist/tools/result.js +15 -0
- package/packages/mcp/dist/tools/result.js.map +1 -0
- package/packages/mcp/dist/tools.d.ts +14 -0
- package/packages/mcp/dist/tools.d.ts.map +1 -0
- package/packages/mcp/dist/tools.js +58 -0
- package/packages/mcp/dist/tools.js.map +1 -0
- package/packages/mcp/package.json +20 -0
- package/packages/orchestrator/dist/index.d.ts +171 -0
- package/packages/orchestrator/dist/index.d.ts.map +1 -0
- package/packages/orchestrator/dist/index.js +524 -0
- package/packages/orchestrator/dist/index.js.map +1 -0
- package/packages/orchestrator/package.json +18 -0
- package/packages/policies/dist/index.d.ts +11 -0
- package/packages/policies/dist/index.d.ts.map +1 -0
- package/packages/policies/dist/index.js +6 -0
- package/packages/policies/dist/index.js.map +1 -0
- package/packages/policies/dist/reconciliation.d.ts +5 -0
- package/packages/policies/dist/reconciliation.d.ts.map +1 -0
- package/packages/policies/dist/reconciliation.js +17 -0
- package/packages/policies/dist/reconciliation.js.map +1 -0
- package/packages/policies/dist/resume.d.ts +14 -0
- package/packages/policies/dist/resume.d.ts.map +1 -0
- package/packages/policies/dist/resume.js +7 -0
- package/packages/policies/dist/resume.js.map +1 -0
- package/packages/policies/dist/retry.d.ts +4 -0
- package/packages/policies/dist/retry.d.ts.map +1 -0
- package/packages/policies/dist/retry.js +7 -0
- package/packages/policies/dist/retry.js.map +1 -0
- package/packages/policies/dist/stopReason.d.ts +4 -0
- package/packages/policies/dist/stopReason.d.ts.map +1 -0
- package/packages/policies/dist/stopReason.js +11 -0
- package/packages/policies/dist/stopReason.js.map +1 -0
- package/packages/policies/dist/usage.d.ts +14 -0
- package/packages/policies/dist/usage.d.ts.map +1 -0
- package/packages/policies/dist/usage.js +38 -0
- package/packages/policies/dist/usage.js.map +1 -0
- package/packages/policies/dist/workerHost.d.ts +8 -0
- package/packages/policies/dist/workerHost.d.ts.map +1 -0
- package/packages/policies/dist/workerHost.js +20 -0
- package/packages/policies/dist/workerHost.js.map +1 -0
- package/packages/policies/package.json +21 -0
- package/packages/presenter/dist/index.d.ts +81 -0
- package/packages/presenter/dist/index.d.ts.map +1 -0
- package/packages/presenter/dist/index.js +421 -0
- package/packages/presenter/dist/index.js.map +1 -0
- package/packages/presenter/package.json +16 -0
- package/packages/projections/dist/index.d.ts +10 -0
- package/packages/projections/dist/index.d.ts.map +1 -0
- package/packages/projections/dist/index.js +30 -0
- package/packages/projections/dist/index.js.map +1 -0
- package/packages/projections/package.json +15 -0
- package/packages/prompt/dist/index.d.ts +9 -0
- package/packages/prompt/dist/index.d.ts.map +1 -0
- package/packages/prompt/dist/index.js +71 -0
- package/packages/prompt/dist/index.js.map +1 -0
- package/packages/prompt/package.json +16 -0
- package/packages/retry-scheduler/dist/index.d.ts +12 -0
- package/packages/retry-scheduler/dist/index.d.ts.map +1 -0
- package/packages/retry-scheduler/dist/index.js +39 -0
- package/packages/retry-scheduler/dist/index.js.map +1 -0
- package/packages/retry-scheduler/package.json +15 -0
- package/packages/runtime/dist/index.d.ts +157 -0
- package/packages/runtime/dist/index.d.ts.map +1 -0
- package/packages/runtime/dist/index.js +1074 -0
- package/packages/runtime/dist/index.js.map +1 -0
- package/packages/runtime/package.json +26 -0
- package/packages/runtime-events/dist/index.d.ts +110 -0
- package/packages/runtime-events/dist/index.d.ts.map +1 -0
- package/packages/runtime-events/dist/index.js +25 -0
- package/packages/runtime-events/dist/index.js.map +1 -0
- package/packages/runtime-events/package.json +14 -0
- package/packages/server/dist/index.d.ts +25 -0
- package/packages/server/dist/index.d.ts.map +1 -0
- package/packages/server/dist/index.js +213 -0
- package/packages/server/dist/index.js.map +1 -0
- package/packages/server/dist/issue-store.d.ts +26 -0
- package/packages/server/dist/issue-store.d.ts.map +1 -0
- package/packages/server/dist/issue-store.js +88 -0
- package/packages/server/dist/issue-store.js.map +1 -0
- package/packages/server/dist/path-params.d.ts +6 -0
- package/packages/server/dist/path-params.d.ts.map +1 -0
- package/packages/server/dist/path-params.js +15 -0
- package/packages/server/dist/path-params.js.map +1 -0
- package/packages/server/dist/source.d.ts +12 -0
- package/packages/server/dist/source.d.ts.map +1 -0
- package/packages/server/dist/source.js +2 -0
- package/packages/server/dist/source.js.map +1 -0
- package/packages/server/dist/trace-routes.d.ts +21 -0
- package/packages/server/dist/trace-routes.d.ts.map +1 -0
- package/packages/server/dist/trace-routes.js +66 -0
- package/packages/server/dist/trace-routes.js.map +1 -0
- package/packages/server/dist/ws.d.ts +18 -0
- package/packages/server/dist/ws.d.ts.map +1 -0
- package/packages/server/dist/ws.js +168 -0
- package/packages/server/dist/ws.js.map +1 -0
- package/packages/server/package.json +22 -0
- package/packages/ssh/dist/index.d.ts +33 -0
- package/packages/ssh/dist/index.d.ts.map +1 -0
- package/packages/ssh/dist/index.js +281 -0
- package/packages/ssh/dist/index.js.map +1 -0
- package/packages/ssh/package.json +15 -0
- package/packages/static-worker/dist/index.d.ts +73 -0
- package/packages/static-worker/dist/index.d.ts.map +1 -0
- package/packages/static-worker/dist/index.js +150 -0
- package/packages/static-worker/dist/index.js.map +1 -0
- package/packages/static-worker/package.json +14 -0
- package/packages/tool-sdk/dist/filter.d.ts +70 -0
- package/packages/tool-sdk/dist/filter.d.ts.map +1 -0
- package/packages/tool-sdk/dist/filter.js +231 -0
- package/packages/tool-sdk/dist/filter.js.map +1 -0
- package/packages/tool-sdk/dist/index.d.ts +6 -0
- package/packages/tool-sdk/dist/index.d.ts.map +1 -0
- package/packages/tool-sdk/dist/index.js +4 -0
- package/packages/tool-sdk/dist/index.js.map +1 -0
- package/packages/tool-sdk/dist/provider.d.ts +51 -0
- package/packages/tool-sdk/dist/provider.d.ts.map +1 -0
- package/packages/tool-sdk/dist/provider.js +2 -0
- package/packages/tool-sdk/dist/provider.js.map +1 -0
- package/packages/tool-sdk/dist/registry.d.ts +35 -0
- package/packages/tool-sdk/dist/registry.d.ts.map +1 -0
- package/packages/tool-sdk/dist/registry.js +85 -0
- package/packages/tool-sdk/dist/registry.js.map +1 -0
- package/packages/tool-sdk/dist/result.d.ts +5 -0
- package/packages/tool-sdk/dist/result.d.ts.map +1 -0
- package/packages/tool-sdk/dist/result.js +15 -0
- package/packages/tool-sdk/dist/result.js.map +1 -0
- package/packages/tool-sdk/package.json +14 -0
- package/packages/traceviz-emitter/dist/index.d.ts +19 -0
- package/packages/traceviz-emitter/dist/index.d.ts.map +1 -0
- package/packages/traceviz-emitter/dist/index.js +97 -0
- package/packages/traceviz-emitter/dist/index.js.map +1 -0
- package/packages/traceviz-emitter/package.json +17 -0
- package/packages/traceviz-server/dist/index.d.ts +14 -0
- package/packages/traceviz-server/dist/index.d.ts.map +1 -0
- package/packages/traceviz-server/dist/index.js +10 -0
- package/packages/traceviz-server/dist/index.js.map +1 -0
- package/packages/traceviz-server/dist/models/api.d.ts +51 -0
- package/packages/traceviz-server/dist/models/api.d.ts.map +1 -0
- package/packages/traceviz-server/dist/models/api.js +5 -0
- package/packages/traceviz-server/dist/models/api.js.map +1 -0
- package/packages/traceviz-server/dist/models/display-events.d.ts +58 -0
- package/packages/traceviz-server/dist/models/display-events.d.ts.map +1 -0
- package/packages/traceviz-server/dist/models/display-events.js +6 -0
- package/packages/traceviz-server/dist/models/display-events.js.map +1 -0
- package/packages/traceviz-server/dist/parser.d.ts +14 -0
- package/packages/traceviz-server/dist/parser.d.ts.map +1 -0
- package/packages/traceviz-server/dist/parser.js +363 -0
- package/packages/traceviz-server/dist/parser.js.map +1 -0
- package/packages/traceviz-server/dist/stats.d.ts +7 -0
- package/packages/traceviz-server/dist/stats.d.ts.map +1 -0
- package/packages/traceviz-server/dist/stats.js +81 -0
- package/packages/traceviz-server/dist/stats.js.map +1 -0
- package/packages/traceviz-server/dist/watcher.d.ts +54 -0
- package/packages/traceviz-server/dist/watcher.d.ts.map +1 -0
- package/packages/traceviz-server/dist/watcher.js +368 -0
- package/packages/traceviz-server/dist/watcher.js.map +1 -0
- package/packages/traceviz-server/package.json +16 -0
- package/packages/tracker-sdk/dist/index.d.ts +5 -0
- package/packages/tracker-sdk/dist/index.d.ts.map +1 -0
- package/packages/tracker-sdk/dist/index.js +4 -0
- package/packages/tracker-sdk/dist/index.js.map +1 -0
- package/packages/tracker-sdk/dist/options.d.ts +20 -0
- package/packages/tracker-sdk/dist/options.d.ts.map +1 -0
- package/packages/tracker-sdk/dist/options.js +46 -0
- package/packages/tracker-sdk/dist/options.js.map +1 -0
- package/packages/tracker-sdk/dist/provider.d.ts +104 -0
- package/packages/tracker-sdk/dist/provider.d.ts.map +1 -0
- package/packages/tracker-sdk/dist/provider.js +2 -0
- package/packages/tracker-sdk/dist/provider.js.map +1 -0
- package/packages/tracker-sdk/dist/registry.d.ts +26 -0
- package/packages/tracker-sdk/dist/registry.d.ts.map +1 -0
- package/packages/tracker-sdk/dist/registry.js +52 -0
- package/packages/tracker-sdk/dist/registry.js.map +1 -0
- package/packages/tracker-sdk/dist/toolPack.d.ts +10 -0
- package/packages/tracker-sdk/dist/toolPack.d.ts.map +1 -0
- package/packages/tracker-sdk/dist/toolPack.js +185 -0
- package/packages/tracker-sdk/dist/toolPack.js.map +1 -0
- package/packages/tracker-sdk/package.json +15 -0
- package/packages/tui/dist/index.d.ts +35 -0
- package/packages/tui/dist/index.d.ts.map +1 -0
- package/packages/tui/dist/index.js +354 -0
- package/packages/tui/dist/index.js.map +1 -0
- package/packages/tui/package.json +18 -0
- package/packages/worker-host-pool/dist/index.d.ts +33 -0
- package/packages/worker-host-pool/dist/index.d.ts.map +1 -0
- package/packages/worker-host-pool/dist/index.js +311 -0
- package/packages/worker-host-pool/dist/index.js.map +1 -0
- package/packages/worker-host-pool/package.json +14 -0
- package/packages/worker-pool/dist/index.d.ts +6 -0
- package/packages/worker-pool/dist/index.d.ts.map +1 -0
- package/packages/worker-pool/dist/index.js +15 -0
- package/packages/worker-pool/dist/index.js.map +1 -0
- package/packages/worker-pool/dist/lease.d.ts +36 -0
- package/packages/worker-pool/dist/lease.d.ts.map +1 -0
- package/packages/worker-pool/dist/lease.js +53 -0
- package/packages/worker-pool/dist/lease.js.map +1 -0
- package/packages/worker-pool/dist/ledger.d.ts +51 -0
- package/packages/worker-pool/dist/ledger.d.ts.map +1 -0
- package/packages/worker-pool/dist/ledger.js +165 -0
- package/packages/worker-pool/dist/ledger.js.map +1 -0
- package/packages/worker-pool/dist/mutex.d.ts +10 -0
- package/packages/worker-pool/dist/mutex.d.ts.map +1 -0
- package/packages/worker-pool/dist/mutex.js +22 -0
- package/packages/worker-pool/dist/mutex.js.map +1 -0
- package/packages/worker-pool/dist/pool.d.ts +33 -0
- package/packages/worker-pool/dist/pool.d.ts.map +1 -0
- package/packages/worker-pool/dist/pool.js +1727 -0
- package/packages/worker-pool/dist/pool.js.map +1 -0
- package/packages/worker-pool/dist/reaper.d.ts +94 -0
- package/packages/worker-pool/dist/reaper.d.ts.map +1 -0
- package/packages/worker-pool/dist/reaper.js +295 -0
- package/packages/worker-pool/dist/reaper.js.map +1 -0
- package/packages/worker-pool/dist/types.d.ts +249 -0
- package/packages/worker-pool/dist/types.d.ts.map +1 -0
- package/packages/worker-pool/dist/types.js +2 -0
- package/packages/worker-pool/dist/types.js.map +1 -0
- package/packages/worker-pool/package.json +16 -0
- package/packages/worker-sdk/dist/conformance.d.ts +64 -0
- package/packages/worker-sdk/dist/conformance.d.ts.map +1 -0
- package/packages/worker-sdk/dist/conformance.js +109 -0
- package/packages/worker-sdk/dist/conformance.js.map +1 -0
- package/packages/worker-sdk/dist/fake.d.ts +76 -0
- package/packages/worker-sdk/dist/fake.d.ts.map +1 -0
- package/packages/worker-sdk/dist/fake.js +142 -0
- package/packages/worker-sdk/dist/fake.js.map +1 -0
- package/packages/worker-sdk/dist/index.d.ts +5 -0
- package/packages/worker-sdk/dist/index.d.ts.map +1 -0
- package/packages/worker-sdk/dist/index.js +10 -0
- package/packages/worker-sdk/dist/index.js.map +1 -0
- package/packages/worker-sdk/dist/module.d.ts +46 -0
- package/packages/worker-sdk/dist/module.d.ts.map +1 -0
- package/packages/worker-sdk/dist/module.js +59 -0
- package/packages/worker-sdk/dist/module.js.map +1 -0
- package/packages/worker-sdk/dist/registry.d.ts +24 -0
- package/packages/worker-sdk/dist/registry.d.ts.map +1 -0
- package/packages/worker-sdk/dist/registry.js +49 -0
- package/packages/worker-sdk/dist/registry.js.map +1 -0
- package/packages/worker-sdk/dist/types.d.ts +138 -0
- package/packages/worker-sdk/dist/types.d.ts.map +1 -0
- package/packages/worker-sdk/dist/types.js +21 -0
- package/packages/worker-sdk/dist/types.js.map +1 -0
- package/packages/worker-sdk/package.json +15 -0
- package/packages/workflow/dist/index.d.ts +33 -0
- package/packages/workflow/dist/index.d.ts.map +1 -0
- package/packages/workflow/dist/index.js +125 -0
- package/packages/workflow/dist/index.js.map +1 -0
- package/packages/workflow/package.json +19 -0
- package/packages/workspace/dist/index.d.ts +70 -0
- package/packages/workspace/dist/index.d.ts.map +1 -0
- package/packages/workspace/dist/index.js +1016 -0
- package/packages/workspace/dist/index.js.map +1 -0
- package/packages/workspace/package.json +17 -0
- package/runtime-deps/anthropic-claude-agent-sdk/LICENSE.md +1 -0
- package/runtime-deps/anthropic-claude-agent-sdk/README.md +65 -0
- package/runtime-deps/anthropic-claude-agent-sdk/agentSdkTypes.d.ts +1 -0
- package/runtime-deps/anthropic-claude-agent-sdk/assistant.d.ts +135 -0
- package/runtime-deps/anthropic-claude-agent-sdk/assistant.mjs +190 -0
- package/runtime-deps/anthropic-claude-agent-sdk/bridge.d.ts +231 -0
- package/runtime-deps/anthropic-claude-agent-sdk/bridge.mjs +168 -0
- package/runtime-deps/anthropic-claude-agent-sdk/browser-sdk.d.ts +53 -0
- package/runtime-deps/anthropic-claude-agent-sdk/browser-sdk.js +93 -0
- package/runtime-deps/anthropic-claude-agent-sdk/extractFromBunfs.d.ts +1 -0
- package/runtime-deps/anthropic-claude-agent-sdk/extractFromBunfs.js +156 -0
- package/runtime-deps/anthropic-claude-agent-sdk/manifest.json +47 -0
- package/runtime-deps/anthropic-claude-agent-sdk/manifest.zst.json +55 -0
- package/runtime-deps/anthropic-claude-agent-sdk/node_modules/.bin/anthropic-ai-sdk +21 -0
- package/runtime-deps/anthropic-claude-agent-sdk/package.json +81 -0
- package/runtime-deps/anthropic-claude-agent-sdk/sdk-tools.d.ts +3170 -0
- package/runtime-deps/anthropic-claude-agent-sdk/sdk.d.ts +6000 -0
- package/runtime-deps/anthropic-claude-agent-sdk/sdk.mjs +119 -0
- package/runtime-deps/openai-codex/README.md +60 -0
- package/runtime-deps/openai-codex/bin/codex.js +229 -0
- package/runtime-deps/openai-codex/bin/rg +79 -0
- package/runtime-deps/openai-codex/package.json +22 -0
- package/vendor/claude-agent-acp/dist/acp-agent.d.ts +239 -0
- package/vendor/claude-agent-acp/dist/acp-agent.d.ts.map +1 -0
- package/vendor/claude-agent-acp/dist/acp-agent.js +2693 -0
- package/vendor/claude-agent-acp/dist/bundle.js +41230 -0
- package/vendor/claude-agent-acp/dist/index.d.ts +3 -0
- package/vendor/claude-agent-acp/dist/index.d.ts.map +1 -0
- package/vendor/claude-agent-acp/dist/index.js +67 -0
- package/vendor/claude-agent-acp/dist/lib.d.ts +6 -0
- package/vendor/claude-agent-acp/dist/lib.d.ts.map +1 -0
- package/vendor/claude-agent-acp/dist/lib.js +5 -0
- package/vendor/claude-agent-acp/dist/settings.d.ts +68 -0
- package/vendor/claude-agent-acp/dist/settings.d.ts.map +1 -0
- package/vendor/claude-agent-acp/dist/settings.js +182 -0
- package/vendor/claude-agent-acp/dist/tools.d.ts +103 -0
- package/vendor/claude-agent-acp/dist/tools.d.ts.map +1 -0
- package/vendor/claude-agent-acp/dist/tools.js +713 -0
- package/vendor/claude-agent-acp/dist/utils.d.ts +16 -0
- package/vendor/claude-agent-acp/dist/utils.d.ts.map +1 -0
- package/vendor/claude-agent-acp/dist/utils.js +83 -0
- package/vendor/claude-agent-acp/package.json +23 -0
- package/vendor/codex-acp/dist/index.js +21280 -0
- package/vendor/codex-acp/package.json +17 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { LinearGraphQLClient } from "@linear/sdk";
|
|
2
|
+
export { LinearClient } from "./client.js";
|
|
3
|
+
export { LINEAR_DEFAULT_ENDPOINT, linearEndpoint, linearTrackerOptions, } from "./options.js";
|
|
4
|
+
export { linearTrackerProvider } from "./provider.js";
|
|
5
|
+
export { executeLinearTool, linearToolProvider, linearToolSpecs } from "./tools.js";
|
|
6
|
+
export { registerLinearTracker } from "./register.js";
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAQ3C,OAAO,EACL,uBAAuB,EACvB,cAAc,EACd,oBAAoB,GAErB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AACpF,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { Settings } from "@lorenz/domain";
|
|
2
|
+
export declare const LINEAR_DEFAULT_ENDPOINT = "https://api.linear.app/graphql";
|
|
3
|
+
/** Linear-specific keys of the selected tracker bundle, validated by the provider. */
|
|
4
|
+
export interface LinearTrackerOptions {
|
|
5
|
+
/** @deprecated Use `projectSlugs` instead. Single Linear project slug. */
|
|
6
|
+
projectSlug?: string | undefined;
|
|
7
|
+
/** Linear project slugs to monitor. Mutually exclusive with `projectLabels`. */
|
|
8
|
+
projectSlugs?: string[] | undefined;
|
|
9
|
+
/** Linear project labels for dynamic discovery. Mutually exclusive with `projectSlugs`. */
|
|
10
|
+
projectLabels?: string[] | undefined;
|
|
11
|
+
}
|
|
12
|
+
/** Typed view over `settings.tracker.options` for the Linear provider. */
|
|
13
|
+
export declare function linearTrackerOptions(settings: Settings): LinearTrackerOptions;
|
|
14
|
+
/** The configured Linear API endpoint, falling back to the public GraphQL endpoint. */
|
|
15
|
+
export declare function linearEndpoint(settings: Settings): string;
|
|
16
|
+
/** Credential and endpoint the mounted linear TOOL pack calls Linear with. */
|
|
17
|
+
export interface LinearToolPackOptions {
|
|
18
|
+
apiKey?: string | undefined;
|
|
19
|
+
endpoint: string;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Auth resolution for the linear TOOL pack. Prefers the pack's own `tools.linear` slice
|
|
23
|
+
* (secret references already resolved at config-parse time), then the dispatch tracker's
|
|
24
|
+
* credential and endpoint only when Linear itself drives dispatch.
|
|
25
|
+
*/
|
|
26
|
+
export declare function linearToolPackOptions(settings: Settings): LinearToolPackOptions;
|
|
27
|
+
/**
|
|
28
|
+
* Validate the pack's `tools.linear` slice; backs `linearToolProvider.validateOptions`.
|
|
29
|
+
* Errors name the offending `tools.linear.<key>` so config typos fail at startup.
|
|
30
|
+
*/
|
|
31
|
+
export declare function validateLinearToolOptions(options: Record<string, unknown>): void;
|
|
32
|
+
//# sourceMappingURL=options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../src/options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAG/C,eAAO,MAAM,uBAAuB,mCAAmC,CAAC;AAExE,sFAAsF;AACtF,MAAM,WAAW,oBAAoB;IACnC,0EAA0E;IAC1E,WAAW,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACjC,gFAAgF;IAChF,YAAY,CAAC,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IACpC,2FAA2F;IAC3F,aAAa,CAAC,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;CACtC;AAED,0EAA0E;AAC1E,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,QAAQ,GAAG,oBAAoB,CAO7E;AAED,uFAAuF;AACvF,wBAAgB,cAAc,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM,CAEzD;AASD,8EAA8E;AAC9E,MAAM,WAAW,qBAAqB;IACpC,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;;;GAIG;AACH,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,QAAQ,GAAG,qBAAqB,CAU/E;AAED;;;GAGG;AACH,wBAAgB,yBAAyB,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAEhF"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { stringListOption, stringOption } from "@lorenz/tracker-sdk";
|
|
2
|
+
export const LINEAR_DEFAULT_ENDPOINT = "https://api.linear.app/graphql";
|
|
3
|
+
/** Typed view over `settings.tracker.options` for the Linear provider. */
|
|
4
|
+
export function linearTrackerOptions(settings) {
|
|
5
|
+
const options = settings.tracker.options;
|
|
6
|
+
return {
|
|
7
|
+
projectSlug: stringOption(options, "projectSlug") || undefined,
|
|
8
|
+
projectSlugs: stringListOption(options, "projectSlugs"),
|
|
9
|
+
projectLabels: stringListOption(options, "projectLabels"),
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
/** The configured Linear API endpoint, falling back to the public GraphQL endpoint. */
|
|
13
|
+
export function linearEndpoint(settings) {
|
|
14
|
+
return settings.tracker.endpoint ?? LINEAR_DEFAULT_ENDPOINT;
|
|
15
|
+
}
|
|
16
|
+
/** Keys of the pack's `tools.linear` slice. */
|
|
17
|
+
const LINEAR_PACK_OPTION_KEYS = {
|
|
18
|
+
apiKey: "apiKey",
|
|
19
|
+
api_key: "apiKey",
|
|
20
|
+
endpoint: "endpoint",
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Auth resolution for the linear TOOL pack. Prefers the pack's own `tools.linear` slice
|
|
24
|
+
* (secret references already resolved at config-parse time), then the dispatch tracker's
|
|
25
|
+
* credential and endpoint only when Linear itself drives dispatch.
|
|
26
|
+
*/
|
|
27
|
+
export function linearToolPackOptions(settings) {
|
|
28
|
+
const packOptions = normalizeLinearPackOptions(settings.toolOptions?.["linear"] ?? {});
|
|
29
|
+
const dispatchIsLinear = settings.tracker.kind === "linear";
|
|
30
|
+
const apiKey = packOptions.apiKey || (dispatchIsLinear ? settings.tracker.apiKey : undefined) || undefined;
|
|
31
|
+
const endpoint = packOptions.endpoint ??
|
|
32
|
+
(dispatchIsLinear ? settings.tracker.endpoint : undefined) ??
|
|
33
|
+
LINEAR_DEFAULT_ENDPOINT;
|
|
34
|
+
return { apiKey, endpoint };
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Validate the pack's `tools.linear` slice; backs `linearToolProvider.validateOptions`.
|
|
38
|
+
* Errors name the offending `tools.linear.<key>` so config typos fail at startup.
|
|
39
|
+
*/
|
|
40
|
+
export function validateLinearToolOptions(options) {
|
|
41
|
+
normalizeLinearPackOptions(options);
|
|
42
|
+
}
|
|
43
|
+
function normalizeLinearPackOptions(options) {
|
|
44
|
+
const normalized = {};
|
|
45
|
+
for (const [key, value] of Object.entries(options)) {
|
|
46
|
+
const canonical = LINEAR_PACK_OPTION_KEYS[key];
|
|
47
|
+
if (canonical === undefined) {
|
|
48
|
+
throw new Error(`tools.linear.${key} is not supported (known keys: ${Object.keys(LINEAR_PACK_OPTION_KEYS).join(", ")})`);
|
|
49
|
+
}
|
|
50
|
+
if (value === undefined || value === null)
|
|
51
|
+
continue;
|
|
52
|
+
if (typeof value !== "string") {
|
|
53
|
+
throw new Error(`tools.linear.${key} must be a string`);
|
|
54
|
+
}
|
|
55
|
+
normalized[canonical] = value;
|
|
56
|
+
}
|
|
57
|
+
return normalized;
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.js","sourceRoot":"","sources":["../src/options.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAErE,MAAM,CAAC,MAAM,uBAAuB,GAAG,gCAAgC,CAAC;AAYxE,0EAA0E;AAC1E,MAAM,UAAU,oBAAoB,CAAC,QAAkB;IACrD,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC;IACzC,OAAO;QACL,WAAW,EAAE,YAAY,CAAC,OAAO,EAAE,aAAa,CAAC,IAAI,SAAS;QAC9D,YAAY,EAAE,gBAAgB,CAAC,OAAO,EAAE,cAAc,CAAC;QACvD,aAAa,EAAE,gBAAgB,CAAC,OAAO,EAAE,eAAe,CAAC;KAC1D,CAAC;AACJ,CAAC;AAED,uFAAuF;AACvF,MAAM,UAAU,cAAc,CAAC,QAAkB;IAC/C,OAAO,QAAQ,CAAC,OAAO,CAAC,QAAQ,IAAI,uBAAuB,CAAC;AAC9D,CAAC;AAED,+CAA+C;AAC/C,MAAM,uBAAuB,GAA0C;IACrE,MAAM,EAAE,QAAQ;IAChB,OAAO,EAAE,QAAQ;IACjB,QAAQ,EAAE,UAAU;CACrB,CAAC;AAQF;;;;GAIG;AACH,MAAM,UAAU,qBAAqB,CAAC,QAAkB;IACtD,MAAM,WAAW,GAAG,0BAA0B,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;IACvF,MAAM,gBAAgB,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,QAAQ,CAAC;IAC5D,MAAM,MAAM,GACV,WAAW,CAAC,MAAM,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC;IAC9F,MAAM,QAAQ,GACZ,WAAW,CAAC,QAAQ;QACpB,CAAC,gBAAgB,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;QAC1D,uBAAuB,CAAC;IAC1B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;AAC9B,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,yBAAyB,CAAC,OAAgC;IACxE,0BAA0B,CAAC,OAAO,CAAC,CAAC;AACtC,CAAC;AAED,SAAS,0BAA0B,CAAC,OAAgC;IAIlE,MAAM,UAAU,GAAmE,EAAE,CAAC;IACtF,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QACnD,MAAM,SAAS,GAAG,uBAAuB,CAAC,GAAG,CAAC,CAAC;QAC/C,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CACb,gBAAgB,GAAG,kCAAkC,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CACxG,CAAC;QACJ,CAAC;QACD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI;YAAE,SAAS;QACpD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CAAC,gBAAgB,GAAG,mBAAmB,CAAC,CAAC;QAC1D,CAAC;QACD,UAAU,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC;IAChC,CAAC;IACD,OAAO,UAAU,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAY3D,mFAAmF;AACnF,eAAO,MAAM,qBAAqB,EAAE,eAsDnC,CAAC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { rejectUnknownOptions, resolveEnvReference, stringListOption, stringOption, } from "@lorenz/tracker-sdk";
|
|
2
|
+
import { LinearClient } from "./client.js";
|
|
3
|
+
import { LINEAR_DEFAULT_ENDPOINT, linearTrackerOptions } from "./options.js";
|
|
4
|
+
import { linearToolOps } from "./toolOps.js";
|
|
5
|
+
/** Linear.app tracker: issues are polled from configured projects over GraphQL. */
|
|
6
|
+
export const linearTrackerProvider = {
|
|
7
|
+
kind: "linear",
|
|
8
|
+
configAliases: {
|
|
9
|
+
project_slug: "projectSlug",
|
|
10
|
+
project_slugs: "projectSlugs",
|
|
11
|
+
project_labels: "projectLabels",
|
|
12
|
+
},
|
|
13
|
+
envFallbacks: { apiKey: "LINEAR_API_KEY", assignee: "LINEAR_ASSIGNEE" },
|
|
14
|
+
defaultEndpoint: LINEAR_DEFAULT_ENDPOINT,
|
|
15
|
+
parseOptions(options, context) {
|
|
16
|
+
rejectUnknownOptions(options, ["projectSlug", "projectSlugs", "projectLabels"], "linear");
|
|
17
|
+
const projectSlugRaw = stringOption(options, "projectSlug");
|
|
18
|
+
const projectSlug = projectSlugRaw === undefined
|
|
19
|
+
? undefined
|
|
20
|
+
: resolveEnvReference(projectSlugRaw, context.env) || undefined;
|
|
21
|
+
const projectSlugs = stringListOption(options, "projectSlugs");
|
|
22
|
+
const projectLabels = stringListOption(options, "projectLabels");
|
|
23
|
+
return {
|
|
24
|
+
...(projectSlug !== undefined ? { projectSlug } : {}),
|
|
25
|
+
...(projectSlugs !== undefined ? { projectSlugs } : {}),
|
|
26
|
+
...(projectLabels !== undefined ? { projectLabels } : {}),
|
|
27
|
+
};
|
|
28
|
+
},
|
|
29
|
+
validateDispatch(settings) {
|
|
30
|
+
if (!settings.tracker.apiKey)
|
|
31
|
+
throw new Error("tracker.api_key is required");
|
|
32
|
+
const { projectSlug, projectSlugs, projectLabels } = linearTrackerOptions(settings);
|
|
33
|
+
const configured = [!!projectSlug, !!projectSlugs?.length, !!projectLabels?.length];
|
|
34
|
+
const count = configured.filter(Boolean).length;
|
|
35
|
+
if (count === 0) {
|
|
36
|
+
throw new Error("tracker.project_slug, tracker.project_slugs, or tracker.project_labels is required");
|
|
37
|
+
}
|
|
38
|
+
if (count > 1) {
|
|
39
|
+
throw new Error("tracker.project_slug, tracker.project_slugs, and tracker.project_labels are mutually exclusive");
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
createClient(settings) {
|
|
43
|
+
const client = new LinearClient(settings);
|
|
44
|
+
// Resolve project slugs (e.g. from project_labels) in the background so the first poll
|
|
45
|
+
// does not pay the discovery round-trip.
|
|
46
|
+
void client.resolveProjectSlugs().catch(() => { });
|
|
47
|
+
return client;
|
|
48
|
+
},
|
|
49
|
+
createToolOps: (settings, context) => linearToolOps(settings, context),
|
|
50
|
+
defaultToolPacks: () => ["linear"],
|
|
51
|
+
projectUrl(settings) {
|
|
52
|
+
const slug = linearTrackerOptions(settings).projectSlug?.trim();
|
|
53
|
+
if (!slug)
|
|
54
|
+
return undefined;
|
|
55
|
+
return `https://linear.app/project/${encodeURIComponent(slug)}/issues`;
|
|
56
|
+
},
|
|
57
|
+
};
|
|
58
|
+
//# sourceMappingURL=provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type ToolRegistry } from "@lorenz/tool-sdk";
|
|
2
|
+
import { type TrackerRegistry } from "@lorenz/tracker-sdk";
|
|
3
|
+
/**
|
|
4
|
+
* Register this extension's tracker provider and tool pack. Idempotent; called by the
|
|
5
|
+
* composition root (or a test) against its registries, defaulting to the process-wide ones.
|
|
6
|
+
*/
|
|
7
|
+
export declare function registerLinearTracker(registries?: {
|
|
8
|
+
trackers?: TrackerRegistry;
|
|
9
|
+
tools?: ToolRegistry;
|
|
10
|
+
}): void;
|
|
11
|
+
//# sourceMappingURL=register.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register.d.ts","sourceRoot":"","sources":["../src/register.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,KAAK,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAA0B,KAAK,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAKnF;;;GAGG;AACH,wBAAgB,qBAAqB,CACnC,UAAU,GAAE;IAAE,QAAQ,CAAC,EAAE,eAAe,CAAC;IAAC,KAAK,CAAC,EAAE,YAAY,CAAA;CAAO,GACpE,IAAI,CASN"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { defaultToolRegistry } from "@lorenz/tool-sdk";
|
|
2
|
+
import { defaultTrackerRegistry } from "@lorenz/tracker-sdk";
|
|
3
|
+
import { linearTrackerProvider } from "./provider.js";
|
|
4
|
+
import { linearToolProvider } from "./tools.js";
|
|
5
|
+
/**
|
|
6
|
+
* Register this extension's tracker provider and tool pack. Idempotent; called by the
|
|
7
|
+
* composition root (or a test) against its registries, defaulting to the process-wide ones.
|
|
8
|
+
*/
|
|
9
|
+
export function registerLinearTracker(registries = {}) {
|
|
10
|
+
const trackers = registries.trackers ?? defaultTrackerRegistry;
|
|
11
|
+
const tools = registries.tools ?? defaultToolRegistry;
|
|
12
|
+
if (trackers.get(linearTrackerProvider.kind) === undefined) {
|
|
13
|
+
trackers.register(linearTrackerProvider);
|
|
14
|
+
}
|
|
15
|
+
if (tools.get(linearToolProvider.name) === undefined) {
|
|
16
|
+
tools.register(linearToolProvider);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=register.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register.js","sourceRoot":"","sources":["../src/register.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAAE,sBAAsB,EAAwB,MAAM,qBAAqB,CAAC;AAEnF,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAEhD;;;GAGG;AACH,MAAM,UAAU,qBAAqB,CACnC,aAAmE,EAAE;IAErE,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,IAAI,sBAAsB,CAAC;IAC/D,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,IAAI,mBAAmB,CAAC;IACtD,IAAI,QAAQ,CAAC,GAAG,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,SAAS,EAAE,CAAC;QAC3D,QAAQ,CAAC,QAAQ,CAAC,qBAAqB,CAAC,CAAC;IAC3C,CAAC;IACD,IAAI,KAAK,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,SAAS,EAAE,CAAC;QACrD,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type Settings } from "@lorenz/domain";
|
|
2
|
+
import type { TrackerOpsContext, TrackerToolOps } from "@lorenz/tracker-sdk";
|
|
3
|
+
/**
|
|
4
|
+
* Normalized issue operations behind the provider-neutral `tracker_*` pack, implemented over
|
|
5
|
+
* the same GraphQL transport as the `linear_graphql` tool (credentials, retries, logging).
|
|
6
|
+
*/
|
|
7
|
+
export declare function linearToolOps(settings: Settings, context: TrackerOpsContext): TrackerToolOps;
|
|
8
|
+
//# sourceMappingURL=toolOps.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolOps.d.ts","sourceRoot":"","sources":["../src/toolOps.ts"],"names":[],"mappings":"AACA,OAAO,EAAwB,KAAK,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACrE,OAAO,KAAK,EAEV,iBAAiB,EACjB,cAAc,EACf,MAAM,qBAAqB,CAAC;AA0B7B;;;GAGG;AACH,wBAAgB,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,iBAAiB,GAAG,cAAc,CAU5F"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { normalizeIssue } from "@lorenz/issue";
|
|
2
|
+
import { isRecord } from "@lorenz/domain";
|
|
3
|
+
import { linearTrackerOptions } from "./options.js";
|
|
4
|
+
import { executeLinearTool } from "./tools.js";
|
|
5
|
+
const linearIssueFields = `
|
|
6
|
+
id
|
|
7
|
+
identifier
|
|
8
|
+
title
|
|
9
|
+
description
|
|
10
|
+
priority
|
|
11
|
+
state { id name type }
|
|
12
|
+
branchName
|
|
13
|
+
url
|
|
14
|
+
assignee { id }
|
|
15
|
+
labels(first: 50) { nodes { name } }
|
|
16
|
+
inverseRelations(first: 50) {
|
|
17
|
+
nodes {
|
|
18
|
+
type
|
|
19
|
+
issue { id identifier state { name type } }
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
createdAt
|
|
23
|
+
updatedAt
|
|
24
|
+
`;
|
|
25
|
+
/**
|
|
26
|
+
* Normalized issue operations behind the provider-neutral `tracker_*` pack, implemented over
|
|
27
|
+
* the same GraphQL transport as the `linear_graphql` tool (credentials, retries, logging).
|
|
28
|
+
*/
|
|
29
|
+
export function linearToolOps(settings, context) {
|
|
30
|
+
const { fetchImpl } = context;
|
|
31
|
+
return {
|
|
32
|
+
readIssue: async (issueId) => readLinearIssue(settings, issueId, fetchImpl),
|
|
33
|
+
queryIssues: async (args) => queryLinearIssues(settings, args, fetchImpl),
|
|
34
|
+
updateStatus: async (issueId, status) => updateLinearStatus(settings, issueId, status, fetchImpl),
|
|
35
|
+
addComment: async (issueId, body) => createLinearComment(settings, issueId, body, fetchImpl),
|
|
36
|
+
createIssue: async (input) => createLinearIssue(settings, input, fetchImpl),
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
async function readLinearIssue(settings, issueId, fetchImpl) {
|
|
40
|
+
const data = await linearData(settings, `query SymphonyTrackerReadIssue($id: String!) {
|
|
41
|
+
issue(id: $id) { ${linearIssueFields} }
|
|
42
|
+
}`, { id: issueId }, fetchImpl);
|
|
43
|
+
if (!data.issue)
|
|
44
|
+
throw new Error(`linear issue not found: ${issueId}`);
|
|
45
|
+
return normalizeLinearIssue(data.issue, settings.tracker.assignee);
|
|
46
|
+
}
|
|
47
|
+
async function queryLinearIssues(settings, args, fetchImpl) {
|
|
48
|
+
const issueIds = stringArray(args.issueIds);
|
|
49
|
+
if (issueIds) {
|
|
50
|
+
const data = await linearData(settings, `query SymphonyTrackerIssuesById($ids: [ID!]!, $first: Int!) {
|
|
51
|
+
issues(filter: {id: {in: $ids}}, first: $first) { nodes { ${linearIssueFields} } }
|
|
52
|
+
}`, { ids: issueIds, first: issueIds.length }, fetchImpl);
|
|
53
|
+
return data.issues.nodes.map((issue) => normalizeLinearIssue(issue, settings.tracker.assignee));
|
|
54
|
+
}
|
|
55
|
+
const states = stringArray(args.states) ?? settings.tracker.activeStates;
|
|
56
|
+
const options = linearTrackerOptions(settings);
|
|
57
|
+
const projectSlugs = options.projectSlugs ?? (options.projectSlug ? [options.projectSlug] : []);
|
|
58
|
+
const data = await linearData(settings, `query SymphonyTrackerQuery($projectSlugs: [String!]!, $stateNames: [String!]!, $first: Int!) {
|
|
59
|
+
issues(filter: {project: {slugId: {in: $projectSlugs}}, state: {name: {in: $stateNames}}}, first: $first) {
|
|
60
|
+
nodes { ${linearIssueFields} }
|
|
61
|
+
}
|
|
62
|
+
}`, { projectSlugs, stateNames: states, first: numberArg(args.limit, 50) }, fetchImpl);
|
|
63
|
+
return data.issues.nodes.map((issue) => normalizeLinearIssue(issue, settings.tracker.assignee));
|
|
64
|
+
}
|
|
65
|
+
async function updateLinearStatus(settings, issueId, status, fetchImpl) {
|
|
66
|
+
const lookup = await linearData(settings, `query SymphonyTrackerLinearStates($id: String!) {
|
|
67
|
+
issue(id: $id) { team { states(first: 100) { nodes { id name } } } }
|
|
68
|
+
}`, { id: issueId }, fetchImpl);
|
|
69
|
+
const state = lookup.issue?.team?.states?.nodes?.find((candidate) => candidate.name.trim().toLowerCase() === status.trim().toLowerCase());
|
|
70
|
+
if (!state)
|
|
71
|
+
throw new Error(`linear state not found: ${status}`);
|
|
72
|
+
const data = await linearData(settings, `mutation SymphonyTrackerLinearUpdate($id: String!, $input: IssueUpdateInput!) {
|
|
73
|
+
issueUpdate(id: $id, input: $input) { success issue { ${linearIssueFields} } }
|
|
74
|
+
}`, { id: issueId, input: { stateId: state.id } }, fetchImpl);
|
|
75
|
+
if (!data.issueUpdate.success || !data.issueUpdate.issue)
|
|
76
|
+
throw new Error("linear issueUpdate failed");
|
|
77
|
+
return normalizeLinearIssue(data.issueUpdate.issue, settings.tracker.assignee);
|
|
78
|
+
}
|
|
79
|
+
async function createLinearComment(settings, issueId, body, fetchImpl) {
|
|
80
|
+
const data = await linearData(settings, `mutation SymphonyTrackerLinearComment($input: CommentCreateInput!) {
|
|
81
|
+
commentCreate(input: $input) { success }
|
|
82
|
+
}`, { input: { issueId, body } }, fetchImpl);
|
|
83
|
+
if (!data.commentCreate.success)
|
|
84
|
+
throw new Error("linear commentCreate failed");
|
|
85
|
+
}
|
|
86
|
+
async function createLinearIssue(settings, input, fetchImpl) {
|
|
87
|
+
const options = linearTrackerOptions(settings);
|
|
88
|
+
const projectSlug = options.projectSlug ?? options.projectSlugs?.[0];
|
|
89
|
+
if (!projectSlug)
|
|
90
|
+
throw new Error("tracker.project_slug is required to create Linear issues");
|
|
91
|
+
const projectData = await linearData(settings, `query SymphonyTrackerLinearProject($slug: String!) {
|
|
92
|
+
projects(filter: {slugId: {eq: $slug}}, first: 1) {
|
|
93
|
+
nodes { id teams(first: 1) { nodes { id states(first: 100) { nodes { id name type } } } } }
|
|
94
|
+
}
|
|
95
|
+
}`, { slug: projectSlug }, fetchImpl);
|
|
96
|
+
const project = projectData.projects.nodes[0];
|
|
97
|
+
const team = project?.teams.nodes[0];
|
|
98
|
+
if (!project || !team)
|
|
99
|
+
throw new Error(`linear project not found: ${projectSlug}`);
|
|
100
|
+
const state = team.states.nodes.find((candidate) => candidate.name === input.status) ??
|
|
101
|
+
team.states.nodes.find((candidate) => candidate.type === "unstarted") ??
|
|
102
|
+
team.states.nodes[0];
|
|
103
|
+
if (!state)
|
|
104
|
+
throw new Error("linear project has no workflow states");
|
|
105
|
+
const assignee = input.assignee?.trim() || settings.tracker.assignee?.trim();
|
|
106
|
+
const data = await linearData(settings, `mutation SymphonyTrackerLinearCreate($input: IssueCreateInput!) {
|
|
107
|
+
issueCreate(input: $input) { success issue { ${linearIssueFields} } }
|
|
108
|
+
}`, {
|
|
109
|
+
input: {
|
|
110
|
+
teamId: team.id,
|
|
111
|
+
projectId: project.id,
|
|
112
|
+
stateId: state.id,
|
|
113
|
+
title: input.title,
|
|
114
|
+
description: input.body ?? "",
|
|
115
|
+
...(assignee ? { assigneeId: assignee } : {}),
|
|
116
|
+
},
|
|
117
|
+
}, fetchImpl);
|
|
118
|
+
if (!data.issueCreate.success || !data.issueCreate.issue)
|
|
119
|
+
throw new Error("linear issueCreate failed");
|
|
120
|
+
return normalizeLinearIssue(data.issueCreate.issue, settings.tracker.assignee);
|
|
121
|
+
}
|
|
122
|
+
async function linearData(settings, query, variables, fetchImpl) {
|
|
123
|
+
const result = await executeLinearTool("linear_graphql", { query, variables }, settings, fetchImpl);
|
|
124
|
+
if (!result.success)
|
|
125
|
+
throw new Error(result.error ?? "linear_graphql failed");
|
|
126
|
+
const body = result.result;
|
|
127
|
+
if (!isRecord(body) || !isRecord(body.data))
|
|
128
|
+
throw new Error("linear_graphql returned no data");
|
|
129
|
+
return body.data;
|
|
130
|
+
}
|
|
131
|
+
function normalizeLinearIssue(issue, assignee) {
|
|
132
|
+
return normalizeIssue({
|
|
133
|
+
...issue,
|
|
134
|
+
state: issue.state,
|
|
135
|
+
state_type: isRecord(issue.state) ? issue.state.type : null,
|
|
136
|
+
branch_name: issue.branchName,
|
|
137
|
+
assignee_id: isRecord(issue.assignee) ? issue.assignee.id : null,
|
|
138
|
+
labels: nodesFromConnection(issue.labels),
|
|
139
|
+
relations: nodesFromConnection(issue.inverseRelations),
|
|
140
|
+
created_at: issue.createdAt,
|
|
141
|
+
updated_at: issue.updatedAt,
|
|
142
|
+
}, assignee);
|
|
143
|
+
}
|
|
144
|
+
function nodesFromConnection(value) {
|
|
145
|
+
if (!isRecord(value) || !Array.isArray(value.nodes))
|
|
146
|
+
return [];
|
|
147
|
+
return value.nodes;
|
|
148
|
+
}
|
|
149
|
+
function stringArray(value) {
|
|
150
|
+
if (value === undefined || value === null)
|
|
151
|
+
return null;
|
|
152
|
+
if (!Array.isArray(value) || !value.every((entry) => typeof entry === "string")) {
|
|
153
|
+
throw new Error("expected an array of strings");
|
|
154
|
+
}
|
|
155
|
+
return value;
|
|
156
|
+
}
|
|
157
|
+
function numberArg(value, fallback) {
|
|
158
|
+
return typeof value === "number" && Number.isInteger(value) && value > 0 ? value : fallback;
|
|
159
|
+
}
|
|
160
|
+
//# sourceMappingURL=toolOps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolOps.js","sourceRoot":"","sources":["../src/toolOps.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type Settings } from "@lorenz/domain";
|
|
2
|
+
import { type ToolProvider, type ToolResult, type ToolSpec } from "@lorenz/tool-sdk";
|
|
3
|
+
export declare function linearToolSpecs(): ToolSpec[];
|
|
4
|
+
export declare function executeLinearTool(name: string, input: unknown, settings: Settings, fetchImpl?: typeof fetch): Promise<ToolResult>;
|
|
5
|
+
/** The Linear tool pack: raw GraphQL access using the pack's own Linear credentials. */
|
|
6
|
+
export declare const linearToolProvider: ToolProvider;
|
|
7
|
+
//# sourceMappingURL=tools.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tools.d.ts","sourceRoot":"","sources":["../src/tools.ts"],"names":[],"mappings":"AAGA,OAAO,EAA0B,KAAK,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAIL,KAAK,YAAY,EACjB,KAAK,UAAU,EACf,KAAK,QAAQ,EACd,MAAM,kBAAkB,CAAC;AA6B1B,wBAAgB,eAAe,IAAI,QAAQ,EAAE,CAuB5C;AAED,wBAAsB,iBAAiB,CACrC,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,OAAO,EACd,QAAQ,EAAE,QAAQ,EAClB,SAAS,GAAE,OAAO,KAAa,GAC9B,OAAO,CAAC,UAAU,CAAC,CA2DrB;AAED,wFAAwF;AACxF,eAAO,MAAM,kBAAkB,EAAE,YAOhC,CAAC"}
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { fileURLToPath } from "node:url";
|
|
3
|
+
import { errorMessage, isRecord } from "@lorenz/domain";
|
|
4
|
+
import { toolFailure, toolSuccess, unsupportedToolFailure, } from "@lorenz/tool-sdk";
|
|
5
|
+
import { linearToolPackOptions, validateLinearToolOptions } from "./options.js";
|
|
6
|
+
/**
|
|
7
|
+
* The `symphony-linear` skill ships inside this extension (`skills/symphony-linear`, a sibling
|
|
8
|
+
* of `src`/`dist`) so mounting the Linear pack also overlays the doc that teaches the agent to
|
|
9
|
+
* call `linear_graphql`. Resolved from this module so it works from both `src` and `dist`.
|
|
10
|
+
*/
|
|
11
|
+
const symphonyLinearSkillDir = path.resolve(path.dirname(fileURLToPath(import.meta.url)), "..", "skills", "symphony-linear");
|
|
12
|
+
const LINEAR_MAX_RETRIES = 4;
|
|
13
|
+
const MAX_ERROR_BODY_LOG_BYTES = 1000;
|
|
14
|
+
const defaultLinearToolLogger = {
|
|
15
|
+
warn: (message) => console.warn(message),
|
|
16
|
+
error: (message) => console.error(message),
|
|
17
|
+
};
|
|
18
|
+
export function linearToolSpecs() {
|
|
19
|
+
return [
|
|
20
|
+
{
|
|
21
|
+
name: "linear_graphql",
|
|
22
|
+
description: "Run a Linear GraphQL operation using Symphony's configured Linear credentials.",
|
|
23
|
+
inputSchema: {
|
|
24
|
+
type: "object",
|
|
25
|
+
additionalProperties: false,
|
|
26
|
+
properties: {
|
|
27
|
+
query: {
|
|
28
|
+
type: "string",
|
|
29
|
+
description: "GraphQL query or mutation document to execute against Linear.",
|
|
30
|
+
},
|
|
31
|
+
variables: {
|
|
32
|
+
type: ["object", "null"],
|
|
33
|
+
description: "Optional GraphQL variables object.",
|
|
34
|
+
additionalProperties: true,
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
required: ["query"],
|
|
38
|
+
},
|
|
39
|
+
},
|
|
40
|
+
];
|
|
41
|
+
}
|
|
42
|
+
export async function executeLinearTool(name, input, settings, fetchImpl = fetch) {
|
|
43
|
+
if (name !== "linear_graphql") {
|
|
44
|
+
return unsupportedToolFailure(name, ["linear_graphql"]);
|
|
45
|
+
}
|
|
46
|
+
const normalizedInput = normalizeLinearGraphqlInput(input);
|
|
47
|
+
if (!normalizedInput.ok) {
|
|
48
|
+
return toolFailure(normalizedInput.error);
|
|
49
|
+
}
|
|
50
|
+
const { apiKey, endpoint } = linearToolPackOptions(settings);
|
|
51
|
+
if (!apiKey)
|
|
52
|
+
return toolFailure("Symphony is missing Linear auth. Set `linear.api_key` in `WORKFLOW.md` or export `LINEAR_API_KEY`.");
|
|
53
|
+
if (normalizedInput.variables !== undefined &&
|
|
54
|
+
normalizedInput.variables !== null &&
|
|
55
|
+
!isRecord(normalizedInput.variables)) {
|
|
56
|
+
return toolFailure("`linear_graphql.variables` must be a JSON object when provided.");
|
|
57
|
+
}
|
|
58
|
+
try {
|
|
59
|
+
const logger = defaultLinearToolLogger;
|
|
60
|
+
const response = await fetchWithRateLimitRetry(fetchImpl, { apiKey, endpoint }, normalizedInput.query, normalizedInput.variables ?? {}, logger);
|
|
61
|
+
const bodyResult = await readResponseJson(response);
|
|
62
|
+
if (!bodyResult.ok) {
|
|
63
|
+
if (!response.ok) {
|
|
64
|
+
logStatusError(logger, normalizedInput.query, response.status, bodyResult.rawBody);
|
|
65
|
+
return toolFailure(`Linear GraphQL request failed with HTTP ${response.status}.`, {
|
|
66
|
+
status: response.status,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
return toolFailure(`linear_invalid_json: ${errorMessage(bodyResult.error)}`);
|
|
70
|
+
}
|
|
71
|
+
const body = bodyResult.body;
|
|
72
|
+
if (!response.ok) {
|
|
73
|
+
logStatusError(logger, normalizedInput.query, response.status, body);
|
|
74
|
+
return toolFailure(`Linear GraphQL request failed with HTTP ${response.status}.`, {
|
|
75
|
+
status: response.status,
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
if (isRecord(body) && Array.isArray(body.errors) && body.errors.length > 0) {
|
|
79
|
+
return { success: false, result: body };
|
|
80
|
+
}
|
|
81
|
+
return toolSuccess(body);
|
|
82
|
+
}
|
|
83
|
+
catch (error) {
|
|
84
|
+
defaultLinearToolLogger.error(`Linear GraphQL request failed: ${errorMessage(error)}${linearErrorContext(normalizedInput.query)}`);
|
|
85
|
+
return toolFailure("Linear GraphQL request failed before receiving a successful response.", {
|
|
86
|
+
reason: errorMessage(error),
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
/** The Linear tool pack: raw GraphQL access using the pack's own Linear credentials. */
|
|
91
|
+
export const linearToolProvider = {
|
|
92
|
+
name: "linear",
|
|
93
|
+
skills: [symphonyLinearSkillDir],
|
|
94
|
+
validateOptions: validateLinearToolOptions,
|
|
95
|
+
toolSpecs: () => linearToolSpecs(),
|
|
96
|
+
executeTool: async (name, input, context) => executeLinearTool(name, input, context.settings, context.fetchImpl),
|
|
97
|
+
};
|
|
98
|
+
function normalizeLinearGraphqlInput(input) {
|
|
99
|
+
if (typeof input === "string") {
|
|
100
|
+
if (input.trim() === "")
|
|
101
|
+
return { ok: false, error: "`linear_graphql` requires a non-empty `query` string." };
|
|
102
|
+
return { ok: true, query: input };
|
|
103
|
+
}
|
|
104
|
+
if (!isRecord(input) || typeof input.query !== "string") {
|
|
105
|
+
return { ok: false, error: "`linear_graphql` requires a non-empty `query` string." };
|
|
106
|
+
}
|
|
107
|
+
if (input.query.trim() === "")
|
|
108
|
+
return { ok: false, error: "`linear_graphql` requires a non-empty `query` string." };
|
|
109
|
+
if (input.variables !== undefined && input.variables !== null && !isRecord(input.variables)) {
|
|
110
|
+
return { ok: false, error: "`linear_graphql.variables` must be a JSON object when provided." };
|
|
111
|
+
}
|
|
112
|
+
return {
|
|
113
|
+
ok: true,
|
|
114
|
+
query: input.query,
|
|
115
|
+
variables: input.variables,
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
async function fetchWithRateLimitRetry(fetchImpl, auth, query, variables, logger) {
|
|
119
|
+
for (let retryCount = 0;; retryCount += 1) {
|
|
120
|
+
const response = await fetchImpl(auth.endpoint, {
|
|
121
|
+
method: "POST",
|
|
122
|
+
signal: AbortSignal.timeout(30_000),
|
|
123
|
+
headers: {
|
|
124
|
+
"content-type": "application/json",
|
|
125
|
+
authorization: auth.apiKey,
|
|
126
|
+
},
|
|
127
|
+
body: JSON.stringify({ query, variables }),
|
|
128
|
+
});
|
|
129
|
+
if (response.status !== 429 || retryCount >= LINEAR_MAX_RETRIES)
|
|
130
|
+
return response;
|
|
131
|
+
const delayMs = retryDelayMs(response.headers, retryCount);
|
|
132
|
+
logger.warn(`Linear GraphQL request rate limited status=429 retry=${retryCount + 1}/${LINEAR_MAX_RETRIES} delay_ms=${delayMs}${linearErrorContext(query, await responseBodyForLog(response))}`);
|
|
133
|
+
await sleep(delayMs);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
function retryDelayMs(headers, retryCount) {
|
|
137
|
+
const retryAfter = headers.get("retry-after");
|
|
138
|
+
if (retryAfter !== null) {
|
|
139
|
+
const seconds = Number(retryAfter.trim());
|
|
140
|
+
if (Number.isInteger(seconds) && seconds >= 0)
|
|
141
|
+
return seconds * 1000;
|
|
142
|
+
const dateMs = Date.parse(retryAfter.trim());
|
|
143
|
+
if (!Number.isNaN(dateMs))
|
|
144
|
+
return Math.max(0, dateMs - Date.now());
|
|
145
|
+
}
|
|
146
|
+
return Math.min(1_000 * 2 ** retryCount, 30_000);
|
|
147
|
+
}
|
|
148
|
+
async function sleep(delayMs) {
|
|
149
|
+
await new Promise((resolve) => setTimeout(resolve, delayMs));
|
|
150
|
+
}
|
|
151
|
+
async function readResponseJson(response) {
|
|
152
|
+
let rawBody;
|
|
153
|
+
try {
|
|
154
|
+
rawBody = await response.text();
|
|
155
|
+
}
|
|
156
|
+
catch (error) {
|
|
157
|
+
return { ok: false, error };
|
|
158
|
+
}
|
|
159
|
+
try {
|
|
160
|
+
return { ok: true, body: JSON.parse(rawBody) };
|
|
161
|
+
}
|
|
162
|
+
catch (error) {
|
|
163
|
+
return { ok: false, error, rawBody };
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
async function responseBodyForLog(response) {
|
|
167
|
+
try {
|
|
168
|
+
const rawBody = await response.clone().text();
|
|
169
|
+
try {
|
|
170
|
+
return JSON.parse(rawBody);
|
|
171
|
+
}
|
|
172
|
+
catch {
|
|
173
|
+
return rawBody;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
catch {
|
|
177
|
+
return undefined;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
function logStatusError(logger, query, status, body) {
|
|
181
|
+
logger.error(`Linear GraphQL request failed status=${status}${linearErrorContext(query, body)}`);
|
|
182
|
+
}
|
|
183
|
+
function linearErrorContext(query, body) {
|
|
184
|
+
const parts = [];
|
|
185
|
+
const operation = operationName(query);
|
|
186
|
+
if (operation)
|
|
187
|
+
parts.push(`operation=${operation}`);
|
|
188
|
+
if (body !== undefined)
|
|
189
|
+
parts.push(`body=${summarizeErrorBody(body)}`);
|
|
190
|
+
return parts.length === 0 ? "" : ` ${parts.join(" ")}`;
|
|
191
|
+
}
|
|
192
|
+
function operationName(query) {
|
|
193
|
+
return /\b(?:query|mutation)\s+([A-Za-z_][A-Za-z0-9_]*)/.exec(query)?.[1] ?? null;
|
|
194
|
+
}
|
|
195
|
+
function summarizeErrorBody(body) {
|
|
196
|
+
const text = typeof body === "string" ? body : stringifyErrorBody(body);
|
|
197
|
+
const compact = text.replace(/\s+/g, " ").trim();
|
|
198
|
+
if (compact.length <= MAX_ERROR_BODY_LOG_BYTES)
|
|
199
|
+
return compact;
|
|
200
|
+
return `${compact.slice(0, MAX_ERROR_BODY_LOG_BYTES)}...<truncated>`;
|
|
201
|
+
}
|
|
202
|
+
function stringifyErrorBody(body) {
|
|
203
|
+
try {
|
|
204
|
+
return JSON.stringify(body) ?? String(body);
|
|
205
|
+
}
|
|
206
|
+
catch {
|
|
207
|
+
return String(body);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
//# sourceMappingURL=tools.js.map
|