agent-pipeline 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/CLAUDE.md +134 -0
- package/README.md +209 -0
- package/dist/analytics/pipeline-analytics.d.ts +19 -0
- package/dist/analytics/pipeline-analytics.d.ts.map +1 -0
- package/dist/analytics/pipeline-analytics.js +155 -0
- package/dist/analytics/pipeline-analytics.js.map +1 -0
- package/dist/analytics/types.d.ts +31 -0
- package/dist/analytics/types.d.ts.map +1 -0
- package/dist/analytics/types.js +2 -0
- package/dist/analytics/types.js.map +1 -0
- package/dist/cli/commands/agent/info.d.ts +2 -0
- package/dist/cli/commands/agent/info.d.ts.map +1 -0
- package/dist/cli/commands/agent/info.js +62 -0
- package/dist/cli/commands/agent/info.js.map +1 -0
- package/dist/cli/commands/agent/list.d.ts +2 -0
- package/dist/cli/commands/agent/list.d.ts.map +1 -0
- package/dist/cli/commands/agent/list.js +57 -0
- package/dist/cli/commands/agent/list.js.map +1 -0
- package/dist/cli/commands/agent/pull.d.ts +5 -0
- package/dist/cli/commands/agent/pull.d.ts.map +1 -0
- package/dist/cli/commands/agent/pull.js +71 -0
- package/dist/cli/commands/agent/pull.js.map +1 -0
- package/dist/cli/commands/analytics.d.ts +6 -0
- package/dist/cli/commands/analytics.d.ts.map +1 -0
- package/dist/cli/commands/analytics.js +101 -0
- package/dist/cli/commands/analytics.js.map +1 -0
- package/dist/cli/commands/cleanup.d.ts +7 -0
- package/dist/cli/commands/cleanup.d.ts.map +1 -0
- package/dist/cli/commands/cleanup.js +76 -0
- package/dist/cli/commands/cleanup.js.map +1 -0
- package/dist/cli/commands/history.d.ts +7 -0
- package/dist/cli/commands/history.d.ts.map +1 -0
- package/dist/cli/commands/history.js +173 -0
- package/dist/cli/commands/history.js.map +1 -0
- package/dist/cli/commands/init.d.ts +7 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +158 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/install.d.ts +2 -0
- package/dist/cli/commands/install.d.ts.map +1 -0
- package/dist/cli/commands/install.js +15 -0
- package/dist/cli/commands/install.js.map +1 -0
- package/dist/cli/commands/list.d.ts +2 -0
- package/dist/cli/commands/list.d.ts.map +1 -0
- package/dist/cli/commands/list.js +13 -0
- package/dist/cli/commands/list.js.map +1 -0
- package/dist/cli/commands/pipeline/clone.d.ts +2 -0
- package/dist/cli/commands/pipeline/clone.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/clone.js +42 -0
- package/dist/cli/commands/pipeline/clone.js.map +1 -0
- package/dist/cli/commands/pipeline/config.d.ts +2 -0
- package/dist/cli/commands/pipeline/config.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/config.js +23 -0
- package/dist/cli/commands/pipeline/config.js.map +1 -0
- package/dist/cli/commands/pipeline/create.d.ts +2 -0
- package/dist/cli/commands/pipeline/create.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/create.js +86 -0
- package/dist/cli/commands/pipeline/create.js.map +1 -0
- package/dist/cli/commands/pipeline/delete.d.ts +6 -0
- package/dist/cli/commands/pipeline/delete.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/delete.js +60 -0
- package/dist/cli/commands/pipeline/delete.js.map +1 -0
- package/dist/cli/commands/pipeline/edit.d.ts +2 -0
- package/dist/cli/commands/pipeline/edit.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/edit.js +50 -0
- package/dist/cli/commands/pipeline/edit.js.map +1 -0
- package/dist/cli/commands/pipeline/export.d.ts +6 -0
- package/dist/cli/commands/pipeline/export.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/export.js +48 -0
- package/dist/cli/commands/pipeline/export.js.map +1 -0
- package/dist/cli/commands/pipeline/import.d.ts +2 -0
- package/dist/cli/commands/pipeline/import.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/import.js +59 -0
- package/dist/cli/commands/pipeline/import.js.map +1 -0
- package/dist/cli/commands/pipeline/validate.d.ts +2 -0
- package/dist/cli/commands/pipeline/validate.d.ts.map +1 -0
- package/dist/cli/commands/pipeline/validate.js +28 -0
- package/dist/cli/commands/pipeline/validate.js.map +1 -0
- package/dist/cli/commands/rollback.d.ts +6 -0
- package/dist/cli/commands/rollback.d.ts.map +1 -0
- package/dist/cli/commands/rollback.js +49 -0
- package/dist/cli/commands/rollback.js.map +1 -0
- package/dist/cli/commands/run.d.ts +15 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +61 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/commands/status.d.ts +2 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +52 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/test.d.ts +5 -0
- package/dist/cli/commands/test.d.ts.map +1 -0
- package/dist/cli/commands/test.js +18 -0
- package/dist/cli/commands/test.js.map +1 -0
- package/dist/cli/commands/uninstall.d.ts +2 -0
- package/dist/cli/commands/uninstall.d.ts.map +1 -0
- package/dist/cli/commands/uninstall.js +6 -0
- package/dist/cli/commands/uninstall.js.map +1 -0
- package/dist/cli/hooks.d.ts +8 -0
- package/dist/cli/hooks.d.ts.map +1 -0
- package/dist/cli/hooks.js +98 -0
- package/dist/cli/hooks.js.map +1 -0
- package/dist/cli/templates/agents/cleanup-reporter.md +107 -0
- package/dist/cli/templates/agents/code-reducer.md +51 -0
- package/dist/cli/templates/agents/code-reviewer.md +34 -0
- package/dist/cli/templates/agents/context-reducer.md +94 -0
- package/dist/cli/templates/agents/dependency-auditor.md +127 -0
- package/dist/cli/templates/agents/detective-empath.md +26 -0
- package/dist/cli/templates/agents/detective-linguist.md +26 -0
- package/dist/cli/templates/agents/detective-logician.md +26 -0
- package/dist/cli/templates/agents/detective-skeptic.md +26 -0
- package/dist/cli/templates/agents/detective-statistician.md +26 -0
- package/dist/cli/templates/agents/doc-updater.md +30 -0
- package/dist/cli/templates/agents/judge.md +27 -0
- package/dist/cli/templates/agents/memory-updater.md +72 -0
- package/dist/cli/templates/agents/quality-checker.md +32 -0
- package/dist/cli/templates/agents/security-auditor.md +32 -0
- package/dist/cli/templates/agents/storyteller.md +26 -0
- package/dist/cli/templates/agents/summary.md +32 -0
- package/dist/cli/templates/agents/synthesizer.md +26 -0
- package/dist/cli/templates/pipelines/large-pipeline-example.yml +178 -0
- package/dist/cli/templates/pipelines/post-commit-example.yml +67 -0
- package/dist/cli/templates/pipelines/post-merge-example.yml +78 -0
- package/dist/cli/templates/pipelines/pre-commit-example.yml +41 -0
- package/dist/cli/templates/pipelines/pre-push-example.yml +51 -0
- package/dist/cli/templates/pipelines/test-pipeline.yml +90 -0
- package/dist/cli/utils/agent-importer.d.ts +21 -0
- package/dist/cli/utils/agent-importer.d.ts.map +1 -0
- package/dist/cli/utils/agent-importer.js +150 -0
- package/dist/cli/utils/agent-importer.js.map +1 -0
- package/dist/cli/utils/interactive-prompts.d.ts +10 -0
- package/dist/cli/utils/interactive-prompts.d.ts.map +1 -0
- package/dist/cli/utils/interactive-prompts.js +75 -0
- package/dist/cli/utils/interactive-prompts.js.map +1 -0
- package/dist/config/pipeline-loader.d.ts +14 -0
- package/dist/config/pipeline-loader.d.ts.map +1 -0
- package/dist/config/pipeline-loader.js +71 -0
- package/dist/config/pipeline-loader.js.map +1 -0
- package/dist/config/project-config-loader.d.ts +11 -0
- package/dist/config/project-config-loader.d.ts.map +1 -0
- package/dist/config/project-config-loader.js +100 -0
- package/dist/config/project-config-loader.js.map +1 -0
- package/dist/config/schema.d.ts +165 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +2 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/core/agent-query-runner.d.ts +25 -0
- package/dist/core/agent-query-runner.d.ts.map +1 -0
- package/dist/core/agent-query-runner.js +76 -0
- package/dist/core/agent-query-runner.js.map +1 -0
- package/dist/core/agent-runtime-registry.d.ts +11 -0
- package/dist/core/agent-runtime-registry.d.ts.map +1 -0
- package/dist/core/agent-runtime-registry.js +32 -0
- package/dist/core/agent-runtime-registry.js.map +1 -0
- package/dist/core/agent-runtimes/claude-code-headless-runtime.d.ts +16 -0
- package/dist/core/agent-runtimes/claude-code-headless-runtime.d.ts.map +1 -0
- package/dist/core/agent-runtimes/claude-code-headless-runtime.js +301 -0
- package/dist/core/agent-runtimes/claude-code-headless-runtime.js.map +1 -0
- package/dist/core/agent-runtimes/claude-sdk-runtime.d.ts +15 -0
- package/dist/core/agent-runtimes/claude-sdk-runtime.d.ts.map +1 -0
- package/dist/core/agent-runtimes/claude-sdk-runtime.js +92 -0
- package/dist/core/agent-runtimes/claude-sdk-runtime.js.map +1 -0
- package/dist/core/branch-manager.d.ts +15 -0
- package/dist/core/branch-manager.d.ts.map +1 -0
- package/dist/core/branch-manager.js +90 -0
- package/dist/core/branch-manager.js.map +1 -0
- package/dist/core/condition-evaluator.d.ts +16 -0
- package/dist/core/condition-evaluator.d.ts.map +1 -0
- package/dist/core/condition-evaluator.js +121 -0
- package/dist/core/condition-evaluator.js.map +1 -0
- package/dist/core/context-reducer.d.ts +15 -0
- package/dist/core/context-reducer.d.ts.map +1 -0
- package/dist/core/context-reducer.js +224 -0
- package/dist/core/context-reducer.js.map +1 -0
- package/dist/core/dag-planner.d.ts +13 -0
- package/dist/core/dag-planner.d.ts.map +1 -0
- package/dist/core/dag-planner.js +233 -0
- package/dist/core/dag-planner.js.map +1 -0
- package/dist/core/git-manager.d.ts +14 -0
- package/dist/core/git-manager.d.ts.map +1 -0
- package/dist/core/git-manager.js +70 -0
- package/dist/core/git-manager.js.map +1 -0
- package/dist/core/group-execution-orchestrator.d.ts +34 -0
- package/dist/core/group-execution-orchestrator.d.ts.map +1 -0
- package/dist/core/group-execution-orchestrator.js +238 -0
- package/dist/core/group-execution-orchestrator.js.map +1 -0
- package/dist/core/loop-state-manager.d.ts +29 -0
- package/dist/core/loop-state-manager.d.ts.map +1 -0
- package/dist/core/loop-state-manager.js +78 -0
- package/dist/core/loop-state-manager.js.map +1 -0
- package/dist/core/output-storage-manager.d.ts +14 -0
- package/dist/core/output-storage-manager.d.ts.map +1 -0
- package/dist/core/output-storage-manager.js +68 -0
- package/dist/core/output-storage-manager.js.map +1 -0
- package/dist/core/output-tool-builder.d.ts +6 -0
- package/dist/core/output-tool-builder.d.ts.map +1 -0
- package/dist/core/output-tool-builder.js +50 -0
- package/dist/core/output-tool-builder.js.map +1 -0
- package/dist/core/parallel-executor.d.ts +21 -0
- package/dist/core/parallel-executor.d.ts.map +1 -0
- package/dist/core/parallel-executor.js +93 -0
- package/dist/core/parallel-executor.js.map +1 -0
- package/dist/core/pipeline-finalizer.d.ts +24 -0
- package/dist/core/pipeline-finalizer.d.ts.map +1 -0
- package/dist/core/pipeline-finalizer.js +103 -0
- package/dist/core/pipeline-finalizer.js.map +1 -0
- package/dist/core/pipeline-initializer.d.ts +36 -0
- package/dist/core/pipeline-initializer.d.ts.map +1 -0
- package/dist/core/pipeline-initializer.js +105 -0
- package/dist/core/pipeline-initializer.js.map +1 -0
- package/dist/core/pipeline-runner.d.ts +36 -0
- package/dist/core/pipeline-runner.d.ts.map +1 -0
- package/dist/core/pipeline-runner.js +326 -0
- package/dist/core/pipeline-runner.js.map +1 -0
- package/dist/core/pr-creator.d.ts +23 -0
- package/dist/core/pr-creator.d.ts.map +1 -0
- package/dist/core/pr-creator.js +138 -0
- package/dist/core/pr-creator.js.map +1 -0
- package/dist/core/retry-handler.d.ts +15 -0
- package/dist/core/retry-handler.d.ts.map +1 -0
- package/dist/core/retry-handler.js +95 -0
- package/dist/core/retry-handler.js.map +1 -0
- package/dist/core/stage-executor.d.ts +27 -0
- package/dist/core/stage-executor.d.ts.map +1 -0
- package/dist/core/stage-executor.js +365 -0
- package/dist/core/stage-executor.js.map +1 -0
- package/dist/core/state-manager.d.ts +10 -0
- package/dist/core/state-manager.d.ts.map +1 -0
- package/dist/core/state-manager.js +61 -0
- package/dist/core/state-manager.js.map +1 -0
- package/dist/core/types/agent-runtime.d.ts +51 -0
- package/dist/core/types/agent-runtime.d.ts.map +1 -0
- package/dist/core/types/agent-runtime.js +2 -0
- package/dist/core/types/agent-runtime.js.map +1 -0
- package/dist/core/types/execution-graph.d.ts +29 -0
- package/dist/core/types/execution-graph.d.ts.map +1 -0
- package/dist/core/types/execution-graph.js +2 -0
- package/dist/core/types/execution-graph.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +400 -0
- package/dist/index.js.map +1 -0
- package/dist/notifications/notification-manager.d.ts +12 -0
- package/dist/notifications/notification-manager.d.ts.map +1 -0
- package/dist/notifications/notification-manager.js +74 -0
- package/dist/notifications/notification-manager.js.map +1 -0
- package/dist/notifications/notifiers/base-notifier.d.ts +9 -0
- package/dist/notifications/notifiers/base-notifier.d.ts.map +1 -0
- package/dist/notifications/notifiers/base-notifier.js +27 -0
- package/dist/notifications/notifiers/base-notifier.js.map +1 -0
- package/dist/notifications/notifiers/local-notifier.d.ts +11 -0
- package/dist/notifications/notifiers/local-notifier.d.ts.map +1 -0
- package/dist/notifications/notifiers/local-notifier.js +91 -0
- package/dist/notifications/notifiers/local-notifier.js.map +1 -0
- package/dist/notifications/notifiers/slack-notifier.d.ts +13 -0
- package/dist/notifications/notifiers/slack-notifier.d.ts.map +1 -0
- package/dist/notifications/notifiers/slack-notifier.js +209 -0
- package/dist/notifications/notifiers/slack-notifier.js.map +1 -0
- package/dist/notifications/types.d.ts +34 -0
- package/dist/notifications/types.d.ts.map +1 -0
- package/dist/notifications/types.js +2 -0
- package/dist/notifications/types.js.map +1 -0
- package/dist/ui/components/execution-group.d.ts +10 -0
- package/dist/ui/components/execution-group.d.ts.map +1 -0
- package/dist/ui/components/execution-group.js +19 -0
- package/dist/ui/components/execution-group.js.map +1 -0
- package/dist/ui/components/stage-row.d.ts +10 -0
- package/dist/ui/components/stage-row.d.ts.map +1 -0
- package/dist/ui/components/stage-row.js +69 -0
- package/dist/ui/components/stage-row.js.map +1 -0
- package/dist/ui/components/status-badge.d.ts +7 -0
- package/dist/ui/components/status-badge.d.ts.map +1 -0
- package/dist/ui/components/status-badge.js +18 -0
- package/dist/ui/components/status-badge.js.map +1 -0
- package/dist/ui/components/summary-line.d.ts +9 -0
- package/dist/ui/components/summary-line.d.ts.map +1 -0
- package/dist/ui/components/summary-line.js +13 -0
- package/dist/ui/components/summary-line.js.map +1 -0
- package/dist/ui/pipeline-ui.d.ts +8 -0
- package/dist/ui/pipeline-ui.d.ts.map +1 -0
- package/dist/ui/pipeline-ui.js +82 -0
- package/dist/ui/pipeline-ui.js.map +1 -0
- package/dist/utils/error-factory.d.ts +21 -0
- package/dist/utils/error-factory.d.ts.map +1 -0
- package/dist/utils/error-factory.js +74 -0
- package/dist/utils/error-factory.js.map +1 -0
- package/dist/utils/errors.d.ts +11 -0
- package/dist/utils/errors.d.ts.map +1 -0
- package/dist/utils/errors.js +21 -0
- package/dist/utils/errors.js.map +1 -0
- package/dist/utils/gh-cli-checker.d.ts +6 -0
- package/dist/utils/gh-cli-checker.d.ts.map +1 -0
- package/dist/utils/gh-cli-checker.js +42 -0
- package/dist/utils/gh-cli-checker.js.map +1 -0
- package/dist/utils/logger.d.ts +16 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +39 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/pipeline-formatter.d.ts +10 -0
- package/dist/utils/pipeline-formatter.d.ts.map +1 -0
- package/dist/utils/pipeline-formatter.js +92 -0
- package/dist/utils/pipeline-formatter.js.map +1 -0
- package/dist/utils/token-estimator.d.ts +15 -0
- package/dist/utils/token-estimator.d.ts.map +1 -0
- package/dist/utils/token-estimator.js +46 -0
- package/dist/utils/token-estimator.js.map +1 -0
- package/dist/validators/pipeline-validator.d.ts +31 -0
- package/dist/validators/pipeline-validator.d.ts.map +1 -0
- package/dist/validators/pipeline-validator.js +540 -0
- package/dist/validators/pipeline-validator.js.map +1 -0
- package/license +21 -0
- package/package.json +90 -0
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import Spinner from 'ink-spinner';
|
|
4
|
+
import { PipelineFormatter } from '../../utils/pipeline-formatter.js';
|
|
5
|
+
export const StageRow = ({ stage, isLast, condition, }) => {
|
|
6
|
+
const getIcon = () => {
|
|
7
|
+
switch (stage.status) {
|
|
8
|
+
case 'running':
|
|
9
|
+
return (React.createElement(Text, { color: "yellow" },
|
|
10
|
+
React.createElement(Spinner, { type: "dots" })));
|
|
11
|
+
case 'success':
|
|
12
|
+
return React.createElement(Text, { color: "green" }, "\u2705");
|
|
13
|
+
case 'failed':
|
|
14
|
+
return React.createElement(Text, { color: "red" }, "\u274C");
|
|
15
|
+
case 'skipped':
|
|
16
|
+
return React.createElement(Text, { dimColor: true }, "\u23ED\uFE0F");
|
|
17
|
+
default:
|
|
18
|
+
return React.createElement(Text, null, "\u23F8\uFE0F");
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
const hasExtractedData = stage.extractedData && Object.keys(stage.extractedData).length > 0;
|
|
22
|
+
return (React.createElement(Box, { flexDirection: "column", marginLeft: 2, marginBottom: isLast ? 0 : 1 },
|
|
23
|
+
React.createElement(Box, null,
|
|
24
|
+
getIcon(),
|
|
25
|
+
React.createElement(Text, { bold: true },
|
|
26
|
+
" ",
|
|
27
|
+
stage.stageName),
|
|
28
|
+
stage.duration && (React.createElement(Text, { dimColor: true },
|
|
29
|
+
" (",
|
|
30
|
+
stage.duration.toFixed(1),
|
|
31
|
+
"s)")),
|
|
32
|
+
stage.retryAttempt !== undefined && stage.retryAttempt > 0 && (React.createElement(Text, { color: "yellow" },
|
|
33
|
+
' ',
|
|
34
|
+
"[retry ",
|
|
35
|
+
stage.retryAttempt,
|
|
36
|
+
"/",
|
|
37
|
+
stage.maxRetries,
|
|
38
|
+
"]"))),
|
|
39
|
+
stage.conditionEvaluated && !stage.conditionResult && condition && (React.createElement(Box, { marginLeft: 3 },
|
|
40
|
+
React.createElement(Text, { dimColor: true }, "\u2514\u2500 Condition not met: "),
|
|
41
|
+
React.createElement(Text, { color: "gray" }, condition))),
|
|
42
|
+
stage.commitSha && (React.createElement(Box, { marginLeft: 3 },
|
|
43
|
+
React.createElement(Text, { dimColor: true }, "\u2514\u2500 Commit: "),
|
|
44
|
+
React.createElement(Text, { color: "cyan" }, stage.commitSha.substring(0, 7)))),
|
|
45
|
+
stage.tokenUsage && stage.status === 'success' && (React.createElement(Box, { marginLeft: 3 },
|
|
46
|
+
React.createElement(Text, { dimColor: true }, "\u2514\u2500 Tokens: "),
|
|
47
|
+
React.createElement(Text, { color: "magenta" }, PipelineFormatter.formatTokenUsage(stage.tokenUsage)))),
|
|
48
|
+
stage.status === 'success' && hasExtractedData && (React.createElement(Box, { marginLeft: 3, flexDirection: "column" },
|
|
49
|
+
React.createElement(Text, { dimColor: true }, "\u2514\u2500 Outputs:"),
|
|
50
|
+
Object.entries(stage.extractedData || {}).map(([key, value]) => (React.createElement(Box, { key: key, marginLeft: 2 },
|
|
51
|
+
React.createElement(Text, null,
|
|
52
|
+
"- ",
|
|
53
|
+
key,
|
|
54
|
+
": ",
|
|
55
|
+
JSON.stringify(value))))))),
|
|
56
|
+
(stage.status === 'running' || stage.status === 'failed') &&
|
|
57
|
+
stage.agentOutput && (React.createElement(Box, { marginLeft: 3, flexDirection: "column" },
|
|
58
|
+
React.createElement(Text, { dimColor: true }, "\u2514\u2500 Output:"),
|
|
59
|
+
React.createElement(Box, { marginLeft: 3, flexDirection: "column" },
|
|
60
|
+
React.createElement(Text, null, stage.agentOutput.split('\n').slice(-3).join('\n'))))),
|
|
61
|
+
stage.error && (React.createElement(Box, { marginLeft: 3, flexDirection: "column" },
|
|
62
|
+
React.createElement(Text, { color: "red" },
|
|
63
|
+
"\u2514\u2500 Error: ",
|
|
64
|
+
stage.error.message),
|
|
65
|
+
stage.error.suggestion && (React.createElement(Text, { color: "yellow" },
|
|
66
|
+
" \uD83D\uDCA1 ",
|
|
67
|
+
stage.error.suggestion))))));
|
|
68
|
+
};
|
|
69
|
+
//# sourceMappingURL=stage-row.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stage-row.js","sourceRoot":"","sources":["../../../src/ui/components/stage-row.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status-badge.d.ts","sourceRoot":"","sources":["../../../src/ui/components/status-badge.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,gBAAgB;IACxB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAoBlD,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Text } from 'ink';
|
|
3
|
+
export const StatusBadge = ({ status }) => {
|
|
4
|
+
const colors = {
|
|
5
|
+
running: 'yellow',
|
|
6
|
+
completed: 'green',
|
|
7
|
+
failed: 'red',
|
|
8
|
+
partial: 'yellow',
|
|
9
|
+
skipped: 'gray',
|
|
10
|
+
pending: 'gray',
|
|
11
|
+
};
|
|
12
|
+
const dimColor = {
|
|
13
|
+
skipped: true,
|
|
14
|
+
pending: true,
|
|
15
|
+
};
|
|
16
|
+
return (React.createElement(Text, { bold: true, color: colors[status] || 'white', dimColor: dimColor[status] }, status.toUpperCase()));
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=status-badge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status-badge.js","sourceRoot":"","sources":["../../../src/ui/components/status-badge.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAM3B,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IACpE,MAAM,MAAM,GAA2B;QACrC,OAAO,EAAE,QAAQ;QACjB,SAAS,EAAE,OAAO;QAClB,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,QAAQ;QACjB,OAAO,EAAE,MAAM;QACf,OAAO,EAAE,MAAM;KAChB,CAAC;IAEF,MAAM,QAAQ,GAA4B;QACxC,OAAO,EAAE,IAAI;QACb,OAAO,EAAE,IAAI;KACd,CAAC;IAEF,OAAO,CACL,oBAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC,MAAM,CAAC,IACpE,MAAM,CAAC,WAAW,EAAE,CAChB,CACR,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"summary-line.d.ts","sourceRoot":"","sources":["../../../src/ui/components/summary-line.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAWlD,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
export const SummaryLine = ({ label, value, color = 'white' }) => {
|
|
4
|
+
if (!value) {
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
return (React.createElement(Box, null,
|
|
8
|
+
React.createElement(Text, { bold: true },
|
|
9
|
+
label,
|
|
10
|
+
": "),
|
|
11
|
+
React.createElement(Text, { color: color }, value)));
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=summary-line.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"summary-line.js","sourceRoot":"","sources":["../../../src/ui/components/summary-line.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAQhC,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,GAAG,OAAO,EAAE,EAAE,EAAE;IAC3F,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CACL,oBAAC,GAAG;QACF,oBAAC,IAAI,IAAC,IAAI;YAAE,KAAK;iBAAU;QAC3B,oBAAC,IAAI,IAAC,KAAK,EAAE,KAAK,IAAG,KAAK,CAAQ,CAC9B,CACP,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { PipelineState } from '../config/schema.js';
|
|
3
|
+
interface PipelineUIProps {
|
|
4
|
+
onStateChange: (callback: (state: PipelineState) => void) => void;
|
|
5
|
+
}
|
|
6
|
+
export declare const PipelineUI: React.FC<PipelineUIProps>;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=pipeline-ui.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline-ui.d.ts","sourceRoot":"","sources":["../../src/ui/pipeline-ui.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAEnD,OAAO,EAGL,aAAa,EACd,MAAM,qBAAqB,CAAC;AAK7B,UAAU,eAAe;IACvB,aAAa,EAAE,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,KAAK,IAAI,CAAC;CACnE;AAgDD,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAiEhD,CAAC"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import { Box, Text, Newline } from 'ink';
|
|
3
|
+
import { ExecutionGroup } from './components/execution-group.js';
|
|
4
|
+
import { StatusBadge } from './components/status-badge.js';
|
|
5
|
+
import { SummaryLine } from './components/summary-line.js';
|
|
6
|
+
const getExecutionGroups = (pipelineConfig) => {
|
|
7
|
+
const groups = [];
|
|
8
|
+
const stages = [...pipelineConfig.agents];
|
|
9
|
+
const stageNames = new Set(stages.map((s) => s.name));
|
|
10
|
+
let level = 0;
|
|
11
|
+
while (stages.length > 0) {
|
|
12
|
+
const currentGroup = [];
|
|
13
|
+
const remainingStages = [];
|
|
14
|
+
stages.forEach((stage) => {
|
|
15
|
+
const deps = stage.dependsOn || [];
|
|
16
|
+
const depsMet = deps.every((dep) => !stageNames.has(dep));
|
|
17
|
+
if (depsMet) {
|
|
18
|
+
currentGroup.push(stage);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
remainingStages.push(stage);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
if (currentGroup.length === 0 && remainingStages.length > 0) {
|
|
25
|
+
groups.push(remainingStages);
|
|
26
|
+
break;
|
|
27
|
+
}
|
|
28
|
+
groups.push(currentGroup);
|
|
29
|
+
currentGroup.forEach((s) => stageNames.delete(s.name));
|
|
30
|
+
stages.splice(0, stages.length, ...remainingStages);
|
|
31
|
+
level++;
|
|
32
|
+
}
|
|
33
|
+
return groups;
|
|
34
|
+
};
|
|
35
|
+
const FinalSummary = ({ state }) => (React.createElement(Box, { flexDirection: "column", marginTop: 1, borderStyle: "round", padding: 1 },
|
|
36
|
+
React.createElement(Text, { bold: true },
|
|
37
|
+
"Pipeline ",
|
|
38
|
+
state.status),
|
|
39
|
+
React.createElement(Newline, null),
|
|
40
|
+
React.createElement(SummaryLine, { label: "Total Duration", value: `${state.artifacts.totalDuration.toFixed(1)}s` }),
|
|
41
|
+
React.createElement(SummaryLine, { label: "Total Commits", value: `${state.stages.filter(s => s.commitSha).length}` }),
|
|
42
|
+
React.createElement(SummaryLine, { label: "PR", value: state.artifacts.pullRequest?.url, color: "cyan" })));
|
|
43
|
+
export const PipelineUI = ({ onStateChange }) => {
|
|
44
|
+
const [state, setState] = useState(null);
|
|
45
|
+
useEffect(() => {
|
|
46
|
+
onStateChange(setState);
|
|
47
|
+
}, [onStateChange]);
|
|
48
|
+
if (!state) {
|
|
49
|
+
return React.createElement(Text, null, "Initializing pipeline...");
|
|
50
|
+
}
|
|
51
|
+
const executionGroups = getExecutionGroups(state.pipelineConfig);
|
|
52
|
+
const isFinished = state.status === 'completed' || state.status === 'failed' || state.status === 'partial';
|
|
53
|
+
return (React.createElement(Box, { flexDirection: "column", padding: 1 },
|
|
54
|
+
React.createElement(Box, { borderStyle: "round", borderColor: "cyan", paddingX: 1, paddingY: 0 },
|
|
55
|
+
React.createElement(Box, { flexDirection: "column" },
|
|
56
|
+
React.createElement(Text, { bold: true, color: "cyan" },
|
|
57
|
+
"\uD83E\uDD16 Agent Pipeline: ",
|
|
58
|
+
state.pipelineConfig.name),
|
|
59
|
+
state.loopContext && (React.createElement(SummaryLine, { label: "Loop", value: state.loopContext.maxIterations
|
|
60
|
+
? `${state.loopContext.currentIteration}/${state.loopContext.maxIterations}`
|
|
61
|
+
: `${state.loopContext.currentIteration}`, color: "magenta" })),
|
|
62
|
+
React.createElement(SummaryLine, { label: "Run ID", value: state.runId.substring(0, 8) }),
|
|
63
|
+
React.createElement(SummaryLine, { label: "Branch", value: state.artifacts.pullRequest?.branch }))),
|
|
64
|
+
React.createElement(Newline, null),
|
|
65
|
+
executionGroups.map((group, index) => (React.createElement(ExecutionGroup, { key: index, title: `Group ${index + 1}`, group: group, executedStages: state.stages }))),
|
|
66
|
+
isFinished && React.createElement(FinalSummary, { state: state }),
|
|
67
|
+
!isFinished && (React.createElement(Box, { borderStyle: "single", borderColor: "gray", paddingX: 1, marginTop: 1 },
|
|
68
|
+
React.createElement(Text, null,
|
|
69
|
+
state.loopContext && React.createElement(Text, { color: "magenta" },
|
|
70
|
+
"\uD83D\uDD01 Loop ",
|
|
71
|
+
state.loopContext.currentIteration,
|
|
72
|
+
" | "),
|
|
73
|
+
"Status: ",
|
|
74
|
+
React.createElement(StatusBadge, { status: state.status }),
|
|
75
|
+
" | Duration:",
|
|
76
|
+
' ',
|
|
77
|
+
state.artifacts.totalDuration.toFixed(1),
|
|
78
|
+
"s | Commits:",
|
|
79
|
+
' ',
|
|
80
|
+
state.stages.filter((s) => s.commitSha).length)))));
|
|
81
|
+
};
|
|
82
|
+
//# sourceMappingURL=pipeline-ui.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline-ui.js","sourceRoot":"","sources":["../../src/ui/pipeline-ui.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export interface StageErrorDetails {
|
|
2
|
+
message: string;
|
|
3
|
+
stack?: string;
|
|
4
|
+
agentPath?: string;
|
|
5
|
+
timestamp: string;
|
|
6
|
+
suggestion?: string;
|
|
7
|
+
}
|
|
8
|
+
export interface GitErrorDetails {
|
|
9
|
+
message: string;
|
|
10
|
+
stack?: string;
|
|
11
|
+
operation?: string;
|
|
12
|
+
timestamp: string;
|
|
13
|
+
suggestion?: string;
|
|
14
|
+
}
|
|
15
|
+
export declare class ErrorFactory {
|
|
16
|
+
static createStageError(error: unknown, agentPath?: string): StageErrorDetails;
|
|
17
|
+
static createGitError(error: unknown, operation?: string): GitErrorDetails;
|
|
18
|
+
private static getSuggestion;
|
|
19
|
+
private static getGitSuggestion;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=error-factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-factory.d.ts","sourceRoot":"","sources":["../../src/utils/error-factory.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,qBAAa,YAAY;IACvB,MAAM,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,iBAAiB;IAgB9E,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,eAAe;IAgB1E,OAAO,CAAC,MAAM,CAAC,aAAa;IAwB5B,OAAO,CAAC,MAAM,CAAC,gBAAgB;CAmChC"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
export class ErrorFactory {
|
|
2
|
+
static createStageError(error, agentPath) {
|
|
3
|
+
const baseError = {
|
|
4
|
+
message: error instanceof Error ? error.message : String(error),
|
|
5
|
+
stack: error instanceof Error ? error.stack : undefined,
|
|
6
|
+
agentPath,
|
|
7
|
+
timestamp: new Date().toISOString()
|
|
8
|
+
};
|
|
9
|
+
const suggestion = this.getSuggestion(baseError.message, agentPath);
|
|
10
|
+
if (suggestion) {
|
|
11
|
+
baseError.suggestion = suggestion;
|
|
12
|
+
}
|
|
13
|
+
return baseError;
|
|
14
|
+
}
|
|
15
|
+
static createGitError(error, operation) {
|
|
16
|
+
const baseError = {
|
|
17
|
+
message: error instanceof Error ? error.message : String(error),
|
|
18
|
+
stack: error instanceof Error ? error.stack : undefined,
|
|
19
|
+
operation,
|
|
20
|
+
timestamp: new Date().toISOString()
|
|
21
|
+
};
|
|
22
|
+
const suggestion = this.getGitSuggestion(baseError.message, operation);
|
|
23
|
+
if (suggestion) {
|
|
24
|
+
baseError.suggestion = suggestion;
|
|
25
|
+
}
|
|
26
|
+
return baseError;
|
|
27
|
+
}
|
|
28
|
+
static getSuggestion(message, agentPath) {
|
|
29
|
+
if (message.includes('ENOENT')) {
|
|
30
|
+
return `Agent file not found. Check path: ${agentPath}`;
|
|
31
|
+
}
|
|
32
|
+
if (message.includes('timeout') || message.includes('Agent timeout')) {
|
|
33
|
+
return 'Agent exceeded timeout (default: 15 minutes). Consider increasing timeout in pipeline config or optimizing agent complexity.';
|
|
34
|
+
}
|
|
35
|
+
if (message.includes('API') || message.includes('401') || message.includes('403')) {
|
|
36
|
+
return 'Check ANTHROPIC_API_KEY environment variable is set correctly.';
|
|
37
|
+
}
|
|
38
|
+
if (message.includes('YAML') || message.includes('parse')) {
|
|
39
|
+
return 'Check YAML syntax in pipeline configuration file.';
|
|
40
|
+
}
|
|
41
|
+
if (message.includes('permission')) {
|
|
42
|
+
return 'Check file permissions for agent definition and working directory.';
|
|
43
|
+
}
|
|
44
|
+
return undefined;
|
|
45
|
+
}
|
|
46
|
+
static getGitSuggestion(message, operation) {
|
|
47
|
+
if (message.includes('ambiguous argument') || message.includes('unknown revision')) {
|
|
48
|
+
return 'Commit SHA or branch may not exist. This might be the first commit in the repository.';
|
|
49
|
+
}
|
|
50
|
+
if (message.includes('ENOTFOUND') || message.includes('Could not resolve host')) {
|
|
51
|
+
return 'Network error. Check internet connection and git remote URL.';
|
|
52
|
+
}
|
|
53
|
+
if (message.includes('authentication failed') || message.includes('Permission denied')) {
|
|
54
|
+
return 'Git authentication failed. Check SSH keys or HTTPS credentials.';
|
|
55
|
+
}
|
|
56
|
+
if (message.includes('rejected') || message.includes('non-fast-forward')) {
|
|
57
|
+
return 'Push rejected. Pull latest changes or use force push (not recommended).';
|
|
58
|
+
}
|
|
59
|
+
if (message.includes('CONFLICT') || message.includes('merge conflict')) {
|
|
60
|
+
return 'Merge conflict detected. Resolve conflicts manually before continuing.';
|
|
61
|
+
}
|
|
62
|
+
if (message.includes('not a git repository')) {
|
|
63
|
+
return 'Current directory is not a git repository. Initialize with: git init';
|
|
64
|
+
}
|
|
65
|
+
if (message.includes('nothing to commit') || message.includes('no changes added')) {
|
|
66
|
+
return 'No staged changes to commit. Stage changes with: git add';
|
|
67
|
+
}
|
|
68
|
+
if (operation === 'push' && message.includes('failed')) {
|
|
69
|
+
return 'Push failed. Ensure remote branch exists and you have push permissions.';
|
|
70
|
+
}
|
|
71
|
+
return undefined;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=error-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-factory.js","sourceRoot":"","sources":["../../src/utils/error-factory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare class PipelineError extends Error {
|
|
2
|
+
constructor(message: string);
|
|
3
|
+
}
|
|
4
|
+
export declare class StageError extends Error {
|
|
5
|
+
stageName: string;
|
|
6
|
+
constructor(stageName: string, message: string);
|
|
7
|
+
}
|
|
8
|
+
export declare class ConfigurationError extends Error {
|
|
9
|
+
constructor(message: string);
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/utils/errors.ts"],"names":[],"mappings":"AAEA,qBAAa,aAAc,SAAQ,KAAK;gBAC1B,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,UAAW,SAAQ,KAAK;IAE1B,SAAS,EAAE,MAAM;gBAAjB,SAAS,EAAE,MAAM,EACxB,OAAO,EAAE,MAAM;CAKlB;AAED,qBAAa,kBAAmB,SAAQ,KAAK;gBAC/B,OAAO,EAAE,MAAM;CAI5B"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export class PipelineError extends Error {
|
|
2
|
+
constructor(message) {
|
|
3
|
+
super(message);
|
|
4
|
+
this.name = 'PipelineError';
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
export class StageError extends Error {
|
|
8
|
+
stageName;
|
|
9
|
+
constructor(stageName, message) {
|
|
10
|
+
super(`[${stageName}] ${message}`);
|
|
11
|
+
this.stageName = stageName;
|
|
12
|
+
this.name = 'StageError';
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
export class ConfigurationError extends Error {
|
|
16
|
+
constructor(message) {
|
|
17
|
+
super(message);
|
|
18
|
+
this.name = 'ConfigurationError';
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/utils/errors.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,aAAc,SAAQ,KAAK;IACtC,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;IAC9B,CAAC;CACF;AAED,MAAM,OAAO,UAAW,SAAQ,KAAK;IAE1B;IADT,YACS,SAAiB,EACxB,OAAe;QAEf,KAAK,CAAC,IAAI,SAAS,KAAK,OAAO,EAAE,CAAC,CAAC;QAH5B,cAAS,GAAT,SAAS,CAAQ;QAIxB,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;IAC3B,CAAC;CACF;AAED,MAAM,OAAO,kBAAmB,SAAQ,KAAK;IAC3C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,oBAAoB,CAAC;IACnC,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gh-cli-checker.d.ts","sourceRoot":"","sources":["../../src/utils/gh-cli-checker.ts"],"names":[],"mappings":"AAOA,MAAM,WAAW,WAAW;IAC1B,SAAS,EAAE,OAAO,CAAC;IACnB,aAAa,EAAE,OAAO,CAAC;CACxB;AAwDD,wBAAsB,UAAU,IAAI,OAAO,CAAC,WAAW,CAAC,CAevD"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { spawn } from 'child_process';
|
|
2
|
+
function executeGhCommand(args) {
|
|
3
|
+
return new Promise((resolve, reject) => {
|
|
4
|
+
const process = spawn('gh', args);
|
|
5
|
+
let stdout = '';
|
|
6
|
+
let stderr = '';
|
|
7
|
+
process.stdout.on('data', (data) => {
|
|
8
|
+
stdout += data.toString();
|
|
9
|
+
});
|
|
10
|
+
process.stderr.on('data', (data) => {
|
|
11
|
+
stderr += data.toString();
|
|
12
|
+
});
|
|
13
|
+
process.on('close', (code) => {
|
|
14
|
+
if (code === 0) {
|
|
15
|
+
resolve(stdout);
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
const errorMessage = stderr || stdout || 'Unknown error';
|
|
19
|
+
reject(new Error(`gh command failed with exit code ${code}: ${errorMessage}`));
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
process.on('error', (err) => {
|
|
23
|
+
reject(err);
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
export async function checkGHCLI() {
|
|
28
|
+
try {
|
|
29
|
+
await executeGhCommand(['--version']);
|
|
30
|
+
try {
|
|
31
|
+
await executeGhCommand(['auth', 'status']);
|
|
32
|
+
return { installed: true, authenticated: true };
|
|
33
|
+
}
|
|
34
|
+
catch {
|
|
35
|
+
return { installed: true, authenticated: false };
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
return { installed: false, authenticated: false };
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=gh-cli-checker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gh-cli-checker.js","sourceRoot":"","sources":["../../src/utils/gh-cli-checker.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAetC,SAAS,gBAAgB,CAAC,IAAc;IACtC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAClC,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,MAAM,GAAG,EAAE,CAAC;QAEhB,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;YACjC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;YACjC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YAC3B,IAAI,IAAI,KAAK,CAAC,EAAE,CAAC;gBACf,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC;iBAAM,CAAC;gBAEN,MAAM,YAAY,GAAG,MAAM,IAAI,MAAM,IAAI,eAAe,CAAC;gBACzD,MAAM,CAAC,IAAI,KAAK,CAAC,oCAAoC,IAAI,KAAK,YAAY,EAAE,CAAC,CAAC,CAAC;YACjF,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;YAC1B,MAAM,CAAC,GAAG,CAAC,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAqBD,MAAM,CAAC,KAAK,UAAU,UAAU;IAC9B,IAAI,CAAC;QAEH,MAAM,gBAAgB,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;QAGtC,IAAI,CAAC;YACH,MAAM,gBAAgB,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;YAC3C,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;QAClD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;QACnD,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;IACpD,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export declare enum LogLevel {
|
|
2
|
+
DEBUG = 0,
|
|
3
|
+
INFO = 1,
|
|
4
|
+
WARN = 2,
|
|
5
|
+
ERROR = 3
|
|
6
|
+
}
|
|
7
|
+
export declare class Logger {
|
|
8
|
+
private static level;
|
|
9
|
+
static setLevel(level: LogLevel): void;
|
|
10
|
+
static debug(message: string, ...args: any[]): void;
|
|
11
|
+
static info(message: string, ...args: any[]): void;
|
|
12
|
+
static warn(message: string, ...args: any[]): void;
|
|
13
|
+
static error(message: string, ...args: any[]): void;
|
|
14
|
+
static success(message: string, ...args: any[]): void;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAEA,oBAAY,QAAQ;IAClB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,KAAK,IAAI;CACV;AAED,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAC,KAAK,CAA2B;IAE/C,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAItC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAMnD,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAMlD,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAMlD,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAMnD,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;CAKtD"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export var LogLevel;
|
|
2
|
+
(function (LogLevel) {
|
|
3
|
+
LogLevel[LogLevel["DEBUG"] = 0] = "DEBUG";
|
|
4
|
+
LogLevel[LogLevel["INFO"] = 1] = "INFO";
|
|
5
|
+
LogLevel[LogLevel["WARN"] = 2] = "WARN";
|
|
6
|
+
LogLevel[LogLevel["ERROR"] = 3] = "ERROR";
|
|
7
|
+
})(LogLevel || (LogLevel = {}));
|
|
8
|
+
export class Logger {
|
|
9
|
+
static level = LogLevel.INFO;
|
|
10
|
+
static setLevel(level) {
|
|
11
|
+
this.level = level;
|
|
12
|
+
}
|
|
13
|
+
static debug(message, ...args) {
|
|
14
|
+
if (this.level <= LogLevel.DEBUG) {
|
|
15
|
+
console.debug(`đ ${message}`, ...args);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
static info(message, ...args) {
|
|
19
|
+
if (this.level <= LogLevel.INFO) {
|
|
20
|
+
console.log(`âšī¸ ${message}`, ...args);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
static warn(message, ...args) {
|
|
24
|
+
if (this.level <= LogLevel.WARN) {
|
|
25
|
+
console.warn(`â ī¸ ${message}`, ...args);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
static error(message, ...args) {
|
|
29
|
+
if (this.level <= LogLevel.ERROR) {
|
|
30
|
+
console.error(`â ${message}`, ...args);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
static success(message, ...args) {
|
|
34
|
+
if (this.level <= LogLevel.INFO) {
|
|
35
|
+
console.log(`â
${message}`, ...args);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAEA,MAAM,CAAN,IAAY,QAKX;AALD,WAAY,QAAQ;IAClB,yCAAS,CAAA;IACT,uCAAQ,CAAA;IACR,uCAAQ,CAAA;IACR,yCAAS,CAAA;AACX,CAAC,EALW,QAAQ,KAAR,QAAQ,QAKnB;AAED,MAAM,OAAO,MAAM;IACT,MAAM,CAAC,KAAK,GAAa,QAAQ,CAAC,IAAI,CAAC;IAE/C,MAAM,CAAC,QAAQ,CAAC,KAAe;QAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,OAAe,EAAE,GAAG,IAAW;QAC1C,IAAI,IAAI,CAAC,KAAK,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;YACjC,OAAO,CAAC,KAAK,CAAC,MAAM,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,MAAM,CAAC,IAAI,CAAC,OAAe,EAAE,GAAG,IAAW;QACzC,IAAI,IAAI,CAAC,KAAK,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,OAAO,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,MAAM,CAAC,IAAI,CAAC,OAAe,EAAE,GAAG,IAAW;QACzC,IAAI,IAAI,CAAC,KAAK,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;YAChC,OAAO,CAAC,IAAI,CAAC,OAAO,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,OAAe,EAAE,GAAG,IAAW;QAC1C,IAAI,IAAI,CAAC,KAAK,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;YACjC,OAAO,CAAC,KAAK,CAAC,KAAK,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,MAAM,CAAC,OAAO,CAAC,OAAe,EAAE,GAAG,IAAW;QAC5C,IAAI,IAAI,CAAC,KAAK,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,KAAK,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;QACvC,CAAC;IACH,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { PipelineState, StageExecution } from '../config/schema.js';
|
|
2
|
+
export declare class PipelineFormatter {
|
|
3
|
+
static getStatusEmoji(status: string): string;
|
|
4
|
+
static formatSummary(state: PipelineState): string;
|
|
5
|
+
static formatStageInfo(stage: StageExecution): string;
|
|
6
|
+
static formatRetryInfo(retryAttempt: number | undefined, maxRetries: number | undefined): string;
|
|
7
|
+
static formatTokenCount(tokens: number): string;
|
|
8
|
+
static formatTokenUsage(tokenUsage: StageExecution['tokenUsage']): string;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=pipeline-formatter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline-formatter.d.ts","sourceRoot":"","sources":["../../src/utils/pipeline-formatter.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAEpE,qBAAa,iBAAiB;IAC5B,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAa7C,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,aAAa,GAAG,MAAM;IAgClD,MAAM,CAAC,eAAe,CAAC,KAAK,EAAE,cAAc,GAAG,MAAM;IAkBrD,MAAM,CAAC,eAAe,CAAC,YAAY,EAAE,MAAM,GAAG,SAAS,EAAE,UAAU,EAAE,MAAM,GAAG,SAAS,GAAG,MAAM;IAUhG,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAc/C,MAAM,CAAC,gBAAgB,CAAC,UAAU,EAAE,cAAc,CAAC,YAAY,CAAC,GAAG,MAAM;CAsC1E"}
|