prior-cli 1.6.3 → 1.6.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 (2) hide show
  1. package/bin/prior.js +43 -1
  2. package/package.json +1 -1
package/bin/prior.js CHANGED
@@ -45,6 +45,48 @@ let _spinIdx = 0;
45
45
  let _spinStart = null;
46
46
  let _spinLabel = '';
47
47
 
48
+ // ── Tool keyword hints ─────────────────────────────────────────
49
+ // Detects keywords in user input and prepends a hard directive so
50
+ // the model can't second-guess which tool to use.
51
+ const TOOL_HINTS = [
52
+ {
53
+ tool: 'ssl_check',
54
+ patterns: [
55
+ /\bssl\b/i, /\btls\b/i, /\bcertificate\b/i, /\bcert\b/i,
56
+ /\bhttps check\b/i, /\bcert expir/i, /\bssl expir/i,
57
+ ],
58
+ hint: '[TOOL DIRECTIVE: You MUST call ssl_check — do NOT use zap_scan or zap_alerts]',
59
+ },
60
+ {
61
+ tool: 'dns_lookup',
62
+ patterns: [
63
+ /\bdns\b/i, /\bmx record/i, /\bnameserver/i, /\bnslookup\b/i,
64
+ /\bdig\b/i, /\bdns record/i, /\btxt record/i, /\bcname\b/i,
65
+ /\bns record/i, /\baaaa record/i,
66
+ ],
67
+ hint: '[TOOL DIRECTIVE: You MUST call dns_lookup]',
68
+ },
69
+ {
70
+ tool: 'ip_lookup',
71
+ patterns: [
72
+ /\bip lookup\b/i, /\blook up.*ip\b/i, /\bwhere is .+ hosted\b/i,
73
+ /\bwho owns .+(ip|domain)\b/i, /\basn\b/i, /\bgeolocation\b/i,
74
+ /\bwhat ip\b/i, /\bresolve .+(domain|host)\b/i,
75
+ /\blookup\b.*\b(ip|domain|host)\b/i,
76
+ ],
77
+ hint: '[TOOL DIRECTIVE: You MUST call ip_lookup]',
78
+ },
79
+ ];
80
+
81
+ function injectToolHint(text) {
82
+ for (const { patterns, hint } of TOOL_HINTS) {
83
+ if (patterns.some(re => re.test(text))) {
84
+ return `${hint}\n${text}`;
85
+ }
86
+ }
87
+ return text;
88
+ }
89
+
48
90
  function fmtElapsed(ms) {
49
91
  const s = Math.floor(ms / 1000);
50
92
  if (s < 60) return `${s}s`;
@@ -1285,7 +1327,7 @@ Be concise but thorough — this summary replaces the full history to save conte
1285
1327
 
1286
1328
  _currentAbortController = new AbortController();
1287
1329
  await runAgent({
1288
- messages: [...chatHistory, { role: 'user', content: input }],
1330
+ messages: [...chatHistory, { role: 'user', content: injectToolHint(input) }],
1289
1331
  model: currentModel,
1290
1332
  cwd: process.cwd(),
1291
1333
  projectContext,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "prior-cli",
3
- "version": "1.6.3",
3
+ "version": "1.6.4",
4
4
  "description": "Prior Network AI — command-line interface",
5
5
  "bin": {
6
6
  "prior": "bin/prior.js"