medusa-plugin-mcp 0.1.0

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 (44) hide show
  1. package/.medusa/server/medusa-config.d.ts +1 -0
  2. package/.medusa/server/medusa-config.js +23 -0
  3. package/.medusa/server/src/admin/index.js +192 -0
  4. package/.medusa/server/src/admin/index.mjs +191 -0
  5. package/.medusa/server/src/api/admin/chat/route.d.ts +3 -0
  6. package/.medusa/server/src/api/admin/chat/route.js +102 -0
  7. package/.medusa/server/src/api/admin/mcp/route.d.ts +4 -0
  8. package/.medusa/server/src/api/admin/mcp/route.js +60 -0
  9. package/.medusa/server/src/api/middlewares.d.ts +2 -0
  10. package/.medusa/server/src/api/middlewares.js +24 -0
  11. package/.medusa/server/src/api/validators.d.ts +24 -0
  12. package/.medusa/server/src/api/validators.js +11 -0
  13. package/.medusa/server/src/lib/llm-provider.d.ts +32 -0
  14. package/.medusa/server/src/lib/llm-provider.js +22 -0
  15. package/.medusa/server/src/lib/providers/anthropic.d.ts +11 -0
  16. package/.medusa/server/src/lib/providers/anthropic.js +53 -0
  17. package/.medusa/server/src/lib/providers/ollama.d.ts +11 -0
  18. package/.medusa/server/src/lib/providers/ollama.js +39 -0
  19. package/.medusa/server/src/lib/providers/openai.d.ts +12 -0
  20. package/.medusa/server/src/lib/providers/openai.js +49 -0
  21. package/.medusa/server/src/mcp/server.d.ts +3 -0
  22. package/.medusa/server/src/mcp/server.js +42 -0
  23. package/.medusa/server/src/mcp/tools/automations.d.ts +3 -0
  24. package/.medusa/server/src/mcp/tools/automations.js +176 -0
  25. package/.medusa/server/src/mcp/tools/customers.d.ts +3 -0
  26. package/.medusa/server/src/mcp/tools/customers.js +72 -0
  27. package/.medusa/server/src/mcp/tools/inventory.d.ts +3 -0
  28. package/.medusa/server/src/mcp/tools/inventory.js +70 -0
  29. package/.medusa/server/src/mcp/tools/orders.d.ts +3 -0
  30. package/.medusa/server/src/mcp/tools/orders.js +80 -0
  31. package/.medusa/server/src/mcp/tools/products.d.ts +3 -0
  32. package/.medusa/server/src/mcp/tools/products.js +72 -0
  33. package/.medusa/server/src/mcp/tools/query.d.ts +3 -0
  34. package/.medusa/server/src/mcp/tools/query.js +42 -0
  35. package/.medusa/server/src/mcp/tools/statistics.d.ts +3 -0
  36. package/.medusa/server/src/mcp/tools/statistics.js +10 -0
  37. package/.medusa/server/src/modules/mcp/index.d.ts +7 -0
  38. package/.medusa/server/src/modules/mcp/index.js +25 -0
  39. package/.medusa/server/src/modules/mcp/service.d.ts +8 -0
  40. package/.medusa/server/src/modules/mcp/service.js +15 -0
  41. package/.medusa/server/src/types.d.ts +7 -0
  42. package/.medusa/server/src/types.js +3 -0
  43. package/LICENSE.md +73 -0
  44. package/package.json +98 -0
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.registerInventoryTools = registerInventoryTools;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ const zod_1 = require("zod");
6
+ function registerInventoryTools(server, scope) {
7
+ const query = scope.resolve(utils_1.ContainerRegistrationKeys.QUERY);
8
+ server.registerTool('low_stock_items', {
9
+ description: 'Find inventory items with stock levels at or below a threshold.',
10
+ inputSchema: {
11
+ threshold: zod_1.z.coerce.number().int().min(0).optional().default(10),
12
+ limit: zod_1.z.coerce.number().int().min(1).max(100).optional().default(20)
13
+ }
14
+ }, async ({ threshold, limit }) => {
15
+ const { data } = await query.graph({
16
+ entity: 'inventory_item',
17
+ fields: [
18
+ 'id',
19
+ 'sku',
20
+ 'title',
21
+ 'location_levels.id',
22
+ 'location_levels.stocked_quantity',
23
+ 'location_levels.reserved_quantity',
24
+ 'location_levels.stock_location.id',
25
+ 'location_levels.stock_location.name'
26
+ ],
27
+ filters: {
28
+ location_levels: {
29
+ stocked_quantity: { $lte: threshold }
30
+ }
31
+ },
32
+ pagination: { take: limit }
33
+ });
34
+ return {
35
+ content: [{ type: 'text', text: JSON.stringify(data, null, 2) }]
36
+ };
37
+ });
38
+ server.registerTool('get_inventory_item', {
39
+ description: 'Fetch a single inventory item by ID with stock levels across locations.',
40
+ inputSchema: {
41
+ inventory_item_id: zod_1.z.string().describe('The inventory item ID')
42
+ }
43
+ }, async ({ inventory_item_id }) => {
44
+ const { data: [item] } = await query.graph({
45
+ entity: 'inventory_item',
46
+ fields: [
47
+ 'id',
48
+ 'sku',
49
+ 'title',
50
+ 'requires_shipping',
51
+ 'location_levels.id',
52
+ 'location_levels.stocked_quantity',
53
+ 'location_levels.reserved_quantity',
54
+ 'location_levels.incoming_quantity',
55
+ 'location_levels.stock_location.id',
56
+ 'location_levels.stock_location.name',
57
+ 'created_at',
58
+ 'updated_at'
59
+ ],
60
+ filters: { id: inventory_item_id }
61
+ });
62
+ if (!item) {
63
+ return { content: [{ type: 'text', text: 'Inventory item not found.' }] };
64
+ }
65
+ return {
66
+ content: [{ type: 'text', text: JSON.stringify(item, null, 2) }]
67
+ };
68
+ });
69
+ }
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW52ZW50b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL21jcC90b29scy9pbnZlbnRvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFLQSx3REE4RUM7QUFqRkQscURBQXFFO0FBQ3JFLDZCQUF1QjtBQUV2QixTQUFnQixzQkFBc0IsQ0FBQyxNQUFpQixFQUFFLEtBQXNCO0lBQy9FLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsaUNBQXlCLENBQUMsS0FBSyxDQUFDLENBQUE7SUFFNUQsTUFBTSxDQUFDLFlBQVksQ0FDbEIsaUJBQWlCLEVBQ2pCO1FBQ0MsV0FBVyxFQUFFLGlFQUFpRTtRQUM5RSxXQUFXLEVBQUU7WUFDWixTQUFTLEVBQUUsT0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNoRSxLQUFLLEVBQUUsT0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7U0FDckU7S0FDRCxFQUNELEtBQUssRUFBRSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFO1FBQzlCLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxNQUFNLEtBQUssQ0FBQyxLQUFLLENBQUM7WUFDbEMsTUFBTSxFQUFFLGdCQUFnQjtZQUN4QixNQUFNLEVBQUU7Z0JBQ1AsSUFBSTtnQkFDSixLQUFLO2dCQUNMLE9BQU87Z0JBQ1Asb0JBQW9CO2dCQUNwQixrQ0FBa0M7Z0JBQ2xDLG1DQUFtQztnQkFDbkMsbUNBQW1DO2dCQUNuQyxxQ0FBcUM7YUFDckM7WUFDRCxPQUFPLEVBQUU7Z0JBQ1IsZUFBZSxFQUFFO29CQUNoQixnQkFBZ0IsRUFBRSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUU7aUJBQ3JDO2FBQ007WUFDUixVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFO1NBQzNCLENBQUMsQ0FBQTtRQUVGLE9BQU87WUFDTixPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFlLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDO1NBQ3pFLENBQUE7SUFDRixDQUFDLENBQ0QsQ0FBQTtJQUVELE1BQU0sQ0FBQyxZQUFZLENBQ2xCLG9CQUFvQixFQUNwQjtRQUNDLFdBQVcsRUFBRSx5RUFBeUU7UUFDdEYsV0FBVyxFQUFFO1lBQ1osaUJBQWlCLEVBQUUsT0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsQ0FBQyx1QkFBdUIsQ0FBQztTQUMvRDtLQUNELEVBQ0QsS0FBSyxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsRUFBRSxFQUFFO1FBQy9CLE1BQU0sRUFDTCxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFDWixHQUFHLE1BQU0sS0FBSyxDQUFDLEtBQUssQ0FBQztZQUNyQixNQUFNLEVBQUUsZ0JBQWdCO1lBQ3hCLE1BQU0sRUFBRTtnQkFDUCxJQUFJO2dCQUNKLEtBQUs7Z0JBQ0wsT0FBTztnQkFDUCxtQkFBbUI7Z0JBQ25CLG9CQUFvQjtnQkFDcEIsa0NBQWtDO2dCQUNsQyxtQ0FBbUM7Z0JBQ25DLG1DQUFtQztnQkFDbkMsbUNBQW1DO2dCQUNuQyxxQ0FBcUM7Z0JBQ3JDLFlBQVk7Z0JBQ1osWUFBWTthQUNaO1lBQ0QsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLGlCQUFpQixFQUFFO1NBQ2xDLENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNYLE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFlLEVBQUUsSUFBSSxFQUFFLDJCQUEyQixFQUFFLENBQUMsRUFBRSxDQUFBO1FBQ25GLENBQUM7UUFFRCxPQUFPO1lBQ04sT0FBTyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBZSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUN6RSxDQUFBO0lBQ0YsQ0FBQyxDQUNELENBQUE7QUFDRixDQUFDIn0=
@@ -0,0 +1,3 @@
1
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
2
+ import { MedusaContainer } from '@medusajs/framework/types';
3
+ export declare function registerOrderTools(server: McpServer, scope: MedusaContainer): void;
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.registerOrderTools = registerOrderTools;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ const zod_1 = require("zod");
6
+ function registerOrderTools(server, scope) {
7
+ const query = scope.resolve(utils_1.ContainerRegistrationKeys.QUERY);
8
+ server.registerTool('recent_orders', {
9
+ description: 'Fetch recent orders with status, totals, and customer info.',
10
+ inputSchema: {
11
+ limit: zod_1.z.coerce.number().int().min(1).max(50).optional().default(10),
12
+ status: zod_1.z.string().optional().describe('Filter by order status')
13
+ }
14
+ }, async ({ limit, status }) => {
15
+ const { data } = await query.graph({
16
+ entity: 'order',
17
+ fields: [
18
+ 'id',
19
+ 'display_id',
20
+ 'status',
21
+ 'email',
22
+ 'total',
23
+ 'subtotal',
24
+ 'tax_total',
25
+ 'shipping_total',
26
+ 'customer.first_name',
27
+ 'customer.last_name',
28
+ 'created_at'
29
+ ],
30
+ filters: (status ? { status } : {}),
31
+ pagination: { take: limit, order: { created_at: 'DESC' } }
32
+ });
33
+ return {
34
+ content: [{ type: 'text', text: JSON.stringify(data, null, 2) }]
35
+ };
36
+ });
37
+ server.registerTool('get_order', {
38
+ description: 'Fetch a single order by ID with full details including items, fulfillments, and customer.',
39
+ inputSchema: {
40
+ order_id: zod_1.z.string().describe('The order ID')
41
+ }
42
+ }, async ({ order_id }) => {
43
+ const { data: [order] } = await query.graph({
44
+ entity: 'order',
45
+ fields: [
46
+ 'id',
47
+ 'display_id',
48
+ 'status',
49
+ 'email',
50
+ 'total',
51
+ 'subtotal',
52
+ 'tax_total',
53
+ 'shipping_total',
54
+ 'discount_total',
55
+ 'customer.id',
56
+ 'customer.first_name',
57
+ 'customer.last_name',
58
+ 'customer.email',
59
+ 'items.id',
60
+ 'items.title',
61
+ 'items.quantity',
62
+ 'items.unit_price',
63
+ 'shipping_address.*',
64
+ 'billing_address.*',
65
+ 'fulfillments.id',
66
+ 'fulfillments.status',
67
+ 'created_at',
68
+ 'updated_at'
69
+ ],
70
+ filters: { id: order_id }
71
+ });
72
+ if (!order) {
73
+ return { content: [{ type: 'text', text: 'Order not found.' }] };
74
+ }
75
+ return {
76
+ content: [{ type: 'text', text: JSON.stringify(order, null, 2) }]
77
+ };
78
+ });
79
+ }
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL21jcC90b29scy9vcmRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFLQSxnREF3RkM7QUEzRkQscURBQXFFO0FBQ3JFLDZCQUF1QjtBQUV2QixTQUFnQixrQkFBa0IsQ0FBQyxNQUFpQixFQUFFLEtBQXNCO0lBQzNFLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsaUNBQXlCLENBQUMsS0FBSyxDQUFDLENBQUE7SUFFNUQsTUFBTSxDQUFDLFlBQVksQ0FDbEIsZUFBZSxFQUNmO1FBQ0MsV0FBVyxFQUFFLDZEQUE2RDtRQUMxRSxXQUFXLEVBQUU7WUFDWixLQUFLLEVBQUUsT0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDcEUsTUFBTSxFQUFFLE9BQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxRQUFRLENBQUMsd0JBQXdCLENBQUM7U0FDaEU7S0FDRCxFQUNELEtBQUssRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFO1FBQzNCLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxNQUFNLEtBQUssQ0FBQyxLQUFLLENBQUM7WUFDbEMsTUFBTSxFQUFFLE9BQU87WUFDZixNQUFNLEVBQUU7Z0JBQ1AsSUFBSTtnQkFDSixZQUFZO2dCQUNaLFFBQVE7Z0JBQ1IsT0FBTztnQkFDUCxPQUFPO2dCQUNQLFVBQVU7Z0JBQ1YsV0FBVztnQkFDWCxnQkFBZ0I7Z0JBQ2hCLHFCQUFxQjtnQkFDckIsb0JBQW9CO2dCQUNwQixZQUFZO2FBQ1o7WUFDRCxPQUFPLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBUTtZQUMxQyxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsRUFBRTtTQUMxRCxDQUFDLENBQUE7UUFFRixPQUFPO1lBQ04sT0FBTyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBZSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUN6RSxDQUFBO0lBQ0YsQ0FBQyxDQUNELENBQUE7SUFFRCxNQUFNLENBQUMsWUFBWSxDQUNsQixXQUFXLEVBQ1g7UUFDQyxXQUFXLEVBQUUsMkZBQTJGO1FBQ3hHLFdBQVcsRUFBRTtZQUNaLFFBQVEsRUFBRSxPQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQztTQUM3QztLQUNELEVBQ0QsS0FBSyxFQUFFLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRTtRQUN0QixNQUFNLEVBQ0wsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDLEVBQ2IsR0FBRyxNQUFNLEtBQUssQ0FBQyxLQUFLLENBQUM7WUFDckIsTUFBTSxFQUFFLE9BQU87WUFDZixNQUFNLEVBQUU7Z0JBQ1AsSUFBSTtnQkFDSixZQUFZO2dCQUNaLFFBQVE7Z0JBQ1IsT0FBTztnQkFDUCxPQUFPO2dCQUNQLFVBQVU7Z0JBQ1YsV0FBVztnQkFDWCxnQkFBZ0I7Z0JBQ2hCLGdCQUFnQjtnQkFDaEIsYUFBYTtnQkFDYixxQkFBcUI7Z0JBQ3JCLG9CQUFvQjtnQkFDcEIsZ0JBQWdCO2dCQUNoQixVQUFVO2dCQUNWLGFBQWE7Z0JBQ2IsZ0JBQWdCO2dCQUNoQixrQkFBa0I7Z0JBQ2xCLG9CQUFvQjtnQkFDcEIsbUJBQW1CO2dCQUNuQixpQkFBaUI7Z0JBQ2pCLHFCQUFxQjtnQkFDckIsWUFBWTtnQkFDWixZQUFZO2FBQ1o7WUFDRCxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsUUFBUSxFQUFFO1NBQ3pCLENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNaLE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFlLEVBQUUsSUFBSSxFQUFFLGtCQUFrQixFQUFFLENBQUMsRUFBRSxDQUFBO1FBQzFFLENBQUM7UUFFRCxPQUFPO1lBQ04sT0FBTyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBZSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUMxRSxDQUFBO0lBQ0YsQ0FBQyxDQUNELENBQUE7QUFDRixDQUFDIn0=
@@ -0,0 +1,3 @@
1
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
2
+ import { MedusaContainer } from '@medusajs/framework/types';
3
+ export declare function registerProductTools(server: McpServer, scope: MedusaContainer): void;
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.registerProductTools = registerProductTools;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ const zod_1 = require("zod");
6
+ function registerProductTools(server, scope) {
7
+ const query = scope.resolve(utils_1.ContainerRegistrationKeys.QUERY);
8
+ server.registerTool('search_products', {
9
+ description: 'Search products by title.',
10
+ inputSchema: {
11
+ q: zod_1.z.string().describe('Search term (matches title)'),
12
+ limit: zod_1.z.coerce.number().int().min(1).max(50).optional().default(10)
13
+ }
14
+ }, async ({ q, limit }) => {
15
+ const { data } = await query.graph({
16
+ entity: 'product',
17
+ fields: [
18
+ 'id',
19
+ 'title',
20
+ 'handle',
21
+ 'status',
22
+ 'variants.id',
23
+ 'variants.title',
24
+ 'variants.sku',
25
+ 'created_at'
26
+ ],
27
+ filters: { title: { $ilike: `%${q}%` } },
28
+ pagination: { take: limit }
29
+ });
30
+ return {
31
+ content: [{ type: 'text', text: JSON.stringify(data, null, 2) }]
32
+ };
33
+ });
34
+ server.registerTool('get_product', {
35
+ description: 'Fetch a single product by ID with variants and pricing.',
36
+ inputSchema: {
37
+ product_id: zod_1.z.string().describe('The product ID')
38
+ }
39
+ }, async ({ product_id }) => {
40
+ const { data: [product] } = await query.graph({
41
+ entity: 'product',
42
+ fields: [
43
+ 'id',
44
+ 'title',
45
+ 'handle',
46
+ 'subtitle',
47
+ 'description',
48
+ 'status',
49
+ 'variants.id',
50
+ 'variants.title',
51
+ 'variants.sku',
52
+ 'variants.prices.amount',
53
+ 'variants.prices.currency_code',
54
+ 'options.id',
55
+ 'options.title',
56
+ 'options.values.value',
57
+ 'tags.id',
58
+ 'tags.value',
59
+ 'created_at',
60
+ 'updated_at'
61
+ ],
62
+ filters: { id: product_id }
63
+ });
64
+ if (!product) {
65
+ return { content: [{ type: 'text', text: 'Product not found.' }] };
66
+ }
67
+ return {
68
+ content: [{ type: 'text', text: JSON.stringify(product, null, 2) }]
69
+ };
70
+ });
71
+ }
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbWNwL3Rvb2xzL3Byb2R1Y3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBS0Esb0RBZ0ZDO0FBbkZELHFEQUFxRTtBQUNyRSw2QkFBdUI7QUFFdkIsU0FBZ0Isb0JBQW9CLENBQUMsTUFBaUIsRUFBRSxLQUFzQjtJQUM3RSxNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLGlDQUF5QixDQUFDLEtBQUssQ0FBQyxDQUFBO0lBRTVELE1BQU0sQ0FBQyxZQUFZLENBQ2xCLGlCQUFpQixFQUNqQjtRQUNDLFdBQVcsRUFBRSwyQkFBMkI7UUFDeEMsV0FBVyxFQUFFO1lBQ1osQ0FBQyxFQUFFLE9BQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxRQUFRLENBQUMsNkJBQTZCLENBQUM7WUFDckQsS0FBSyxFQUFFLE9BQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1NBQ3BFO0tBQ0QsRUFDRCxLQUFLLEVBQUUsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRTtRQUN0QixNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsTUFBTSxLQUFLLENBQUMsS0FBSyxDQUFDO1lBQ2xDLE1BQU0sRUFBRSxTQUFTO1lBQ2pCLE1BQU0sRUFBRTtnQkFDUCxJQUFJO2dCQUNKLE9BQU87Z0JBQ1AsUUFBUTtnQkFDUixRQUFRO2dCQUNSLGFBQWE7Z0JBQ2IsZ0JBQWdCO2dCQUNoQixjQUFjO2dCQUNkLFlBQVk7YUFDWjtZQUNELE9BQU8sRUFBRSxFQUFFLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDeEMsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRTtTQUMzQixDQUFDLENBQUE7UUFFRixPQUFPO1lBQ04sT0FBTyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBZSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUN6RSxDQUFBO0lBQ0YsQ0FBQyxDQUNELENBQUE7SUFFRCxNQUFNLENBQUMsWUFBWSxDQUNsQixhQUFhLEVBQ2I7UUFDQyxXQUFXLEVBQUUseURBQXlEO1FBQ3RFLFdBQVcsRUFBRTtZQUNaLFVBQVUsRUFBRSxPQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsUUFBUSxDQUFDLGdCQUFnQixDQUFDO1NBQ2pEO0tBQ0QsRUFDRCxLQUFLLEVBQUUsRUFBRSxVQUFVLEVBQUUsRUFBRSxFQUFFO1FBQ3hCLE1BQU0sRUFDTCxJQUFJLEVBQUUsQ0FBQyxPQUFPLENBQUMsRUFDZixHQUFHLE1BQU0sS0FBSyxDQUFDLEtBQUssQ0FBQztZQUNyQixNQUFNLEVBQUUsU0FBUztZQUNqQixNQUFNLEVBQUU7Z0JBQ1AsSUFBSTtnQkFDSixPQUFPO2dCQUNQLFFBQVE7Z0JBQ1IsVUFBVTtnQkFDVixhQUFhO2dCQUNiLFFBQVE7Z0JBQ1IsYUFBYTtnQkFDYixnQkFBZ0I7Z0JBQ2hCLGNBQWM7Z0JBQ2Qsd0JBQXdCO2dCQUN4QiwrQkFBK0I7Z0JBQy9CLFlBQVk7Z0JBQ1osZUFBZTtnQkFDZixzQkFBc0I7Z0JBQ3RCLFNBQVM7Z0JBQ1QsWUFBWTtnQkFDWixZQUFZO2dCQUNaLFlBQVk7YUFDWjtZQUNELE9BQU8sRUFBRSxFQUFFLEVBQUUsRUFBRSxVQUFVLEVBQUU7U0FDM0IsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ2QsT0FBTyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQWUsRUFBRSxJQUFJLEVBQUUsb0JBQW9CLEVBQUUsQ0FBQyxFQUFFLENBQUE7UUFDNUUsQ0FBQztRQUVELE9BQU87WUFDTixPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFlLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDO1NBQzVFLENBQUE7SUFDRixDQUFDLENBQ0QsQ0FBQTtBQUNGLENBQUMifQ==
@@ -0,0 +1,3 @@
1
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
2
+ import { MedusaContainer } from '@medusajs/framework/types';
3
+ export declare function registerQueryTool(server: McpServer, scope: MedusaContainer): void;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.registerQueryTool = registerQueryTool;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ const zod_1 = require("zod");
6
+ const ALLOWED_ENTITIES = [
7
+ 'order', 'product', 'product_variant', 'customer', 'inventory_item',
8
+ 'fulfillment', 'cart', 'shipping_option', 'sales_channel', 'store',
9
+ 'form', 'form_submission', 'review', 'complaint', 'complaint_tag',
10
+ 'content_item', 'content_collection', 'stock_lot', 'serial_number',
11
+ 'veeqo_order', 'veeqo_shipment', 'webhook_trigger', 'webhook_action',
12
+ 'barcode', 'order_note', 'customer_tag'
13
+ ];
14
+ function registerQueryTool(server, scope) {
15
+ server.registerTool('query', {
16
+ description: `Run a query against any Medusa entity using query.graph(). Allowed entities: ${ALLOWED_ENTITIES.join(', ')}. ` +
17
+ 'Use dot notation for relations (e.g. "customer.first_name"). ' +
18
+ 'Filters support operators: $eq, $ne, $in, $nin, $like, $ilike, $gt, $gte, $lt, $lte.',
19
+ inputSchema: {
20
+ entity: zod_1.z.enum(ALLOWED_ENTITIES),
21
+ fields: zod_1.z.array(zod_1.z.string()).min(1).describe('Fields to return, e.g. ["id", "email", "orders.id"]'),
22
+ filters: zod_1.z.record(zod_1.z.unknown()).optional().describe('Filter conditions, e.g. { status: "completed" }'),
23
+ limit: zod_1.z.coerce.number().int().min(1).max(100).optional().default(20),
24
+ offset: zod_1.z.coerce.number().int().min(0).optional().default(0)
25
+ }
26
+ }, async ({ entity, fields, filters, limit, offset }) => {
27
+ const query = scope.resolve(utils_1.ContainerRegistrationKeys.QUERY);
28
+ const { data, metadata } = await query.graph({
29
+ entity,
30
+ fields,
31
+ filters: filters ?? {},
32
+ pagination: { take: limit, skip: offset }
33
+ });
34
+ return {
35
+ content: [{
36
+ type: 'text',
37
+ text: JSON.stringify({ data, count: metadata?.count ?? data.length, limit, offset }, null, 2)
38
+ }]
39
+ };
40
+ });
41
+ }
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbWNwL3Rvb2xzL3F1ZXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBY0EsOENBa0NDO0FBOUNELHFEQUFxRTtBQUNyRSw2QkFBdUI7QUFFdkIsTUFBTSxnQkFBZ0IsR0FBRztJQUN4QixPQUFPLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLFVBQVUsRUFBRSxnQkFBZ0I7SUFDbkUsYUFBYSxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxlQUFlLEVBQUUsT0FBTztJQUNsRSxNQUFNLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFBRSxlQUFlO0lBQ2pFLGNBQWMsRUFBRSxvQkFBb0IsRUFBRSxXQUFXLEVBQUUsZUFBZTtJQUNsRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCO0lBQ3BFLFNBQVMsRUFBRSxZQUFZLEVBQUUsY0FBYztDQUN2QyxDQUFBO0FBRUQsU0FBZ0IsaUJBQWlCLENBQUMsTUFBaUIsRUFBRSxLQUFzQjtJQUMxRSxNQUFNLENBQUMsWUFBWSxDQUNsQixPQUFPLEVBQ1A7UUFDQyxXQUFXLEVBQ1YsZ0ZBQWdGLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSTtZQUMvRywrREFBK0Q7WUFDL0Qsc0ZBQXNGO1FBQ3ZGLFdBQVcsRUFBRTtZQUNaLE1BQU0sRUFBRSxPQUFDLENBQUMsSUFBSSxDQUFDLGdCQUF5QyxDQUFDO1lBQ3pELE1BQU0sRUFBRSxPQUFDLENBQUMsS0FBSyxDQUFDLE9BQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMscURBQXFELENBQUM7WUFDbEcsT0FBTyxFQUFFLE9BQUMsQ0FBQyxNQUFNLENBQUMsT0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxDQUFDLGlEQUFpRCxDQUFDO1lBQ3JHLEtBQUssRUFBRSxPQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNyRSxNQUFNLEVBQUUsT0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztTQUM1RDtLQUNELEVBQ0QsS0FBSyxFQUFFLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUU7UUFDcEQsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxpQ0FBeUIsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUU1RCxNQUFNLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxHQUFHLE1BQU0sS0FBSyxDQUFDLEtBQUssQ0FBQztZQUM1QyxNQUFNO1lBQ04sTUFBTTtZQUNOLE9BQU8sRUFBRSxPQUFPLElBQUksRUFBRTtZQUN0QixVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUU7U0FDekMsQ0FBQyxDQUFBO1FBRUYsT0FBTztZQUNOLE9BQU8sRUFBRSxDQUFDO29CQUNULElBQUksRUFBRSxNQUFlO29CQUNyQixJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLEtBQUssSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO2lCQUM3RixDQUFDO1NBQ0YsQ0FBQTtJQUNGLENBQUMsQ0FDRCxDQUFBO0FBQ0YsQ0FBQyJ9
@@ -0,0 +1,3 @@
1
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
2
+ import { MedusaContainer } from '@medusajs/framework/types';
3
+ export declare function registerStatisticsTools(_server: McpServer, _scope: MedusaContainer, _moduleKey: string): void;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.registerStatisticsTools = registerStatisticsTools;
4
+ function registerStatisticsTools(_server, _scope, _moduleKey) {
5
+ // Future: register tools that query statistics_daily data
6
+ // e.g. get_revenue_trend, get_order_stats, compare_periods
7
+ // These tools will return structured data that the chat UI
8
+ // can render as Recharts charts.
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGlzdGljcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9tY3AvdG9vbHMvc3RhdGlzdGljcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUdBLDBEQVNDO0FBVEQsU0FBZ0IsdUJBQXVCLENBQ3RDLE9BQWtCLEVBQ2xCLE1BQXVCLEVBQ3ZCLFVBQWtCO0lBRWxCLDBEQUEwRDtJQUMxRCwyREFBMkQ7SUFDM0QsMkRBQTJEO0lBQzNELGlDQUFpQztBQUNsQyxDQUFDIn0=
@@ -0,0 +1,7 @@
1
+ import { McpService } from './service';
2
+ export declare const MCP_MODULE = "mcp";
3
+ declare const _default: import("@medusajs/types").ModuleExports<typeof McpService> & {
4
+ linkable: Record<string, any>;
5
+ };
6
+ export default _default;
7
+ export * from './service';
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.MCP_MODULE = void 0;
18
+ const utils_1 = require("@medusajs/framework/utils");
19
+ const service_1 = require("./service");
20
+ exports.MCP_MODULE = 'mcp';
21
+ exports.default = (0, utils_1.Module)(exports.MCP_MODULE, {
22
+ service: service_1.McpService
23
+ });
24
+ __exportStar(require("./service"), exports);
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbW9kdWxlcy9tY3AvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxxREFBa0Q7QUFDbEQsdUNBQXNDO0FBRXpCLFFBQUEsVUFBVSxHQUFHLEtBQUssQ0FBQTtBQUUvQixrQkFBZSxJQUFBLGNBQU0sRUFBQyxrQkFBVSxFQUFFO0lBQ2pDLE9BQU8sRUFBRSxvQkFBVTtDQUNuQixDQUFDLENBQUE7QUFFRiw0Q0FBeUIifQ==
@@ -0,0 +1,8 @@
1
+ import type { McpPluginOptions } from '../../types';
2
+ declare const McpService_base: import("@medusajs/framework/utils").MedusaServiceReturnType<import("@medusajs/framework/utils").ModelConfigurationsToConfigTemplate<{}>>;
3
+ export declare class McpService extends McpService_base {
4
+ protected readonly options_: McpPluginOptions;
5
+ constructor(_container: object, options: McpPluginOptions);
6
+ getOptions(): McpPluginOptions;
7
+ }
8
+ export {};
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.McpService = void 0;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ class McpService extends (0, utils_1.MedusaService)({}) {
6
+ constructor(_container, options) {
7
+ super(...arguments);
8
+ this.options_ = options;
9
+ }
10
+ getOptions() {
11
+ return this.options_;
12
+ }
13
+ }
14
+ exports.McpService = McpService;
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9tb2R1bGVzL21jcC9zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFEQUF5RDtBQUd6RCxNQUFhLFVBQVcsU0FBUSxJQUFBLHFCQUFhLEVBQUMsRUFBRSxDQUFDO0lBR2hELFlBQVksVUFBa0IsRUFBRSxPQUF5QjtRQUN4RCxLQUFLLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQTtRQUNuQixJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQTtJQUN4QixDQUFDO0lBRUQsVUFBVTtRQUNULE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQTtJQUNyQixDQUFDO0NBQ0Q7QUFYRCxnQ0FXQyJ9
@@ -0,0 +1,7 @@
1
+ export type McpPluginOptions = {
2
+ provider: 'anthropic' | 'openai' | 'ollama';
3
+ model: string;
4
+ apiKey?: string;
5
+ baseUrl?: string;
6
+ systemPrompt?: string;
7
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
package/LICENSE.md ADDED
@@ -0,0 +1,73 @@
1
+ ## Sustainable Use License
2
+
3
+ Version 1.0
4
+
5
+ ### Acceptance
6
+
7
+ By using the software, you agree to all of the terms and conditions below.
8
+
9
+ ### Copyright License
10
+
11
+ The licensor grants you a non-exclusive, royalty-free, worldwide, non-sublicensable, non-transferable license
12
+ to use, copy, distribute, make available, and prepare derivative works of the software, in each case subject
13
+ to the limitations below.
14
+
15
+ ### Limitations
16
+
17
+ You may use or modify the software only for your own internal business purposes or for non-commercial or
18
+ personal use. You may distribute the software or provide it to others only if you do so free of charge for
19
+ non-commercial purposes. You may not alter, remove, or obscure any licensing, copyright, or other notices of
20
+ the licensor in the software. Any use of the licensor’s trademarks is subject to applicable law.
21
+
22
+ ### Patents
23
+
24
+ The licensor grants you a license, under any patent claims the licensor can license, or becomes able to
25
+ license, to make, have made, use, sell, offer for sale, import and have imported the software, in each case
26
+ subject to the limitations and conditions in this license. This license does not cover any patent claims that
27
+ you cause to be infringed by modifications or additions to the software. If you or your company make any
28
+ written claim that the software infringes or contributes to infringement of any patent, your patent license
29
+ for the software granted under these terms ends immediately. If your company makes such a claim, your patent
30
+ license ends immediately for work on behalf of your company.
31
+
32
+ ### Notices
33
+
34
+ You must ensure that anyone who gets a copy of any part of the software from you also gets a copy of these
35
+ terms. If you modify the software, you must include in any modified copies of the software a prominent notice
36
+ stating that you have modified the software.
37
+
38
+ ### No Other Rights
39
+
40
+ These terms do not imply any licenses other than those expressly granted in these terms.
41
+
42
+ ### Termination
43
+
44
+ If you use the software in violation of these terms, such use is not licensed, and your license will
45
+ automatically terminate. If the licensor provides you with a notice of your violation, and you cease all
46
+ violation of this license no later than 30 days after you receive that notice, your license will be reinstated
47
+ retroactively. However, if you violate these terms after such reinstatement, any additional violation of these
48
+ terms will cause your license to terminate automatically and permanently.
49
+
50
+ ### No Liability
51
+
52
+ As far as the law allows, the software comes as is, without any warranty or condition, and the licensor will
53
+ not be liable to you for any damages arising out of these terms or the use or nature of the software, under
54
+ any kind of legal claim.
55
+
56
+ ### Definitions
57
+
58
+ The “licensor” is the entity offering these terms.
59
+
60
+ The “software” is the software the licensor makes available under these terms, including any portion of it.
61
+
62
+ “You” refers to the individual or entity agreeing to these terms.
63
+
64
+ “Your company” is any legal entity, sole proprietorship, or other kind of organization that you work for, plus
65
+ all organizations that have control over, are under the control of, or are under common control with that
66
+ organization. Control means ownership of substantially all the assets of an entity, or the power to direct its
67
+ management and policies by vote, contract, or otherwise. Control can be direct or indirect.
68
+
69
+ “Your license” is the license granted to you for the software under these terms.
70
+
71
+ “Use” means anything you do with the software requiring your license.
72
+
73
+ “Trademark” means trademarks, service marks, and similar rights.
package/package.json ADDED
@@ -0,0 +1,98 @@
1
+ {
2
+ "name": "medusa-plugin-mcp",
3
+ "version": "0.1.0",
4
+ "description": "MCP server and LLM chat plugin for Medusa v2",
5
+ "author": "Lacey Pevey",
6
+ "repository": {
7
+ "type": "git",
8
+ "url": "https://github.com/pevey/medusa-plugins"
9
+ },
10
+ "homepage": "https://pevey.com/medusa-plugin-mcp",
11
+ "files": [
12
+ ".medusa/server"
13
+ ],
14
+ "exports": {
15
+ "./package.json": "./package.json",
16
+ "./admin": {
17
+ "import": "./.medusa/server/src/admin/index.mjs",
18
+ "require": "./.medusa/server/src/admin/index.js",
19
+ "default": "./.medusa/server/src/admin/index.js"
20
+ },
21
+ "./.medusa/server/src/modules/*": {
22
+ "types": "./.medusa/server/src/modules/*/index.d.ts",
23
+ "default": "./.medusa/server/src/modules/*/index.js"
24
+ },
25
+ "./modules/*": {
26
+ "types": "./.medusa/server/src/modules/*/index.d.ts",
27
+ "default": "./.medusa/server/src/modules/*/index.js"
28
+ },
29
+ "./providers/*": {
30
+ "types": "./.medusa/server/src/providers/*/index.d.ts",
31
+ "default": "./.medusa/server/src/providers/*/index.js"
32
+ },
33
+ "./*": {
34
+ "types": "./.medusa/server/src/*.d.ts",
35
+ "default": "./.medusa/server/src/*.js"
36
+ },
37
+ ".": {
38
+ "types": "./.medusa/server/src/modules/mcp/index.d.ts",
39
+ "default": "./.medusa/server/src/modules/mcp/index.js"
40
+ }
41
+ },
42
+ "keywords": [
43
+ "medusa-v2",
44
+ "medusa",
45
+ "mcp",
46
+ "chat",
47
+ "ai",
48
+ "llm",
49
+ "model-context-protocol"
50
+ ],
51
+ "scripts": {
52
+ "build": "medusa plugin:build",
53
+ "dev": "medusa plugin:develop",
54
+ "prepublishOnly": "medusa plugin:build"
55
+ },
56
+ "dependencies": {
57
+ "@anthropic-ai/sdk": "^0.51.0",
58
+ "@modelcontextprotocol/sdk": "^1.29.0",
59
+ "ollama": "^0.6.3",
60
+ "openai": "^4.98.0",
61
+ "recharts": "^2.15.3"
62
+ },
63
+ "devDependencies": {
64
+ "@medusajs/admin-sdk": "2.13.6",
65
+ "@medusajs/cli": "2.13.6",
66
+ "@medusajs/framework": "2.13.6",
67
+ "@medusajs/icons": "2.13.6",
68
+ "@medusajs/ui": "4.0.25",
69
+ "@types/node": "^20.0.0",
70
+ "@types/react": "^18.3.2",
71
+ "@types/react-dom": "^18.2.25",
72
+ "medusa-plugin-automation": "workspace:*",
73
+ "medusa-plugin-statistics": "workspace:*",
74
+ "prop-types": "^15.8.1",
75
+ "react": "^18.2.0",
76
+ "react-dom": "^18.2.0",
77
+ "typescript": "^5.6.2",
78
+ "vite": "^5.2.11"
79
+ },
80
+ "peerDependencies": {
81
+ "@medusajs/framework": "2.13.6",
82
+ "@medusajs/js-sdk": "2.13.6",
83
+ "@medusajs/medusa": "2.13.6",
84
+ "medusa-plugin-automation": "*",
85
+ "medusa-plugin-statistics": "*"
86
+ },
87
+ "peerDependenciesMeta": {
88
+ "medusa-plugin-automation": {
89
+ "optional": true
90
+ },
91
+ "medusa-plugin-statistics": {
92
+ "optional": true
93
+ }
94
+ },
95
+ "engines": {
96
+ "node": ">=20"
97
+ }
98
+ }