@rubytech/create-maxy 1.0.876 → 1.0.877

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 (55) hide show
  1. package/package.json +1 -1
  2. package/payload/platform/neo4j/edge-annotations.json +11 -3
  3. package/payload/platform/plugins/admin/hooks/archive-ingest-surface-gate.sh +11 -5
  4. package/payload/platform/plugins/admin/skills/onboarding/SKILL.md +5 -1
  5. package/payload/platform/plugins/cloudflare/scripts/setup-tunnel.sh +88 -9
  6. package/payload/platform/plugins/cloudflare/skills/setup-tunnel/SKILL.md +1 -1
  7. package/payload/platform/plugins/docs/references/admin-session.md +80 -0
  8. package/payload/platform/plugins/docs/references/platform.md +1 -1
  9. package/payload/platform/plugins/docs/references/plugins-guide.md +1 -0
  10. package/payload/platform/plugins/memory/PLUGIN.md +4 -1
  11. package/payload/platform/plugins/memory/mcp/dist/index.js +127 -0
  12. package/payload/platform/plugins/memory/mcp/dist/index.js.map +1 -1
  13. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.d.ts +2 -0
  14. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.d.ts.map +1 -0
  15. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.js +97 -0
  16. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-derive-insights.test.js.map +1 -0
  17. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.d.ts +2 -0
  18. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.d.ts.map +1 -0
  19. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.js +184 -0
  20. package/payload/platform/plugins/memory/mcp/dist/tools/__tests__/conversation-archive-enrich-rejection.test.js.map +1 -0
  21. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.d.ts +89 -0
  22. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.d.ts.map +1 -0
  23. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.js +542 -0
  24. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-derive-insights.js.map +1 -0
  25. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.d.ts +41 -0
  26. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.d.ts.map +1 -0
  27. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.js +116 -0
  28. package/payload/platform/plugins/memory/mcp/dist/tools/conversation-archive-enrich-rejection.js.map +1 -0
  29. package/payload/platform/plugins/memory/skills/conversation-archive-enrich/SKILL.md +159 -0
  30. package/payload/platform/templates/specialists/agents/database-operator.md +3 -2
  31. package/payload/server/chunk-GOZP57CX.js +1373 -0
  32. package/payload/server/chunk-I4AQMEJA.js +11265 -0
  33. package/payload/server/chunk-LU6TUP3E.js +2169 -0
  34. package/payload/server/chunk-RRVBWC66.js +667 -0
  35. package/payload/server/client-pool-VYDOIFG7.js +34 -0
  36. package/payload/server/cloudflare-task-tracker-M7APAYEF.js +20 -0
  37. package/payload/server/maxy-edge.js +6 -5
  38. package/payload/server/public/assets/{Checkbox-BsqexMy3.js → Checkbox-m3yLBLrp.js} +1 -1
  39. package/payload/server/public/assets/{admin-pIeHRytz.js → admin-DEm0CCga.js} +6 -6
  40. package/payload/server/public/assets/data-BkbjVYwP.js +1 -0
  41. package/payload/server/public/assets/graph-Cic-rDfg.js +1 -0
  42. package/payload/server/public/assets/{graph-labels-t_04n4zX.js → graph-labels-C13OVh5P.js} +1 -1
  43. package/payload/server/public/assets/{jsx-runtime-CGCRFPeX.css → jsx-runtime-DJwgVAMg.css} +1 -1
  44. package/payload/server/public/assets/{page-qI0NJSs6.js → page-BLRjaAoU.js} +1 -1
  45. package/payload/server/public/assets/{page-BM9O7QN8.js → page-p-Fj8Guk.js} +1 -1
  46. package/payload/server/public/assets/{public-oNo_2gt0.js → public-4udeVi_T.js} +1 -1
  47. package/payload/server/public/assets/{useVoiceRecorder-DVVSQc-9.js → useVoiceRecorder-JwwBC5pd.js} +1 -1
  48. package/payload/server/public/data.html +5 -5
  49. package/payload/server/public/graph.html +6 -6
  50. package/payload/server/public/index.html +8 -8
  51. package/payload/server/public/public.html +5 -5
  52. package/payload/server/server.js +53 -23
  53. package/payload/server/public/assets/data-rhAG7W2b.js +0 -1
  54. package/payload/server/public/assets/graph-DVAWZmkb.js +0 -1
  55. /package/payload/server/public/assets/{jsx-runtime-B8sGPXtT.js → jsx-runtime-Bd3TJ8Bg.js} +0 -0
@@ -1,19 +1,11 @@
1
1
  import {
2
2
  ACCOUNTS_DIR,
3
3
  ATTACHMENTS_ROOT,
4
- CDP_PORT,
5
- COMMERCIAL_MODE,
6
4
  Hono,
7
- LOG_DIR,
8
- MAXY_DIR,
9
5
  MAX_FILES_PER_MESSAGE,
10
6
  MAX_FILE_SIZE_BYTES,
11
7
  PLATFORM_ROOT,
12
8
  SUPPORTED_MIME_TYPES,
13
- TELEGRAM_ADMIN_WEBHOOK_SECRET_FILE,
14
- TELEGRAM_WEBHOOK_SECRET_FILE,
15
- USERS_FILE,
16
- WEBSOCKIFY_PORT,
17
9
  assertSupportedMime,
18
10
  autoDeliverPremiumPlugins,
19
11
  browserViewerLog,
@@ -83,12 +75,22 @@ import {
83
75
  vncLog,
84
76
  waitForExit,
85
77
  writeChromiumWrapper
86
- } from "./chunk-5U36PKG4.js";
78
+ } from "./chunk-I4AQMEJA.js";
87
79
  import {
80
+ CDP_PORT,
81
+ COMMERCIAL_MODE,
82
+ LOG_DIR,
83
+ MAXY_DIR,
84
+ TELEGRAM_ADMIN_WEBHOOK_SECRET_FILE,
85
+ TELEGRAM_WEBHOOK_SECRET_FILE,
86
+ USERS_FILE,
87
+ WEBSOCKIFY_PORT,
88
88
  agentLogStream,
89
89
  clearSessionHistory,
90
90
  completeGrantSetup,
91
+ consumeWantsPriorConversation,
91
92
  getAccountIdForSession,
93
+ getActiveClient,
92
94
  getAgentNameForSession,
93
95
  getConversationIdForSession,
94
96
  getGrantForSession,
@@ -100,6 +102,7 @@ import {
100
102
  getVisitorIdForSession,
101
103
  interruptClient,
102
104
  listAdminSessionsInProgress,
105
+ mintAdminSessionKey,
103
106
  preConversationLogStream,
104
107
  registerGrantSession,
105
108
  registerResumedSession,
@@ -107,10 +110,11 @@ import {
107
110
  setAgentSessionId,
108
111
  setConversationIdForSession,
109
112
  setGroupContextForSession,
113
+ setWantsPriorConversation,
110
114
  sigtermFlushStreamLogs,
111
115
  unregisterSession,
112
116
  validateSession
113
- } from "./chunk-NDEQBCVI.js";
117
+ } from "./chunk-GOZP57CX.js";
114
118
  import {
115
119
  CLOUDFLARE_TASK_DIAGNOSTICS,
116
120
  appendCloudflareSteps,
@@ -118,7 +122,7 @@ import {
118
122
  openCloudflareTask,
119
123
  readTunnelState,
120
124
  resolveUnitGoneVerdict
121
- } from "./chunk-UXLZ5Z3Y.js";
125
+ } from "./chunk-RRVBWC66.js";
122
126
  import {
123
127
  GREETING_DIRECTIVE,
124
128
  HAIKU_MODEL,
@@ -137,6 +141,7 @@ import {
137
141
  getAgentSessionIdForConversation,
138
142
  getGroupParticipants,
139
143
  getMessagesSince,
144
+ getMostRecentAdminConversationForUser,
140
145
  getRecentMessages,
141
146
  getSession,
142
147
  getUserTimezone,
@@ -150,7 +155,7 @@ import {
150
155
  verifyAndGetConversationUpdatedAt,
151
156
  verifyConversationOwnership,
152
157
  writeAdminUserAndPerson
153
- } from "./chunk-FHNFKJZN.js";
158
+ } from "./chunk-LU6TUP3E.js";
154
159
  import {
155
160
  __commonJS,
156
161
  __toESM
@@ -7000,8 +7005,9 @@ async function resolveUserIdentity(accountId, userId) {
7000
7005
  async function createAdminSession(accountId, thinkingView, userId, userName, role, avatar) {
7001
7006
  const account = resolveAccount();
7002
7007
  const effectiveThinkingView = thinkingView ?? account?.config.thinkingView ?? "default";
7003
- const sessionKey = crypto.randomUUID();
7008
+ const sessionKey = userId ? mintAdminSessionKey({ accountId, userId }) : crypto.randomUUID();
7004
7009
  registerSession(sessionKey, "admin", accountId, void 0, userId, userName, role);
7010
+ if (userId) setWantsPriorConversation(sessionKey);
7005
7011
  let onboardingComplete = true;
7006
7012
  try {
7007
7013
  const step = await loadOnboardingStep(accountId);
@@ -7439,7 +7445,7 @@ var app11 = new Hono();
7439
7445
  app11.post("/cancel", requireAdminSession, async (c) => {
7440
7446
  const session_key = c.var.sessionKey;
7441
7447
  try {
7442
- const { interruptClient: interruptClient2 } = await import("./client-pool-XAEDMS5D.js");
7448
+ const { interruptClient: interruptClient2 } = await import("./client-pool-VYDOIFG7.js");
7443
7449
  await interruptClient2(session_key);
7444
7450
  return c.json({ ok: true });
7445
7451
  } catch (err) {
@@ -7596,22 +7602,41 @@ app11.post("/", requireAdminSession, async (c) => {
7596
7602
  if (!isSystemMessage) {
7597
7603
  gatewayResult = await processInbound(message, "web-admin");
7598
7604
  }
7605
+ let acquireReason = "cold";
7606
+ let resumedAgentSessionId = null;
7599
7607
  let conversationId = getConversationIdForSession(session_key);
7600
- if (!conversationId) {
7608
+ if (conversationId) {
7609
+ acquireReason = getActiveClient(session_key) ? "warm" : "cold";
7610
+ } else {
7601
7611
  const userId = getUserIdForSession(session_key);
7602
7612
  const userName = getUserNameForSession(session_key);
7603
7613
  const accountId = getAccountIdForSession(session_key);
7604
7614
  if (!userId || !accountId) {
7605
7615
  return chatReject(401, "Invalid or expired admin session", session_key);
7606
7616
  }
7607
- const minted = randomUUID6();
7608
- const created = await createNewAdminConversation(userId, accountId, session_key, userName, minted);
7609
- if (!created) {
7610
- return chatReject(500, "Failed to create conversation", session_key);
7617
+ const wantsPrior = consumeWantsPriorConversation(session_key);
7618
+ const prior = wantsPrior ? await getMostRecentAdminConversationForUser(accountId, userId) : null;
7619
+ if (prior) {
7620
+ conversationId = prior.conversationId;
7621
+ setConversationIdForSession(session_key, conversationId);
7622
+ setAgentSessionId(session_key, prior.agentSessionId);
7623
+ resumedAgentSessionId = prior.agentSessionId;
7624
+ acquireReason = "pin-rebind";
7625
+ console.log(`[chat-route] resume-from-prior conversationId=${conversationId.slice(0, 8)}\u2026 priorAgentSessionId=${prior.agentSessionId.slice(0, 8)}\u2026 sessionKey=${session_key.slice(0, 12)}\u2026`);
7626
+ } else {
7627
+ if (wantsPrior) {
7628
+ console.log(`[chat-route] prior-conversation-not-found accountId=${accountId.slice(0, 8)}\u2026 userId=${userId.slice(0, 8)}\u2026 sessionKey=${session_key.slice(0, 12)}\u2026 \u2014 cold-minting`);
7629
+ }
7630
+ const minted = randomUUID6();
7631
+ const created = await createNewAdminConversation(userId, accountId, session_key, userName, minted);
7632
+ if (!created) {
7633
+ return chatReject(500, "Failed to create conversation", session_key);
7634
+ }
7635
+ conversationId = created;
7636
+ setConversationIdForSession(session_key, conversationId);
7637
+ acquireReason = "cold";
7638
+ console.log(`[chat-route] new conversation conversationId=${conversationId} sessionKey=${session_key.slice(0, 12)}\u2026`);
7611
7639
  }
7612
- conversationId = created;
7613
- setConversationIdForSession(session_key, conversationId);
7614
- console.log(`[chat-route] new conversation conversationId=${conversationId} sessionKey=${session_key.slice(0, 12)}\u2026`);
7615
7640
  }
7616
7641
  const encoder = new TextEncoder();
7617
7642
  const sseLogStream = agentLogStream("sse-events", account.accountDir, conversationId);
@@ -7619,6 +7644,11 @@ app11.post("/", requireAdminSession, async (c) => {
7619
7644
  const teeStreamLogPath = resolve8(account.accountDir, "logs", `claude-agent-stream-${conversationId}.log`);
7620
7645
  try {
7621
7646
  appendFileSync3(teeStreamLogPath, `[${(/* @__PURE__ */ new Date()).toISOString()}] [chat-route-version=task965-mint-at-entry] sessionKey=${session_key.slice(0, 12)}\u2026 conversationId=${conversationId}
7647
+ `);
7648
+ } catch {
7649
+ }
7650
+ try {
7651
+ appendFileSync3(teeStreamLogPath, `[${(/* @__PURE__ */ new Date()).toISOString()}] [client-acquire] sessionKey=${session_key.slice(0, 12)}\u2026 resume=${resumedAgentSessionId ? resumedAgentSessionId.slice(0, 8) + "\u2026" : "none"} reason=${acquireReason}
7622
7652
  `);
7623
7653
  } catch {
7624
7654
  }
@@ -13467,7 +13497,7 @@ autoDeliverPremiumPlugins(bootEntitlement?.purchasedPlugins ?? void 0);
13467
13497
  (async () => {
13468
13498
  if (!bootAccount) return;
13469
13499
  try {
13470
- const { recoverRunningCloudflareTasks } = await import("./cloudflare-task-tracker-OCFIVXEJ.js");
13500
+ const { recoverRunningCloudflareTasks } = await import("./cloudflare-task-tracker-M7APAYEF.js");
13471
13501
  const result = await recoverRunningCloudflareTasks(
13472
13502
  bootAccount.accountId,
13473
13503
  configDirForWhatsApp,
@@ -1 +0,0 @@
1
- import{i as e,t}from"./jsx-runtime-B8sGPXtT.js";import{t as n}from"./page-BM9O7QN8.js";import"./graph-labels-t_04n4zX.js";var r=e(),i=t();(0,r.createRoot)(document.getElementById(`root`)).render((0,i.jsx)(n,{}));
@@ -1 +0,0 @@
1
- import{i as e,t}from"./jsx-runtime-B8sGPXtT.js";import{n}from"./page-qI0NJSs6.js";import"./graph-labels-t_04n4zX.js";import"./Checkbox-BsqexMy3.js";var r=e(),i=t();(0,r.createRoot)(document.getElementById(`root`)).render((0,i.jsx)(n,{}));