@rubytech/create-maxy 1.0.774 → 1.0.775

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 (40) hide show
  1. package/package.json +1 -1
  2. package/payload/platform/config/brand.json +1 -0
  3. package/payload/platform/lib/entitlement/PUBKEY-HASH.txt +1 -0
  4. package/payload/platform/lib/entitlement/dist/canonicalize.d.ts +26 -0
  5. package/payload/platform/lib/entitlement/dist/canonicalize.d.ts.map +1 -0
  6. package/payload/platform/lib/entitlement/dist/canonicalize.js +54 -0
  7. package/payload/platform/lib/entitlement/dist/canonicalize.js.map +1 -0
  8. package/payload/platform/lib/entitlement/dist/index.d.ts +76 -0
  9. package/payload/platform/lib/entitlement/dist/index.d.ts.map +1 -0
  10. package/payload/platform/lib/entitlement/dist/index.js +293 -0
  11. package/payload/platform/lib/entitlement/dist/index.js.map +1 -0
  12. package/payload/platform/lib/entitlement/rubytech-pubkey.pem +3 -0
  13. package/payload/platform/package.json +2 -2
  14. package/payload/platform/plugins/admin/hooks/pre-tool-use.sh +32 -0
  15. package/payload/platform/plugins/admin/mcp/dist/index.js +97 -6
  16. package/payload/platform/plugins/admin/mcp/dist/index.js.map +1 -1
  17. package/payload/platform/plugins/admin/skills/plugin-management/SKILL.md +10 -5
  18. package/payload/platform/scripts/generate-entitlement-fixture.mjs +152 -0
  19. package/payload/server/chunk-MIP54X7Q.js +3244 -0
  20. package/payload/server/chunk-TM3EQSID.js +9800 -0
  21. package/payload/server/client-pool-4MZN42GG.js +28 -0
  22. package/payload/server/maxy-edge.js +2 -2
  23. package/payload/server/public/assets/{Checkbox-DEE8t2QO.js → Checkbox-C_KxaLc-.js} +1 -1
  24. package/payload/server/public/assets/{admin-BCLHIuWG.js → admin-xbKPR6ZI.js} +30 -30
  25. package/payload/server/public/assets/data-D23IzpJ2.js +1 -0
  26. package/payload/server/public/assets/graph-D2AS9zFS.js +1 -0
  27. package/payload/server/public/assets/{jsx-runtime-DSbkOE76.css → jsx-runtime-BZtBxBng.css} +1 -1
  28. package/payload/server/public/assets/{page-BOpPVs9J.js → page-CjTfZ3O6.js} +1 -1
  29. package/payload/server/public/assets/{page-ZATk95ZG.js → page-DEWgk_nR.js} +1 -1
  30. package/payload/server/public/assets/{public-BLi3J8KU.js → public-CehiL-qZ.js} +1 -1
  31. package/payload/server/public/assets/{share-2-DS7Pnkkq.js → share-2-BG1VXt3z.js} +1 -1
  32. package/payload/server/public/assets/{useVoiceRecorder-pEHqS1ib.js → useVoiceRecorder-1Dvb-yHn.js} +1 -1
  33. package/payload/server/public/data.html +5 -5
  34. package/payload/server/public/graph.html +6 -6
  35. package/payload/server/public/index.html +8 -8
  36. package/payload/server/public/public.html +5 -5
  37. package/payload/server/server.js +31 -16
  38. package/payload/server/public/assets/data-ryPag-T-.js +0 -1
  39. package/payload/server/public/assets/graph-CD-Zqscg.js +0 -1
  40. /package/payload/server/public/assets/{jsx-runtime-DeNudFNA.js → jsx-runtime-DrneHL3t.js} +0 -0
@@ -1,4 +1,5 @@
1
1
  import {
2
+ COMMERCIAL_MODE,
2
3
  Hono,
3
4
  LOG_DIR,
4
5
  MAXY_DIR,
@@ -34,6 +35,7 @@ import {
34
35
  requireAdminSession,
35
36
  resolveBrowserTransport,
36
37
  resolveClientIp,
38
+ resolveEntitlement,
37
39
  safeJson,
38
40
  sanitizeClientCorrId,
39
41
  serve,
@@ -47,7 +49,7 @@ import {
47
49
  vncLog,
48
50
  waitForExit,
49
51
  writeChromiumWrapper
50
- } from "./chunk-PIMJJCOQ.js";
52
+ } from "./chunk-TM3EQSID.js";
51
53
  import {
52
54
  ACCOUNTS_DIR,
53
55
  GREETING_DIRECTIVE,
@@ -109,7 +111,7 @@ import {
109
111
  verifyAndGetConversationUpdatedAt,
110
112
  verifyConversationOwnership,
111
113
  writeAdminUserAndPerson
112
- } from "./chunk-2HBD6IRL.js";
114
+ } from "./chunk-MIP54X7Q.js";
113
115
 
114
116
  // ../lib/graph-trash/dist/index.js
115
117
  var require_dist = __commonJS({
@@ -7763,16 +7765,17 @@ function stripLegacyNameField(users) {
7763
7765
  console.error(`[admin-identity] users-json strip failed: ${err instanceof Error ? err.message : String(err)}`);
7764
7766
  }
7765
7767
  }
7766
- async function resolveUserName(accountId, userId) {
7768
+ async function resolveUserIdentity(accountId, userId) {
7767
7769
  const result = await loadAdminUserName(accountId, userId);
7768
7770
  if (result.source === "neo4j") {
7769
- console.log(`[admin-identity] userName-source=neo4j userId=${userId.slice(0, 8)} givenName=${result.givenName} familyName=${result.familyName ?? "null"} joined=${result.joined}`);
7770
- return result.joined;
7771
+ console.log(`[admin-identity] userName-source=neo4j userId=${userId.slice(0, 8)} givenName=${result.givenName} familyName=${result.familyName ?? "null"} joined=${result.joined} avatar=${result.avatar ? "present" : "absent"}`);
7772
+ return { userName: result.joined, avatar: result.avatar };
7771
7773
  }
7772
7774
  console.log(`[admin-identity] userName-source=fallback reason=${result.reason} userId=${userId.slice(0, 8)} accountId=${accountId.slice(0, 8)}`);
7773
- return result.reason === "neo4j-unreachable" ? "Owner" : void 0;
7775
+ const userName = result.reason === "neo4j-unreachable" ? "Owner" : void 0;
7776
+ return { userName, avatar: null };
7774
7777
  }
7775
- async function createAdminSession(accountId, thinkingView, userId, userName, role) {
7778
+ async function createAdminSession(accountId, thinkingView, userId, userName, role, avatar) {
7776
7779
  const account = resolveAccount();
7777
7780
  const effectiveThinkingView = thinkingView ?? account?.config.thinkingView ?? "default";
7778
7781
  const sessionKey = crypto.randomUUID();
@@ -7797,6 +7800,7 @@ async function createAdminSession(accountId, thinkingView, userId, userName, rol
7797
7800
  agent_id: "admin",
7798
7801
  userId,
7799
7802
  userName,
7803
+ avatar: avatar ?? null,
7800
7804
  role: role ?? null,
7801
7805
  thinkingView: effectiveThinkingView,
7802
7806
  onboardingComplete,
@@ -7833,11 +7837,13 @@ app10.get("/", async (c) => {
7833
7837
  console.log(`[admin-session] role=${role ?? "null"} sessionKey=${sessionKey.slice(0, 8)} phase=restore`);
7834
7838
  const restoredUserId = getUserIdForSession(sessionKey);
7835
7839
  let restoredUserName = getUserNameForSession(sessionKey);
7840
+ let restoredAvatar = null;
7836
7841
  if (restoredUserId) {
7837
- const resolved = await resolveUserName(accountId, restoredUserId);
7838
- restoredUserName = resolved;
7839
- if (resolved !== void 0) {
7840
- registerSession(sessionKey, "admin", accountId, void 0, restoredUserId, resolved, role ?? void 0);
7842
+ const resolved = await resolveUserIdentity(accountId, restoredUserId);
7843
+ restoredUserName = resolved.userName;
7844
+ restoredAvatar = resolved.avatar;
7845
+ if (resolved.userName !== void 0) {
7846
+ registerSession(sessionKey, "admin", accountId, void 0, restoredUserId, resolved.userName, role ?? void 0);
7841
7847
  }
7842
7848
  }
7843
7849
  return c.json({
@@ -7845,6 +7851,7 @@ app10.get("/", async (c) => {
7845
7851
  agent_id: "admin",
7846
7852
  userId: restoredUserId,
7847
7853
  userName: restoredUserName,
7854
+ avatar: restoredAvatar,
7848
7855
  role: role ?? null,
7849
7856
  thinkingView,
7850
7857
  onboardingComplete,
@@ -7903,8 +7910,8 @@ app10.post("/", async (c) => {
7903
7910
  console.log(`[session] account selection invalid: userId=${userId} requested=${body.accountId}`);
7904
7911
  return c.json({ error: "Invalid account selection." }, 403);
7905
7912
  }
7906
- const userName = await resolveUserName(selected.accountId, userId);
7907
- const payload = await createAdminSession(selected.accountId, selected.config.thinkingView, userId, userName, selected.role);
7913
+ const { userName, avatar } = await resolveUserIdentity(selected.accountId, userId);
7914
+ const payload = await createAdminSession(selected.accountId, selected.config.thinkingView, userId, userName, selected.role, avatar);
7908
7915
  return c.json(payload);
7909
7916
  });
7910
7917
  var session_default2 = app10;
@@ -8201,7 +8208,7 @@ var app11 = new Hono();
8201
8208
  app11.post("/cancel", requireAdminSession, async (c) => {
8202
8209
  const session_key = c.var.sessionKey;
8203
8210
  try {
8204
- const { interruptClient: interruptClient2 } = await import("./client-pool-U3A5YUO7.js");
8211
+ const { interruptClient: interruptClient2 } = await import("./client-pool-4MZN42GG.js");
8205
8212
  await interruptClient2(session_key);
8206
8213
  return c.json({ ok: true });
8207
8214
  } catch (err) {
@@ -12966,8 +12973,16 @@ var configDirForWhatsApp = basename7(MAXY_DIR) || ".maxy";
12966
12973
  var bootAccount = resolveAccount();
12967
12974
  var bootAccountConfig = bootAccount?.config;
12968
12975
  var bootPublicAgent = bootAccount ? getPublicAgent(bootAccount.accountDir) : null;
12969
- var bootPurchased = Array.isArray(bootAccountConfig?.purchasedPlugins) ? bootAccountConfig.purchasedPlugins : void 0;
12970
- autoDeliverPremiumPlugins(bootPurchased);
12976
+ var bootEntitlement = bootAccountConfig ? resolveEntitlement(
12977
+ { configDir: MAXY_DIR, platformRoot: PLATFORM_ROOT, commercialMode: COMMERCIAL_MODE },
12978
+ {
12979
+ accountId: typeof bootAccountConfig.accountId === "string" ? bootAccountConfig.accountId : "",
12980
+ customerEmail: typeof bootAccountConfig.customerEmail === "string" ? bootAccountConfig.customerEmail : void 0,
12981
+ tier: typeof bootAccountConfig.tier === "string" ? bootAccountConfig.tier : void 0,
12982
+ purchasedPlugins: Array.isArray(bootAccountConfig.purchasedPlugins) ? bootAccountConfig.purchasedPlugins : void 0
12983
+ }
12984
+ ) : null;
12985
+ autoDeliverPremiumPlugins(bootEntitlement?.purchasedPlugins ?? void 0);
12971
12986
  var bootEnabled = Array.isArray(bootAccountConfig?.enabledPlugins) ? bootAccountConfig.enabledPlugins : [];
12972
12987
  var bootDelivered = [];
12973
12988
  var bootDistMissing = [];
@@ -1 +0,0 @@
1
- import{i as e,t}from"./jsx-runtime-DeNudFNA.js";import{t as n}from"./page-ZATk95ZG.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-DeNudFNA.js";import{n}from"./page-BOpPVs9J.js";import"./Checkbox-DEE8t2QO.js";var r=e(),i=t();(0,r.createRoot)(document.getElementById(`root`)).render((0,i.jsx)(n,{}));