@atoms-tech/atoms-mcp 0.2.1 → 0.3.1

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 (129) hide show
  1. package/LICENSE +9 -0
  2. package/README.md +31 -19
  3. package/dist/apps/src/apps/coverage/coverage-app.html +237 -0
  4. package/dist/apps/src/apps/import/import-app.html +239 -0
  5. package/dist/apps/src/apps/mermaid/mermaid-app.html +112 -0
  6. package/dist/apps/src/apps/summary/summary-app.html +279 -0
  7. package/dist/apps/src/apps/trace/trace-app.html +171 -0
  8. package/dist/index.cjs +2 -0
  9. package/dist/index.js +1 -91
  10. package/package.json +21 -5
  11. package/dist/auth/login.d.ts +0 -25
  12. package/dist/auth/login.d.ts.map +0 -1
  13. package/dist/auth/login.js +0 -414
  14. package/dist/auth/login.js.map +0 -1
  15. package/dist/auth/refresh.d.ts +0 -17
  16. package/dist/auth/refresh.d.ts.map +0 -1
  17. package/dist/auth/refresh.js +0 -82
  18. package/dist/auth/refresh.js.map +0 -1
  19. package/dist/auth/token-store.d.ts +0 -34
  20. package/dist/auth/token-store.d.ts.map +0 -1
  21. package/dist/auth/token-store.js +0 -61
  22. package/dist/auth/token-store.js.map +0 -1
  23. package/dist/config.d.ts +0 -19
  24. package/dist/config.d.ts.map +0 -1
  25. package/dist/config.js +0 -19
  26. package/dist/config.js.map +0 -1
  27. package/dist/db/client.d.ts +0 -30
  28. package/dist/db/client.d.ts.map +0 -1
  29. package/dist/db/client.js +0 -110
  30. package/dist/db/client.js.map +0 -1
  31. package/dist/db/graph.d.ts +0 -8
  32. package/dist/db/graph.d.ts.map +0 -1
  33. package/dist/db/graph.js +0 -8
  34. package/dist/db/graph.js.map +0 -1
  35. package/dist/db/queries.d.ts +0 -77
  36. package/dist/db/queries.d.ts.map +0 -1
  37. package/dist/db/queries.js +0 -210
  38. package/dist/db/queries.js.map +0 -1
  39. package/dist/index.d.ts +0 -12
  40. package/dist/index.d.ts.map +0 -1
  41. package/dist/index.js.map +0 -1
  42. package/dist/middleware/audit.d.ts +0 -26
  43. package/dist/middleware/audit.d.ts.map +0 -1
  44. package/dist/middleware/audit.js +0 -44
  45. package/dist/middleware/audit.js.map +0 -1
  46. package/dist/middleware/rate-limiter.d.ts +0 -21
  47. package/dist/middleware/rate-limiter.d.ts.map +0 -1
  48. package/dist/middleware/rate-limiter.js +0 -43
  49. package/dist/middleware/rate-limiter.js.map +0 -1
  50. package/dist/middleware/validator.d.ts +0 -22
  51. package/dist/middleware/validator.d.ts.map +0 -1
  52. package/dist/middleware/validator.js +0 -91
  53. package/dist/middleware/validator.js.map +0 -1
  54. package/dist/server.d.ts +0 -14
  55. package/dist/server.d.ts.map +0 -1
  56. package/dist/server.js +0 -637
  57. package/dist/server.js.map +0 -1
  58. package/dist/tools/_base.d.ts +0 -58
  59. package/dist/tools/_base.d.ts.map +0 -1
  60. package/dist/tools/_base.js +0 -109
  61. package/dist/tools/_base.js.map +0 -1
  62. package/dist/tools/bulk-import.d.ts +0 -70
  63. package/dist/tools/bulk-import.d.ts.map +0 -1
  64. package/dist/tools/bulk-import.js +0 -188
  65. package/dist/tools/bulk-import.js.map +0 -1
  66. package/dist/tools/create-item.d.ts +0 -43
  67. package/dist/tools/create-item.d.ts.map +0 -1
  68. package/dist/tools/create-item.js +0 -118
  69. package/dist/tools/create-item.js.map +0 -1
  70. package/dist/tools/delete-item.d.ts +0 -38
  71. package/dist/tools/delete-item.d.ts.map +0 -1
  72. package/dist/tools/delete-item.js +0 -69
  73. package/dist/tools/delete-item.js.map +0 -1
  74. package/dist/tools/export-mermaid.d.ts +0 -36
  75. package/dist/tools/export-mermaid.d.ts.map +0 -1
  76. package/dist/tools/export-mermaid.js +0 -125
  77. package/dist/tools/export-mermaid.js.map +0 -1
  78. package/dist/tools/get-coverage.d.ts +0 -34
  79. package/dist/tools/get-coverage.d.ts.map +0 -1
  80. package/dist/tools/get-coverage.js +0 -36
  81. package/dist/tools/get-coverage.js.map +0 -1
  82. package/dist/tools/get-history.d.ts +0 -34
  83. package/dist/tools/get-history.d.ts.map +0 -1
  84. package/dist/tools/get-history.js +0 -53
  85. package/dist/tools/get-history.js.map +0 -1
  86. package/dist/tools/get-item.d.ts +0 -62
  87. package/dist/tools/get-item.d.ts.map +0 -1
  88. package/dist/tools/get-item.js +0 -93
  89. package/dist/tools/get-item.js.map +0 -1
  90. package/dist/tools/link-items.d.ts +0 -41
  91. package/dist/tools/link-items.d.ts.map +0 -1
  92. package/dist/tools/link-items.js +0 -150
  93. package/dist/tools/link-items.js.map +0 -1
  94. package/dist/tools/list-items.d.ts +0 -37
  95. package/dist/tools/list-items.d.ts.map +0 -1
  96. package/dist/tools/list-items.js +0 -36
  97. package/dist/tools/list-items.js.map +0 -1
  98. package/dist/tools/list-projects.d.ts +0 -38
  99. package/dist/tools/list-projects.d.ts.map +0 -1
  100. package/dist/tools/list-projects.js +0 -28
  101. package/dist/tools/list-projects.js.map +0 -1
  102. package/dist/tools/project-summary.d.ts +0 -64
  103. package/dist/tools/project-summary.d.ts.map +0 -1
  104. package/dist/tools/project-summary.js +0 -170
  105. package/dist/tools/project-summary.js.map +0 -1
  106. package/dist/tools/record-test-result.d.ts +0 -41
  107. package/dist/tools/record-test-result.d.ts.map +0 -1
  108. package/dist/tools/record-test-result.js +0 -80
  109. package/dist/tools/record-test-result.js.map +0 -1
  110. package/dist/tools/search.d.ts +0 -34
  111. package/dist/tools/search.d.ts.map +0 -1
  112. package/dist/tools/search.js +0 -28
  113. package/dist/tools/search.js.map +0 -1
  114. package/dist/tools/trace.d.ts +0 -53
  115. package/dist/tools/trace.d.ts.map +0 -1
  116. package/dist/tools/trace.js +0 -166
  117. package/dist/tools/trace.js.map +0 -1
  118. package/dist/tools/update-item.d.ts +0 -43
  119. package/dist/tools/update-item.d.ts.map +0 -1
  120. package/dist/tools/update-item.js +0 -98
  121. package/dist/tools/update-item.js.map +0 -1
  122. package/dist/types/responses.d.ts +0 -58
  123. package/dist/types/responses.d.ts.map +0 -1
  124. package/dist/types/responses.js +0 -6
  125. package/dist/types/responses.js.map +0 -1
  126. package/dist/types/work-item.d.ts +0 -69
  127. package/dist/types/work-item.d.ts.map +0 -1
  128. package/dist/types/work-item.js +0 -8
  129. package/dist/types/work-item.js.map +0 -1
package/dist/config.js DELETED
@@ -1,19 +0,0 @@
1
- /**
2
- * ATOMS MCP Server — Public client configuration.
3
- *
4
- * These are PUBLISHABLE values — identical to the ones embedded in the
5
- * ATOMS.tech React frontend bundle (NEXT_PUBLIC_SUPABASE_*).
6
- *
7
- * The anon key is NOT a secret. It only grants access to Supabase's API
8
- * gateway. All data access is gated by Row Level Security (RLS) policies
9
- * which require a valid user JWT. Without authentication, these values
10
- * grant zero data access.
11
- *
12
- * This is the standard pattern used by Supabase, Firebase, and Clerk
13
- * for client-side applications.
14
- */
15
- export const ATOMS_SUPABASE_URL = "https://gmebjyhomsbvhrxffzre.supabase.co";
16
- export const ATOMS_SUPABASE_ANON_KEY = "sb_publishable_b49MUAB8XCrQiF7x5b9lUA_w1aplSBH";
17
- /** ATOMS web app URL — hosts the MCP consent page */
18
- export const ATOMS_APP_URL = process.env.ATOMS_APP_URL ?? "https://x.atoms.tech";
19
- //# sourceMappingURL=config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,MAAM,CAAC,MAAM,kBAAkB,GAAG,0CAA0C,CAAC;AAC7E,MAAM,CAAC,MAAM,uBAAuB,GAClC,gDAAgD,CAAC;AAEnD,qDAAqD;AACrD,MAAM,CAAC,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,sBAAsB,CAAC"}
@@ -1,30 +0,0 @@
1
- /**
2
- * Supabase client factory for the MCP server.
3
- *
4
- * Creates a user-scoped client with JWT — RLS enforced automatically.
5
- * Never uses service role key (all queries respect user permissions).
6
- */
7
- import { type SupabaseClient } from "@supabase/supabase-js";
8
- /**
9
- * Get or create an authenticated Supabase client.
10
- * Auto-refreshes JWT when expired. All queries run with user's RLS permissions.
11
- */
12
- export declare function getClient(): Promise<SupabaseClient>;
13
- /**
14
- * Get the authenticated user's ID. Must call getClient() first.
15
- */
16
- export declare function getUserId(): string;
17
- /**
18
- * Get the authenticated user's email.
19
- */
20
- export declare function getUserEmail(): string;
21
- /**
22
- * Reset the cached client (for token refresh).
23
- */
24
- export declare function resetClient(): void;
25
- /**
26
- * Check if the user has write access to a project.
27
- * Returns the user's org role, or throws a descriptive error.
28
- */
29
- export declare function requireWriteAccess(client: SupabaseClient, projectId: string): Promise<string>;
30
- //# sourceMappingURL=client.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/db/client.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAgB,KAAK,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAS1E;;;GAGG;AACH,wBAAsB,SAAS,IAAI,OAAO,CAAC,cAAc,CAAC,CAuCzD;AAED;;GAEG;AACH,wBAAgB,SAAS,IAAI,MAAM,CAKlC;AAED;;GAEG;AACH,wBAAgB,YAAY,IAAI,MAAM,CAErC;AAED;;GAEG;AACH,wBAAgB,WAAW,IAAI,IAAI,CAKlC;AAED;;;GAGG;AACH,wBAAsB,kBAAkB,CACtC,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,MAAM,CAAC,CAoCjB"}
package/dist/db/client.js DELETED
@@ -1,110 +0,0 @@
1
- /**
2
- * Supabase client factory for the MCP server.
3
- *
4
- * Creates a user-scoped client with JWT — RLS enforced automatically.
5
- * Never uses service role key (all queries respect user permissions).
6
- */
7
- import { createClient } from "@supabase/supabase-js";
8
- import { getValidToken } from "../auth/refresh.js";
9
- import { ATOMS_SUPABASE_URL, ATOMS_SUPABASE_ANON_KEY } from "../config.js";
10
- let cachedClient = null;
11
- let cachedUserId = null;
12
- let cachedEmail = null;
13
- let tokenExpiresAt = 0;
14
- /**
15
- * Get or create an authenticated Supabase client.
16
- * Auto-refreshes JWT when expired. All queries run with user's RLS permissions.
17
- */
18
- export async function getClient() {
19
- // If token is within 60s of expiry, force refresh
20
- if (cachedClient && tokenExpiresAt > Date.now() + 60_000) {
21
- return cachedClient;
22
- }
23
- // Token expired or no client — get a fresh token
24
- if (cachedClient) {
25
- process.stderr.write("[atoms-mcp] Token expiring, refreshing client...\n");
26
- }
27
- const { access_token, user_id, email } = await getValidToken();
28
- // Decode expiry from JWT
29
- const parts = access_token.split(".");
30
- if (parts.length === 3) {
31
- try {
32
- const payload = JSON.parse(Buffer.from(parts[1].replace(/-/g, "+").replace(/_/g, "/"), "base64").toString());
33
- tokenExpiresAt = (payload.exp ?? 0) * 1000; // convert to ms
34
- }
35
- catch {
36
- // Fallback: assume 1hr from now
37
- tokenExpiresAt = Date.now() + 3600_000;
38
- }
39
- }
40
- // Use global Authorization header — works with all Supabase key formats
41
- const client = createClient(ATOMS_SUPABASE_URL, ATOMS_SUPABASE_ANON_KEY, {
42
- global: {
43
- headers: { Authorization: `Bearer ${access_token}` },
44
- },
45
- });
46
- cachedClient = client;
47
- cachedUserId = user_id;
48
- cachedEmail = email;
49
- return cachedClient;
50
- }
51
- /**
52
- * Get the authenticated user's ID. Must call getClient() first.
53
- */
54
- export function getUserId() {
55
- if (!cachedUserId) {
56
- throw new Error("Not authenticated. Call getClient() first.");
57
- }
58
- return cachedUserId;
59
- }
60
- /**
61
- * Get the authenticated user's email.
62
- */
63
- export function getUserEmail() {
64
- return cachedEmail ?? "";
65
- }
66
- /**
67
- * Reset the cached client (for token refresh).
68
- */
69
- export function resetClient() {
70
- cachedClient = null;
71
- cachedUserId = null;
72
- cachedEmail = null;
73
- tokenExpiresAt = 0;
74
- }
75
- /**
76
- * Check if the user has write access to a project.
77
- * Returns the user's org role, or throws a descriptive error.
78
- */
79
- export async function requireWriteAccess(client, projectId) {
80
- const userId = getUserId();
81
- // Get the project's org
82
- const { data: project, error: projErr } = await client
83
- .from("projects")
84
- .select("org_id")
85
- .eq("id", projectId)
86
- .maybeSingle();
87
- if (projErr || !project) {
88
- throw new Error(`Project '${projectId}' not found`);
89
- }
90
- // Get user's role in that org
91
- const { data: membership, error: memErr } = await client
92
- .from("org_members")
93
- .select("role")
94
- .eq("user_id", userId)
95
- .eq("org_id", project.org_id)
96
- .maybeSingle();
97
- if (memErr || !membership) {
98
- // Check if user is a platform admin (can access all orgs)
99
- const { data: adminCheck } = await client.rpc("is_platform_admin");
100
- if (adminCheck === true) {
101
- return "admin";
102
- }
103
- throw new Error("Not a member of this project's organization");
104
- }
105
- if (membership.role === "viewer") {
106
- throw new Error("VIEWER_ROLE");
107
- }
108
- return membership.role;
109
- }
110
- //# sourceMappingURL=client.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/db/client.ts"],"names":[],"mappings":"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"}
@@ -1,8 +0,0 @@
1
- export {};
2
- /**
3
- * Graph traversal helpers for traceability links.
4
- * Used by get-coverage and export-mermaid tools.
5
- *
6
- * TODO: Implement graph traversal in Phase 2.
7
- */
8
- //# sourceMappingURL=graph.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"graph.d.ts","sourceRoot":"","sources":["../../src/db/graph.ts"],"names":[],"mappings":";AAAA;;;;;GAKG"}
package/dist/db/graph.js DELETED
@@ -1,8 +0,0 @@
1
- export {};
2
- /**
3
- * Graph traversal helpers for traceability links.
4
- * Used by get-coverage and export-mermaid tools.
5
- *
6
- * TODO: Implement graph traversal in Phase 2.
7
- */
8
- //# sourceMappingURL=graph.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"graph.js","sourceRoot":"","sources":["../../src/db/graph.ts"],"names":[],"mappings":";AAAA;;;;;GAKG"}
@@ -1,77 +0,0 @@
1
- /**
2
- * Shared Supabase query helpers for MCP tools.
3
- *
4
- * All queries use the user's JWT via RLS — no service role key.
5
- * Query patterns adapted from supabase/functions/.../db.ts.
6
- */
7
- import type { SupabaseClient } from "@supabase/supabase-js";
8
- import type { ItemRow } from "../types/work-item.js";
9
- /**
10
- * List projects the authenticated user has access to (via org membership).
11
- */
12
- export declare function listProjects(client: SupabaseClient): Promise<Array<{
13
- id: string;
14
- name: string;
15
- description: string | null;
16
- org_id: string;
17
- org_name: string;
18
- created_at: string;
19
- }>>;
20
- /**
21
- * List items in a project with optional filters.
22
- * Returns rows ordered by created_at, respects soft deletes.
23
- */
24
- export declare function listItems(client: SupabaseClient, projectId: string, opts: {
25
- type?: string;
26
- domain?: string;
27
- level?: string;
28
- limit: number;
29
- offset: number;
30
- }): Promise<{
31
- items: ItemRow[];
32
- totalCount: number;
33
- }>;
34
- /**
35
- * Get a single item by ID (excludes soft-deleted).
36
- */
37
- export declare function getItemById(client: SupabaseClient, projectId: string, itemId: string): Promise<ItemRow | null>;
38
- /**
39
- * Full-text search across items in a project.
40
- * Uses ilike on title, body, and summary for broad matching.
41
- */
42
- export declare function searchItems(client: SupabaseClient, projectId: string, query: string, opts: {
43
- type?: string;
44
- limit: number;
45
- }): Promise<{
46
- items: ItemRow[];
47
- totalCount: number;
48
- }>;
49
- /**
50
- * Get all relationships for an item (both directions).
51
- */
52
- export declare function getItemRelationships(client: SupabaseClient, projectId: string, itemId: string): Promise<Array<{
53
- from_id: string;
54
- to_id: string;
55
- type: string;
56
- }>>;
57
- /**
58
- * Get test coverage report: requirements with/without linked test cases.
59
- */
60
- export declare function getCoverageReport(client: SupabaseClient, projectId: string, opts: {
61
- domain?: string;
62
- level?: string;
63
- }): Promise<{
64
- covered: ItemRow[];
65
- uncovered: ItemRow[];
66
- total: number;
67
- }>;
68
- /**
69
- * Get change history for an item, newest first.
70
- */
71
- export declare function getChangeHistory(client: SupabaseClient, projectId: string, itemId: string, limit: number): Promise<Array<Record<string, unknown>>>;
72
- /**
73
- * Generate the next item ID for a given type in a project.
74
- * Format: PREFIX-NNNNN (e.g., REQ-00058)
75
- */
76
- export declare function generateItemId(client: SupabaseClient, projectId: string, type: string): Promise<string>;
77
- //# sourceMappingURL=queries.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"queries.d.ts","sourceRoot":"","sources":["../../src/db/queries.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AAMrD;;GAEG;AACH,wBAAsB,YAAY,CAChC,MAAM,EAAE,cAAc,GACrB,OAAO,CAAC,KAAK,CAAC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC,CAiBhI;AAMD;;;GAGG;AACH,wBAAsB,SAAS,CAC7B,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE;IACJ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,GACA,OAAO,CAAC;IAAE,KAAK,EAAE,OAAO,EAAE,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,CAAC,CAkCnD;AAED;;GAEG;AACH,wBAAsB,WAAW,CAC/B,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,CAWzB;AAED;;;GAGG;AACH,wBAAsB,WAAW,CAC/B,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GACrC,OAAO,CAAC;IAAE,KAAK,EAAE,OAAO,EAAE,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,CAAC,CA2BnD;AAMD;;GAEG;AACH,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,KAAK,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC,CASlE;AAMD;;GAEG;AACH,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,GACxC,OAAO,CAAC;IACT,OAAO,EAAE,OAAO,EAAE,CAAC;IACnB,SAAS,EAAE,OAAO,EAAE,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC,CAwCD;AAMD;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAWzC;AAMD;;;GAGG;AACH,wBAAsB,cAAc,CAClC,MAAM,EAAE,cAAc,EACtB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,GACX,OAAO,CAAC,MAAM,CAAC,CAejB"}
@@ -1,210 +0,0 @@
1
- /**
2
- * Shared Supabase query helpers for MCP tools.
3
- *
4
- * All queries use the user's JWT via RLS — no service role key.
5
- * Query patterns adapted from supabase/functions/.../db.ts.
6
- */
7
- // ---------------------------------------------------------------------------
8
- // Project queries
9
- // ---------------------------------------------------------------------------
10
- /**
11
- * List projects the authenticated user has access to (via org membership).
12
- */
13
- export async function listProjects(client) {
14
- const { data, error } = await client
15
- .from("projects")
16
- .select("id, name, description, org_id, created_at, organizations(name)")
17
- .is("deleted_at", null)
18
- .order("created_at", { ascending: false });
19
- if (error)
20
- throw new Error(error.message);
21
- return (data ?? []).map((p) => ({
22
- id: p.id,
23
- name: p.name,
24
- description: p.description,
25
- org_id: p.org_id,
26
- org_name: p.organizations?.name ?? "Unknown",
27
- created_at: p.created_at,
28
- }));
29
- }
30
- // ---------------------------------------------------------------------------
31
- // Item queries
32
- // ---------------------------------------------------------------------------
33
- /**
34
- * List items in a project with optional filters.
35
- * Returns rows ordered by created_at, respects soft deletes.
36
- */
37
- export async function listItems(client, projectId, opts) {
38
- let query = client
39
- .from("items")
40
- .select("*", { count: "exact" })
41
- .eq("project_id", projectId)
42
- .is("deleted_at", null)
43
- .order("created_at", { ascending: true })
44
- .range(opts.offset, opts.offset + opts.limit - 1);
45
- if (opts.type) {
46
- query = query.eq("type", opts.type);
47
- }
48
- const { data, error, count } = await query;
49
- if (error)
50
- throw new Error(error.message);
51
- // Apply domain/level filters in JS (JSONB nested field filtering)
52
- let filtered = (data ?? []);
53
- if (opts.domain) {
54
- filtered = filtered.filter((item) => {
55
- const domains = item.data?.tags?.domains ?? [];
56
- return domains.includes(opts.domain);
57
- });
58
- }
59
- if (opts.level) {
60
- filtered = filtered.filter((item) => {
61
- return item.data?.tags?.level === opts.level;
62
- });
63
- }
64
- return {
65
- items: filtered,
66
- totalCount: opts.domain || opts.level ? filtered.length : (count ?? 0),
67
- };
68
- }
69
- /**
70
- * Get a single item by ID (excludes soft-deleted).
71
- */
72
- export async function getItemById(client, projectId, itemId) {
73
- const { data, error } = await client
74
- .from("items")
75
- .select("*")
76
- .eq("id", itemId)
77
- .eq("project_id", projectId)
78
- .is("deleted_at", null)
79
- .maybeSingle();
80
- if (error)
81
- throw new Error(error.message);
82
- return data;
83
- }
84
- /**
85
- * Full-text search across items in a project.
86
- * Uses ilike on title, body, and summary for broad matching.
87
- */
88
- export async function searchItems(client, projectId, query, opts) {
89
- const searchTerm = query.trim();
90
- if (!searchTerm) {
91
- return { items: [], totalCount: 0 };
92
- }
93
- // Use ilike for broad matching across title and JSONB fields
94
- let queryBuilder = client
95
- .from("items")
96
- .select("*", { count: "exact" })
97
- .eq("project_id", projectId)
98
- .is("deleted_at", null)
99
- .or(`title.ilike.%${searchTerm}%,` +
100
- `data->>body.ilike.%${searchTerm}%,` +
101
- `data->>summary.ilike.%${searchTerm}%`)
102
- .limit(opts.limit);
103
- if (opts.type) {
104
- queryBuilder = queryBuilder.eq("type", opts.type);
105
- }
106
- const { data, error, count } = await queryBuilder;
107
- if (error)
108
- throw new Error(error.message);
109
- return { items: (data ?? []), totalCount: count ?? 0 };
110
- }
111
- // ---------------------------------------------------------------------------
112
- // Relationship queries
113
- // ---------------------------------------------------------------------------
114
- /**
115
- * Get all relationships for an item (both directions).
116
- */
117
- export async function getItemRelationships(client, projectId, itemId) {
118
- const { data, error } = await client
119
- .from("item_relationships")
120
- .select("from_id, to_id, type")
121
- .eq("project_id", projectId)
122
- .or(`from_id.eq.${itemId},to_id.eq.${itemId}`);
123
- if (error)
124
- throw new Error(error.message);
125
- return data ?? [];
126
- }
127
- // ---------------------------------------------------------------------------
128
- // Coverage queries
129
- // ---------------------------------------------------------------------------
130
- /**
131
- * Get test coverage report: requirements with/without linked test cases.
132
- */
133
- export async function getCoverageReport(client, projectId, opts) {
134
- // Get all requirements in the project
135
- const { data: requirements, error: reqErr } = await client
136
- .from("items")
137
- .select("*")
138
- .eq("project_id", projectId)
139
- .eq("type", "requirement")
140
- .is("deleted_at", null);
141
- if (reqErr)
142
- throw new Error(reqErr.message);
143
- const allReqs = (requirements ?? []);
144
- // Filter by domain/level on the JSONB data
145
- const filteredReqs = allReqs.filter((req) => {
146
- if (opts.domain) {
147
- const domains = req.data?.tags?.domains ?? [];
148
- if (!domains.includes(opts.domain))
149
- return false;
150
- }
151
- if (opts.level) {
152
- if (req.data?.tags?.level !== opts.level)
153
- return false;
154
- }
155
- return true;
156
- });
157
- // Get all verified_by relationships for this project
158
- const { data: verifiedRels, error: relErr } = await client
159
- .from("item_relationships")
160
- .select("from_id")
161
- .eq("project_id", projectId)
162
- .eq("type", "verified_by");
163
- if (relErr)
164
- throw new Error(relErr.message);
165
- const coveredIds = new Set((verifiedRels ?? []).map((r) => r.from_id));
166
- const covered = filteredReqs.filter((r) => coveredIds.has(r.id));
167
- const uncovered = filteredReqs.filter((r) => !coveredIds.has(r.id));
168
- return { covered, uncovered, total: filteredReqs.length };
169
- }
170
- // ---------------------------------------------------------------------------
171
- // History queries
172
- // ---------------------------------------------------------------------------
173
- /**
174
- * Get change history for an item, newest first.
175
- */
176
- export async function getChangeHistory(client, projectId, itemId, limit) {
177
- const { data, error } = await client
178
- .from("change_history")
179
- .select("*")
180
- .eq("item_id", itemId)
181
- .eq("project_id", projectId)
182
- .order("changed_at", { ascending: false })
183
- .limit(limit);
184
- if (error)
185
- throw new Error(error.message);
186
- return data ?? [];
187
- }
188
- // ---------------------------------------------------------------------------
189
- // Item mutations (for write tools — Phase 3)
190
- // ---------------------------------------------------------------------------
191
- /**
192
- * Generate the next item ID for a given type in a project.
193
- * Format: PREFIX-NNNNN (e.g., REQ-00058)
194
- */
195
- export async function generateItemId(client, projectId, type) {
196
- const prefix = type === "requirement" ? "REQ"
197
- : type === "test-case" ? "TC"
198
- : type === "note" ? "NOTE"
199
- : "TABLE";
200
- // Use Postgres SECURITY DEFINER function that sees ALL items (including soft-deleted)
201
- // to avoid ID collisions. Only returns the next ID string, never exposes item data.
202
- const { data, error } = await client.rpc("next_item_id", {
203
- p_project_id: projectId,
204
- p_prefix: prefix,
205
- });
206
- if (error)
207
- throw new Error(`ID generation failed: ${error.message}`);
208
- return data;
209
- }
210
- //# sourceMappingURL=queries.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"queries.js","sourceRoot":"","sources":["../../src/db/queries.ts"],"names":[],"mappings":"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"}
package/dist/index.d.ts DELETED
@@ -1,12 +0,0 @@
1
- #!/usr/bin/env node
2
- /**
3
- * ATOMS MCP Server — CLI Entry Point
4
- *
5
- * Commands:
6
- * npx @atoms-tech/atoms-mcp → Start MCP server (stdio transport)
7
- * npx @atoms-tech/atoms-mcp login → Authenticate with ATOMS.tech
8
- * npx @atoms-tech/atoms-mcp whoami → Show current user
9
- * npx @atoms-tech/atoms-mcp --version → Show version
10
- */
11
- export {};
12
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AACA;;;;;;;;GAQG"}
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -1,26 +0,0 @@
1
- /**
2
- * Fire-and-forget MCP audit logging.
3
- *
4
- * Every tool call is logged to mcp_audit_log for enterprise compliance.
5
- * Logging NEVER blocks or delays the tool response.
6
- */
7
- import type { SupabaseClient } from "@supabase/supabase-js";
8
- export interface AuditEntry {
9
- tool_name: string;
10
- params: Record<string, unknown>;
11
- status: "success" | "error";
12
- duration_ms: number;
13
- error_msg?: string;
14
- project_id?: string;
15
- session_id?: string;
16
- client_name?: string;
17
- }
18
- /**
19
- * Log a tool call to mcp_audit_log. Fire-and-forget — errors are swallowed.
20
- */
21
- export declare function logAudit(client: SupabaseClient, userId: string, entry: AuditEntry): void;
22
- /**
23
- * Timer utility for measuring tool duration.
24
- */
25
- export declare function startTimer(): () => number;
26
- //# sourceMappingURL=audit.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"audit.d.ts","sourceRoot":"","sources":["../../src/middleware/audit.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,WAAW,UAAU;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,wBAAgB,QAAQ,CACtB,MAAM,EAAE,cAAc,EACtB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,UAAU,GAChB,IAAI,CA6BN;AAED;;GAEG;AACH,wBAAgB,UAAU,IAAI,MAAM,MAAM,CAGzC"}
@@ -1,44 +0,0 @@
1
- /**
2
- * Fire-and-forget MCP audit logging.
3
- *
4
- * Every tool call is logged to mcp_audit_log for enterprise compliance.
5
- * Logging NEVER blocks or delays the tool response.
6
- */
7
- /**
8
- * Log a tool call to mcp_audit_log. Fire-and-forget — errors are swallowed.
9
- */
10
- export function logAudit(client, userId, entry) {
11
- // Sanitize params — strip any secrets
12
- const sanitizedParams = { ...entry.params };
13
- delete sanitizedParams.access_token;
14
- delete sanitizedParams.refresh_token;
15
- delete sanitizedParams.password;
16
- // Fire and forget — don't await
17
- client
18
- .from("mcp_audit_log")
19
- .insert({
20
- user_id: userId,
21
- tool_name: entry.tool_name,
22
- params: sanitizedParams,
23
- status: entry.status,
24
- duration_ms: entry.duration_ms,
25
- error_msg: entry.error_msg ?? null,
26
- project_id: entry.project_id ?? null,
27
- session_id: entry.session_id ?? null,
28
- client_name: entry.client_name ?? null,
29
- })
30
- .then(({ error }) => {
31
- if (error) {
32
- // Log to stderr, never throw
33
- process.stderr.write(`[audit] Failed to log: ${error.message}\n`);
34
- }
35
- });
36
- }
37
- /**
38
- * Timer utility for measuring tool duration.
39
- */
40
- export function startTimer() {
41
- const start = performance.now();
42
- return () => Math.round(performance.now() - start);
43
- }
44
- //# sourceMappingURL=audit.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"audit.js","sourceRoot":"","sources":["../../src/middleware/audit.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAeH;;GAEG;AACH,MAAM,UAAU,QAAQ,CACtB,MAAsB,EACtB,MAAc,EACd,KAAiB;IAEjB,sCAAsC;IACtC,MAAM,eAAe,GAAG,EAAE,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;IAC5C,OAAO,eAAe,CAAC,YAAY,CAAC;IACpC,OAAO,eAAe,CAAC,aAAa,CAAC;IACrC,OAAO,eAAe,CAAC,QAAQ,CAAC;IAEhC,gCAAgC;IAChC,MAAM;SACH,IAAI,CAAC,eAAe,CAAC;SACrB,MAAM,CAAC;QACN,OAAO,EAAE,MAAM;QACf,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,MAAM,EAAE,eAAe;QACvB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,SAAS,EAAE,KAAK,CAAC,SAAS,IAAI,IAAI;QAClC,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,IAAI;QACpC,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,IAAI;QACpC,WAAW,EAAE,KAAK,CAAC,WAAW,IAAI,IAAI;KACvC,CAAC;SACD,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;QAClB,IAAI,KAAK,EAAE,CAAC;YACV,6BAA6B;YAC7B,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,0BAA0B,KAAK,CAAC,OAAO,IAAI,CAC5C,CAAC;QACJ,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,UAAU;IACxB,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC;IAChC,OAAO,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC;AACrD,CAAC"}
@@ -1,21 +0,0 @@
1
- /**
2
- * In-memory per-user rate limiting for MCP tool calls.
3
- *
4
- * Default: 60 requests/minute. Configurable via ATOMS_RATE_LIMIT_RPM env var.
5
- * Uses sliding window algorithm.
6
- */
7
- /**
8
- * Check if a user has exceeded their rate limit.
9
- * Returns { allowed: true } or { allowed: false, retryAfterSeconds }.
10
- */
11
- export declare function checkRateLimit(userId: string): {
12
- allowed: true;
13
- } | {
14
- allowed: false;
15
- retryAfterSeconds: number;
16
- };
17
- /**
18
- * Clear rate limit state. Useful for testing.
19
- */
20
- export declare function clearRateLimits(): void;
21
- //# sourceMappingURL=rate-limiter.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rate-limiter.d.ts","sourceRoot":"","sources":["../../src/middleware/rate-limiter.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAWH;;;GAGG;AACH,wBAAgB,cAAc,CAC5B,MAAM,EAAE,MAAM,GACb;IAAE,OAAO,EAAE,IAAI,CAAA;CAAE,GAAG;IAAE,OAAO,EAAE,KAAK,CAAC;IAAC,iBAAiB,EAAE,MAAM,CAAA;CAAE,CA0BnE;AAED;;GAEG;AACH,wBAAgB,eAAe,IAAI,IAAI,CAEtC"}