@visorcraft/idlehands 2.0.1 → 2.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.
Files changed (59) hide show
  1. package/dist/agent/prompt-builder.js +188 -0
  2. package/dist/agent/prompt-builder.js.map +1 -0
  3. package/dist/agent/query-classifier.js +72 -0
  4. package/dist/agent/query-classifier.js.map +1 -0
  5. package/dist/agent/resilient-provider.js +170 -0
  6. package/dist/agent/resilient-provider.js.map +1 -0
  7. package/dist/agent/response-cache.js +124 -0
  8. package/dist/agent/response-cache.js.map +1 -0
  9. package/dist/agent/semantic-search.js +138 -0
  10. package/dist/agent/semantic-search.js.map +1 -0
  11. package/dist/agent/tool-calls.js +261 -1
  12. package/dist/agent/tool-calls.js.map +1 -1
  13. package/dist/agent/tool-name-alias.js +140 -0
  14. package/dist/agent/tool-name-alias.js.map +1 -0
  15. package/dist/agent.js +146 -43
  16. package/dist/agent.js.map +1 -1
  17. package/dist/anton/controller.js +442 -186
  18. package/dist/anton/controller.js.map +1 -1
  19. package/dist/anton/preflight.js +89 -28
  20. package/dist/anton/preflight.js.map +1 -1
  21. package/dist/anton/prompt.js +20 -0
  22. package/dist/anton/prompt.js.map +1 -1
  23. package/dist/anton/reporter.js +6 -1
  24. package/dist/anton/reporter.js.map +1 -1
  25. package/dist/bot/discord-commands.js +25 -0
  26. package/dist/bot/discord-commands.js.map +1 -1
  27. package/dist/bot/discord.js +15 -0
  28. package/dist/bot/discord.js.map +1 -1
  29. package/dist/bot/telegram-commands.js +21 -0
  30. package/dist/bot/telegram-commands.js.map +1 -1
  31. package/dist/bot/telegram.js +1 -0
  32. package/dist/bot/telegram.js.map +1 -1
  33. package/dist/bot/upgrade-command.js +398 -0
  34. package/dist/bot/upgrade-command.js.map +1 -0
  35. package/dist/bot/ux/discord-renderer.js +5 -21
  36. package/dist/bot/ux/discord-renderer.js.map +1 -1
  37. package/dist/bot/ux/emitter.js +104 -0
  38. package/dist/bot/ux/emitter.js.map +1 -0
  39. package/dist/bot/ux/shared-formatter.js +43 -0
  40. package/dist/bot/ux/shared-formatter.js.map +1 -0
  41. package/dist/bot/ux/telegram-renderer.js +5 -21
  42. package/dist/bot/ux/telegram-renderer.js.map +1 -1
  43. package/dist/cli/commands/upgrade.js +27 -0
  44. package/dist/cli/commands/upgrade.js.map +1 -0
  45. package/dist/client.js +51 -7
  46. package/dist/client.js.map +1 -1
  47. package/dist/harnesses.js +2 -0
  48. package/dist/harnesses.js.map +1 -1
  49. package/dist/index.js +4 -0
  50. package/dist/index.js.map +1 -1
  51. package/dist/model-customization.js +3 -1
  52. package/dist/model-customization.js.map +1 -1
  53. package/dist/security/leak-detector.js +109 -0
  54. package/dist/security/leak-detector.js.map +1 -0
  55. package/dist/security/prompt-guard.js +120 -0
  56. package/dist/security/prompt-guard.js.map +1 -0
  57. package/dist/tui/command-handler.js +2 -0
  58. package/dist/tui/command-handler.js.map +1 -1
  59. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"model-customization.js","sourceRoot":"","sources":["../src/model-customization.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,CAAC;AAErC,MAAM,UAAU,mBAAmB,CAAC,KAAa,EAAE,SAAc,EAAE,OAAgB;IACjF,IAAI,OAAO,OAAO,CAAC,cAAc,KAAK,SAAS;QAAE,OAAO,OAAO,CAAC,cAAc,CAAC;IAC/E,IAAI,OAAO,SAAS,EAAE,MAAM,KAAK,SAAS;QAAE,OAAO,SAAS,CAAC,MAAM,CAAC;IAEpE,MAAM,eAAe,GAAG,SAAS,EAAE,gBAAgB,CAAC;IACpD,IACE,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC;QAC9B,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,EACtE,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,UAAU,GAAG,SAAS,EAAE,UAAU,CAAC;IACzC,IACE,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC;QACzB,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,EACjE,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,EAAE,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;IAC/B,IAAI,sEAAsE,CAAC,IAAI,CAAC,EAAE,CAAC;QAAE,OAAO,IAAI,CAAC;IACjG,IAAI,OAAO,CAAC,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAE5E,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,QAAQ,CAAC,GAAG,IAAW;IAC9B,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;QACrB,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;YAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,IAMnC;IACC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC;IAEzC,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,OAAO,IAAI,CAAC,uBAAuB,IAAI,IAAI,CAAC,qBAAqB,IAAI,QAAQ,CAAC;IAChF,CAAC;IAED,MAAM,OAAO,GAAG,QAAQ,CACtB,IAAI,CAAC,SAAS,EAAE,cAAc,EAC9B,IAAI,CAAC,SAAS,EAAE,cAAc,EAC9B,IAAI,CAAC,SAAS,EAAE,kBAAkB,CACnC,CAAC;IAEF,OAAO,OAAO,IAAI,IAAI,CAAC,qBAAqB,IAAI,QAAQ,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,IAMtC;IACC,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,IAAI,eAAe,CAAC;IAEnD,IAAI,SAAS,GAAG,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC;IACjD,IACE,SAAS,KAAK,IAAI;QAClB,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,UAAU;QACjC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,EACvC,CAAC;QACD,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;IAC/C,CAAC;IAED,MAAM,WAAW,GAAG,IAAI,CAAC,qBAAqB,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,WAAW,IAAI,GAAG,CAAC;IAC5F,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,IAAI,IAAI,CAAC;IAEzE,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;AAC1C,CAAC"}
1
+ {"version":3,"file":"model-customization.js","sourceRoot":"","sources":["../src/model-customization.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,109 @@
1
+ /**
2
+ * Credential Leak Detector
3
+ *
4
+ * Scans outbound content (tool outputs, model responses) for potential
5
+ * credential leaks before they reach the chat channel.
6
+ *
7
+ * Detects: API keys (Stripe, OpenAI, Anthropic, Google, GitHub),
8
+ * AWS credentials, private keys (PEM), JWT tokens, database URLs,
9
+ * generic secrets/passwords/tokens.
10
+ *
11
+ * Inspired by ZeroClaw's leak_detector.rs.
12
+ */
13
+ const API_KEY_PATTERNS = [
14
+ // Stripe
15
+ { re: /sk_(live|test)_[a-zA-Z0-9]{24,}/g, name: 'Stripe secret key', replacement: '[REDACTED_STRIPE_KEY]' },
16
+ { re: /pk_(live|test)_[a-zA-Z0-9]{24,}/g, name: 'Stripe publishable key', replacement: '[REDACTED_STRIPE_KEY]' },
17
+ // OpenAI
18
+ { re: /sk-[a-zA-Z0-9]{20,}T3BlbkFJ[a-zA-Z0-9]{20,}/g, name: 'OpenAI API key', replacement: '[REDACTED_OPENAI_KEY]' },
19
+ { re: /sk-[a-zA-Z0-9]{48,}/g, name: 'OpenAI-style API key', replacement: '[REDACTED_API_KEY]' },
20
+ // Anthropic
21
+ { re: /sk-ant-[a-zA-Z0-9\-_]{32,}/g, name: 'Anthropic API key', replacement: '[REDACTED_ANTHROPIC_KEY]' },
22
+ // Google
23
+ { re: /AIza[a-zA-Z0-9_-]{35}/g, name: 'Google API key', replacement: '[REDACTED_GOOGLE_KEY]' },
24
+ // GitHub
25
+ { re: /gh[pousr]_[a-zA-Z0-9]{36,}/g, name: 'GitHub token', replacement: '[REDACTED_GITHUB_TOKEN]' },
26
+ { re: /github_pat_[a-zA-Z0-9_]{22,}/g, name: 'GitHub PAT', replacement: '[REDACTED_GITHUB_PAT]' },
27
+ // Generic API key assignment
28
+ { re: /api[_-]?key[=:]\s*['"]?[a-zA-Z0-9_-]{20,}/gi, name: 'Generic API key', replacement: '[REDACTED_API_KEY]' },
29
+ ];
30
+ const AWS_PATTERNS = [
31
+ { re: /AKIA[A-Z0-9]{16}/g, name: 'AWS Access Key ID', replacement: '[REDACTED_AWS_KEY]' },
32
+ { re: /aws[_-]?secret[_-]?access[_-]?key[=:]\s*['"]?[a-zA-Z0-9/+=]{40}/gi, name: 'AWS Secret Access Key', replacement: '[REDACTED_AWS_SECRET]' },
33
+ ];
34
+ const GENERIC_SECRET_PATTERNS = [
35
+ { re: /(?:password|passwd|pwd)[=:]\s*['"]?[^\s'"]{8,}/gi, name: 'Password in config', replacement: '[REDACTED_PASSWORD]' },
36
+ { re: /(?:secret)[=:]\s*['"]?[a-zA-Z0-9_-]{16,}/gi, name: 'Secret value', replacement: '[REDACTED_SECRET]' },
37
+ { re: /(?:token)[=:]\s*['"]?[a-zA-Z0-9_.-]{20,}/gi, name: 'Token value', replacement: '[REDACTED_TOKEN]' },
38
+ ];
39
+ const JWT_PATTERN = {
40
+ re: /eyJ[a-zA-Z0-9_-]*\.eyJ[a-zA-Z0-9_-]*\.[a-zA-Z0-9_-]+/g,
41
+ name: 'JWT token',
42
+ replacement: '[REDACTED_JWT]',
43
+ };
44
+ const DB_URL_PATTERNS = [
45
+ { re: /postgres(?:ql)?:\/\/[^:]+:[^@]+@[^\s]+/g, name: 'PostgreSQL connection URL', replacement: '[REDACTED_DATABASE_URL]' },
46
+ { re: /mysql:\/\/[^:]+:[^@]+@[^\s]+/g, name: 'MySQL connection URL', replacement: '[REDACTED_DATABASE_URL]' },
47
+ { re: /mongodb(?:\+srv)?:\/\/[^:]+:[^@]+@[^\s]+/g, name: 'MongoDB connection URL', replacement: '[REDACTED_DATABASE_URL]' },
48
+ { re: /redis:\/\/[^:]+:[^@]+@[^\s]+/g, name: 'Redis connection URL', replacement: '[REDACTED_DATABASE_URL]' },
49
+ ];
50
+ const PEM_MARKERS = [
51
+ { begin: '-----BEGIN RSA PRIVATE KEY-----', end: '-----END RSA PRIVATE KEY-----', name: 'RSA private key' },
52
+ { begin: '-----BEGIN EC PRIVATE KEY-----', end: '-----END EC PRIVATE KEY-----', name: 'EC private key' },
53
+ { begin: '-----BEGIN PRIVATE KEY-----', end: '-----END PRIVATE KEY-----', name: 'Private key' },
54
+ { begin: '-----BEGIN OPENSSH PRIVATE KEY-----', end: '-----END OPENSSH PRIVATE KEY-----', name: 'OpenSSH private key' },
55
+ ];
56
+ export class LeakDetector {
57
+ sensitivity;
58
+ constructor(sensitivity = 0.7) {
59
+ this.sensitivity = Math.max(0, Math.min(1, sensitivity));
60
+ }
61
+ /** Scan content for credential leaks. */
62
+ scan(content) {
63
+ const patterns = [];
64
+ let redacted = content;
65
+ const apply = (defs, sensitivityGate = 0) => {
66
+ if (this.sensitivity < sensitivityGate)
67
+ return;
68
+ for (const def of defs) {
69
+ // Reset lastIndex for global regexes
70
+ def.re.lastIndex = 0;
71
+ if (def.re.test(content)) {
72
+ patterns.push(def.name);
73
+ def.re.lastIndex = 0;
74
+ redacted = redacted.replace(def.re, def.replacement);
75
+ }
76
+ }
77
+ };
78
+ apply(API_KEY_PATTERNS);
79
+ apply(AWS_PATTERNS);
80
+ apply(GENERIC_SECRET_PATTERNS, 0.5);
81
+ apply([JWT_PATTERN]);
82
+ apply(DB_URL_PATTERNS);
83
+ // PEM private keys
84
+ for (const marker of PEM_MARKERS) {
85
+ if (content.includes(marker.begin) && content.includes(marker.end)) {
86
+ patterns.push(marker.name);
87
+ const startIdx = redacted.indexOf(marker.begin);
88
+ const endIdx = redacted.indexOf(marker.end);
89
+ if (startIdx >= 0 && endIdx > startIdx) {
90
+ redacted = redacted.slice(0, startIdx) + '[REDACTED_PRIVATE_KEY]' + redacted.slice(endIdx + marker.end.length);
91
+ }
92
+ }
93
+ }
94
+ return {
95
+ clean: patterns.length === 0,
96
+ patterns,
97
+ redacted,
98
+ };
99
+ }
100
+ /**
101
+ * Convenience: redact content in-place.
102
+ * Returns original content if clean, redacted version if leaks detected.
103
+ */
104
+ redactIfNeeded(content) {
105
+ const result = this.scan(content);
106
+ return result.clean ? content : result.redacted;
107
+ }
108
+ }
109
+ //# sourceMappingURL=leak-detector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"leak-detector.js","sourceRoot":"","sources":["../../src/security/leak-detector.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,120 @@
1
+ /**
2
+ * Prompt Injection Guard
3
+ *
4
+ * Scans incoming user messages for prompt injection patterns:
5
+ * - System prompt override attempts
6
+ * - Role confusion attacks
7
+ * - Secret extraction attempts
8
+ * - Jailbreak attempts (DAN, developer mode, etc.)
9
+ * - Tool call JSON injection
10
+ *
11
+ * Returns a scored result with configurable action (warn/block/sanitize).
12
+ *
13
+ * Inspired by ZeroClaw's prompt_guard.rs.
14
+ */
15
+ const systemOverridePatterns = [
16
+ /ignore\s+(?:(?:all\s+)?(?:previous|above|prior)|all)\s+(?:instructions?|prompts?|commands?)/i,
17
+ /disregard\s+(?:previous|all|above|prior)/i,
18
+ /forget\s+(?:previous|all|everything|above)/i,
19
+ /new\s+(?:instructions?|rules?|system\s+prompt)/i,
20
+ /override\s+(?:system|instructions?|rules?)/i,
21
+ /reset\s+(?:instructions?|context|system)/i,
22
+ ];
23
+ const roleConfusionPatterns = [
24
+ /(?:you\s+are\s+now|act\s+as|pretend\s+(?:you're|to\s+be))\s+(?:a|an|the)?/i,
25
+ /(?:your\s+new\s+role|you\s+have\s+become|you\s+must\s+be)/i,
26
+ /from\s+now\s+on\s+(?:you\s+are|act\s+as|pretend)/i,
27
+ /(?:assistant|AI|system|model):\s*\[?(?:system|override|new\s+role)/i,
28
+ ];
29
+ const secretExtractionPatterns = [
30
+ /(?:list|show|print|display|reveal|tell\s+me)\s+(?:all\s+)?(?:secrets?|credentials?|passwords?|tokens?|keys?)/i,
31
+ /(?:what|show)\s+(?:are|is|me)\s+(?:all\s+)?(?:your|the)\s+(?:api\s+)?(?:keys?|secrets?|credentials?)/i,
32
+ /contents?\s+of\s+(?:vault|secrets?|credentials?)/i,
33
+ /(?:dump|export)\s+(?:vault|secrets?|credentials?)/i,
34
+ ];
35
+ const jailbreakPatterns = [
36
+ /\bDAN\b.*mode/i,
37
+ /do\s+anything\s+now/i,
38
+ /enter\s+(?:developer|debug|admin)\s+mode/i,
39
+ /enable\s+(?:developer|debug|admin)\s+mode/i,
40
+ /in\s+this\s+hypothetical/i,
41
+ /imagine\s+you\s+(?:have\s+no|don't\s+have)\s+(?:restrictions?|rules?|limits?)/i,
42
+ /decode\s+(?:this|the\s+following)\s+(?:base64|hex|rot13)/i,
43
+ ];
44
+ const categoryCheckers = [
45
+ (content, _lower) => {
46
+ for (const re of systemOverridePatterns) {
47
+ if (re.test(content))
48
+ return { name: 'system_prompt_override', score: 1.0 };
49
+ }
50
+ return null;
51
+ },
52
+ (content, _lower) => {
53
+ for (const re of roleConfusionPatterns) {
54
+ if (re.test(content))
55
+ return { name: 'role_confusion', score: 0.9 };
56
+ }
57
+ return null;
58
+ },
59
+ (content, lower) => {
60
+ // Tool call injection
61
+ if (lower.includes('tool_calls') || lower.includes('function_call')) {
62
+ if (content.includes('{"type":') || content.includes('{"name":')) {
63
+ return { name: 'tool_call_injection', score: 0.8 };
64
+ }
65
+ }
66
+ if (content.includes('}"}') || content.includes("}'}")) {
67
+ return { name: 'json_escape_attempt', score: 0.7 };
68
+ }
69
+ return null;
70
+ },
71
+ (content, _lower) => {
72
+ for (const re of secretExtractionPatterns) {
73
+ if (re.test(content))
74
+ return { name: 'secret_extraction', score: 0.95 };
75
+ }
76
+ return null;
77
+ },
78
+ (content, _lower) => {
79
+ for (const re of jailbreakPatterns) {
80
+ if (re.test(content))
81
+ return { name: 'jailbreak_attempt', score: 0.85 };
82
+ }
83
+ return null;
84
+ },
85
+ ];
86
+ export class PromptGuard {
87
+ action;
88
+ sensitivity;
89
+ constructor(action = 'warn', sensitivity = 0.7) {
90
+ this.action = action;
91
+ this.sensitivity = Math.max(0, Math.min(1, sensitivity));
92
+ }
93
+ /** Scan a message for prompt injection patterns. */
94
+ scan(content) {
95
+ const lower = content.toLowerCase();
96
+ const detected = [];
97
+ for (const checker of categoryCheckers) {
98
+ const result = checker(content, lower);
99
+ if (result)
100
+ detected.push(result);
101
+ }
102
+ if (detected.length === 0) {
103
+ return { safe: true, patterns: [], score: 0 };
104
+ }
105
+ const maxScore = Math.max(...detected.map((d) => d.score));
106
+ const totalScore = detected.reduce((sum, d) => sum + d.score, 0);
107
+ const normalizedScore = Math.min(1, totalScore / categoryCheckers.length);
108
+ const patterns = detected.map((d) => d.name);
109
+ if (this.action === 'block' && maxScore > this.sensitivity) {
110
+ return {
111
+ safe: false,
112
+ patterns,
113
+ score: normalizedScore,
114
+ blocked: `Potential prompt injection detected (score: ${normalizedScore.toFixed(2)}): ${patterns.join(', ')}`,
115
+ };
116
+ }
117
+ return { safe: false, patterns, score: normalizedScore };
118
+ }
119
+ }
120
+ //# sourceMappingURL=prompt-guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-guard.js","sourceRoot":"","sources":["../../src/security/prompt-guard.ts"],"names":[],"mappings":"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"}
@@ -11,6 +11,7 @@ import { runtimeCommands } from '../cli/commands/runtime.js';
11
11
  import { sessionCommands } from '../cli/commands/session.js';
12
12
  import { toolCommands } from '../cli/commands/tools.js';
13
13
  import { trifectaCommands } from '../cli/commands/trifecta.js';
14
+ import { upgradeCommands } from '../cli/commands/upgrade.js';
14
15
  import { makeStyler } from '../term.js';
15
16
  import { projectDir, PKG_VERSION } from '../utils.js';
16
17
  let registered = false;
@@ -27,6 +28,7 @@ export function ensureCommandsRegistered() {
27
28
  ...trifectaCommands,
28
29
  ...toolCommands,
29
30
  ...antonCommands,
31
+ ...upgradeCommands,
30
32
  ]);
31
33
  }
32
34
  export { allCommandNames };
@@ -1 +1 @@
1
- {"version":3,"file":"command-handler.js","sourceRoot":"","sources":["../../src/tui/command-handler.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"command-handler.js","sourceRoot":"","sources":["../../src/tui/command-handler.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AACvF,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAE7D,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAExC,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAEtD,IAAI,UAAU,GAAG,KAAK,CAAC;AAEvB,MAAM,UAAU,wBAAwB;IACtC,IAAI,UAAU;QAAE,OAAO;IACvB,UAAU,GAAG,IAAI,CAAC;IAClB,WAAW,CAAC;QACV,GAAG,eAAe;QAClB,GAAG,eAAe;QAClB,GAAG,aAAa;QAChB,GAAG,eAAe;QAClB,GAAG,eAAe;QAClB,GAAG,gBAAgB;QACnB,GAAG,YAAY;QACf,GAAG,aAAa;QAChB,GAAG,eAAe;KACnB,CAAC,CAAC;AACL,CAAC;AAED,OAAO,EAAE,eAAe,EAAE,CAAC;AAE3B,6EAA6E;AAC7E,MAAM,UAAU,gBAAgB,CAC9B,OAA4B,EAC5B,MAAuB,EACvB,SAAuC,EACvC,MAA2B,EAC3B,iBAA0C;IAE1C,MAAM,IAAI,GAAG,GAAG,EAAE,GAAE,CAAC,EACnB,SAAS,GAAG,KAAK,IAAI,EAAE,GAAE,CAAC,CAAC;IAC7B,OAAO;QACL,OAAO;QACP,MAAM;QACN,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,IAAI,EAAE,CAAC,EAAE,EAAS;QACvC,CAAC,EAAE,UAAU,CAAC,IAAI,CAAC;QACnB,OAAO,EAAE,WAAW;QACpB,SAAS,EAAE,KAAK;QAChB,eAAe,EAAE,IAAI;QACrB,gBAAgB,EAAE,KAAK;QACvB,SAAS,EAAE,EAAS;QACpB,cAAc,EAAE,EAAE;QAClB,uBAAuB,EAAE,EAAE;QAC3B,gBAAgB,EAAE,IAAI,CAAC,GAAG,EAAE;QAC5B,iBAAiB,EAAE,IAAI,CAAC,GAAG,EAAE;QAC7B,iBAAiB,EAAE,EAAE;QACrB,WAAW,EAAE,EAAE;QACf,iBAAiB,EAAE,KAAK;QACxB,iBAAiB,EAAE,EAAE;QACrB,kBAAkB,EAAE,IAAI;QACxB,oBAAoB,EAAE,CAAC;QACvB,eAAe,EAAE,IAAI;QACrB,cAAc,EAAE,IAAI,GAAG,EAAE;QACzB,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,IAAI;QACb,UAAU,EAAE,EAAE;QACd,4BAA4B,EAAE,CAAC;QAC/B,WAAW,EAAE,KAAK;QAClB,aAAa,EAAE,EAAE;QACjB,kBAAkB,EAAE,IAAI;QACxB,mBAAmB,EAAE,IAAI,GAAG,EAAE;QAC9B,gBAAgB,EAAE,KAAK;QACvB,cAAc,EAAE,KAAK;QACrB,YAAY,EAAE,KAAK;QACnB,cAAc,EAAE,CAAC;QACjB,aAAa,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE;QACrD,eAAe,EAAE,IAAI;QACrB,cAAc,EAAE,EAAE;QAClB,WAAW,EAAE,KAAK;QAClB,gBAAgB,EAAE,IAAI;QACtB,eAAe,EAAE,IAAI;QACrB,aAAa,EAAE,IAAI;QACnB,kBAAkB,EAAE,IAAI;QACxB,iBAAiB;QACjB,QAAQ,EAAE,KAAK,IAAI,EAAE;YACnB,IAAI,SAAS;gBAAE,MAAM,SAAS,EAAE,CAAC;QACnC,CAAC;QACD,gBAAgB,EAAE,KAAK,IAAI,EAAE,CAAC,IAAI;QAClC,qBAAqB,EAAE,SAAS;QAChC,oBAAoB,EAAE,SAAS;QAC/B,kBAAkB,EAAE,MAAM;QAC1B,cAAc,EAAE,SAAS;QACzB,aAAa,EAAE,IAAI;QACnB,cAAc,EAAE,SAAS;QACzB,sBAAsB,EAAE,SAAS;QACjC,eAAe,EAAE,SAAS;QAC1B,UAAU,EAAE,SAAS;QACrB,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC,IAAI;KAC1B,CAAC;AACJ,CAAC;AAUD,sFAAsF;AACtF,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,IAAY,EACZ,MAAuB;IAEvB,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACrC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;IAClD,IAAI,CAAC,OAAO;QAAE,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAEvE,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,oBAAoB,CAAC,CAAC;IACrD,MAAM,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;IAC/B,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,EAAE;QAC3C,GAAG;QACH,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE;QACvC,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;KAChC,CAAC,CAAC;IACH,IAAI,GAAG,GAAG,EAAE,EACV,GAAG,GAAG,EAAE,CAAC;IACX,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;QAC9B,IAAI,CAAC;YACH,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxB,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACZ,CAAC,EAAE,MAAM,CAAC,CAAC;IACX,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE;QAC5B,GAAG,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC,CAAC,CAAC;IACH,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE;QAC5B,GAAG,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC,CAAC,CAAC;IACH,MAAM,EAAE,GAAG,MAAM,IAAI,OAAO,CAAS,CAAC,GAAG,EAAE,EAAE;QAC3C,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YACzB,YAAY,CAAC,OAAO,CAAC,CAAC;YACtB,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;YACrB,YAAY,CAAC,OAAO,CAAC,CAAC;YACtB,GAAG,CAAC,CAAC,CAAC,CAAC;QACT,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,EAAE,MAAM,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC;AAC7E,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,IAAY,EACZ,OAA4B,EAC5B,MAAuB,EACvB,SAAuC,EACvC,MAA2B,EAC3B,iBAA0C;IAE1C,wBAAwB,EAAE,CAAC;IAC3B,MAAM,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;IAC9B,IAAI,CAAC,GAAG;QAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IAE9C,MAAM,QAAQ,GAAa,EAAE,CAAC;IAC9B,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC;IAC5B,MAAM,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC;IAC9B,OAAO,CAAC,GAAG,GAAG,CAAC,GAAG,IAAe,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IAChF,OAAO,CAAC,KAAK,GAAG,CAAC,GAAG,IAAe,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IAElF,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;QACpF,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACzC,MAAM,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACrC,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,OAAO,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACrD,CAAC;YAAS,CAAC;QACT,OAAO,CAAC,GAAG,GAAG,OAAO,CAAC;QACtB,OAAO,CAAC,KAAK,GAAG,OAAO,CAAC;IAC1B,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;AACtD,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visorcraft/idlehands",
3
- "version": "2.0.1",
3
+ "version": "2.1.0",
4
4
  "type": "module",
5
5
  "description": "Local-first coding agent CLI for OpenAI-compatible endpoints",
6
6
  "license": "MIT",