@ch4p/cli 0.1.3 → 0.1.4

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.
Files changed (44) hide show
  1. package/dist/agent-6WIHK7NM.js +767 -0
  2. package/dist/agent-ANIZYPPF.js +767 -0
  3. package/dist/agent-HSAJ5EBN.js +761 -0
  4. package/dist/audit-HLOQBMBT.js +12 -0
  5. package/dist/audit-UIGPH3FK.js +12 -0
  6. package/dist/canvas-3VTC4XPV.js +313 -0
  7. package/dist/canvas-4FMNW6FZ.js +313 -0
  8. package/dist/canvas-XQHVCY27.js +313 -0
  9. package/dist/chunk-3XAW4XHG.js +185 -0
  10. package/dist/chunk-4IRZQCRN.js +1832 -0
  11. package/dist/chunk-AORLXQHZ.js +304 -0
  12. package/dist/chunk-BMEBRUYL.js +6995 -0
  13. package/dist/chunk-IN2I6XRM.js +185 -0
  14. package/dist/chunk-TB4IZ7F7.js +301 -0
  15. package/dist/chunk-U7S375OS.js +1841 -0
  16. package/dist/dist-37TB6EWP.js +25 -0
  17. package/dist/dist-CIJPZC2B.js +25 -0
  18. package/dist/doctor-5M3ZB435.js +274 -0
  19. package/dist/doctor-IQ3MWQSN.js +274 -0
  20. package/dist/gateway-DV5OL45G.js +2164 -0
  21. package/dist/gateway-LUCG72YX.js +2129 -0
  22. package/dist/gateway-O3QNSZKF.js +2123 -0
  23. package/dist/gateway-OJW7RY3H.js +2094 -0
  24. package/dist/gateway-PBLJEK5I.js +2165 -0
  25. package/dist/gateway-PHPRQTZP.js +2165 -0
  26. package/dist/gateway-YKKJ4DZE.js +2115 -0
  27. package/dist/gateway-Z65DCM2Q.js +2097 -0
  28. package/dist/gateway-ZSXTAYPF.js +2157 -0
  29. package/dist/identity-RHQFPSDS.js +215 -0
  30. package/dist/identity-VGDDAKBY.js +215 -0
  31. package/dist/index.js +12 -12
  32. package/dist/install-6LV7B2SV.js +378 -0
  33. package/dist/install-NAUPXVCI.js +378 -0
  34. package/dist/message-TGAPVVI4.js +189 -0
  35. package/dist/message-YQGIARNE.js +189 -0
  36. package/dist/onboard-CN56V5P6.js +849 -0
  37. package/dist/onboard-LJFC6HXD.js +849 -0
  38. package/dist/pairing-ARWQYATE.js +147 -0
  39. package/dist/pairing-PXCJMCT2.js +147 -0
  40. package/dist/skills-4EELFYO2.js +138 -0
  41. package/dist/skills-KXRTDSF2.js +138 -0
  42. package/dist/status-2ZJPK3VL.js +94 -0
  43. package/dist/status-W2OXOSH4.js +94 -0
  44. package/package.json +24 -24
@@ -0,0 +1,147 @@
1
+ import {
2
+ PairingManager
3
+ } from "./chunk-XRUNSIVU.js";
4
+ import "./chunk-YSCX2QQQ.js";
5
+ import {
6
+ loadConfig
7
+ } from "./chunk-AORLXQHZ.js";
8
+ import {
9
+ BOLD,
10
+ DIM,
11
+ GREEN,
12
+ RED,
13
+ RESET,
14
+ TEAL,
15
+ YELLOW,
16
+ separator
17
+ } from "./chunk-NMGPBPNU.js";
18
+
19
+ // src/commands/pairing.ts
20
+ var manager = null;
21
+ function getManager() {
22
+ if (!manager) {
23
+ manager = new PairingManager();
24
+ }
25
+ return manager;
26
+ }
27
+ function handleGenerate(args) {
28
+ const label = args[0] ?? "CLI";
29
+ const pm = getManager();
30
+ try {
31
+ const code = pm.generateCode(label);
32
+ console.log(` ${GREEN}${BOLD}Pairing code generated${RESET}
33
+ `);
34
+ console.log(` ${BOLD}Code${RESET} ${TEAL}${BOLD}${code.code}${RESET}`);
35
+ console.log(` ${BOLD}Label${RESET} ${code.label ?? DIM + "none" + RESET}`);
36
+ console.log(` ${BOLD}Expires${RESET} ${code.expiresAt.toLocaleTimeString()}`);
37
+ console.log("");
38
+ console.log(` ${DIM}Share this code with the client. It can only be used once.${RESET}`);
39
+ console.log(` ${DIM}Exchange via: POST /pair { "code": "${code.code}" }${RESET}`);
40
+ } catch (err) {
41
+ const message = err instanceof Error ? err.message : String(err);
42
+ console.log(` ${RED}Failed to generate code:${RESET} ${message}`);
43
+ }
44
+ }
45
+ function handleList() {
46
+ const pm = getManager();
47
+ const codes = pm.listCodes();
48
+ const clients = pm.listClients();
49
+ const stats = pm.stats();
50
+ console.log(` ${BOLD}Active Codes${RESET} ${DIM}(${stats.activeCodes})${RESET}`);
51
+ if (codes.length === 0) {
52
+ console.log(` ${DIM}No active pairing codes.${RESET}`);
53
+ } else {
54
+ for (const code of codes) {
55
+ const remaining = Math.max(0, Math.ceil((code.expiresAt.getTime() - Date.now()) / 1e3));
56
+ console.log(
57
+ ` ${TEAL}${code.code}${RESET} ${DIM}label=${code.label ?? "none"} expires in ${remaining}s${RESET}`
58
+ );
59
+ }
60
+ }
61
+ console.log("");
62
+ console.log(` ${BOLD}Paired Clients${RESET} ${DIM}(${stats.pairedClients})${RESET}`);
63
+ if (clients.length === 0) {
64
+ console.log(` ${DIM}No paired clients.${RESET}`);
65
+ } else {
66
+ for (const client of clients) {
67
+ console.log(
68
+ ` ${GREEN}${client.tokenPreview}${RESET} ${DIM}label=${client.label ?? "none"} paired=${client.pairedAt.toLocaleTimeString()} seen=${client.lastSeenAt.toLocaleTimeString()}${RESET}`
69
+ );
70
+ }
71
+ }
72
+ }
73
+ function handleRevoke(args) {
74
+ const target = args[0];
75
+ if (!target) {
76
+ console.log(` ${RED}Usage:${RESET} ch4p pairing revoke <code-or-token-hash>`);
77
+ console.log(` ${DIM}Use 'ch4p pairing list' to see active codes and clients.${RESET}`);
78
+ process.exitCode = 1;
79
+ return;
80
+ }
81
+ const pm = getManager();
82
+ if (pm.revokeCode(target)) {
83
+ console.log(` ${GREEN}Revoked pairing code:${RESET} ${target}`);
84
+ return;
85
+ }
86
+ if (pm.revokeClient(target)) {
87
+ console.log(` ${GREEN}Revoked paired client:${RESET} ${target.slice(0, 16)}...`);
88
+ return;
89
+ }
90
+ console.log(` ${YELLOW}Not found:${RESET} ${target}`);
91
+ console.log(` ${DIM}No active code or client matched. Use 'ch4p pairing list' to see current state.${RESET}`);
92
+ }
93
+ function handleStatus(requirePairing, port) {
94
+ const pm = getManager();
95
+ const stats = pm.stats();
96
+ console.log(` ${BOLD}Configuration${RESET}`);
97
+ console.log(` ${BOLD} Pairing required${RESET} ${requirePairing ? `${GREEN}yes${RESET}` : `${YELLOW}no${RESET}`}`);
98
+ console.log(` ${BOLD} Gateway port${RESET} ${port}`);
99
+ console.log("");
100
+ console.log(` ${BOLD}Local State${RESET}`);
101
+ console.log(` ${BOLD} Active codes${RESET} ${stats.activeCodes}`);
102
+ console.log(` ${BOLD} Paired clients${RESET} ${stats.pairedClients}`);
103
+ console.log("");
104
+ console.log(` ${DIM}Subcommands: generate [label], list, revoke <target>, status${RESET}`);
105
+ }
106
+ async function pairing(args) {
107
+ let config;
108
+ try {
109
+ config = loadConfig();
110
+ } catch (err) {
111
+ const message = err instanceof Error ? err.message : String(err);
112
+ console.error(`
113
+ ${RED}Failed to load config:${RESET} ${message}`);
114
+ console.error(` ${DIM}Run ${TEAL}ch4p onboard${DIM} to set up ch4p.${RESET}
115
+ `);
116
+ process.exitCode = 1;
117
+ return;
118
+ }
119
+ const subcommand = args[0] ?? "status";
120
+ const subArgs = args.slice(1);
121
+ console.log(`
122
+ ${TEAL}${BOLD}ch4p Pairing${RESET}`);
123
+ console.log(separator());
124
+ console.log("");
125
+ switch (subcommand) {
126
+ case "generate":
127
+ handleGenerate(subArgs);
128
+ break;
129
+ case "list":
130
+ handleList();
131
+ break;
132
+ case "revoke":
133
+ handleRevoke(subArgs);
134
+ break;
135
+ case "status":
136
+ handleStatus(config.gateway.requirePairing, config.gateway.port);
137
+ break;
138
+ default:
139
+ console.log(` ${RED}Unknown subcommand: ${subcommand}${RESET}`);
140
+ console.log(` ${DIM}Available: generate, list, revoke, status${RESET}`);
141
+ process.exitCode = 1;
142
+ }
143
+ console.log("");
144
+ }
145
+ export {
146
+ pairing
147
+ };
@@ -0,0 +1,147 @@
1
+ import {
2
+ PairingManager
3
+ } from "./chunk-XRUNSIVU.js";
4
+ import "./chunk-YSCX2QQQ.js";
5
+ import {
6
+ loadConfig
7
+ } from "./chunk-TB4IZ7F7.js";
8
+ import {
9
+ BOLD,
10
+ DIM,
11
+ GREEN,
12
+ RED,
13
+ RESET,
14
+ TEAL,
15
+ YELLOW,
16
+ separator
17
+ } from "./chunk-NMGPBPNU.js";
18
+
19
+ // src/commands/pairing.ts
20
+ var manager = null;
21
+ function getManager() {
22
+ if (!manager) {
23
+ manager = new PairingManager();
24
+ }
25
+ return manager;
26
+ }
27
+ function handleGenerate(args) {
28
+ const label = args[0] ?? "CLI";
29
+ const pm = getManager();
30
+ try {
31
+ const code = pm.generateCode(label);
32
+ console.log(` ${GREEN}${BOLD}Pairing code generated${RESET}
33
+ `);
34
+ console.log(` ${BOLD}Code${RESET} ${TEAL}${BOLD}${code.code}${RESET}`);
35
+ console.log(` ${BOLD}Label${RESET} ${code.label ?? DIM + "none" + RESET}`);
36
+ console.log(` ${BOLD}Expires${RESET} ${code.expiresAt.toLocaleTimeString()}`);
37
+ console.log("");
38
+ console.log(` ${DIM}Share this code with the client. It can only be used once.${RESET}`);
39
+ console.log(` ${DIM}Exchange via: POST /pair { "code": "${code.code}" }${RESET}`);
40
+ } catch (err) {
41
+ const message = err instanceof Error ? err.message : String(err);
42
+ console.log(` ${RED}Failed to generate code:${RESET} ${message}`);
43
+ }
44
+ }
45
+ function handleList() {
46
+ const pm = getManager();
47
+ const codes = pm.listCodes();
48
+ const clients = pm.listClients();
49
+ const stats = pm.stats();
50
+ console.log(` ${BOLD}Active Codes${RESET} ${DIM}(${stats.activeCodes})${RESET}`);
51
+ if (codes.length === 0) {
52
+ console.log(` ${DIM}No active pairing codes.${RESET}`);
53
+ } else {
54
+ for (const code of codes) {
55
+ const remaining = Math.max(0, Math.ceil((code.expiresAt.getTime() - Date.now()) / 1e3));
56
+ console.log(
57
+ ` ${TEAL}${code.code}${RESET} ${DIM}label=${code.label ?? "none"} expires in ${remaining}s${RESET}`
58
+ );
59
+ }
60
+ }
61
+ console.log("");
62
+ console.log(` ${BOLD}Paired Clients${RESET} ${DIM}(${stats.pairedClients})${RESET}`);
63
+ if (clients.length === 0) {
64
+ console.log(` ${DIM}No paired clients.${RESET}`);
65
+ } else {
66
+ for (const client of clients) {
67
+ console.log(
68
+ ` ${GREEN}${client.tokenPreview}${RESET} ${DIM}label=${client.label ?? "none"} paired=${client.pairedAt.toLocaleTimeString()} seen=${client.lastSeenAt.toLocaleTimeString()}${RESET}`
69
+ );
70
+ }
71
+ }
72
+ }
73
+ function handleRevoke(args) {
74
+ const target = args[0];
75
+ if (!target) {
76
+ console.log(` ${RED}Usage:${RESET} ch4p pairing revoke <code-or-token-hash>`);
77
+ console.log(` ${DIM}Use 'ch4p pairing list' to see active codes and clients.${RESET}`);
78
+ process.exitCode = 1;
79
+ return;
80
+ }
81
+ const pm = getManager();
82
+ if (pm.revokeCode(target)) {
83
+ console.log(` ${GREEN}Revoked pairing code:${RESET} ${target}`);
84
+ return;
85
+ }
86
+ if (pm.revokeClient(target)) {
87
+ console.log(` ${GREEN}Revoked paired client:${RESET} ${target.slice(0, 16)}...`);
88
+ return;
89
+ }
90
+ console.log(` ${YELLOW}Not found:${RESET} ${target}`);
91
+ console.log(` ${DIM}No active code or client matched. Use 'ch4p pairing list' to see current state.${RESET}`);
92
+ }
93
+ function handleStatus(requirePairing, port) {
94
+ const pm = getManager();
95
+ const stats = pm.stats();
96
+ console.log(` ${BOLD}Configuration${RESET}`);
97
+ console.log(` ${BOLD} Pairing required${RESET} ${requirePairing ? `${GREEN}yes${RESET}` : `${YELLOW}no${RESET}`}`);
98
+ console.log(` ${BOLD} Gateway port${RESET} ${port}`);
99
+ console.log("");
100
+ console.log(` ${BOLD}Local State${RESET}`);
101
+ console.log(` ${BOLD} Active codes${RESET} ${stats.activeCodes}`);
102
+ console.log(` ${BOLD} Paired clients${RESET} ${stats.pairedClients}`);
103
+ console.log("");
104
+ console.log(` ${DIM}Subcommands: generate [label], list, revoke <target>, status${RESET}`);
105
+ }
106
+ async function pairing(args) {
107
+ let config;
108
+ try {
109
+ config = loadConfig();
110
+ } catch (err) {
111
+ const message = err instanceof Error ? err.message : String(err);
112
+ console.error(`
113
+ ${RED}Failed to load config:${RESET} ${message}`);
114
+ console.error(` ${DIM}Run ${TEAL}ch4p onboard${DIM} to set up ch4p.${RESET}
115
+ `);
116
+ process.exitCode = 1;
117
+ return;
118
+ }
119
+ const subcommand = args[0] ?? "status";
120
+ const subArgs = args.slice(1);
121
+ console.log(`
122
+ ${TEAL}${BOLD}ch4p Pairing${RESET}`);
123
+ console.log(separator());
124
+ console.log("");
125
+ switch (subcommand) {
126
+ case "generate":
127
+ handleGenerate(subArgs);
128
+ break;
129
+ case "list":
130
+ handleList();
131
+ break;
132
+ case "revoke":
133
+ handleRevoke(subArgs);
134
+ break;
135
+ case "status":
136
+ handleStatus(config.gateway.requirePairing, config.gateway.port);
137
+ break;
138
+ default:
139
+ console.log(` ${RED}Unknown subcommand: ${subcommand}${RESET}`);
140
+ console.log(` ${DIM}Available: generate, list, revoke, status${RESET}`);
141
+ process.exitCode = 1;
142
+ }
143
+ console.log("");
144
+ }
145
+ export {
146
+ pairing
147
+ };
@@ -0,0 +1,138 @@
1
+ import {
2
+ SkillRegistry
3
+ } from "./chunk-6BURGD2Y.js";
4
+ import {
5
+ loadConfig
6
+ } from "./chunk-TB4IZ7F7.js";
7
+ import {
8
+ BOLD,
9
+ DIM,
10
+ GREEN,
11
+ RED,
12
+ RESET,
13
+ TEAL,
14
+ YELLOW
15
+ } from "./chunk-NMGPBPNU.js";
16
+
17
+ // src/commands/skills.ts
18
+ function loadSkillRegistry() {
19
+ const config = loadConfig();
20
+ if (!config.skills?.enabled) {
21
+ console.log(` ${DIM}Skills are disabled in configuration.${RESET}`);
22
+ return new SkillRegistry();
23
+ }
24
+ return SkillRegistry.createFromPaths(config.skills.paths);
25
+ }
26
+ function listSkills() {
27
+ const registry = loadSkillRegistry();
28
+ const allSkills = registry.list();
29
+ if (allSkills.length === 0) {
30
+ console.log(`
31
+ ${DIM}No skills found.${RESET}`);
32
+ console.log(` ${DIM}Skills are loaded from: ~/.ch4p/skills, .ch4p/skills, .agents/skills${RESET}
33
+ `);
34
+ return;
35
+ }
36
+ console.log(`
37
+ ${BOLD}Installed Skills${RESET} ${DIM}(${allSkills.length})${RESET}
38
+ `);
39
+ for (const skill of allSkills) {
40
+ const sourceTag = skill.source === "global" ? `${DIM}[global]${RESET}` : skill.source === "legacy" ? `${YELLOW}[legacy]${RESET}` : `${GREEN}[project]${RESET}`;
41
+ console.log(` ${TEAL}${skill.manifest.name}${RESET} ${sourceTag}`);
42
+ console.log(` ${DIM}${skill.manifest.description}${RESET}`);
43
+ if (skill.manifest.license) {
44
+ console.log(` ${DIM}License: ${skill.manifest.license}${RESET}`);
45
+ }
46
+ }
47
+ console.log("");
48
+ }
49
+ function showSkill(name) {
50
+ const registry = loadSkillRegistry();
51
+ const skill = registry.get(name);
52
+ if (!skill) {
53
+ console.error(`
54
+ ${RED}Skill not found:${RESET} ${name}`);
55
+ console.error(` ${DIM}Run ${TEAL}ch4p skills${DIM} to list available skills.${RESET}
56
+ `);
57
+ process.exitCode = 1;
58
+ return;
59
+ }
60
+ console.log(`
61
+ ${BOLD}${skill.manifest.name}${RESET} ${DIM}(${skill.source})${RESET}`);
62
+ console.log(` ${DIM}Path: ${skill.path}${RESET}`);
63
+ console.log(` ${DIM}${"\u2500".repeat(60)}${RESET}
64
+ `);
65
+ console.log(skill.body);
66
+ console.log("");
67
+ }
68
+ function verifySkills(name) {
69
+ const config = loadConfig();
70
+ const paths = config.skills?.paths ?? ["~/.ch4p/skills", ".ch4p/skills", ".agents/skills"];
71
+ console.log(`
72
+ ${BOLD}Verifying Skills${RESET}
73
+ `);
74
+ let passed = 0;
75
+ let failed = 0;
76
+ if (name) {
77
+ const registry = loadSkillRegistry();
78
+ const skill = registry.get(name);
79
+ if (!skill) {
80
+ console.error(` ${RED}\u2717${RESET} Skill not found: ${name}`);
81
+ process.exitCode = 1;
82
+ return;
83
+ }
84
+ console.log(` ${GREEN}\u2713${RESET} ${skill.manifest.name} \u2014 valid`);
85
+ passed = 1;
86
+ } else {
87
+ try {
88
+ const registry = SkillRegistry.createFromPaths(paths);
89
+ for (const skill of registry.list()) {
90
+ console.log(` ${GREEN}\u2713${RESET} ${skill.manifest.name} \u2014 valid`);
91
+ passed++;
92
+ }
93
+ } catch (err) {
94
+ const message = err instanceof Error ? err.message : String(err);
95
+ console.log(` ${RED}\u2717${RESET} Error: ${message}`);
96
+ failed++;
97
+ }
98
+ }
99
+ console.log(`
100
+ ${DIM}Results: ${passed} passed, ${failed} failed${RESET}
101
+ `);
102
+ if (failed > 0) {
103
+ process.exitCode = 1;
104
+ }
105
+ }
106
+ async function skills(args) {
107
+ const subcommand = args[0] ?? "list";
108
+ switch (subcommand) {
109
+ case "list":
110
+ listSkills();
111
+ break;
112
+ case "show": {
113
+ const name = args[1];
114
+ if (!name) {
115
+ console.error(`
116
+ ${RED}Usage:${RESET} ch4p skills show <name>
117
+ `);
118
+ process.exitCode = 1;
119
+ return;
120
+ }
121
+ showSkill(name);
122
+ break;
123
+ }
124
+ case "verify":
125
+ verifySkills(args[1]);
126
+ break;
127
+ default:
128
+ console.error(`
129
+ ${YELLOW}Unknown skills subcommand:${RESET} ${subcommand}`);
130
+ console.error(` ${DIM}Available: list, show, verify${RESET}
131
+ `);
132
+ process.exitCode = 1;
133
+ break;
134
+ }
135
+ }
136
+ export {
137
+ skills
138
+ };
@@ -0,0 +1,138 @@
1
+ import {
2
+ SkillRegistry
3
+ } from "./chunk-6BURGD2Y.js";
4
+ import {
5
+ loadConfig
6
+ } from "./chunk-AORLXQHZ.js";
7
+ import {
8
+ BOLD,
9
+ DIM,
10
+ GREEN,
11
+ RED,
12
+ RESET,
13
+ TEAL,
14
+ YELLOW
15
+ } from "./chunk-NMGPBPNU.js";
16
+
17
+ // src/commands/skills.ts
18
+ function loadSkillRegistry() {
19
+ const config = loadConfig();
20
+ if (!config.skills?.enabled) {
21
+ console.log(` ${DIM}Skills are disabled in configuration.${RESET}`);
22
+ return new SkillRegistry();
23
+ }
24
+ return SkillRegistry.createFromPaths(config.skills.paths);
25
+ }
26
+ function listSkills() {
27
+ const registry = loadSkillRegistry();
28
+ const allSkills = registry.list();
29
+ if (allSkills.length === 0) {
30
+ console.log(`
31
+ ${DIM}No skills found.${RESET}`);
32
+ console.log(` ${DIM}Skills are loaded from: ~/.ch4p/skills, .ch4p/skills, .agents/skills${RESET}
33
+ `);
34
+ return;
35
+ }
36
+ console.log(`
37
+ ${BOLD}Installed Skills${RESET} ${DIM}(${allSkills.length})${RESET}
38
+ `);
39
+ for (const skill of allSkills) {
40
+ const sourceTag = skill.source === "global" ? `${DIM}[global]${RESET}` : skill.source === "legacy" ? `${YELLOW}[legacy]${RESET}` : `${GREEN}[project]${RESET}`;
41
+ console.log(` ${TEAL}${skill.manifest.name}${RESET} ${sourceTag}`);
42
+ console.log(` ${DIM}${skill.manifest.description}${RESET}`);
43
+ if (skill.manifest.license) {
44
+ console.log(` ${DIM}License: ${skill.manifest.license}${RESET}`);
45
+ }
46
+ }
47
+ console.log("");
48
+ }
49
+ function showSkill(name) {
50
+ const registry = loadSkillRegistry();
51
+ const skill = registry.get(name);
52
+ if (!skill) {
53
+ console.error(`
54
+ ${RED}Skill not found:${RESET} ${name}`);
55
+ console.error(` ${DIM}Run ${TEAL}ch4p skills${DIM} to list available skills.${RESET}
56
+ `);
57
+ process.exitCode = 1;
58
+ return;
59
+ }
60
+ console.log(`
61
+ ${BOLD}${skill.manifest.name}${RESET} ${DIM}(${skill.source})${RESET}`);
62
+ console.log(` ${DIM}Path: ${skill.path}${RESET}`);
63
+ console.log(` ${DIM}${"\u2500".repeat(60)}${RESET}
64
+ `);
65
+ console.log(skill.body);
66
+ console.log("");
67
+ }
68
+ function verifySkills(name) {
69
+ const config = loadConfig();
70
+ const paths = config.skills?.paths ?? ["~/.ch4p/skills", ".ch4p/skills", ".agents/skills"];
71
+ console.log(`
72
+ ${BOLD}Verifying Skills${RESET}
73
+ `);
74
+ let passed = 0;
75
+ let failed = 0;
76
+ if (name) {
77
+ const registry = loadSkillRegistry();
78
+ const skill = registry.get(name);
79
+ if (!skill) {
80
+ console.error(` ${RED}\u2717${RESET} Skill not found: ${name}`);
81
+ process.exitCode = 1;
82
+ return;
83
+ }
84
+ console.log(` ${GREEN}\u2713${RESET} ${skill.manifest.name} \u2014 valid`);
85
+ passed = 1;
86
+ } else {
87
+ try {
88
+ const registry = SkillRegistry.createFromPaths(paths);
89
+ for (const skill of registry.list()) {
90
+ console.log(` ${GREEN}\u2713${RESET} ${skill.manifest.name} \u2014 valid`);
91
+ passed++;
92
+ }
93
+ } catch (err) {
94
+ const message = err instanceof Error ? err.message : String(err);
95
+ console.log(` ${RED}\u2717${RESET} Error: ${message}`);
96
+ failed++;
97
+ }
98
+ }
99
+ console.log(`
100
+ ${DIM}Results: ${passed} passed, ${failed} failed${RESET}
101
+ `);
102
+ if (failed > 0) {
103
+ process.exitCode = 1;
104
+ }
105
+ }
106
+ async function skills(args) {
107
+ const subcommand = args[0] ?? "list";
108
+ switch (subcommand) {
109
+ case "list":
110
+ listSkills();
111
+ break;
112
+ case "show": {
113
+ const name = args[1];
114
+ if (!name) {
115
+ console.error(`
116
+ ${RED}Usage:${RESET} ch4p skills show <name>
117
+ `);
118
+ process.exitCode = 1;
119
+ return;
120
+ }
121
+ showSkill(name);
122
+ break;
123
+ }
124
+ case "verify":
125
+ verifySkills(args[1]);
126
+ break;
127
+ default:
128
+ console.error(`
129
+ ${YELLOW}Unknown skills subcommand:${RESET} ${subcommand}`);
130
+ console.error(` ${DIM}Available: list, show, verify${RESET}
131
+ `);
132
+ process.exitCode = 1;
133
+ break;
134
+ }
135
+ }
136
+ export {
137
+ skills
138
+ };
@@ -0,0 +1,94 @@
1
+ import {
2
+ getCh4pDir,
3
+ getConfigPath,
4
+ loadConfig
5
+ } from "./chunk-TB4IZ7F7.js";
6
+ import {
7
+ BOLD,
8
+ DIM,
9
+ GREEN,
10
+ RED,
11
+ RESET,
12
+ TEAL,
13
+ YELLOW,
14
+ separator
15
+ } from "./chunk-NMGPBPNU.js";
16
+
17
+ // src/commands/status.ts
18
+ import { existsSync } from "fs";
19
+ async function status() {
20
+ console.log(`
21
+ ${TEAL}${BOLD}ch4p Status${RESET}`);
22
+ console.log(separator());
23
+ console.log("");
24
+ console.log(` ${BOLD}Version${RESET} 0.1.0`);
25
+ const configPath = getConfigPath();
26
+ const configExists = existsSync(configPath);
27
+ console.log(
28
+ ` ${BOLD}Config${RESET} ${configExists ? `${GREEN}${configPath}${RESET}` : `${YELLOW}Not found${RESET} (run ch4p onboard)`}`
29
+ );
30
+ const ch4pDir = getCh4pDir();
31
+ console.log(
32
+ ` ${BOLD}Data dir${RESET} ${existsSync(ch4pDir) ? ch4pDir : `${YELLOW}Not created${RESET}`}`
33
+ );
34
+ if (!configExists) {
35
+ console.log(`
36
+ ${YELLOW}No configuration found.${RESET}`);
37
+ console.log(` ${DIM}Run ${TEAL}ch4p onboard${DIM} to set up ch4p.${RESET}
38
+ `);
39
+ return;
40
+ }
41
+ try {
42
+ const config = loadConfig();
43
+ console.log(` ${BOLD}Provider${RESET} ${config.agent.provider}`);
44
+ console.log(` ${BOLD}Model${RESET} ${config.agent.model}`);
45
+ console.log(` ${BOLD}Engine${RESET} ${config.engines.default}`);
46
+ const autonomyColors = {
47
+ readonly: GREEN,
48
+ supervised: YELLOW,
49
+ full: RED
50
+ };
51
+ const autonomyColor = autonomyColors[config.autonomy.level] ?? DIM;
52
+ console.log(` ${BOLD}Autonomy${RESET} ${autonomyColor}${config.autonomy.level}${RESET}`);
53
+ console.log(` ${BOLD}Memory${RESET} ${config.memory.backend} (auto-save: ${config.memory.autoSave ? "on" : "off"})`);
54
+ console.log(
55
+ ` ${BOLD}Gateway${RESET} port ${config.gateway.port} (pairing: ${config.gateway.requirePairing ? `${GREEN}required${RESET}` : `${YELLOW}disabled${RESET}`})`
56
+ );
57
+ const channelNames = Object.keys(config.channels);
58
+ console.log(
59
+ ` ${BOLD}Channels${RESET} ${channelNames.length > 0 ? channelNames.join(", ") : `${DIM}none configured${RESET}`}`
60
+ );
61
+ console.log(
62
+ ` ${BOLD}Tunnel${RESET} ${config.tunnel.provider === "none" ? `${DIM}disabled${RESET}` : config.tunnel.provider}`
63
+ );
64
+ const observers = config.observability.observers;
65
+ console.log(
66
+ ` ${BOLD}Observers${RESET} ${observers.length > 0 ? observers.join(", ") : `${DIM}none${RESET}`}`
67
+ );
68
+ console.log(
69
+ ` ${BOLD}Secrets${RESET} ${config.secrets.encrypt ? `${GREEN}encrypted${RESET}` : `${YELLOW}plaintext${RESET}`}`
70
+ );
71
+ const hasAnthropicKey = checkApiKey(config, "anthropic");
72
+ const hasOpenaiKey = checkApiKey(config, "openai");
73
+ const keyStatus = [];
74
+ if (hasAnthropicKey) keyStatus.push(`${GREEN}Anthropic${RESET}`);
75
+ if (hasOpenaiKey) keyStatus.push(`${GREEN}OpenAI${RESET}`);
76
+ console.log(
77
+ ` ${BOLD}API Keys${RESET} ${keyStatus.length > 0 ? keyStatus.join(", ") : `${YELLOW}none configured${RESET}`}`
78
+ );
79
+ } catch (err) {
80
+ const message = err instanceof Error ? err.message : String(err);
81
+ console.error(`
82
+ ${RED}Error loading config:${RESET} ${message}`);
83
+ process.exitCode = 1;
84
+ }
85
+ console.log("");
86
+ }
87
+ function checkApiKey(config, provider) {
88
+ const providerConfig = config.providers[provider];
89
+ const key = providerConfig?.["apiKey"];
90
+ return typeof key === "string" && key.length > 0 && !key.includes("${");
91
+ }
92
+ export {
93
+ status
94
+ };