funifier-mcp 0.2.27 → 0.2.28

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.
@@ -1,2 +1,7 @@
1
+ declare function isOutdated(current: string, latest: string): boolean;
2
+ export declare function setUpdateNotice(notice: string): void;
3
+ /** Returns the pending update notice once, then clears it (show only once per session). */
4
+ export declare function consumeUpdateNotice(): string | null;
1
5
  export declare function checkForUpdate(): Promise<void>;
6
+ export { isOutdated };
2
7
  //# sourceMappingURL=check-update.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"check-update.d.ts","sourceRoot":"","sources":["../../src/mcp/check-update.ts"],"names":[],"mappings":"AAaA,wBAAsB,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC,CA4BpD"}
1
+ {"version":3,"file":"check-update.d.ts","sourceRoot":"","sources":["../../src/mcp/check-update.ts"],"names":[],"mappings":"AAAA,iBAAS,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAW5D;AAMD,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAEpD;AAED,2FAA2F;AAC3F,wBAAgB,mBAAmB,IAAI,MAAM,GAAG,IAAI,CAInD;AAED,wBAAsB,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC,CAsBpD;AAED,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -1,6 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.setUpdateNotice = setUpdateNotice;
4
+ exports.consumeUpdateNotice = consumeUpdateNotice;
3
5
  exports.checkForUpdate = checkForUpdate;
6
+ exports.isOutdated = isOutdated;
4
7
  function isOutdated(current, latest) {
5
8
  const toTuple = (v) => v
6
9
  .replace(/[^0-9.]/g, "")
@@ -14,6 +17,18 @@ function isOutdated(current, latest) {
14
17
  return lMin > cMin;
15
18
  return lPatch > cPatch;
16
19
  }
20
+ // Set when an update is detected; surfaced once on the next tool result so the
21
+ // user actually sees it (stdio MCP stderr is hidden from chat by most clients).
22
+ let pendingNotice = null;
23
+ function setUpdateNotice(notice) {
24
+ pendingNotice = notice;
25
+ }
26
+ /** Returns the pending update notice once, then clears it (show only once per session). */
27
+ function consumeUpdateNotice() {
28
+ const notice = pendingNotice;
29
+ pendingNotice = null;
30
+ return notice;
31
+ }
17
32
  async function checkForUpdate() {
18
33
  // eslint-disable-next-line @typescript-eslint/no-var-requires
19
34
  const { version: current } = require("../../package.json");
@@ -30,15 +45,11 @@ async function checkForUpdate() {
30
45
  catch {
31
46
  return;
32
47
  }
33
- if (isOutdated(current, latest)) {
34
- console.error([
35
- "",
36
- "┌─────────────────────────────────────────────────────────┐",
37
- `│ Funifier MCP update available: ${current} ${latest}`,
38
- "│ Run: npx funifier-mcp@latest init │",
39
- "└─────────────────────────────────────────────────────────┘",
40
- "",
41
- ].join("\n"));
42
- }
48
+ if (!isOutdated(current, latest))
49
+ return;
50
+ const notice = `⬆ funifier-mcp update available: ${current} → ${latest}. Run: npx funifier-mcp@latest init`;
51
+ setUpdateNotice(notice);
52
+ // Fallback for clients/power users that surface server stderr.
53
+ console.error(notice);
43
54
  }
44
55
  //# sourceMappingURL=check-update.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"check-update.js","sourceRoot":"","sources":["../../src/mcp/check-update.ts"],"names":[],"mappings":";;AAaA,wCA4BC;AAzCD,SAAS,UAAU,CAAC,OAAe,EAAE,MAAc;IACjD,MAAM,OAAO,GAAG,CAAC,CAAS,EAAE,EAAE,CAC5B,CAAC;SACE,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;SACvB,KAAK,CAAC,GAAG,CAAC;SACV,GAAG,CAAC,MAAM,CAAC,CAAC;IACjB,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAC9C,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7C,IAAI,IAAI,KAAK,IAAI;QAAE,OAAO,IAAI,GAAG,IAAI,CAAC;IACtC,IAAI,IAAI,KAAK,IAAI;QAAE,OAAO,IAAI,GAAG,IAAI,CAAC;IACtC,OAAO,MAAM,GAAG,MAAM,CAAC;AACzB,CAAC;AAEM,KAAK,UAAU,cAAc;IAClC,8DAA8D;IAC9D,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,oBAAoB,CAAwB,CAAC;IAElF,IAAI,MAAc,CAAC;IACnB,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,gDAAgD,EAAE;YACxE,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC;SAClC,CAAC,CAAC;QACH,IAAI,CAAC,GAAG,CAAC,EAAE;YAAE,OAAO;QACpB,MAAM,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAwB,CAAC;QACvD,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAAC,MAAM,CAAC;QACP,OAAO;IACT,CAAC;IAED,IAAI,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,CAAC;QAChC,OAAO,CAAC,KAAK,CACX;YACE,EAAE;YACF,6DAA6D;YAC7D,qCAAqC,OAAO,MAAM,MAAM,EAAE;YAC1D,6DAA6D;YAC7D,6DAA6D;YAC7D,EAAE;SACH,CAAC,IAAI,CAAC,IAAI,CAAC,CACb,CAAC;IACJ,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"check-update.js","sourceRoot":"","sources":["../../src/mcp/check-update.ts"],"names":[],"mappings":";;AAiBA,0CAEC;AAGD,kDAIC;AAED,wCAsBC;AAEQ,gCAAU;AApDnB,SAAS,UAAU,CAAC,OAAe,EAAE,MAAc;IACjD,MAAM,OAAO,GAAG,CAAC,CAAS,EAAE,EAAE,CAC5B,CAAC;SACE,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;SACvB,KAAK,CAAC,GAAG,CAAC;SACV,GAAG,CAAC,MAAM,CAAC,CAAC;IACjB,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAC9C,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7C,IAAI,IAAI,KAAK,IAAI;QAAE,OAAO,IAAI,GAAG,IAAI,CAAC;IACtC,IAAI,IAAI,KAAK,IAAI;QAAE,OAAO,IAAI,GAAG,IAAI,CAAC;IACtC,OAAO,MAAM,GAAG,MAAM,CAAC;AACzB,CAAC;AAED,+EAA+E;AAC/E,gFAAgF;AAChF,IAAI,aAAa,GAAkB,IAAI,CAAC;AAExC,SAAgB,eAAe,CAAC,MAAc;IAC5C,aAAa,GAAG,MAAM,CAAC;AACzB,CAAC;AAED,2FAA2F;AAC3F,SAAgB,mBAAmB;IACjC,MAAM,MAAM,GAAG,aAAa,CAAC;IAC7B,aAAa,GAAG,IAAI,CAAC;IACrB,OAAO,MAAM,CAAC;AAChB,CAAC;AAEM,KAAK,UAAU,cAAc;IAClC,8DAA8D;IAC9D,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,oBAAoB,CAAwB,CAAC;IAElF,IAAI,MAAc,CAAC;IACnB,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,gDAAgD,EAAE;YACxE,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC;SAClC,CAAC,CAAC;QACH,IAAI,CAAC,GAAG,CAAC,EAAE;YAAE,OAAO;QACpB,MAAM,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAwB,CAAC;QACvD,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAAC,MAAM,CAAC;QACP,OAAO;IACT,CAAC;IAED,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC;QAAE,OAAO;IAEzC,MAAM,MAAM,GAAG,oCAAoC,OAAO,MAAM,MAAM,qCAAqC,CAAC;IAC5G,eAAe,CAAC,MAAM,CAAC,CAAC;IACxB,+DAA+D;IAC/D,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AACxB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=check-update.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"check-update.test.d.ts","sourceRoot":"","sources":["../../src/mcp/check-update.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const check_update_1 = require("./check-update");
5
+ (0, vitest_1.describe)("isOutdated", () => {
6
+ (0, vitest_1.it)("detects newer major/minor/patch", () => {
7
+ (0, vitest_1.expect)((0, check_update_1.isOutdated)("1.0.0", "2.0.0")).toBe(true);
8
+ (0, vitest_1.expect)((0, check_update_1.isOutdated)("1.2.0", "1.3.0")).toBe(true);
9
+ (0, vitest_1.expect)((0, check_update_1.isOutdated)("1.2.3", "1.2.4")).toBe(true);
10
+ });
11
+ (0, vitest_1.it)("returns false when current is equal or ahead", () => {
12
+ (0, vitest_1.expect)((0, check_update_1.isOutdated)("1.2.3", "1.2.3")).toBe(false);
13
+ (0, vitest_1.expect)((0, check_update_1.isOutdated)("2.0.0", "1.9.9")).toBe(false);
14
+ (0, vitest_1.expect)((0, check_update_1.isOutdated)("1.3.0", "1.2.9")).toBe(false);
15
+ });
16
+ (0, vitest_1.it)("ignores non-numeric prefixes like ^ or v", () => {
17
+ (0, vitest_1.expect)((0, check_update_1.isOutdated)("0.2.27", "v0.3.0")).toBe(true);
18
+ });
19
+ });
20
+ (0, vitest_1.describe)("update notice", () => {
21
+ (0, vitest_1.beforeEach)(() => {
22
+ (0, check_update_1.consumeUpdateNotice)(); // clear any leftover state
23
+ });
24
+ (0, vitest_1.it)("returns null when no notice is pending", () => {
25
+ (0, vitest_1.expect)((0, check_update_1.consumeUpdateNotice)()).toBeNull();
26
+ });
27
+ (0, vitest_1.it)("returns the notice once, then clears it", () => {
28
+ (0, check_update_1.setUpdateNotice)("update me");
29
+ (0, vitest_1.expect)((0, check_update_1.consumeUpdateNotice)()).toBe("update me");
30
+ (0, vitest_1.expect)((0, check_update_1.consumeUpdateNotice)()).toBeNull();
31
+ });
32
+ });
33
+ //# sourceMappingURL=check-update.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"check-update.test.js","sourceRoot":"","sources":["../../src/mcp/check-update.test.ts"],"names":[],"mappings":";;AAAA,mCAA0D;AAC1D,iDAAkF;AAElF,IAAA,iBAAQ,EAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,IAAA,WAAE,EAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,IAAA,eAAM,EAAC,IAAA,yBAAU,EAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChD,IAAA,eAAM,EAAC,IAAA,yBAAU,EAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChD,IAAA,eAAM,EAAC,IAAA,yBAAU,EAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,IAAA,eAAM,EAAC,IAAA,yBAAU,EAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjD,IAAA,eAAM,EAAC,IAAA,yBAAU,EAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjD,IAAA,eAAM,EAAC,IAAA,yBAAU,EAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,IAAA,eAAM,EAAC,IAAA,yBAAU,EAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,iBAAQ,EAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAA,mBAAU,EAAC,GAAG,EAAE;QACd,IAAA,kCAAmB,GAAE,CAAC,CAAC,2BAA2B;IACpD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,wCAAwC,EAAE,GAAG,EAAE;QAChD,IAAA,eAAM,EAAC,IAAA,kCAAmB,GAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,IAAA,8BAAe,EAAC,WAAW,CAAC,CAAC;QAC7B,IAAA,eAAM,EAAC,IAAA,kCAAmB,GAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAChD,IAAA,eAAM,EAAC,IAAA,kCAAmB,GAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"templates.d.ts","sourceRoot":"","sources":["../../../src/mcp/prompts/templates.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAEpE,wBAAgB,eAAe,CAAC,MAAM,EAAE,SAAS,QA6FhD"}
1
+ {"version":3,"file":"templates.d.ts","sourceRoot":"","sources":["../../../src/mcp/prompts/templates.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAEpE,wBAAgB,eAAe,CAAC,MAAM,EAAE,SAAS,QAsIhD"}
@@ -55,6 +55,41 @@ function registerPrompts(server) {
55
55
  ],
56
56
  };
57
57
  });
58
+ server.prompt("map_instance", "Map, document and audit an existing Funifier instance (read-only) into docs/funifier/, including a Mermaid architecture map", {
59
+ focus: zod_1.z
60
+ .string()
61
+ .optional()
62
+ .describe("Optional focus area, e.g. 'triggers' or 'mechanics'. Omit to map the whole instance."),
63
+ }, ({ focus }) => {
64
+ const scope = focus
65
+ ? `Focus the deep mapping on: ${focus}. Still inventory and count the other categories, but keep their docs at a high level.`
66
+ : "Map the full instance.";
67
+ return {
68
+ messages: [
69
+ {
70
+ role: "user",
71
+ content: {
72
+ type: "text",
73
+ text: [
74
+ "I want to map and document this EXISTING Funifier instance. This is a READ-ONLY audit — never create, edit or delete anything.",
75
+ scope,
76
+ "",
77
+ "If the `acquire-funifier-knowledge` skill is available, follow it for the full contract. Otherwise, follow these steps:",
78
+ "1. Confirm the MCP connection (e.g. funifier_database action=collections) and record the instance URL/name and today's date.",
79
+ "2. Inventory every listable type with funifier_list (trigger, scheduler, action, challenge, point, level, leaderboard, quiz, virtual-good-catalog/item, public-endpoint, custom-page, widget, websocket, aggregate, challenge-aggregate, auth-module, ai-knowledge), and use funifier_database action=collections to find off-enum elements (webhooks, notifications, competitions, player, team).",
80
+ "3. For objects that need detail, use funifier_get mode=read to extract rules, conditions and actions.",
81
+ "4. Cross-link the objects: which trigger feeds which point/challenge, which scheduler calls which endpoint, which actions satisfy each challenge, which leaderboards use which points.",
82
+ "5. From those (and ONLY those) relationships, build a Mermaid architecture map — 'what fires/awards/feeds/calls what' — and put it in OVERVIEW.md. Every edge must trace to a real configured field; never draw a speculative edge — use a dashed `-.->` marked [ASK USER] when unsure. Collapse any category with >8 objects into a single node annotated with its count.",
83
+ "6. Write the documentation set under docs/funifier/ (OVERVIEW, GAME_MECHANICS, TRIGGERS, SCHEDULERS, CUSTOM_ENDPOINTS, CUSTOM_PAGES, LEADERBOARDS, PLAYER_MODEL, INTEGRATIONS, TECHNIQUES_AND_PATTERNS, CONCERNS). Every claim points to an object ID; no section left empty.",
84
+ "7. Finish with a summary of counts, where each doc lives, and a numbered list of [ASK USER] items to resolve.",
85
+ "",
86
+ "Use only read-only tools: funifier_list, funifier_get (mode=read), funifier_logs, funifier_database (query/aggregate/collections only), funifier_folder (inside/breadcrumb only). Never use funifier_save, funifier_delete, funifier_execute, database insert/update/delete/bulk, or folder progress.",
87
+ ].join("\n"),
88
+ },
89
+ },
90
+ ],
91
+ };
92
+ });
58
93
  server.prompt("implement_frontend", "Implement frontend code using Funifier aggregates", async () => {
59
94
  return {
60
95
  messages: [
@@ -1 +1 @@
1
- {"version":3,"file":"templates.js","sourceRoot":"","sources":["../../../src/mcp/prompts/templates.ts"],"names":[],"mappings":";;AAGA,0CA6FC;AAhGD,6BAAwB;AAGxB,SAAgB,eAAe,CAAC,MAAiB;IAC/C,MAAM,CAAC,MAAM,CACX,iBAAiB,EACjB,0DAA0D,EAC1D;QACE,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,mEAAmE,CAAC;KAC/F,EACD,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;QACX,OAAO;YACL,QAAQ,EAAE;gBACR;oBACE,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE;wBACP,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE;4BACJ,mCAAmC,IAAI,GAAG;4BAC1C,EAAE;4BACF,oBAAoB;4BACpB,iFAAiF,IAAI,GAAG;4BACxF,0CAA0C,IAAI,0BAA0B;4BACxE,qEAAqE;4BACrE,kEAAkE,IAAI,EAAE;4BACxE,EAAE;4BACF,2DAA2D,IAAI,aAAa;yBAC7E,CAAC,IAAI,CAAC,IAAI,CAAC;qBACb;iBACF;aACF;SACF,CAAC;IACJ,CAAC,CACF,CAAC;IAEF,MAAM,CAAC,MAAM,CACX,gBAAgB,EAChB,sDAAsD,EACtD;QACE,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,8CAA8C,CAAC;QACzE,EAAE,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,0BAA0B,CAAC;KACpD,EACD,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE;QACf,OAAO;YACL,QAAQ,EAAE;gBACR;oBACE,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE;wBACP,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE;4BACJ,oCAAoC,IAAI,aAAa,EAAE,IAAI;4BAC3D,EAAE;4BACF,oBAAoB;4BACpB,yCAAyC,IAAI,yBAAyB;4BACtE,kEAAkE;4BAClE,oGAAoG;4BACpG,gFAAgF;4BAChF,iDAAiD;4BACjD,EAAE;4BACF,yBAAyB,IAAI,wBAAwB;yBACtD,CAAC,IAAI,CAAC,IAAI,CAAC;qBACb;iBACF;aACF;SACF,CAAC;IACJ,CAAC,CACF,CAAC;IAEF,MAAM,CAAC,MAAM,CACX,oBAAoB,EACpB,mDAAmD,EACnD,KAAK,IAAI,EAAE;QACT,OAAO;YACL,QAAQ,EAAE;gBACR;oBACE,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE;wBACP,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE;4BACJ,uEAAuE;4BACvE,EAAE;4BACF,oBAAoB;4BACpB,+EAA+E;4BAC/E,+DAA+D;4BAC/D,kEAAkE;4BAClE,wEAAwE;4BACxE,gDAAgD;4BAChD,EAAE;4BACF,+EAA+E;yBAChF,CAAC,IAAI,CAAC,IAAI,CAAC;qBACb;iBACF;aACF;SACF,CAAC;IACJ,CAAC,CACF,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"templates.js","sourceRoot":"","sources":["../../../src/mcp/prompts/templates.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AACpE,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAY1C,wBAAgB,aAAa,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,QAWtF"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AACpE,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAoC1C,wBAAgB,aAAa,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,QActF"}
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.registerTools = registerTools;
4
+ const check_update_1 = require("../check-update");
4
5
  const connect_1 = require("./connect");
5
6
  const list_1 = require("./list");
6
7
  const get_1 = require("./get");
@@ -11,7 +12,31 @@ const logs_1 = require("./logs");
11
12
  const database_1 = require("./database");
12
13
  const folder_1 = require("./folder");
13
14
  const search_docs_1 = require("./search-docs");
15
+ /**
16
+ * Wraps every tool handler so a pending update notice is prepended to the first
17
+ * tool result of the session. Tool results are the only channel the user reliably
18
+ * sees in a stdio MCP client. The handler is always the last argument.
19
+ */
20
+ function decorateWithUpdateNotice(server) {
21
+ const original = server.registerTool.bind(server);
22
+ server.registerTool = ((...args) => {
23
+ const handler = args[args.length - 1];
24
+ if (typeof handler === "function") {
25
+ args[args.length - 1] = async (...handlerArgs) => {
26
+ const result = await handler(...handlerArgs);
27
+ const notice = (0, check_update_1.consumeUpdateNotice)();
28
+ if (notice && result && Array.isArray(result.content)) {
29
+ result.content.unshift({ type: "text", text: notice });
30
+ }
31
+ return result;
32
+ };
33
+ }
34
+ return original(...args);
35
+ });
36
+ }
14
37
  function registerTools(server, apiHolder, docsPath) {
38
+ // Must run before the tools below register, so their handlers get wrapped.
39
+ decorateWithUpdateNotice(server);
15
40
  (0, connect_1.registerConnectTool)(server, apiHolder);
16
41
  (0, list_1.registerListTool)(server, apiHolder);
17
42
  (0, get_1.registerGetTool)(server, apiHolder);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/mcp/tools/index.ts"],"names":[],"mappings":";;AAaA,sCAWC;AAtBD,uCAAgD;AAChD,iCAA0C;AAC1C,+BAAwC;AACxC,iCAA0C;AAC1C,qCAA8C;AAC9C,uCAAgD;AAChD,iCAA0C;AAC1C,yCAAkD;AAClD,qCAA8C;AAC9C,+CAAuD;AAEvD,SAAgB,aAAa,CAAC,MAAiB,EAAE,SAAoB,EAAE,QAAgB;IACrF,IAAA,6BAAmB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACvC,IAAA,uBAAgB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,IAAA,qBAAe,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACnC,IAAA,uBAAgB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,IAAA,2BAAkB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACtC,IAAA,6BAAmB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACvC,IAAA,uBAAgB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,IAAA,+BAAoB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACxC,IAAA,2BAAkB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACtC,IAAA,oCAAsB,EAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AAC3C,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/mcp/tools/index.ts"],"names":[],"mappings":";;AAqCA,sCAcC;AAjDD,kDAAsD;AACtD,uCAAgD;AAChD,iCAA0C;AAC1C,+BAAwC;AACxC,iCAA0C;AAC1C,qCAA8C;AAC9C,uCAAgD;AAChD,iCAA0C;AAC1C,yCAAkD;AAClD,qCAA8C;AAC9C,+CAAuD;AAEvD;;;;GAIG;AACH,SAAS,wBAAwB,CAAC,MAAiB;IACjD,MAAM,QAAQ,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAA4B,CAAC;IAC7E,MAAM,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACtC,IAAI,OAAO,OAAO,KAAK,UAAU,EAAE,CAAC;YAClC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,KAAK,EAAE,GAAG,WAAkB,EAAE,EAAE;gBACtD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,WAAW,CAAC,CAAC;gBAC7C,MAAM,MAAM,GAAG,IAAA,kCAAmB,GAAE,CAAC;gBACrC,IAAI,MAAM,IAAI,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;oBACtD,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;gBACzD,CAAC;gBACD,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC;QACJ,CAAC;QACD,OAAO,QAAQ,CAAC,GAAG,IAAI,CAAC,CAAC;IAC3B,CAAC,CAA+B,CAAC;AACnC,CAAC;AAED,SAAgB,aAAa,CAAC,MAAiB,EAAE,SAAoB,EAAE,QAAgB;IACrF,2EAA2E;IAC3E,wBAAwB,CAAC,MAAM,CAAC,CAAC;IAEjC,IAAA,6BAAmB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACvC,IAAA,uBAAgB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,IAAA,qBAAe,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACnC,IAAA,uBAAgB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,IAAA,2BAAkB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACtC,IAAA,6BAAmB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACvC,IAAA,uBAAgB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,IAAA,+BAAoB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACxC,IAAA,2BAAkB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACtC,IAAA,oCAAsB,EAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AAC3C,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "funifier-mcp",
3
- "version": "0.2.27",
3
+ "version": "0.2.28",
4
4
  "description": "Funifier AI toolkit — MCP server, API client, and Claude Code skills for the Funifier gamification platform",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -27,7 +27,7 @@ Produza esta estrutura em `docs/funifier/`. **Nenhum arquivo pode ficar vazio**
27
27
 
28
28
  | Arquivo | Conteúdo |
29
29
  |---------|----------|
30
- | `OVERVIEW.md` | Identificação da instância, contagens agregadas por categoria, data do snapshot, escopo do mapeamento |
30
+ | `OVERVIEW.md` | Identificação da instância, contagens agregadas por categoria, data do snapshot, escopo do mapeamento e o **mapa de arquitetura em Mermaid** (o que dispara/premia/alimenta/chama o quê) |
31
31
  | `GAME_MECHANICS.md` | Pontos, níveis, achievements/badges, challenges, missions, quizzes, virtual goods — com IDs, regras de atribuição e condições |
32
32
  | `TRIGGERS.md` | Todos os triggers: nome, ID, entidade/evento de origem, condições, ações, status |
33
33
  | `SCHEDULERS.md` | Cron jobs: nome, expressão cron, ação, próxima/última execução conhecida, status |
@@ -82,7 +82,7 @@ Avance pelas fases em ordem. As fases 1 e 6 são sempre completas (mesmo em Modo
82
82
  1. **Validar conexão e identificar a instância.** Confirme que o MCP responde (uma chamada `funifier_database action=collections` ou um `funifier_list type=trigger limit=1` serve). Registre serverUrl/nome da conexão e a data do snapshot para o `OVERVIEW.md`.
83
83
  2. **Inventário bruto.** Para cada um dos 18 tipos, rode `funifier_list` e registre os IDs e nomes. Rode `funifier_database action=collections` para descobrir coleções que revelam elementos fora do enum (webhooks, notifications, competitions, custom `__c`, player, team). Consulte `references/funifier-inventory-checklist.md` para a lista de perguntas por categoria.
84
84
  3. **Detalhamento.** Para cada objeto que precisa de detalhe, rode `funifier_get mode=read` e extraia as regras, condições e ações. Amostre coleções relevantes com `funifier_database action=query` (limit pequeno) para entender o modelo de player/team.
85
- 4. **Análise cruzada.** Relacione objetos: qual `trigger` alimenta qual `point`/`challenge`; qual `scheduler` chama qual `public-endpoint`; quais `action`s satisfazem as regras de cada `challenge`; quais `leaderboard`s usam quais `point`s. Anote as relações para `CONCERNS.md` e `TECHNIQUES_AND_PATTERNS.md`.
85
+ 4. **Análise cruzada e diagrama de arquitetura.** Relacione objetos: qual `trigger` alimenta qual `point`/`challenge`; qual `scheduler` chama qual `public-endpoint`; quais `action`s satisfazem as regras de cada `challenge`; quais `leaderboard`s usam quais `point`s. Anote as relações para `CONCERNS.md` e `TECHNIQUES_AND_PATTERNS.md`. Com essas relações já mapeadas (e **somente** com elas), monte o **mapa de arquitetura em Mermaid** e escreva-o na seção própria do `OVERVIEW.md` — siga as convenções em "Diagrama de arquitetura (Mermaid)" abaixo.
86
86
  5. **Inferência de técnicas de jogos.** Classifique as técnicas observadas usando `references/game-techniques-taxonomy.md`. Cada técnica DEVE ser ligada aos IDs concretos que a implementam. Sem objeto que a sustente, não afirme a técnica.
87
87
  6. **Validação.** Verifique: (a) cada claim aponta para um ID/objeto; (b) nenhuma seção obrigatória está vazia; (c) todo nome de ferramenta usado existe; (d) nenhum tipo inventado. Veja a checklist no fim deste arquivo.
88
88
  7. **Apresentar.** Mostre um sumário (contagens + onde está cada doc) e uma lista numerada de itens `[ASK USER]` e divergências encontradas, para o usuário resolver.
@@ -95,6 +95,26 @@ Avance pelas fases em ordem. As fases 1 e 6 são sempre completas (mesmo em Modo
95
95
  - **Nunca infira comportamento sem um objeto que o sustente.** "Provavelmente dispara X" é proibido; cite a config do trigger e o evento exato.
96
96
  - **Toda seção termina com um bloco `## Evidence`** listando os IDs consultados e as chamadas MCP que produziram o conteúdo (ex.: `funifier_list type=trigger`, `funifier_get type=challenge id=...`).
97
97
 
98
+ ## Diagrama de arquitetura (Mermaid)
99
+
100
+ O `OVERVIEW.md` carrega um **mapa de arquitetura** em Mermaid: a visão macro de "o que dispara, premia, alimenta e chama o quê". Ele é a *visualização* das relações já levantadas na Fase 4 — nunca uma fonte nova de verdade.
101
+
102
+ **Regras duras:**
103
+
104
+ 1. **Toda aresta corresponde a um campo configurado num objeto real.** A origem é o `entity`/`event` de um `trigger`, a recompensa de um `challenge`, a métrica de um `leaderboard`, o preço de um `virtual-good-item`, etc. Sem campo que a sustente, a aresta não existe.
105
+ 2. **Toda aresta é rastreável no doc da categoria.** Cada relação desenhada DEVE também aparecer como fato no doc correspondente (`TRIGGERS.md`, `GAME_MECHANICS.md`, `LEADERBOARDS.md`, ...). O diagrama não afirma nada que os docs não afirmem.
106
+ 3. **Relação incerta = aresta tracejada `-.->` rotulada `[ASK USER]`.** Nunca desenhe uma aresta sólida "provável" (mesmo princípio do anti-padrão "provavelmente dispara X").
107
+ 4. **Legibilidade > completude.** Se uma categoria tem **mais de 8 objetos**, não desenhe um nó por objeto: colapse a categoria num único nó anotado com a contagem (ex.: `challenges["challenges (×24)"]`) e desenhe só os fluxos principais. O mapa do `OVERVIEW.md` é macro; diagramas detalhados por área só quando o usuário pedir.
108
+
109
+ **Convenções de sintaxe (para o Mermaid não quebrar):**
110
+
111
+ - Use `flowchart LR`. Agrupe os nós em `subgraph`s por camada: `Ações & Eventos`, `Automação` (`trigger`/`scheduler`), `Mecânicas` (`challenge`/`quiz`/`level`/trilhas), `Recompensas` (`point`/`virtual-good`), `Visualização` (`leaderboard`/`aggregate`/`custom-page`/`widget`), `Integrações` (`public-endpoint`/`webhook`/`websocket`/`auth-module`).
112
+ - **IDs de nó**: apenas `[A-Za-z0-9_]`. Derive do nome substituindo qualquer outro caractere por `_`. Rótulo sempre entre aspas duplas, com nome + tipo: `tr_login["login_trigger · trigger"]`.
113
+ - **Verbos das arestas** (use só estes, sempre rotulados): `dispara` (trigger/scheduler → ação/endpoint), `premia` (challenge/quiz → point/virtual-good), `alimenta` (point → leaderboard; action → challenge), `exige` (level → point; item → preço), `lê` (aggregate → coleção; page/widget → aggregate/leaderboard), `chama` (frontend/page → public-endpoint; trigger → webhook externo).
114
+ - Uma instrução por linha; nunca use parênteses em rótulos sem aspas.
115
+
116
+ O esqueleto pronto para preencher está em `assets/templates/OVERVIEW.md` — substitua os `{{...}}` pelos objetos reais e remova as arestas que não tiverem relação comprovada.
117
+
98
118
  ## Modo Foco (Focus Area Mode)
99
119
 
100
120
  Se o usuário pedir foco ("só triggers", "mecânicas e técnicas apenas"):
@@ -102,6 +122,7 @@ Se o usuário pedir foco ("só triggers", "mecânicas e técnicas apenas"):
102
122
  - A **Fase 1** (validar/identificar) roda sempre, completa.
103
123
  - Os documentos do foco são preenchidos **completos**.
104
124
  - Os demais documentos obrigatórios **existem**, com suas seções presentes mas marcadas `[TODO]` (e uma nota indicando que ficaram fora do escopo desta execução).
125
+ - O **mapa de arquitetura** no `OVERVIEW.md` é sempre gerado; seu escopo reflete o foco — categorias fora do foco aparecem colapsadas num único nó com a contagem.
105
126
  - A **Fase 6** (validação) roda em **todos** os documentos.
106
127
 
107
128
  ## Anti-padrões
@@ -114,6 +135,7 @@ Se o usuário pedir foco ("só triggers", "mecânicas e técnicas apenas"):
114
135
  | Confundir achievement com challenge ou mission | Respeitar a tipagem do Funifier; cada categoria no seu doc |
115
136
  | Inventar um tipo (ex.: tratar "webhook" como `funifier_list type=webhook`) | Usar só os 18 tipos reais; inferir o resto de coleções e ações |
116
137
  | Modificar a instância para "testar" um comportamento | Apenas ler; nunca `save`/`delete`/`execute`/`insert`/`update` |
138
+ | Desenhar uma aresta "provável" no diagrama Mermaid | Só desenhar arestas com um campo de objeto que as sustente; incertezas viram `-.->` `[ASK USER]` |
117
139
 
118
140
  ## Quando ler cada arquivo de referência
119
141
 
@@ -128,5 +150,6 @@ Se o usuário pedir foco ("só triggers", "mecânicas e técnicas apenas"):
128
150
  - [ ] Todo objeto com status conhecido tem o status registrado.
129
151
  - [ ] Nenhum tipo inventado — só os 18 tipos reais + coleções via `funifier_database`.
130
152
  - [ ] Cada documento termina com um bloco `## Evidence`.
153
+ - [ ] O `OVERVIEW.md` contém o mapa de arquitetura em Mermaid; cada aresta tem um campo de objeto que a sustenta e o mesmo fato aparece no doc da categoria. Incertezas são `-.->` `[ASK USER]`, não arestas sólidas.
131
154
  - [ ] Itens dependentes de intenção estão marcados `[ASK USER]`, não adivinhados.
132
155
  - [ ] Nenhuma ferramenta de escrita foi usada (`save`/`delete`/`execute`/`insert`/`update`/`bulk`/`folder progress`).
@@ -38,6 +38,44 @@ Contagem por tipo listável (preencha 0 quando não houver — não omita):
38
38
  |----------|---------|-------------|
39
39
  | {{webhook/notification/competition/...}} | {{collection}} | {{n}} |
40
40
 
41
+ ### Mapa de Arquitetura
42
+
43
+ Visão macro de "o que dispara/premia/alimenta/chama o quê". **Regras:** toda aresta vem de um campo real (trigger `entity`/`event`, recompensa de challenge, métrica de leaderboard, preço de virtual-good...) e o mesmo fato aparece no doc da categoria; relação incerta = `-.->` `[ASK USER]`; categoria com >8 objetos = um único nó com a contagem (`challenges["challenges (×24)"]`). Verbos permitidos: `dispara`, `premia`, `alimenta`, `exige`, `lê`, `chama`. Substitua os `{{...}}` por IDs de nó saneados (`[A-Za-z0-9_]`) e remova as arestas sem relação comprovada.
44
+
45
+ ```mermaid
46
+ flowchart LR
47
+ subgraph Acoes["Ações & Eventos"]
48
+ {{act_id}}["{{nome}} · action"]
49
+ end
50
+ subgraph Automacao["Automação"]
51
+ {{trigger_id}}["{{nome}} · trigger"]
52
+ {{scheduler_id}}["{{nome}} · scheduler"]
53
+ end
54
+ subgraph Mecanicas["Mecânicas"]
55
+ {{challenge_id}}["{{nome}} · challenge"]
56
+ {{level_id}}["{{nome}} · level"]
57
+ end
58
+ subgraph Recompensas["Recompensas"]
59
+ {{point_id}}["{{nome}} · point"]
60
+ {{vg_id}}["{{nome}} · virtual-good"]
61
+ end
62
+ subgraph Visualizacao["Visualização"]
63
+ {{leaderboard_id}}["{{nome}} · leaderboard"]
64
+ {{aggregate_id}}["{{nome}} · aggregate"]
65
+ end
66
+ subgraph Integracoes["Integrações"]
67
+ {{endpoint_id}}["{{nome}} · public-endpoint"]
68
+ end
69
+
70
+ {{act_id}} -->|alimenta| {{challenge_id}}
71
+ {{trigger_id}} -->|premia| {{point_id}}
72
+ {{challenge_id}} -->|premia| {{vg_id}}
73
+ {{point_id}} -->|alimenta| {{leaderboard_id}}
74
+ {{level_id}} -->|exige| {{point_id}}
75
+ {{aggregate_id}} -->|lê| {{point_id}}
76
+ {{scheduler_id}} -.->|chama [ASK USER]| {{endpoint_id}}
77
+ ```
78
+
41
79
  ## Extended (Opcional)
42
80
  - Versão/plano da instância, se conhecido.
43
81
  - Principais áreas funcionais identificadas (resumo de 2-3 linhas).
@@ -45,3 +83,4 @@ Contagem por tipo listável (preencha 0 quando não houver — não omita):
45
83
  ## Evidence
46
84
  - `funifier_list type=<cada um dos 18 tipos>`
47
85
  - `funifier_database action=collections`
86
+ - Mapa de arquitetura: cada aresta é evidenciada pelo objeto/campo que a sustenta, documentado no doc da categoria correspondente ({{ex.: TRIGGERS.md #id, GAME_MECHANICS.md #id}}).