instar 0.28.19 → 0.28.21

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 (46) hide show
  1. package/dist/cli.js +0 -0
  2. package/dist/commands/init.js +2 -2
  3. package/dist/commands/server.d.ts.map +1 -1
  4. package/dist/commands/server.js +27 -22
  5. package/dist/commands/server.js.map +1 -1
  6. package/dist/core/CoherenceGate.d.ts +7 -0
  7. package/dist/core/CoherenceGate.d.ts.map +1 -1
  8. package/dist/core/CoherenceGate.js +57 -3
  9. package/dist/core/CoherenceGate.js.map +1 -1
  10. package/dist/core/CoherenceReviewer.d.ts +2 -0
  11. package/dist/core/CoherenceReviewer.d.ts.map +1 -1
  12. package/dist/core/CoherenceReviewer.js.map +1 -1
  13. package/dist/core/SendGateway.d.ts +13 -3
  14. package/dist/core/SendGateway.d.ts.map +1 -1
  15. package/dist/core/SendGateway.js +107 -4
  16. package/dist/core/SendGateway.js.map +1 -1
  17. package/dist/core/reviewers/claim-provenance.d.ts.map +1 -1
  18. package/dist/core/reviewers/claim-provenance.js +11 -1
  19. package/dist/core/reviewers/claim-provenance.js.map +1 -1
  20. package/dist/core/reviewers/url-validity.d.ts.map +1 -1
  21. package/dist/core/reviewers/url-validity.js +12 -1
  22. package/dist/core/reviewers/url-validity.js.map +1 -1
  23. package/dist/core/types.d.ts +1 -1
  24. package/dist/core/types.d.ts.map +1 -1
  25. package/dist/scaffold/templates.js +2 -2
  26. package/dist/server/AgentServer.d.ts +1 -0
  27. package/dist/server/AgentServer.d.ts.map +1 -1
  28. package/dist/server/routes.d.ts +4 -1
  29. package/dist/server/routes.d.ts.map +1 -1
  30. package/dist/server/routes.js +98 -22
  31. package/dist/server/routes.js.map +1 -1
  32. package/dist/threadline/ThreadlineMCPServer.d.ts +4 -0
  33. package/dist/threadline/ThreadlineMCPServer.d.ts.map +1 -1
  34. package/dist/threadline/ThreadlineMCPServer.js +7 -1
  35. package/dist/threadline/ThreadlineMCPServer.js.map +1 -1
  36. package/dist/threadline/ThreadlineRouter.d.ts +17 -1
  37. package/dist/threadline/ThreadlineRouter.d.ts.map +1 -1
  38. package/dist/threadline/ThreadlineRouter.js +64 -5
  39. package/dist/threadline/ThreadlineRouter.js.map +1 -1
  40. package/dist/threadline/mcp-stdio-entry.js +2 -0
  41. package/dist/threadline/mcp-stdio-entry.js.map +1 -1
  42. package/package.json +1 -1
  43. package/src/data/builtin-manifest.json +48 -48
  44. package/upgrades/0.28.20.md +19 -0
  45. package/upgrades/0.28.21.md +23 -0
  46. package/upgrades/NEXT.md +26 -5
package/dist/cli.js CHANGED
File without changes
@@ -1178,7 +1178,7 @@ curl -X POST http://localhost:${port}/feedback \\
1178
1178
  -d '{"type":"bug","title":"Short description","description":"Full details with context"}'
1179
1179
  \`\`\`
1180
1180
 
1181
- This routes feedback to the Instar maintainers automatically. Valid types: \`bug\`, \`feature\`, \`improvement\`, \`question\`.
1181
+ This routes feedback to the Instar maintainers automatically. Valid types: \`bug\`, \`feature\`, \`improvement\`, \`question\`, \`hallucination\`.
1182
1182
 
1183
1183
  **NEVER use \`gh issue\`, \`gh api\`, or GitHub CLI to file issues.** The feedback API is your channel.
1184
1184
  - View submitted feedback: \`curl http://localhost:${port}/feedback\`
@@ -3275,7 +3275,7 @@ curl -s -X POST http://localhost:${port}/feedback \\
3275
3275
  -d '{"type":"bug","title":"CONCISE_TITLE","description":"FULL_CONTEXT_WITH_ERROR_MESSAGES"}'
3276
3276
  \`\`\`
3277
3277
 
3278
- Types: \`bug\`, \`feature\`, \`improvement\`, \`question\`
3278
+ Types: \`bug\`, \`feature\`, \`improvement\`, \`question\`, \`hallucination\`
3279
3279
 
3280
3280
  **Do not wait for the user to notice.** If a hook throws an error, report it. If a job fails, report it. If the server returns unexpected data, report it. You are not just using instar — you are part of its immune system.
3281
3281
  `);
@@ -1 +1 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/commands/server.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AA2PH,UAAU,YAAY;IACpB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb;2DACuD;IACvD,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA6zCD,wBAAsB,WAAW,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CA2oItE;AAED,wBAAsB,UAAU,CAAC,OAAO,EAAE;IAAE,GAAG,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAsDzE;AAED;;;;;;;;;;;GAWG;AACH,wBAAsB,aAAa,CAAC,OAAO,EAAE;IAAE,GAAG,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAuD5E"}
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/commands/server.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AA2PH,UAAU,YAAY;IACpB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb;2DACuD;IACvD,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA6zCD,wBAAsB,WAAW,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAipItE;AAED,wBAAsB,UAAU,CAAC,OAAO,EAAE;IAAE,GAAG,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAsDzE;AAED;;;;;;;;;;;GAWG;AACH,wBAAsB,aAAa,CAAC,OAAO,EAAE;IAAE,GAAG,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAuD5E"}
@@ -4658,7 +4658,8 @@ export async function startServer(options) {
4658
4658
  },
4659
4659
  });
4660
4660
  // Threadline Router — handles threaded cross-agent conversations via relay
4661
- const threadlineRouter = new ThreadlineRouter(messageRouter, spawnManager, threadResumeMap, messageStore, { localAgent: config.projectName, localMachine: os.hostname() });
4661
+ const threadlineRouter = new ThreadlineRouter(messageRouter, spawnManager, threadResumeMap, messageStore, { localAgent: config.projectName, localMachine: os.hostname() }, null, // autonomyGate
4662
+ messageDelivery);
4662
4663
  // Listener Session Manager — warm session for fast relay responses (Phase 2)
4663
4664
  const listenerManager = config.threadline?.relayEnabled
4664
4665
  ? new ListenerSessionManager(config.stateDir, config.authToken ?? '', config.threadline)
@@ -4873,30 +4874,34 @@ export async function startServer(options) {
4873
4874
  }
4874
4875
  // Check if this message resolves a pending waitForReply request.
4875
4876
  // Skip auto-ack messages (they're from us, not a real reply).
4876
- // Try both fingerprint and agent name as keys the waiter is keyed by
4877
- // agent name (from relay-send), but gate-passed provides the fingerprint.
4877
+ // PR-3: Waiters are now keyed by threadId (unique per conversation)
4878
+ // rather than sender fingerprint or agent name. Fall back to the
4879
+ // legacy fingerprint/name lookup only if no threadId is present,
4880
+ // for compatibility with older senders.
4878
4881
  const isAutoAck = textContent.startsWith('Message received.') || textContent.startsWith('Message received,');
4879
- let waiter = threadlineReplyWaiters.get(senderFingerprint);
4882
+ let waiter = msg.threadId ? threadlineReplyWaiters.get(msg.threadId) : undefined;
4880
4883
  if (!waiter) {
4881
- // Resolve fingerprint agent name via known-agents cache
4882
- const resolvedName = (() => {
4883
- try {
4884
- const kaPath = path.join(config.stateDir, 'threadline', 'known-agents.json');
4885
- const kaData = JSON.parse(fs.readFileSync(kaPath, 'utf-8'));
4886
- const agents = kaData.agents ?? kaData;
4887
- if (Array.isArray(agents)) {
4888
- // Check publicKey field for fingerprint match
4889
- const match = agents.find((a) => a.publicKey === senderFingerprint || a.publicKey?.startsWith(senderFingerprint));
4890
- return match?.name ?? null;
4884
+ // Legacy fallback: try by sender fingerprint, then by resolved name
4885
+ waiter = threadlineReplyWaiters.get(senderFingerprint);
4886
+ if (!waiter) {
4887
+ const resolvedName = (() => {
4888
+ try {
4889
+ const kaPath = path.join(config.stateDir, 'threadline', 'known-agents.json');
4890
+ const kaData = JSON.parse(fs.readFileSync(kaPath, 'utf-8'));
4891
+ const agents = kaData.agents ?? kaData;
4892
+ if (Array.isArray(agents)) {
4893
+ const match = agents.find((a) => a.publicKey === senderFingerprint || a.publicKey?.startsWith(senderFingerprint));
4894
+ return match?.name ?? null;
4895
+ }
4896
+ return null;
4891
4897
  }
4892
- return null;
4893
- }
4894
- catch {
4895
- return null;
4896
- }
4897
- })();
4898
- if (resolvedName)
4899
- waiter = threadlineReplyWaiters.get(resolvedName);
4898
+ catch {
4899
+ return null;
4900
+ }
4901
+ })();
4902
+ if (resolvedName)
4903
+ waiter = threadlineReplyWaiters.get(resolvedName);
4904
+ }
4900
4905
  }
4901
4906
  if (waiter && !isAutoAck) {
4902
4907
  waiter.resolve(textContent);