@agents-inc/cli 0.48.0 → 0.50.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/CHANGELOG.md +26 -0
- package/README.md +1 -2
- package/config/stacks.yaml +0 -1
- package/dist/{chunk-YDASDMTH.js → chunk-26MXZUHU.js} +2 -2
- package/dist/{chunk-WSGKCBY5.js → chunk-2BWCR762.js} +2 -3
- package/dist/chunk-2BWCR762.js.map +1 -0
- package/dist/chunk-3VOL4WEG.js +31 -0
- package/dist/chunk-3VOL4WEG.js.map +1 -0
- package/dist/chunk-4QWDB2MD.js +571 -0
- package/dist/chunk-4QWDB2MD.js.map +1 -0
- package/dist/{chunk-ZML3OCYA.js → chunk-4R52TQ3K.js} +2 -2
- package/dist/{chunk-KPJJOLAQ.js → chunk-5FCHJLM7.js} +34 -16
- package/dist/chunk-5FCHJLM7.js.map +1 -0
- package/dist/chunk-5FPIKTSA.js +40 -0
- package/dist/chunk-5FPIKTSA.js.map +1 -0
- package/dist/{chunk-SPVSWDFM.js → chunk-5L724R4C.js} +5 -6
- package/dist/{chunk-SPVSWDFM.js.map → chunk-5L724R4C.js.map} +1 -1
- package/dist/{chunk-AXV7NFFJ.js → chunk-7LV4V6A4.js} +4 -4
- package/dist/{chunk-LESHL6SM.js → chunk-AWP5A6IM.js} +9 -3
- package/dist/chunk-AWP5A6IM.js.map +1 -0
- package/dist/chunk-C3Q43WLC.js +118 -0
- package/dist/chunk-C3Q43WLC.js.map +1 -0
- package/dist/{chunk-U2AEK4ZL.js → chunk-CMNKHDOX.js} +2 -2
- package/dist/{chunk-X3SZIBVW.js → chunk-D72AFYQR.js} +2 -2
- package/dist/chunk-D72AFYQR.js.map +1 -0
- package/dist/{chunk-FPTUCWBY.js → chunk-DCE423KO.js} +46 -30
- package/dist/chunk-DCE423KO.js.map +1 -0
- package/dist/chunk-GBOW6FUW.js +74 -0
- package/dist/chunk-GBOW6FUW.js.map +1 -0
- package/dist/{chunk-P2SFRDWI.js → chunk-HMSHB5EQ.js} +437 -185
- package/dist/chunk-HMSHB5EQ.js.map +1 -0
- package/dist/{chunk-GSPPOXMG.js → chunk-HYEUETIC.js} +2 -2
- package/dist/{chunk-IS7GP6XC.js → chunk-I6IOGZSZ.js} +61 -52
- package/dist/chunk-I6IOGZSZ.js.map +1 -0
- package/dist/{chunk-OTTITQ7C.js → chunk-JFF7P4LC.js} +30 -93
- package/dist/chunk-JFF7P4LC.js.map +1 -0
- package/dist/{chunk-FHKNG3UA.js → chunk-JWYRXE6C.js} +2 -2
- package/dist/{chunk-W62XVWXB.js → chunk-KAO3LKB5.js} +3 -3
- package/dist/{chunk-AMNCCZSG.js → chunk-KQOU4POU.js} +26 -28
- package/dist/chunk-KQOU4POU.js.map +1 -0
- package/dist/{chunk-VBAAATPU.js → chunk-M3GQ2R3E.js} +29 -28
- package/dist/chunk-M3GQ2R3E.js.map +1 -0
- package/dist/{chunk-2BVZOYJP.js → chunk-PGY5XROM.js} +2 -2
- package/dist/chunk-PGY5XROM.js.map +1 -0
- package/dist/{chunk-5MN5S3DV.js → chunk-QB5HHTAA.js} +8 -19
- package/dist/chunk-QB5HHTAA.js.map +1 -0
- package/dist/{chunk-34BP5BC4.js → chunk-QYLCINGC.js} +2 -2
- package/dist/{chunk-I52THVF6.js → chunk-RA2IPRO2.js} +2 -2
- package/dist/{chunk-G5OZQ376.js → chunk-RDWGYKDY.js} +4 -4
- package/dist/{chunk-7IAKVZL5.js → chunk-RFKDGJAJ.js} +26 -57
- package/dist/chunk-RFKDGJAJ.js.map +1 -0
- package/dist/{chunk-5O6GKXAN.js → chunk-SPFHPHYL.js} +7 -7
- package/dist/{chunk-NJVJ7VO5.js → chunk-U2W5SENM.js} +3 -3
- package/dist/{chunk-37QYD33C.js → chunk-U7X4V4HE.js} +2 -2
- package/dist/{chunk-C7DLY64D.js → chunk-UAD3SC27.js} +4 -12
- package/dist/chunk-UAD3SC27.js.map +1 -0
- package/dist/{chunk-YMUWTPOM.js → chunk-WBHPCBVN.js} +31 -11
- package/dist/chunk-WBHPCBVN.js.map +1 -0
- package/dist/chunk-WFFV254H.js +314 -0
- package/dist/chunk-WFFV254H.js.map +1 -0
- package/dist/{chunk-F7KTUFGU.js → chunk-WJHFV6RI.js} +3 -2
- package/dist/chunk-WJHFV6RI.js.map +1 -0
- package/dist/{chunk-DG2U2WY3.js → chunk-WLZHCM7O.js} +2 -2
- package/dist/{chunk-OHDEJEYB.js → chunk-XDSVV5GZ.js} +4 -4
- package/dist/{chunk-2DNDAXF6.js → chunk-YDYRAXSY.js} +57 -27
- package/dist/chunk-YDYRAXSY.js.map +1 -0
- package/dist/commands/build/marketplace.js +4 -4
- package/dist/commands/build/plugins.js +5 -5
- package/dist/commands/build/stack.js +5 -5
- package/dist/commands/compile.js +11 -9
- package/dist/commands/compile.js.map +1 -1
- package/dist/commands/config/get.js +4 -4
- package/dist/commands/config/index.js +5 -5
- package/dist/commands/config/path.js +4 -4
- package/dist/commands/config/set-project.js +4 -4
- package/dist/commands/config/show.js +5 -5
- package/dist/commands/config/unset-project.js +4 -4
- package/dist/commands/diff.js +4 -4
- package/dist/commands/doctor.js +4 -4
- package/dist/commands/edit.js +58 -52
- package/dist/commands/edit.js.map +1 -1
- package/dist/commands/eject.js +4 -4
- package/dist/commands/import/skill.js +5 -5
- package/dist/commands/info.js +5 -5
- package/dist/commands/init.js +40 -435
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/list.js +4 -4
- package/dist/commands/new/agent.js +11 -10
- package/dist/commands/new/agent.js.map +1 -1
- package/dist/commands/new/marketplace.js +24 -5
- package/dist/commands/new/marketplace.js.map +1 -1
- package/dist/commands/new/skill.js +15 -208
- package/dist/commands/new/skill.js.map +1 -1
- package/dist/commands/outdated.js +11 -7
- package/dist/commands/outdated.js.map +1 -1
- package/dist/commands/search.js +7 -7
- package/dist/commands/uninstall.js +6 -6
- package/dist/commands/update.js +6 -6
- package/dist/commands/validate.js +26 -247
- package/dist/commands/validate.js.map +1 -1
- package/dist/components/skill-search/skill-search.js +3 -3
- package/dist/components/wizard/category-grid.js +3 -2
- package/dist/components/wizard/category-grid.test.js +112 -58
- package/dist/components/wizard/category-grid.test.js.map +1 -1
- package/dist/components/wizard/checkbox-grid.js +5 -3
- package/dist/components/wizard/checkbox-grid.test.js +5 -4
- package/dist/components/wizard/checkbox-grid.test.js.map +1 -1
- package/dist/components/wizard/domain-selection.js +11 -9
- package/dist/components/wizard/help-modal.js +2 -2
- package/dist/components/wizard/menu-item.js +1 -1
- package/dist/components/wizard/search-modal.js +2 -2
- package/dist/components/wizard/search-modal.test.js +2 -2
- package/dist/components/wizard/section-progress.js +2 -2
- package/dist/components/wizard/section-progress.test.js +2 -2
- package/dist/components/wizard/selection-card.js +2 -2
- package/dist/components/wizard/source-grid.js +4 -3
- package/dist/components/wizard/source-grid.test.js +4 -3
- package/dist/components/wizard/source-grid.test.js.map +1 -1
- package/dist/components/wizard/stack-selection.js +8 -8
- package/dist/components/wizard/step-agents.js +10 -8
- package/dist/components/wizard/step-agents.test.js +18 -17
- package/dist/components/wizard/step-agents.test.js.map +1 -1
- package/dist/components/wizard/step-build.js +9 -8
- package/dist/components/wizard/step-build.test.js +11 -25
- package/dist/components/wizard/step-build.test.js.map +1 -1
- package/dist/components/wizard/step-confirm.js +4 -4
- package/dist/components/wizard/step-confirm.test.js +8 -8
- package/dist/components/wizard/step-refine.js +2 -2
- package/dist/components/wizard/step-refine.test.js +2 -2
- package/dist/components/wizard/step-settings.js +7 -5
- package/dist/components/wizard/step-settings.test.js +10 -8
- package/dist/components/wizard/step-settings.test.js.map +1 -1
- package/dist/components/wizard/step-sources.js +11 -10
- package/dist/components/wizard/step-sources.test.js +12 -11
- package/dist/components/wizard/step-sources.test.js.map +1 -1
- package/dist/components/wizard/step-stack.js +15 -12
- package/dist/components/wizard/step-stack.test.js +16 -13
- package/dist/components/wizard/step-stack.test.js.map +1 -1
- package/dist/components/wizard/view-title.js +2 -2
- package/dist/components/wizard/wizard-layout.js +8 -8
- package/dist/components/wizard/wizard-tabs.js +2 -2
- package/dist/components/wizard/wizard-tabs.test.js +2 -2
- package/dist/components/wizard/wizard.js +27 -25
- package/dist/config/stacks.yaml +0 -1
- package/dist/hooks/init.js +55 -3
- package/dist/hooks/init.js.map +1 -1
- package/dist/{source-manager-Y7R6WPOW.js → source-manager-BVB2SG73.js} +4 -4
- package/dist/src/agents/meta/agent-summoner/critical-reminders.md +1 -1
- package/dist/src/agents/meta/agent-summoner/critical-requirements.md +1 -1
- package/dist/src/agents/meta/agent-summoner/examples.md +2 -2
- package/dist/src/agents/meta/agent-summoner/output-format.md +1 -1
- package/dist/src/agents/meta/agent-summoner/workflow.md +5 -7
- package/{src/agents/meta/documentor/agent.yaml → dist/src/agents/meta/documentor/metadata.yaml} +1 -0
- package/dist/stores/wizard-store.js +5 -5
- package/dist/stores/wizard-store.test.js +79 -27
- package/dist/stores/wizard-store.test.js.map +1 -1
- package/package.json +1 -1
- package/src/agents/meta/agent-summoner/critical-reminders.md +1 -1
- package/src/agents/meta/agent-summoner/critical-requirements.md +1 -1
- package/src/agents/meta/agent-summoner/examples.md +2 -2
- package/src/agents/meta/agent-summoner/output-format.md +1 -1
- package/src/agents/meta/agent-summoner/workflow.md +5 -7
- package/{dist/src/agents/meta/documentor/agent.yaml → src/agents/meta/documentor/metadata.yaml} +1 -0
- package/src/schemas/agent.schema.json +1 -1
- package/src/schemas/project-config.schema.json +0 -3
- package/dist/chunk-2BVZOYJP.js.map +0 -1
- package/dist/chunk-2DNDAXF6.js.map +0 -1
- package/dist/chunk-5MN5S3DV.js.map +0 -1
- package/dist/chunk-7IAKVZL5.js.map +0 -1
- package/dist/chunk-AMNCCZSG.js.map +0 -1
- package/dist/chunk-AXZNJ5PN.js +0 -99
- package/dist/chunk-AXZNJ5PN.js.map +0 -1
- package/dist/chunk-C7DLY64D.js.map +0 -1
- package/dist/chunk-F7KTUFGU.js.map +0 -1
- package/dist/chunk-FPTUCWBY.js.map +0 -1
- package/dist/chunk-IS7GP6XC.js.map +0 -1
- package/dist/chunk-KPJJOLAQ.js.map +0 -1
- package/dist/chunk-LESHL6SM.js.map +0 -1
- package/dist/chunk-OTTITQ7C.js.map +0 -1
- package/dist/chunk-P2SFRDWI.js.map +0 -1
- package/dist/chunk-PY2XZUBF.js +0 -29
- package/dist/chunk-PY2XZUBF.js.map +0 -1
- package/dist/chunk-VBAAATPU.js.map +0 -1
- package/dist/chunk-WSGKCBY5.js.map +0 -1
- package/dist/chunk-X3SZIBVW.js.map +0 -1
- package/dist/chunk-YMUWTPOM.js.map +0 -1
- package/dist/src/agents/migration/cli-migrator/agent.yaml +0 -12
- package/dist/src/agents/migration/cli-migrator/anti-patterns.md +0 -158
- package/dist/src/agents/migration/cli-migrator/conversion-mappings.md +0 -63
- package/dist/src/agents/migration/cli-migrator/critical-reminders.md +0 -17
- package/dist/src/agents/migration/cli-migrator/critical-requirements.md +0 -13
- package/dist/src/agents/migration/cli-migrator/intro.md +0 -15
- package/dist/src/agents/migration/cli-migrator/output-format.md +0 -164
- package/dist/src/agents/migration/cli-migrator/workflow.md +0 -230
- package/src/agents/migration/cli-migrator/agent.yaml +0 -12
- package/src/agents/migration/cli-migrator/anti-patterns.md +0 -158
- package/src/agents/migration/cli-migrator/conversion-mappings.md +0 -63
- package/src/agents/migration/cli-migrator/critical-reminders.md +0 -17
- package/src/agents/migration/cli-migrator/critical-requirements.md +0 -13
- package/src/agents/migration/cli-migrator/intro.md +0 -15
- package/src/agents/migration/cli-migrator/output-format.md +0 -164
- package/src/agents/migration/cli-migrator/workflow.md +0 -230
- /package/dist/{chunk-YDASDMTH.js.map → chunk-26MXZUHU.js.map} +0 -0
- /package/dist/{chunk-ZML3OCYA.js.map → chunk-4R52TQ3K.js.map} +0 -0
- /package/dist/{chunk-AXV7NFFJ.js.map → chunk-7LV4V6A4.js.map} +0 -0
- /package/dist/{chunk-U2AEK4ZL.js.map → chunk-CMNKHDOX.js.map} +0 -0
- /package/dist/{chunk-GSPPOXMG.js.map → chunk-HYEUETIC.js.map} +0 -0
- /package/dist/{chunk-FHKNG3UA.js.map → chunk-JWYRXE6C.js.map} +0 -0
- /package/dist/{chunk-W62XVWXB.js.map → chunk-KAO3LKB5.js.map} +0 -0
- /package/dist/{chunk-34BP5BC4.js.map → chunk-QYLCINGC.js.map} +0 -0
- /package/dist/{chunk-I52THVF6.js.map → chunk-RA2IPRO2.js.map} +0 -0
- /package/dist/{chunk-G5OZQ376.js.map → chunk-RDWGYKDY.js.map} +0 -0
- /package/dist/{chunk-5O6GKXAN.js.map → chunk-SPFHPHYL.js.map} +0 -0
- /package/dist/{chunk-NJVJ7VO5.js.map → chunk-U2W5SENM.js.map} +0 -0
- /package/dist/{chunk-37QYD33C.js.map → chunk-U7X4V4HE.js.map} +0 -0
- /package/dist/{chunk-DG2U2WY3.js.map → chunk-WLZHCM7O.js.map} +0 -0
- /package/dist/{chunk-OHDEJEYB.js.map → chunk-XDSVV5GZ.js.map} +0 -0
- /package/dist/{source-manager-Y7R6WPOW.js.map → source-manager-BVB2SG73.js.map} +0 -0
- /package/dist/src/agents/developer/api-developer/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/developer/cli-developer/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/developer/web-architecture/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/developer/web-developer/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/meta/agent-summoner/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/meta/skill-summoner/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/pattern/pattern-scout/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/pattern/web-pattern-critique/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/planning/web-pm/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/researcher/api-researcher/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/researcher/web-researcher/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/reviewer/api-reviewer/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/reviewer/cli-reviewer/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/reviewer/web-reviewer/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/tester/cli-tester/{agent.yaml → metadata.yaml} +0 -0
- /package/dist/src/agents/tester/web-tester/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/developer/api-developer/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/developer/cli-developer/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/developer/web-architecture/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/developer/web-developer/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/meta/agent-summoner/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/meta/skill-summoner/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/pattern/pattern-scout/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/pattern/web-pattern-critique/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/planning/web-pm/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/researcher/api-researcher/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/researcher/web-researcher/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/reviewer/api-reviewer/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/reviewer/cli-reviewer/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/reviewer/web-reviewer/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/tester/cli-tester/{agent.yaml → metadata.yaml} +0 -0
- /package/src/agents/tester/web-tester/{agent.yaml → metadata.yaml} +0 -0
|
@@ -0,0 +1,571 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import {
|
|
3
|
+
Wizard
|
|
4
|
+
} from "./chunk-KQOU4POU.js";
|
|
5
|
+
import {
|
|
6
|
+
claudePluginInstall,
|
|
7
|
+
claudePluginMarketplaceAdd,
|
|
8
|
+
claudePluginMarketplaceExists
|
|
9
|
+
} from "./chunk-26MXZUHU.js";
|
|
10
|
+
import {
|
|
11
|
+
DRY_RUN_MESSAGES,
|
|
12
|
+
STATUS_MESSAGES,
|
|
13
|
+
SUCCESS_MESSAGES
|
|
14
|
+
} from "./chunk-WLZHCM7O.js";
|
|
15
|
+
import {
|
|
16
|
+
BaseCommand,
|
|
17
|
+
EXIT_CODES
|
|
18
|
+
} from "./chunk-PGY5XROM.js";
|
|
19
|
+
import {
|
|
20
|
+
detectProjectInstallation,
|
|
21
|
+
getInstallationInfo,
|
|
22
|
+
getMarketplaceLabel,
|
|
23
|
+
hasIndividualPlugins,
|
|
24
|
+
installLocal,
|
|
25
|
+
installPluginConfig,
|
|
26
|
+
loadProjectConfig,
|
|
27
|
+
loadSkillsMatrixFromSource
|
|
28
|
+
} from "./chunk-HMSHB5EQ.js";
|
|
29
|
+
import {
|
|
30
|
+
disableBuffering,
|
|
31
|
+
drainBuffer,
|
|
32
|
+
enableBuffering,
|
|
33
|
+
fileExists,
|
|
34
|
+
getErrorMessage,
|
|
35
|
+
pushBufferMessage,
|
|
36
|
+
readFileSafe,
|
|
37
|
+
settingsFileSchema,
|
|
38
|
+
warn,
|
|
39
|
+
warnUnknownFields
|
|
40
|
+
} from "./chunk-WBHPCBVN.js";
|
|
41
|
+
import {
|
|
42
|
+
ASCII_LOGO,
|
|
43
|
+
CLAUDE_DIR,
|
|
44
|
+
CLI_BIN_NAME,
|
|
45
|
+
CLI_COLORS,
|
|
46
|
+
DEFAULT_BRANDING,
|
|
47
|
+
LOCAL_SKILLS_PATH,
|
|
48
|
+
MAX_CONFIG_FILE_SIZE
|
|
49
|
+
} from "./chunk-AWP5A6IM.js";
|
|
50
|
+
import {
|
|
51
|
+
init_esm_shims
|
|
52
|
+
} from "./chunk-DHET7RCE.js";
|
|
53
|
+
|
|
54
|
+
// src/cli/commands/init.tsx
|
|
55
|
+
init_esm_shims();
|
|
56
|
+
import { useState } from "react";
|
|
57
|
+
import { Flags } from "@oclif/core";
|
|
58
|
+
import { render, Box as Box2, Text as Text2, useApp, useInput } from "ink";
|
|
59
|
+
import os from "os";
|
|
60
|
+
import path2 from "path";
|
|
61
|
+
|
|
62
|
+
// src/cli/lib/permission-checker.tsx
|
|
63
|
+
init_esm_shims();
|
|
64
|
+
import { Text, Box } from "ink";
|
|
65
|
+
import path from "path";
|
|
66
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
67
|
+
async function checkPermissions(projectRoot) {
|
|
68
|
+
const settingsPath = path.join(projectRoot, CLAUDE_DIR, "settings.json");
|
|
69
|
+
const localSettingsPath = path.join(projectRoot, CLAUDE_DIR, "settings.local.json");
|
|
70
|
+
let permissions;
|
|
71
|
+
for (const filePath of [localSettingsPath, settingsPath]) {
|
|
72
|
+
if (await fileExists(filePath)) {
|
|
73
|
+
try {
|
|
74
|
+
const content = await readFileSafe(filePath, MAX_CONFIG_FILE_SIZE);
|
|
75
|
+
const raw = JSON.parse(content);
|
|
76
|
+
if (typeof raw === "object" && raw !== null && !Array.isArray(raw)) {
|
|
77
|
+
const EXPECTED_SETTINGS_KEYS = [
|
|
78
|
+
"permissions",
|
|
79
|
+
"enabledPlugins",
|
|
80
|
+
"env",
|
|
81
|
+
"allowedTools",
|
|
82
|
+
"customInstructions",
|
|
83
|
+
"defaultModel"
|
|
84
|
+
];
|
|
85
|
+
warnUnknownFields(
|
|
86
|
+
raw,
|
|
87
|
+
EXPECTED_SETTINGS_KEYS,
|
|
88
|
+
`settings file '${filePath}'`
|
|
89
|
+
);
|
|
90
|
+
}
|
|
91
|
+
const result = settingsFileSchema.safeParse(raw);
|
|
92
|
+
const parsed = result.success ? result.data : {};
|
|
93
|
+
if (parsed.permissions) {
|
|
94
|
+
permissions = parsed.permissions;
|
|
95
|
+
break;
|
|
96
|
+
}
|
|
97
|
+
} catch {
|
|
98
|
+
warn(`Malformed settings file at '${filePath}' \u2014 skipping`);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
if (!permissions) {
|
|
103
|
+
return /* @__PURE__ */ jsxs(Box, { flexDirection: "column", borderStyle: "round", borderColor: CLI_COLORS.WARNING, padding: 1, children: [
|
|
104
|
+
/* @__PURE__ */ jsx(Text, { bold: true, color: CLI_COLORS.WARNING, children: "Permission Notice" }),
|
|
105
|
+
/* @__PURE__ */ jsx(Text, { children: "No permissions configured in .claude/settings.json" }),
|
|
106
|
+
/* @__PURE__ */ jsx(Text, { children: "Agents will prompt for approval on each tool use." }),
|
|
107
|
+
/* @__PURE__ */ jsx(Text, { children: " " }),
|
|
108
|
+
/* @__PURE__ */ jsx(Text, { children: "For autonomous operation, add to .claude/settings.json:" }),
|
|
109
|
+
/* @__PURE__ */ jsx(Text, { children: " " }),
|
|
110
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: "{" }),
|
|
111
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: ' "permissions": {' }),
|
|
112
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: ' "allow": [' }),
|
|
113
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: ' "Read(*)",' }),
|
|
114
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: ' "Bash(git *)",' }),
|
|
115
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: ' "Bash(bun *)"' }),
|
|
116
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: " ]" }),
|
|
117
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: " }" }),
|
|
118
|
+
/* @__PURE__ */ jsx(Text, { color: "dim", children: "}" })
|
|
119
|
+
] });
|
|
120
|
+
}
|
|
121
|
+
const hasRestrictiveBash = permissions.deny?.some(
|
|
122
|
+
(rule) => rule === "Bash(*)" || rule === "Bash"
|
|
123
|
+
);
|
|
124
|
+
const hasNoAllows = !permissions.allow || permissions.allow.length === 0;
|
|
125
|
+
if (hasRestrictiveBash || hasNoAllows) {
|
|
126
|
+
return /* @__PURE__ */ jsxs(Box, { flexDirection: "column", borderStyle: "round", borderColor: CLI_COLORS.WARNING, padding: 1, children: [
|
|
127
|
+
/* @__PURE__ */ jsx(Text, { bold: true, color: CLI_COLORS.WARNING, children: "Permission Warnings" }),
|
|
128
|
+
hasRestrictiveBash && /* @__PURE__ */ jsx(Text, { children: "\u26A0 Bash is denied in permissions. Some agents require Bash for git, testing, and build commands." }),
|
|
129
|
+
hasNoAllows && /* @__PURE__ */ jsx(Text, { children: "\u26A0 No allow rules configured. Agents will prompt for each tool use." })
|
|
130
|
+
] });
|
|
131
|
+
}
|
|
132
|
+
return null;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// src/cli/commands/init.tsx
|
|
136
|
+
import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
|
|
137
|
+
var DASHBOARD_OPTIONS = [
|
|
138
|
+
{ label: "Edit", command: "edit" },
|
|
139
|
+
{ label: "Compile", command: "compile" },
|
|
140
|
+
{ label: "Doctor", command: "doctor" },
|
|
141
|
+
{ label: "List", command: "list" }
|
|
142
|
+
];
|
|
143
|
+
var Dashboard = ({
|
|
144
|
+
skillCount,
|
|
145
|
+
agentCount,
|
|
146
|
+
source,
|
|
147
|
+
mode,
|
|
148
|
+
onSelect,
|
|
149
|
+
onCancel
|
|
150
|
+
}) => {
|
|
151
|
+
const { exit } = useApp();
|
|
152
|
+
const [focusIndex, setFocusIndex] = useState(0);
|
|
153
|
+
useInput((input, key) => {
|
|
154
|
+
if (key.escape) {
|
|
155
|
+
onCancel();
|
|
156
|
+
exit();
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
if (key.return) {
|
|
160
|
+
onSelect(DASHBOARD_OPTIONS[focusIndex].command);
|
|
161
|
+
exit();
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
if (key.leftArrow) {
|
|
165
|
+
setFocusIndex((i) => i > 0 ? i - 1 : DASHBOARD_OPTIONS.length - 1);
|
|
166
|
+
}
|
|
167
|
+
if (key.rightArrow) {
|
|
168
|
+
setFocusIndex((i) => i < DASHBOARD_OPTIONS.length - 1 ? i + 1 : 0);
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
return /* @__PURE__ */ jsxs2(Box2, { flexDirection: "column", children: [
|
|
172
|
+
/* @__PURE__ */ jsx2(Text2, { bold: true, children: DEFAULT_BRANDING.NAME }),
|
|
173
|
+
/* @__PURE__ */ jsx2(Text2, { children: " " }),
|
|
174
|
+
/* @__PURE__ */ jsxs2(Text2, { children: [
|
|
175
|
+
" Skills: ",
|
|
176
|
+
skillCount,
|
|
177
|
+
" installed"
|
|
178
|
+
] }),
|
|
179
|
+
/* @__PURE__ */ jsxs2(Text2, { children: [
|
|
180
|
+
" Agents: ",
|
|
181
|
+
agentCount,
|
|
182
|
+
" compiled"
|
|
183
|
+
] }),
|
|
184
|
+
/* @__PURE__ */ jsxs2(Text2, { children: [
|
|
185
|
+
" Mode: ",
|
|
186
|
+
mode === "plugin" ? "Plugin" : "Local"
|
|
187
|
+
] }),
|
|
188
|
+
source && /* @__PURE__ */ jsxs2(Text2, { children: [
|
|
189
|
+
" Source: ",
|
|
190
|
+
source
|
|
191
|
+
] }),
|
|
192
|
+
/* @__PURE__ */ jsx2(Text2, { children: " " }),
|
|
193
|
+
/* @__PURE__ */ jsxs2(Box2, { children: [
|
|
194
|
+
/* @__PURE__ */ jsx2(Text2, { children: " " }),
|
|
195
|
+
DASHBOARD_OPTIONS.map((option, index) => /* @__PURE__ */ jsx2(Box2, { marginRight: 1, children: /* @__PURE__ */ jsxs2(
|
|
196
|
+
Text2,
|
|
197
|
+
{
|
|
198
|
+
color: index === focusIndex ? CLI_COLORS.FOCUS : void 0,
|
|
199
|
+
bold: index === focusIndex,
|
|
200
|
+
children: [
|
|
201
|
+
"[",
|
|
202
|
+
option.label,
|
|
203
|
+
"]"
|
|
204
|
+
]
|
|
205
|
+
}
|
|
206
|
+
) }, option.command))
|
|
207
|
+
] }),
|
|
208
|
+
/* @__PURE__ */ jsx2(Text2, { dimColor: true, children: " Use arrow keys to select, Enter to confirm, Esc to exit" })
|
|
209
|
+
] });
|
|
210
|
+
};
|
|
211
|
+
async function getDashboardData(projectDir) {
|
|
212
|
+
const [info, loaded] = await Promise.all([getInstallationInfo(), loadProjectConfig(projectDir)]);
|
|
213
|
+
const skillCount = loaded?.config?.skills?.length ?? 0;
|
|
214
|
+
const agentCount = info?.agentCount ?? 0;
|
|
215
|
+
const mode = info?.mode ?? loaded?.config?.installMode ?? "local";
|
|
216
|
+
const source = loaded?.config?.source;
|
|
217
|
+
return { skillCount, agentCount, mode, source };
|
|
218
|
+
}
|
|
219
|
+
function formatDashboardText(data) {
|
|
220
|
+
const modeLabel = data.mode === "plugin" ? "Plugin" : "Local";
|
|
221
|
+
const lines = [
|
|
222
|
+
DEFAULT_BRANDING.NAME,
|
|
223
|
+
"",
|
|
224
|
+
` Skills: ${data.skillCount} installed`,
|
|
225
|
+
` Agents: ${data.agentCount} compiled`,
|
|
226
|
+
` Mode: ${modeLabel}`
|
|
227
|
+
];
|
|
228
|
+
if (data.source) {
|
|
229
|
+
lines.push(` Source: ${data.source}`);
|
|
230
|
+
}
|
|
231
|
+
lines.push("");
|
|
232
|
+
lines.push(` [Edit] [Compile] [Doctor] [List]`);
|
|
233
|
+
return lines.join("\n");
|
|
234
|
+
}
|
|
235
|
+
async function showDashboard(projectDir, log) {
|
|
236
|
+
const data = await getDashboardData(projectDir);
|
|
237
|
+
if (!process.stdin.isTTY) {
|
|
238
|
+
const output = log ?? console.log;
|
|
239
|
+
output(formatDashboardText(data));
|
|
240
|
+
return null;
|
|
241
|
+
}
|
|
242
|
+
let selectedCommand = null;
|
|
243
|
+
const { waitUntilExit } = render(
|
|
244
|
+
/* @__PURE__ */ jsx2(
|
|
245
|
+
Dashboard,
|
|
246
|
+
{
|
|
247
|
+
skillCount: data.skillCount,
|
|
248
|
+
agentCount: data.agentCount,
|
|
249
|
+
source: data.source,
|
|
250
|
+
mode: data.mode,
|
|
251
|
+
onSelect: (command) => {
|
|
252
|
+
selectedCommand = command;
|
|
253
|
+
},
|
|
254
|
+
onCancel: () => {
|
|
255
|
+
selectedCommand = null;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
)
|
|
259
|
+
);
|
|
260
|
+
await waitUntilExit();
|
|
261
|
+
return selectedCommand;
|
|
262
|
+
}
|
|
263
|
+
var Init = class _Init extends BaseCommand {
|
|
264
|
+
static summary = `Initialize ${DEFAULT_BRANDING.NAME} in this project`;
|
|
265
|
+
static description = "Interactive wizard to set up skills and agents. Supports Plugin Mode (native install) and Local Mode (copy to .claude/).";
|
|
266
|
+
static examples = [
|
|
267
|
+
{
|
|
268
|
+
description: "Start the setup wizard",
|
|
269
|
+
command: "<%= config.bin %> <%= command.id %>"
|
|
270
|
+
},
|
|
271
|
+
{
|
|
272
|
+
description: "Install globally to home directory",
|
|
273
|
+
command: "<%= config.bin %> <%= command.id %> --global"
|
|
274
|
+
},
|
|
275
|
+
{
|
|
276
|
+
description: "Initialize from a custom marketplace",
|
|
277
|
+
command: "<%= config.bin %> <%= command.id %> --source github:org/marketplace"
|
|
278
|
+
},
|
|
279
|
+
{
|
|
280
|
+
description: "Preview without creating files",
|
|
281
|
+
command: "<%= config.bin %> <%= command.id %> --dry-run"
|
|
282
|
+
},
|
|
283
|
+
{
|
|
284
|
+
description: "Force refresh skills from remote",
|
|
285
|
+
command: "<%= config.bin %> <%= command.id %> --refresh"
|
|
286
|
+
}
|
|
287
|
+
];
|
|
288
|
+
static flags = {
|
|
289
|
+
...BaseCommand.baseFlags,
|
|
290
|
+
global: Flags.boolean({
|
|
291
|
+
char: "g",
|
|
292
|
+
description: "Install globally to home directory (~/.claude-src/)",
|
|
293
|
+
default: false
|
|
294
|
+
}),
|
|
295
|
+
refresh: Flags.boolean({
|
|
296
|
+
description: "Force refresh from remote source",
|
|
297
|
+
default: false
|
|
298
|
+
})
|
|
299
|
+
};
|
|
300
|
+
async run() {
|
|
301
|
+
const { flags } = await this.parse(_Init);
|
|
302
|
+
const projectDir = flags.global ? os.homedir() : process.cwd();
|
|
303
|
+
const individualPluginsExist = await hasIndividualPlugins(projectDir);
|
|
304
|
+
const existingInstallation = await detectProjectInstallation(projectDir);
|
|
305
|
+
if (individualPluginsExist || existingInstallation) {
|
|
306
|
+
const selectedCommand = await showDashboard(projectDir, (msg) => this.log(msg));
|
|
307
|
+
if (selectedCommand) {
|
|
308
|
+
await this.config.runCommand(selectedCommand);
|
|
309
|
+
}
|
|
310
|
+
return;
|
|
311
|
+
}
|
|
312
|
+
if (flags.global) {
|
|
313
|
+
this.log("Installing globally to home directory...");
|
|
314
|
+
}
|
|
315
|
+
enableBuffering();
|
|
316
|
+
if (flags["dry-run"]) {
|
|
317
|
+
pushBufferMessage("info", DRY_RUN_MESSAGES.PREVIEW_NO_FILES_CREATED);
|
|
318
|
+
}
|
|
319
|
+
let sourceResult;
|
|
320
|
+
let startupMessages = [];
|
|
321
|
+
try {
|
|
322
|
+
sourceResult = await loadSkillsMatrixFromSource({
|
|
323
|
+
sourceFlag: flags.source,
|
|
324
|
+
projectDir,
|
|
325
|
+
forceRefresh: flags.refresh
|
|
326
|
+
});
|
|
327
|
+
} catch (error) {
|
|
328
|
+
disableBuffering();
|
|
329
|
+
this.error(getErrorMessage(error), {
|
|
330
|
+
exit: EXIT_CODES.ERROR
|
|
331
|
+
});
|
|
332
|
+
}
|
|
333
|
+
startupMessages = drainBuffer();
|
|
334
|
+
disableBuffering();
|
|
335
|
+
let wizardResult = null;
|
|
336
|
+
const marketplaceLabel = getMarketplaceLabel(sourceResult);
|
|
337
|
+
const { waitUntilExit } = render(
|
|
338
|
+
/* @__PURE__ */ jsx2(
|
|
339
|
+
Wizard,
|
|
340
|
+
{
|
|
341
|
+
matrix: sourceResult.matrix,
|
|
342
|
+
version: this.config.version,
|
|
343
|
+
marketplaceLabel,
|
|
344
|
+
logo: ASCII_LOGO,
|
|
345
|
+
projectDir,
|
|
346
|
+
initialInstallMode: sourceResult.marketplace ? "plugin" : "local",
|
|
347
|
+
startupMessages,
|
|
348
|
+
onComplete: (result2) => {
|
|
349
|
+
wizardResult = result2;
|
|
350
|
+
},
|
|
351
|
+
onCancel: () => {
|
|
352
|
+
this.log("Setup cancelled");
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
)
|
|
356
|
+
);
|
|
357
|
+
await waitUntilExit();
|
|
358
|
+
const result = wizardResult;
|
|
359
|
+
if (!result || result.cancelled) {
|
|
360
|
+
this.exit(EXIT_CODES.CANCELLED);
|
|
361
|
+
}
|
|
362
|
+
if (result.selectedSkills.length === 0) {
|
|
363
|
+
this.error("No skills selected", { exit: EXIT_CODES.ERROR });
|
|
364
|
+
}
|
|
365
|
+
await this.handleInstallation(result, sourceResult, flags);
|
|
366
|
+
}
|
|
367
|
+
async handleInstallation(result, sourceResult, flags) {
|
|
368
|
+
const projectDir = flags.global ? os.homedir() : process.cwd();
|
|
369
|
+
const pluginScope = flags.global ? "user" : "project";
|
|
370
|
+
const dryRun = flags["dry-run"];
|
|
371
|
+
this.log("\n");
|
|
372
|
+
this.log(`Selected ${result.selectedSkills.length} skills`);
|
|
373
|
+
this.log(
|
|
374
|
+
`Install mode: ${result.installMode === "plugin" ? "Plugin (native install)" : "Local (copy to .claude/skills/)"}`
|
|
375
|
+
);
|
|
376
|
+
if (dryRun) {
|
|
377
|
+
if (result.installMode === "plugin" && result.selectedStackId) {
|
|
378
|
+
const useMarketplace = !!sourceResult.marketplace;
|
|
379
|
+
if (useMarketplace) {
|
|
380
|
+
this.log(
|
|
381
|
+
`[dry-run] Would install stack "${result.selectedStackId}" from marketplace "${sourceResult.marketplace}"`
|
|
382
|
+
);
|
|
383
|
+
this.log(
|
|
384
|
+
`[dry-run] claude plugin install ${result.selectedStackId}@${sourceResult.marketplace} --scope ${pluginScope}`
|
|
385
|
+
);
|
|
386
|
+
} else {
|
|
387
|
+
this.log(
|
|
388
|
+
`[dry-run] Would compile and install stack "${result.selectedStackId}" as a native plugin`
|
|
389
|
+
);
|
|
390
|
+
this.log(
|
|
391
|
+
`[dry-run] claude plugin install ./compiled-stack/${result.selectedStackId} --scope ${pluginScope}`
|
|
392
|
+
);
|
|
393
|
+
this.log(
|
|
394
|
+
`[dry-run] Stack includes ${result.selectedSkills.length} skills and agents bundled together`
|
|
395
|
+
);
|
|
396
|
+
}
|
|
397
|
+
} else if (result.installMode === "plugin" && sourceResult.marketplace) {
|
|
398
|
+
this.log(
|
|
399
|
+
`[dry-run] Would install ${result.selectedSkills.length} skills as individual plugins from "${sourceResult.marketplace}"`
|
|
400
|
+
);
|
|
401
|
+
for (const skillId of result.selectedSkills) {
|
|
402
|
+
this.log(
|
|
403
|
+
`[dry-run] claude plugin install ${skillId}@${sourceResult.marketplace} --scope ${pluginScope}`
|
|
404
|
+
);
|
|
405
|
+
}
|
|
406
|
+
const localAgentsDir = path2.join(projectDir, CLAUDE_DIR, "agents");
|
|
407
|
+
this.log(`[dry-run] Would compile agents to ${localAgentsDir}`);
|
|
408
|
+
this.log(`[dry-run] Would save config to .claude-src/config.yaml`);
|
|
409
|
+
} else {
|
|
410
|
+
if (result.installMode === "plugin") {
|
|
411
|
+
this.log(
|
|
412
|
+
`[dry-run] Plugin Mode requires a marketplace for individual skills \u2014 would fall back to Local Mode`
|
|
413
|
+
);
|
|
414
|
+
}
|
|
415
|
+
const localSkillsDir = path2.join(projectDir, LOCAL_SKILLS_PATH);
|
|
416
|
+
const localAgentsDir = path2.join(projectDir, CLAUDE_DIR, "agents");
|
|
417
|
+
this.log(
|
|
418
|
+
`[dry-run] Would copy ${result.selectedSkills.length} skills to ${localSkillsDir}`
|
|
419
|
+
);
|
|
420
|
+
this.log(`[dry-run] Would compile agents to ${localAgentsDir}`);
|
|
421
|
+
this.log(`[dry-run] Would save config to .claude-src/config.yaml`);
|
|
422
|
+
}
|
|
423
|
+
this.log(`
|
|
424
|
+
${DRY_RUN_MESSAGES.COMPLETE_NO_FILES_CREATED}`);
|
|
425
|
+
return;
|
|
426
|
+
}
|
|
427
|
+
if (result.installMode === "plugin") {
|
|
428
|
+
if (sourceResult.marketplace) {
|
|
429
|
+
await this.installIndividualPlugins(result, sourceResult, flags, projectDir, pluginScope);
|
|
430
|
+
} else {
|
|
431
|
+
this.warn("Plugin Mode requires a marketplace for individual skill installation.");
|
|
432
|
+
this.log(`Falling back to Local Mode (copying to .claude/skills/)...`);
|
|
433
|
+
this.log("To use Plugin Mode, either select a stack or configure a marketplace source.\n");
|
|
434
|
+
await this.installLocalMode(result, sourceResult, flags, projectDir);
|
|
435
|
+
}
|
|
436
|
+
return;
|
|
437
|
+
}
|
|
438
|
+
await this.installLocalMode(result, sourceResult, flags, projectDir);
|
|
439
|
+
}
|
|
440
|
+
async installIndividualPlugins(result, sourceResult, flags, projectDir, pluginScope) {
|
|
441
|
+
if (sourceResult.marketplace) {
|
|
442
|
+
const marketplaceExists = await claudePluginMarketplaceExists(sourceResult.marketplace);
|
|
443
|
+
if (!marketplaceExists) {
|
|
444
|
+
this.log(`Registering marketplace "${sourceResult.marketplace}"...`);
|
|
445
|
+
try {
|
|
446
|
+
const marketplaceSource = sourceResult.sourceConfig.source.replace(/^github:/, "");
|
|
447
|
+
await claudePluginMarketplaceAdd(marketplaceSource);
|
|
448
|
+
this.log(`Registered marketplace: ${sourceResult.marketplace}`);
|
|
449
|
+
} catch (error) {
|
|
450
|
+
this.error(getErrorMessage(error), {
|
|
451
|
+
exit: EXIT_CODES.ERROR
|
|
452
|
+
});
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
this.log("Installing skill plugins...");
|
|
457
|
+
for (const skillId of result.selectedSkills) {
|
|
458
|
+
const pluginRef = `${skillId}@${sourceResult.marketplace}`;
|
|
459
|
+
try {
|
|
460
|
+
await claudePluginInstall(pluginRef, pluginScope, projectDir);
|
|
461
|
+
this.log(` Installed ${pluginRef}`);
|
|
462
|
+
} catch (error) {
|
|
463
|
+
this.error(`Failed to install plugin ${pluginRef}: ${getErrorMessage(error)}`, {
|
|
464
|
+
exit: EXIT_CODES.ERROR
|
|
465
|
+
});
|
|
466
|
+
}
|
|
467
|
+
}
|
|
468
|
+
this.log(`Installed ${result.selectedSkills.length} skill plugins
|
|
469
|
+
`);
|
|
470
|
+
this.log("Generating configuration...");
|
|
471
|
+
try {
|
|
472
|
+
const configResult = await installPluginConfig({
|
|
473
|
+
wizardResult: result,
|
|
474
|
+
sourceResult,
|
|
475
|
+
projectDir,
|
|
476
|
+
sourceFlag: flags.source
|
|
477
|
+
});
|
|
478
|
+
if (configResult.wasMerged) {
|
|
479
|
+
this.log(`Merged with existing config at ${configResult.mergedConfigPath}`);
|
|
480
|
+
}
|
|
481
|
+
this.log(`Configuration saved (${configResult.config.agents.length} agents)
|
|
482
|
+
`);
|
|
483
|
+
this.log(STATUS_MESSAGES.COMPILING_AGENTS);
|
|
484
|
+
this.log(`Compiled ${configResult.compiledAgents.length} agents to .claude/agents/
|
|
485
|
+
`);
|
|
486
|
+
this.log(`${SUCCESS_MESSAGES.INIT_SUCCESS}
|
|
487
|
+
`);
|
|
488
|
+
this.log("Agents compiled to:");
|
|
489
|
+
this.log(` ${configResult.agentsDir}`);
|
|
490
|
+
for (const agentName of configResult.compiledAgents) {
|
|
491
|
+
this.log(` ${agentName}.md`);
|
|
492
|
+
}
|
|
493
|
+
this.log("");
|
|
494
|
+
this.log("Configuration:");
|
|
495
|
+
this.log(` ${configResult.configPath}`);
|
|
496
|
+
this.log("");
|
|
497
|
+
this.log("To customize agent-skill assignments:");
|
|
498
|
+
this.log(` 1. Edit .claude-src/config.yaml`);
|
|
499
|
+
this.log(` 2. Run '${CLI_BIN_NAME} compile' to regenerate agents`);
|
|
500
|
+
this.log("");
|
|
501
|
+
const permissionWarning = await checkPermissions(projectDir);
|
|
502
|
+
if (permissionWarning) {
|
|
503
|
+
const { waitUntilExit } = render(permissionWarning);
|
|
504
|
+
await waitUntilExit();
|
|
505
|
+
}
|
|
506
|
+
} catch (error) {
|
|
507
|
+
this.handleError(error);
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
async installLocalMode(result, sourceResult, flags, projectDir) {
|
|
511
|
+
const matrix = sourceResult.matrix;
|
|
512
|
+
this.log("Copying skills to local directory...");
|
|
513
|
+
try {
|
|
514
|
+
const installResult = await installLocal({
|
|
515
|
+
wizardResult: result,
|
|
516
|
+
sourceResult,
|
|
517
|
+
projectDir,
|
|
518
|
+
sourceFlag: flags.source
|
|
519
|
+
});
|
|
520
|
+
this.log(`Copied ${installResult.copiedSkills.length} skills to .claude/skills/
|
|
521
|
+
`);
|
|
522
|
+
this.log("Generating configuration...");
|
|
523
|
+
if (installResult.wasMerged) {
|
|
524
|
+
this.log(`Merged with existing config at ${installResult.mergedConfigPath}`);
|
|
525
|
+
}
|
|
526
|
+
this.log(`Configuration saved (${installResult.config.agents.length} agents)
|
|
527
|
+
`);
|
|
528
|
+
this.log(STATUS_MESSAGES.COMPILING_AGENTS);
|
|
529
|
+
this.log(`Compiled ${installResult.compiledAgents.length} agents to .claude/agents/
|
|
530
|
+
`);
|
|
531
|
+
this.log(`${SUCCESS_MESSAGES.INIT_SUCCESS}
|
|
532
|
+
`);
|
|
533
|
+
this.log("Skills copied to:");
|
|
534
|
+
this.log(` ${installResult.skillsDir}`);
|
|
535
|
+
for (const copiedSkill of installResult.copiedSkills) {
|
|
536
|
+
const skill = matrix.skills[copiedSkill.skillId];
|
|
537
|
+
const displayName = skill?.displayName || copiedSkill.skillId;
|
|
538
|
+
this.log(` ${displayName}/`);
|
|
539
|
+
}
|
|
540
|
+
this.log("");
|
|
541
|
+
this.log("Agents compiled to:");
|
|
542
|
+
this.log(` ${installResult.agentsDir}`);
|
|
543
|
+
for (const agentName of installResult.compiledAgents) {
|
|
544
|
+
this.log(` ${agentName}.md`);
|
|
545
|
+
}
|
|
546
|
+
this.log("");
|
|
547
|
+
this.log("Configuration:");
|
|
548
|
+
this.log(` ${installResult.configPath}`);
|
|
549
|
+
this.log("");
|
|
550
|
+
this.log("To customize agent-skill assignments:");
|
|
551
|
+
this.log(` 1. Edit .claude-src/config.yaml`);
|
|
552
|
+
this.log(` 2. Run '${CLI_BIN_NAME} compile' to regenerate agents`);
|
|
553
|
+
this.log("");
|
|
554
|
+
const permissionWarning = await checkPermissions(projectDir);
|
|
555
|
+
if (permissionWarning) {
|
|
556
|
+
const { waitUntilExit } = render(permissionWarning);
|
|
557
|
+
await waitUntilExit();
|
|
558
|
+
}
|
|
559
|
+
} catch (error) {
|
|
560
|
+
this.handleError(error);
|
|
561
|
+
}
|
|
562
|
+
}
|
|
563
|
+
};
|
|
564
|
+
|
|
565
|
+
export {
|
|
566
|
+
getDashboardData,
|
|
567
|
+
formatDashboardText,
|
|
568
|
+
showDashboard,
|
|
569
|
+
Init
|
|
570
|
+
};
|
|
571
|
+
//# sourceMappingURL=chunk-4QWDB2MD.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/cli/commands/init.tsx","../src/cli/lib/permission-checker.tsx"],"sourcesContent":["import React, { useState } from \"react\";\n\nimport { Flags } from \"@oclif/core\";\nimport { render, Box, Text, useApp, useInput } from \"ink\";\nimport os from \"os\";\nimport path from \"path\";\n\nimport { BaseCommand } from \"../base-command.js\";\nimport { Wizard, type WizardResultV2 } from \"../components/wizard/wizard.js\";\nimport {\n loadSkillsMatrixFromSource,\n getMarketplaceLabel,\n type SourceLoadResult,\n} from \"../lib/loading/index.js\";\nimport {\n installLocal,\n installPluginConfig,\n detectProjectInstallation,\n} from \"../lib/installation/index.js\";\nimport { checkPermissions } from \"../lib/permission-checker.js\";\nimport { getInstallationInfo } from \"../lib/plugins/plugin-info.js\";\nimport { hasIndividualPlugins } from \"../lib/plugins/index.js\";\nimport {\n claudePluginInstall,\n claudePluginMarketplaceExists,\n claudePluginMarketplaceAdd,\n} from \"../utils/exec.js\";\nimport {\n ASCII_LOGO,\n CLAUDE_DIR,\n CLI_BIN_NAME,\n CLI_COLORS,\n DEFAULT_BRANDING,\n LOCAL_SKILLS_PATH,\n} from \"../consts.js\";\nimport { getErrorMessage } from \"../utils/errors.js\";\nimport { EXIT_CODES } from \"../lib/exit-codes.js\";\nimport { loadProjectConfig } from \"../lib/configuration/project-config.js\";\nimport {\n enableBuffering,\n drainBuffer,\n disableBuffering,\n pushBufferMessage,\n type StartupMessage,\n} from \"../utils/logger.js\";\nimport { SUCCESS_MESSAGES, STATUS_MESSAGES, DRY_RUN_MESSAGES } from \"../utils/messages.js\";\n\ntype DashboardOption = {\n label: string;\n command: string;\n};\n\nconst DASHBOARD_OPTIONS: DashboardOption[] = [\n { label: \"Edit\", command: \"edit\" },\n { label: \"Compile\", command: \"compile\" },\n { label: \"Doctor\", command: \"doctor\" },\n { label: \"List\", command: \"list\" },\n];\n\ntype DashboardProps = {\n skillCount: number;\n agentCount: number;\n source?: string;\n mode: string;\n onSelect: (command: string) => void;\n onCancel: () => void;\n};\n\nconst Dashboard: React.FC<DashboardProps> = ({\n skillCount,\n agentCount,\n source,\n mode,\n onSelect,\n onCancel,\n}) => {\n const { exit } = useApp();\n const [focusIndex, setFocusIndex] = useState(0);\n\n useInput((input, key) => {\n if (key.escape) {\n onCancel();\n exit();\n return;\n }\n if (key.return) {\n onSelect(DASHBOARD_OPTIONS[focusIndex].command);\n exit();\n return;\n }\n if (key.leftArrow) {\n setFocusIndex((i) => (i > 0 ? i - 1 : DASHBOARD_OPTIONS.length - 1));\n }\n if (key.rightArrow) {\n setFocusIndex((i) => (i < DASHBOARD_OPTIONS.length - 1 ? i + 1 : 0));\n }\n });\n\n return (\n <Box flexDirection=\"column\">\n <Text bold>{DEFAULT_BRANDING.NAME}</Text>\n <Text> </Text>\n <Text> Skills: {skillCount} installed</Text>\n <Text> Agents: {agentCount} compiled</Text>\n <Text> Mode: {mode === \"plugin\" ? \"Plugin\" : \"Local\"}</Text>\n {source && <Text> Source: {source}</Text>}\n <Text> </Text>\n <Box>\n <Text> </Text>\n {DASHBOARD_OPTIONS.map((option, index) => (\n <Box key={option.command} marginRight={1}>\n <Text\n color={index === focusIndex ? CLI_COLORS.FOCUS : undefined}\n bold={index === focusIndex}\n >\n [{option.label}]\n </Text>\n </Box>\n ))}\n </Box>\n <Text dimColor> Use arrow keys to select, Enter to confirm, Esc to exit</Text>\n </Box>\n );\n};\n\nexport type DashboardData = {\n skillCount: number;\n agentCount: number;\n mode: string;\n source?: string;\n};\n\n/** Gathers dashboard data from the installation and project config. */\nexport async function getDashboardData(projectDir: string): Promise<DashboardData> {\n const [info, loaded] = await Promise.all([getInstallationInfo(), loadProjectConfig(projectDir)]);\n\n // Skill count from config (canonical source of truth for installed skills)\n const skillCount = loaded?.config?.skills?.length ?? 0;\n // Agent count from filesystem (compiled .md files in agents dir)\n const agentCount = info?.agentCount ?? 0;\n const mode = info?.mode ?? loaded?.config?.installMode ?? \"local\";\n const source = loaded?.config?.source;\n\n return { skillCount, agentCount, mode, source };\n}\n\n/** Formats the dashboard summary as plain text lines (for non-interactive/test output). */\nexport function formatDashboardText(data: DashboardData): string {\n const modeLabel = data.mode === \"plugin\" ? \"Plugin\" : \"Local\";\n const lines = [\n DEFAULT_BRANDING.NAME,\n \"\",\n ` Skills: ${data.skillCount} installed`,\n ` Agents: ${data.agentCount} compiled`,\n ` Mode: ${modeLabel}`,\n ];\n if (data.source) {\n lines.push(` Source: ${data.source}`);\n }\n lines.push(\"\");\n lines.push(` [Edit] [Compile] [Doctor] [List]`);\n return lines.join(\"\\n\");\n}\n\n/**\n * Shows the project dashboard and returns the selected command (or null if cancelled).\n * In non-interactive environments (no TTY), prints the summary text and returns null.\n */\nexport async function showDashboard(\n projectDir: string,\n log?: (message: string) => void,\n): Promise<string | null> {\n const data = await getDashboardData(projectDir);\n\n // Non-interactive: print text summary and exit (CI, piped, tests)\n if (!process.stdin.isTTY) {\n const output = log ?? console.log;\n output(formatDashboardText(data));\n return null;\n }\n\n let selectedCommand: string | null = null;\n\n const { waitUntilExit } = render(\n <Dashboard\n skillCount={data.skillCount}\n agentCount={data.agentCount}\n source={data.source}\n mode={data.mode}\n onSelect={(command) => {\n selectedCommand = command;\n }}\n onCancel={() => {\n selectedCommand = null;\n }}\n />,\n );\n\n await waitUntilExit();\n\n return selectedCommand;\n}\n\nexport default class Init extends BaseCommand {\n static summary = `Initialize ${DEFAULT_BRANDING.NAME} in this project`;\n static description =\n \"Interactive wizard to set up skills and agents. Supports Plugin Mode (native install) and Local Mode (copy to .claude/).\";\n\n static examples = [\n {\n description: \"Start the setup wizard\",\n command: \"<%= config.bin %> <%= command.id %>\",\n },\n {\n description: \"Install globally to home directory\",\n command: \"<%= config.bin %> <%= command.id %> --global\",\n },\n {\n description: \"Initialize from a custom marketplace\",\n command: \"<%= config.bin %> <%= command.id %> --source github:org/marketplace\",\n },\n {\n description: \"Preview without creating files\",\n command: \"<%= config.bin %> <%= command.id %> --dry-run\",\n },\n {\n description: \"Force refresh skills from remote\",\n command: \"<%= config.bin %> <%= command.id %> --refresh\",\n },\n ];\n\n static flags = {\n ...BaseCommand.baseFlags,\n global: Flags.boolean({\n char: \"g\",\n description: \"Install globally to home directory (~/.claude-src/)\",\n default: false,\n }),\n refresh: Flags.boolean({\n description: \"Force refresh from remote source\",\n default: false,\n }),\n };\n\n async run(): Promise<void> {\n const { flags } = await this.parse(Init);\n const projectDir = flags.global ? os.homedir() : process.cwd();\n\n // For \"already initialized\" check, only look at the target directory (no global fallback)\n const individualPluginsExist = await hasIndividualPlugins(projectDir);\n const existingInstallation = await detectProjectInstallation(projectDir);\n\n if (individualPluginsExist || existingInstallation) {\n const selectedCommand = await showDashboard(projectDir, (msg) => this.log(msg));\n if (selectedCommand) {\n await this.config.runCommand(selectedCommand);\n }\n return;\n }\n\n if (flags.global) {\n this.log(\"Installing globally to home directory...\");\n }\n\n enableBuffering();\n\n if (flags[\"dry-run\"]) {\n pushBufferMessage(\"info\", DRY_RUN_MESSAGES.PREVIEW_NO_FILES_CREATED);\n }\n\n let sourceResult: SourceLoadResult;\n let startupMessages: StartupMessage[] = [];\n try {\n sourceResult = await loadSkillsMatrixFromSource({\n sourceFlag: flags.source,\n projectDir,\n forceRefresh: flags.refresh,\n });\n } catch (error) {\n disableBuffering();\n this.error(getErrorMessage(error), {\n exit: EXIT_CODES.ERROR,\n });\n }\n\n startupMessages = drainBuffer();\n disableBuffering();\n\n let wizardResult: WizardResultV2 | null = null;\n\n const marketplaceLabel = getMarketplaceLabel(sourceResult);\n const { waitUntilExit } = render(\n <Wizard\n matrix={sourceResult.matrix}\n version={this.config.version}\n marketplaceLabel={marketplaceLabel}\n logo={ASCII_LOGO}\n projectDir={projectDir}\n initialInstallMode={sourceResult.marketplace ? \"plugin\" : \"local\"}\n startupMessages={startupMessages}\n onComplete={(result) => {\n // Boundary cast: Ink render callback returns unknown result type\n wizardResult = result as WizardResultV2;\n }}\n onCancel={() => {\n this.log(\"Setup cancelled\");\n }}\n />,\n );\n\n await waitUntilExit();\n\n // Boundary cast: re-narrow after Ink waitUntilExit()\n const result = wizardResult as WizardResultV2 | null;\n if (!result || result.cancelled) {\n this.exit(EXIT_CODES.CANCELLED);\n }\n\n if (result.selectedSkills.length === 0) {\n this.error(\"No skills selected\", { exit: EXIT_CODES.ERROR });\n }\n\n await this.handleInstallation(result, sourceResult, flags);\n }\n\n private async handleInstallation(\n result: WizardResultV2,\n sourceResult: SourceLoadResult,\n flags: { \"dry-run\": boolean; source?: string; refresh: boolean; global: boolean },\n ): Promise<void> {\n const projectDir = flags.global ? os.homedir() : process.cwd();\n const pluginScope = flags.global ? \"user\" : \"project\";\n const dryRun = flags[\"dry-run\"];\n\n this.log(\"\\n\");\n this.log(`Selected ${result.selectedSkills.length} skills`);\n this.log(\n `Install mode: ${result.installMode === \"plugin\" ? \"Plugin (native install)\" : \"Local (copy to .claude/skills/)\"}`,\n );\n\n if (dryRun) {\n if (result.installMode === \"plugin\" && result.selectedStackId) {\n const useMarketplace = !!sourceResult.marketplace;\n if (useMarketplace) {\n this.log(\n `[dry-run] Would install stack \"${result.selectedStackId}\" from marketplace \"${sourceResult.marketplace}\"`,\n );\n this.log(\n `[dry-run] claude plugin install ${result.selectedStackId}@${sourceResult.marketplace} --scope ${pluginScope}`,\n );\n } else {\n this.log(\n `[dry-run] Would compile and install stack \"${result.selectedStackId}\" as a native plugin`,\n );\n this.log(\n `[dry-run] claude plugin install ./compiled-stack/${result.selectedStackId} --scope ${pluginScope}`,\n );\n this.log(\n `[dry-run] Stack includes ${result.selectedSkills.length} skills and agents bundled together`,\n );\n }\n } else if (result.installMode === \"plugin\" && sourceResult.marketplace) {\n this.log(\n `[dry-run] Would install ${result.selectedSkills.length} skills as individual plugins from \"${sourceResult.marketplace}\"`,\n );\n for (const skillId of result.selectedSkills) {\n this.log(\n `[dry-run] claude plugin install ${skillId}@${sourceResult.marketplace} --scope ${pluginScope}`,\n );\n }\n const localAgentsDir = path.join(projectDir, CLAUDE_DIR, \"agents\");\n this.log(`[dry-run] Would compile agents to ${localAgentsDir}`);\n this.log(`[dry-run] Would save config to .claude-src/config.yaml`);\n } else {\n if (result.installMode === \"plugin\") {\n this.log(\n `[dry-run] Plugin Mode requires a marketplace for individual skills — would fall back to Local Mode`,\n );\n }\n const localSkillsDir = path.join(projectDir, LOCAL_SKILLS_PATH);\n const localAgentsDir = path.join(projectDir, CLAUDE_DIR, \"agents\");\n this.log(\n `[dry-run] Would copy ${result.selectedSkills.length} skills to ${localSkillsDir}`,\n );\n this.log(`[dry-run] Would compile agents to ${localAgentsDir}`);\n this.log(`[dry-run] Would save config to .claude-src/config.yaml`);\n }\n this.log(`\\n${DRY_RUN_MESSAGES.COMPLETE_NO_FILES_CREATED}`);\n return;\n }\n\n if (result.installMode === \"plugin\") {\n if (sourceResult.marketplace) {\n await this.installIndividualPlugins(result, sourceResult, flags, projectDir, pluginScope);\n } else {\n this.warn(\"Plugin Mode requires a marketplace for individual skill installation.\");\n this.log(`Falling back to Local Mode (copying to .claude/skills/)...`);\n this.log(\"To use Plugin Mode, either select a stack or configure a marketplace source.\\n\");\n await this.installLocalMode(result, sourceResult, flags, projectDir);\n }\n return;\n }\n\n await this.installLocalMode(result, sourceResult, flags, projectDir);\n }\n\n private async installIndividualPlugins(\n result: WizardResultV2,\n sourceResult: SourceLoadResult,\n flags: { source?: string },\n projectDir: string,\n pluginScope: \"project\" | \"user\",\n ): Promise<void> {\n if (sourceResult.marketplace) {\n const marketplaceExists = await claudePluginMarketplaceExists(sourceResult.marketplace);\n\n if (!marketplaceExists) {\n this.log(`Registering marketplace \"${sourceResult.marketplace}\"...`);\n try {\n const marketplaceSource = sourceResult.sourceConfig.source.replace(/^github:/, \"\");\n await claudePluginMarketplaceAdd(marketplaceSource);\n this.log(`Registered marketplace: ${sourceResult.marketplace}`);\n } catch (error) {\n this.error(getErrorMessage(error), {\n exit: EXIT_CODES.ERROR,\n });\n }\n }\n }\n\n this.log(\"Installing skill plugins...\");\n for (const skillId of result.selectedSkills) {\n const pluginRef = `${skillId}@${sourceResult.marketplace}`;\n try {\n await claudePluginInstall(pluginRef, pluginScope, projectDir);\n this.log(` Installed ${pluginRef}`);\n } catch (error) {\n this.error(`Failed to install plugin ${pluginRef}: ${getErrorMessage(error)}`, {\n exit: EXIT_CODES.ERROR,\n });\n }\n }\n\n this.log(`Installed ${result.selectedSkills.length} skill plugins\\n`);\n\n this.log(\"Generating configuration...\");\n try {\n const configResult = await installPluginConfig({\n wizardResult: result,\n sourceResult,\n projectDir,\n sourceFlag: flags.source,\n });\n\n if (configResult.wasMerged) {\n this.log(`Merged with existing config at ${configResult.mergedConfigPath}`);\n }\n\n this.log(`Configuration saved (${configResult.config.agents.length} agents)\\n`);\n this.log(STATUS_MESSAGES.COMPILING_AGENTS);\n this.log(`Compiled ${configResult.compiledAgents.length} agents to .claude/agents/\\n`);\n\n this.log(`${SUCCESS_MESSAGES.INIT_SUCCESS}\\n`);\n this.log(\"Agents compiled to:\");\n this.log(` ${configResult.agentsDir}`);\n for (const agentName of configResult.compiledAgents) {\n this.log(` ${agentName}.md`);\n }\n this.log(\"\");\n this.log(\"Configuration:\");\n this.log(` ${configResult.configPath}`);\n this.log(\"\");\n this.log(\"To customize agent-skill assignments:\");\n this.log(` 1. Edit .claude-src/config.yaml`);\n this.log(` 2. Run '${CLI_BIN_NAME} compile' to regenerate agents`);\n this.log(\"\");\n\n const permissionWarning = await checkPermissions(projectDir);\n if (permissionWarning) {\n const { waitUntilExit } = render(permissionWarning);\n await waitUntilExit();\n }\n } catch (error) {\n this.handleError(error);\n }\n }\n\n private async installLocalMode(\n result: WizardResultV2,\n sourceResult: SourceLoadResult,\n flags: { source?: string },\n projectDir: string,\n ): Promise<void> {\n const matrix = sourceResult.matrix;\n\n this.log(\"Copying skills to local directory...\");\n try {\n const installResult = await installLocal({\n wizardResult: result,\n sourceResult,\n projectDir,\n sourceFlag: flags.source,\n });\n\n this.log(`Copied ${installResult.copiedSkills.length} skills to .claude/skills/\\n`);\n this.log(\"Generating configuration...\");\n\n if (installResult.wasMerged) {\n this.log(`Merged with existing config at ${installResult.mergedConfigPath}`);\n }\n\n this.log(`Configuration saved (${installResult.config.agents.length} agents)\\n`);\n this.log(STATUS_MESSAGES.COMPILING_AGENTS);\n this.log(`Compiled ${installResult.compiledAgents.length} agents to .claude/agents/\\n`);\n\n this.log(`${SUCCESS_MESSAGES.INIT_SUCCESS}\\n`);\n this.log(\"Skills copied to:\");\n this.log(` ${installResult.skillsDir}`);\n for (const copiedSkill of installResult.copiedSkills) {\n const skill = matrix.skills[copiedSkill.skillId];\n const displayName = skill?.displayName || copiedSkill.skillId;\n this.log(` ${displayName}/`);\n }\n this.log(\"\");\n this.log(\"Agents compiled to:\");\n this.log(` ${installResult.agentsDir}`);\n for (const agentName of installResult.compiledAgents) {\n this.log(` ${agentName}.md`);\n }\n this.log(\"\");\n this.log(\"Configuration:\");\n this.log(` ${installResult.configPath}`);\n this.log(\"\");\n this.log(\"To customize agent-skill assignments:\");\n this.log(` 1. Edit .claude-src/config.yaml`);\n this.log(` 2. Run '${CLI_BIN_NAME} compile' to regenerate agents`);\n this.log(\"\");\n\n const permissionWarning = await checkPermissions(projectDir);\n if (permissionWarning) {\n const { waitUntilExit } = render(permissionWarning);\n await waitUntilExit();\n }\n } catch (error) {\n this.handleError(error);\n }\n }\n}\n","import React from \"react\";\n\nimport { Text, Box } from \"ink\";\nimport path from \"path\";\n\nimport { CLAUDE_DIR, CLI_COLORS, MAX_CONFIG_FILE_SIZE } from \"../consts\";\nimport { fileExists, readFileSafe } from \"../utils/fs\";\nimport { warn } from \"../utils/logger\";\nimport { settingsFileSchema, warnUnknownFields } from \"./schemas\";\n\ntype PermissionConfig = {\n allow?: string[];\n deny?: string[];\n};\n\ntype SettingsFile = {\n permissions?: PermissionConfig;\n};\n\nexport async function checkPermissions(projectRoot: string): Promise<React.ReactElement | null> {\n const settingsPath = path.join(projectRoot, CLAUDE_DIR, \"settings.json\");\n const localSettingsPath = path.join(projectRoot, CLAUDE_DIR, \"settings.local.json\");\n\n let permissions: PermissionConfig | undefined;\n\n for (const filePath of [localSettingsPath, settingsPath]) {\n if (await fileExists(filePath)) {\n try {\n const content = await readFileSafe(filePath, MAX_CONFIG_FILE_SIZE);\n const raw = JSON.parse(content);\n if (typeof raw === \"object\" && raw !== null && !Array.isArray(raw)) {\n // Known Claude CLI settings.json fields (permissions is ours; the rest are managed by Claude CLI)\n const EXPECTED_SETTINGS_KEYS = [\n \"permissions\",\n \"enabledPlugins\",\n \"env\",\n \"allowedTools\",\n \"customInstructions\",\n \"defaultModel\",\n ] as const;\n warnUnknownFields(\n raw as Record<string, unknown>,\n EXPECTED_SETTINGS_KEYS,\n `settings file '${filePath}'`,\n );\n }\n const result = settingsFileSchema.safeParse(raw);\n const parsed: SettingsFile = result.success ? (result.data as SettingsFile) : {};\n if (parsed.permissions) {\n permissions = parsed.permissions;\n break;\n }\n } catch {\n warn(`Malformed settings file at '${filePath}' — skipping`);\n }\n }\n }\n\n if (!permissions) {\n return (\n <Box flexDirection=\"column\" borderStyle=\"round\" borderColor={CLI_COLORS.WARNING} padding={1}>\n <Text bold color={CLI_COLORS.WARNING}>\n Permission Notice\n </Text>\n <Text>No permissions configured in .claude/settings.json</Text>\n <Text>Agents will prompt for approval on each tool use.</Text>\n <Text> </Text>\n <Text>For autonomous operation, add to .claude/settings.json:</Text>\n <Text> </Text>\n <Text color=\"dim\">{\"{\"}</Text>\n <Text color=\"dim\">{' \"permissions\": {'}</Text>\n <Text color=\"dim\">{' \"allow\": ['}</Text>\n <Text color=\"dim\">{' \"Read(*)\",'}</Text>\n <Text color=\"dim\">{' \"Bash(git *)\",'}</Text>\n <Text color=\"dim\">{' \"Bash(bun *)\"'}</Text>\n <Text color=\"dim\">{\" ]\"}</Text>\n <Text color=\"dim\">{\" }\"}</Text>\n <Text color=\"dim\">{\"}\"}</Text>\n </Box>\n );\n }\n\n const hasRestrictiveBash = permissions.deny?.some(\n (rule) => rule === \"Bash(*)\" || rule === \"Bash\",\n );\n const hasNoAllows = !permissions.allow || permissions.allow.length === 0;\n\n if (hasRestrictiveBash || hasNoAllows) {\n return (\n <Box flexDirection=\"column\" borderStyle=\"round\" borderColor={CLI_COLORS.WARNING} padding={1}>\n <Text bold color={CLI_COLORS.WARNING}>\n Permission Warnings\n </Text>\n {hasRestrictiveBash && (\n <Text>\n ⚠ Bash is denied in permissions. Some agents require Bash for git, testing, and build\n commands.\n </Text>\n )}\n {hasNoAllows && (\n <Text>⚠ No allow rules configured. Agents will prompt for each tool use.</Text>\n )}\n </Box>\n );\n }\n\n return null;\n}\n"],"mappings":"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","names":["Box","Text","path","jsx","jsxs","Box","Text","result","path"]}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import {
|
|
3
3
|
CLI_COLORS,
|
|
4
4
|
DEFAULT_BRANDING
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-AWP5A6IM.js";
|
|
6
6
|
import {
|
|
7
7
|
init_esm_shims
|
|
8
8
|
} from "./chunk-DHET7RCE.js";
|
|
@@ -108,4 +108,4 @@ var StepRefine = ({
|
|
|
108
108
|
export {
|
|
109
109
|
StepRefine
|
|
110
110
|
};
|
|
111
|
-
//# sourceMappingURL=chunk-
|
|
111
|
+
//# sourceMappingURL=chunk-4R52TQ3K.js.map
|