medusa-plugin-automation 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 (59) 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 +9920 -0
  4. package/.medusa/server/src/admin/index.mjs +9918 -0
  5. package/.medusa/server/src/admin/lib/medusa-events.d.ts +16 -0
  6. package/.medusa/server/src/admin/lib/medusa-events.js +131 -0
  7. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/deliveries/retry/route.d.ts +3 -0
  8. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/deliveries/retry/route.js +56 -0
  9. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/deliveries/route.d.ts +2 -0
  10. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/deliveries/route.js +26 -0
  11. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/query/route.d.ts +5 -0
  12. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/query/route.js +46 -0
  13. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/route.d.ts +5 -0
  14. package/.medusa/server/src/api/admin/automations/[id]/actions/[actionId]/route.js +37 -0
  15. package/.medusa/server/src/api/admin/automations/[id]/actions/route.d.ts +5 -0
  16. package/.medusa/server/src/api/admin/automations/[id]/actions/route.js +44 -0
  17. package/.medusa/server/src/api/admin/automations/[id]/receipts/route.d.ts +2 -0
  18. package/.medusa/server/src/api/admin/automations/[id]/receipts/route.js +17 -0
  19. package/.medusa/server/src/api/admin/automations/[id]/route.d.ts +5 -0
  20. package/.medusa/server/src/api/admin/automations/[id]/route.js +37 -0
  21. package/.medusa/server/src/api/admin/automations/route.d.ts +5 -0
  22. package/.medusa/server/src/api/admin/automations/route.js +36 -0
  23. package/.medusa/server/src/api/admin/automations/secrets/[id]/route.d.ts +2 -0
  24. package/.medusa/server/src/api/admin/automations/secrets/[id]/route.js +13 -0
  25. package/.medusa/server/src/api/admin/automations/secrets/route.d.ts +4 -0
  26. package/.medusa/server/src/api/admin/automations/secrets/route.js +38 -0
  27. package/.medusa/server/src/api/middlewares.d.ts +2 -0
  28. package/.medusa/server/src/api/middlewares.js +169 -0
  29. package/.medusa/server/src/api/validators.d.ts +470 -0
  30. package/.medusa/server/src/api/validators.js +123 -0
  31. package/.medusa/server/src/api/webhooks/[id]/route.d.ts +2 -0
  32. package/.medusa/server/src/api/webhooks/[id]/route.js +78 -0
  33. package/.medusa/server/src/lib/dispatch.d.ts +43 -0
  34. package/.medusa/server/src/lib/dispatch.js +400 -0
  35. package/.medusa/server/src/modules/automation/index.d.ts +92 -0
  36. package/.medusa/server/src/modules/automation/index.js +25 -0
  37. package/.medusa/server/src/modules/automation/migrations/Migration20260409171930.d.ts +5 -0
  38. package/.medusa/server/src/modules/automation/migrations/Migration20260409171930.js +47 -0
  39. package/.medusa/server/src/modules/automation/models/automation-action.d.ts +75 -0
  40. package/.medusa/server/src/modules/automation/models/automation-action.js +41 -0
  41. package/.medusa/server/src/modules/automation/models/automation-delivery.d.ts +57 -0
  42. package/.medusa/server/src/modules/automation/models/automation-delivery.js +23 -0
  43. package/.medusa/server/src/modules/automation/models/automation-query.d.ts +52 -0
  44. package/.medusa/server/src/modules/automation/models/automation-query.js +14 -0
  45. package/.medusa/server/src/modules/automation/models/automation-receipt.d.ts +53 -0
  46. package/.medusa/server/src/modules/automation/models/automation-receipt.js +29 -0
  47. package/.medusa/server/src/modules/automation/models/automation-secret.d.ts +5 -0
  48. package/.medusa/server/src/modules/automation/models/automation-secret.js +10 -0
  49. package/.medusa/server/src/modules/automation/models/automation-trigger.d.ts +56 -0
  50. package/.medusa/server/src/modules/automation/models/automation-trigger.js +27 -0
  51. package/.medusa/server/src/modules/automation/service.d.ts +274 -0
  52. package/.medusa/server/src/modules/automation/service.js +21 -0
  53. package/.medusa/server/src/modules/automation/types.d.ts +13 -0
  54. package/.medusa/server/src/modules/automation/types.js +3 -0
  55. package/.medusa/server/src/subscribers/automation-dispatcher.d.ts +3 -0
  56. package/.medusa/server/src/subscribers/automation-dispatcher.js +51 -0
  57. package/LICENSE.md +73 -0
  58. package/README.md +53 -0
  59. package/package.json +91 -0
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.POST = exports.GET = void 0;
4
+ const crypto_1 = require("crypto");
5
+ const automation_1 = require("../../../../modules/automation");
6
+ // GET /admin/automations/secrets — list all secrets (label + id only, never the secret value)
7
+ const GET = async (req, res) => {
8
+ const automationService = req.scope.resolve(automation_1.AUTOMATION_MODULE);
9
+ const [secrets, count] = await automationService.listAndCountAutomationSecrets({}, { take: req.validatedQuery?.limit ?? 100, skip: req.validatedQuery?.offset ?? 0 });
10
+ res.json({
11
+ secrets: secrets.map(({ id, label, created_at, updated_at }) => ({
12
+ id,
13
+ label,
14
+ created_at,
15
+ updated_at
16
+ })),
17
+ count
18
+ });
19
+ };
20
+ exports.GET = GET;
21
+ // POST /admin/automations/secrets — create a new secret, return the secret value once
22
+ const POST = async (req, res) => {
23
+ const automationService = req.scope.resolve(automation_1.AUTOMATION_MODULE);
24
+ const { label } = req.validatedBody;
25
+ const secret = (0, crypto_1.randomBytes)(32).toString('hex');
26
+ const created = await automationService.createAutomationSecrets({ label, secret });
27
+ // Return the secret value exactly once — it is never returned again
28
+ res.json({
29
+ secret: {
30
+ id: created.id,
31
+ label: created.label,
32
+ secret: created.secret,
33
+ created_at: created.created_at
34
+ }
35
+ });
36
+ };
37
+ exports.POST = POST;
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL2FkbWluL2F1dG9tYXRpb25zL3NlY3JldHMvcm91dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQW9DO0FBRXBDLCtEQUFrRTtBQUlsRSw4RkFBOEY7QUFDdkYsTUFBTSxHQUFHLEdBQUcsS0FBSyxFQUN2QixHQUE4RCxFQUM5RCxHQUFtQixFQUNsQixFQUFFO0lBQ0gsTUFBTSxpQkFBaUIsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyw4QkFBaUIsQ0FBc0IsQ0FBQTtJQUNuRixNQUFNLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxHQUFHLE1BQU0saUJBQWlCLENBQUMsNkJBQTZCLENBQzdFLEVBQUUsRUFDRixFQUFFLElBQUksRUFBRSxHQUFHLENBQUMsY0FBYyxFQUFFLEtBQUssSUFBSSxHQUFHLEVBQUUsSUFBSSxFQUFFLEdBQUcsQ0FBQyxjQUFjLEVBQUUsTUFBTSxJQUFJLENBQUMsRUFBRSxDQUNqRixDQUFBO0lBQ0QsR0FBRyxDQUFDLElBQUksQ0FBQztRQUNSLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztZQUNyRSxFQUFFO1lBQ0YsS0FBSztZQUNMLFVBQVU7WUFDVixVQUFVO1NBQ1YsQ0FBQyxDQUFDO1FBQ0gsS0FBSztLQUNMLENBQUMsQ0FBQTtBQUNILENBQUMsQ0FBQTtBQWxCWSxRQUFBLEdBQUcsT0FrQmY7QUFFRCxzRkFBc0Y7QUFDL0UsTUFBTSxJQUFJLEdBQUcsS0FBSyxFQUN4QixHQUFnRSxFQUNoRSxHQUFtQixFQUNsQixFQUFFO0lBQ0gsTUFBTSxpQkFBaUIsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyw4QkFBaUIsQ0FBc0IsQ0FBQTtJQUNuRixNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsR0FBRyxDQUFDLGFBQWEsQ0FBQTtJQUNuQyxNQUFNLE1BQU0sR0FBRyxJQUFBLG9CQUFXLEVBQUMsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQzlDLE1BQU0sT0FBTyxHQUFHLE1BQU0saUJBQWlCLENBQUMsdUJBQXVCLENBQUMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQTtJQUNsRixvRUFBb0U7SUFDcEUsR0FBRyxDQUFDLElBQUksQ0FBQztRQUNSLE1BQU0sRUFBRTtZQUNQLEVBQUUsRUFBRSxPQUFPLENBQUMsRUFBRTtZQUNkLEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSztZQUNwQixNQUFNLEVBQUUsT0FBTyxDQUFDLE1BQU07WUFDdEIsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVO1NBQzlCO0tBQ0QsQ0FBQyxDQUFBO0FBQ0gsQ0FBQyxDQUFBO0FBakJZLFFBQUEsSUFBSSxRQWlCaEIifQ==
@@ -0,0 +1,2 @@
1
+ declare const _default: import("@medusajs/framework/http").MiddlewaresConfig;
2
+ export default _default;
@@ -0,0 +1,169 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const http_1 = require("@medusajs/framework/http");
4
+ const validators_1 = require("./validators");
5
+ exports.default = (0, http_1.defineMiddlewares)([
6
+ // Triggers
7
+ {
8
+ matcher: '/admin/automations',
9
+ method: ['GET'],
10
+ middlewares: [
11
+ (0, http_1.validateAndTransformQuery)(validators_1.AdminGetAutomationTriggers, {
12
+ defaults: [
13
+ 'id', 'name', 'description', 'trigger_type', 'is_active',
14
+ 'trigger_events', 'metadata', 'created_at', 'updated_at'
15
+ ],
16
+ isList: true,
17
+ defaultLimit: 20
18
+ })
19
+ ]
20
+ },
21
+ {
22
+ matcher: '/admin/automations',
23
+ method: ['POST'],
24
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminCreateAutomationTrigger)]
25
+ },
26
+ {
27
+ matcher: '/admin/automations',
28
+ method: ['DELETE'],
29
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminDeleteAutomationTriggers)]
30
+ },
31
+ {
32
+ matcher: '/admin/automations/:id',
33
+ method: ['GET'],
34
+ middlewares: [
35
+ (0, http_1.validateAndTransformQuery)(validators_1.AdminGetAutomationTrigger, {
36
+ defaults: [
37
+ 'id', 'name', 'description', 'trigger_type', 'is_active',
38
+ 'trigger_events', 'metadata', 'created_at', 'updated_at'
39
+ ],
40
+ isList: false
41
+ })
42
+ ]
43
+ },
44
+ {
45
+ matcher: '/admin/automations/:id',
46
+ method: ['POST'],
47
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminUpdateAutomationTrigger)]
48
+ },
49
+ // Actions
50
+ {
51
+ matcher: '/admin/automations/:id/actions',
52
+ method: ['GET'],
53
+ middlewares: [
54
+ (0, http_1.validateAndTransformQuery)(validators_1.AdminGetAutomationActions, {
55
+ defaults: [
56
+ 'id', 'name', 'description', 'action_type', 'is_active', 'target_url',
57
+ 'signing_secret_id', 'target_headers', 'medusa_workflow', 'field_mappings',
58
+ 'metadata', 'created_at', 'updated_at'
59
+ ],
60
+ isList: true,
61
+ defaultLimit: 20
62
+ })
63
+ ]
64
+ },
65
+ {
66
+ matcher: '/admin/automations/:id/actions',
67
+ method: ['POST'],
68
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminCreateAutomationAction)]
69
+ },
70
+ {
71
+ matcher: '/admin/automations/:id/actions',
72
+ method: ['DELETE'],
73
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminDeleteAutomationActions)]
74
+ },
75
+ {
76
+ matcher: '/admin/automations/:id/actions/:actionId',
77
+ method: ['GET'],
78
+ middlewares: [
79
+ (0, http_1.validateAndTransformQuery)(validators_1.AdminGetAutomationAction, {
80
+ defaults: [
81
+ 'id', 'name', 'description', 'action_type', 'is_active', 'target_url',
82
+ 'signing_secret_id', 'target_headers', 'medusa_workflow', 'field_mappings',
83
+ 'metadata', 'created_at', 'updated_at'
84
+ ],
85
+ isList: false
86
+ })
87
+ ]
88
+ },
89
+ {
90
+ matcher: '/admin/automations/:id/actions/:actionId',
91
+ method: ['POST'],
92
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminUpdateAutomationAction)]
93
+ },
94
+ {
95
+ matcher: '/admin/automations/:id/actions/:actionId/query',
96
+ method: ['GET'],
97
+ middlewares: []
98
+ },
99
+ {
100
+ matcher: '/admin/automations/:id/actions/:actionId/query',
101
+ method: ['POST'],
102
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminUpsertAutomationQuery)]
103
+ },
104
+ {
105
+ matcher: '/admin/automations/:id/actions/:actionId/query',
106
+ method: ['DELETE'],
107
+ middlewares: []
108
+ },
109
+ {
110
+ matcher: '/admin/automations/:id/actions/:actionId/deliveries',
111
+ method: ['GET'],
112
+ middlewares: [
113
+ (0, http_1.validateAndTransformQuery)(validators_1.AdminGetAutomationDeliveries, {
114
+ defaults: [
115
+ 'id', 'event_name', 'status', 'attempts', 'response_status',
116
+ 'response_body', 'request_payload', 'error_message', 'created_at', 'updated_at'
117
+ ],
118
+ isList: true,
119
+ defaultLimit: 20
120
+ })
121
+ ]
122
+ },
123
+ {
124
+ matcher: '/admin/automations/:id/actions/:actionId/deliveries/retry',
125
+ method: ['POST'],
126
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminRetryAutomationDeliveries)]
127
+ },
128
+ {
129
+ matcher: '/admin/automations/:id/receipts',
130
+ method: ['GET'],
131
+ middlewares: [
132
+ (0, http_1.validateAndTransformQuery)(validators_1.AdminGetAutomationReceipts, {
133
+ defaults: ['id', 'request_ip', 'payload', 'created_at'],
134
+ isList: true,
135
+ defaultLimit: 20
136
+ })
137
+ ]
138
+ },
139
+ // Secrets
140
+ {
141
+ matcher: '/admin/automations/secrets',
142
+ method: ['GET'],
143
+ middlewares: [
144
+ (0, http_1.validateAndTransformQuery)(validators_1.AdminGetAutomationSecrets, {
145
+ defaults: ['id', 'label', 'created_at', 'updated_at'],
146
+ isList: true,
147
+ defaultLimit: 100
148
+ })
149
+ ]
150
+ },
151
+ {
152
+ matcher: '/admin/automations/secrets',
153
+ method: ['POST'],
154
+ middlewares: [(0, http_1.validateAndTransformBody)(validators_1.AdminCreateAutomationSecret)]
155
+ },
156
+ {
157
+ matcher: '/admin/automations/secrets/:id',
158
+ method: ['DELETE'],
159
+ middlewares: []
160
+ },
161
+ // Public listener
162
+ {
163
+ matcher: '/webhooks/:id',
164
+ method: ['POST'],
165
+ bodyParser: { sizeLimit: '5mb' },
166
+ middlewares: []
167
+ }
168
+ ]);
169
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlkZGxld2FyZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBpL21pZGRsZXdhcmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsbURBQWlIO0FBQ2pILDZDQWlCcUI7QUFFckIsa0JBQWUsSUFBQSx3QkFBaUIsRUFBQztJQUNoQyxXQUFXO0lBQ1g7UUFDQyxPQUFPLEVBQUUsb0JBQW9CO1FBQzdCLE1BQU0sRUFBRSxDQUFDLEtBQUssQ0FBQztRQUNmLFdBQVcsRUFBRTtZQUNaLElBQUEsZ0NBQXlCLEVBQUMsdUNBQTBCLEVBQUU7Z0JBQ3JELFFBQVEsRUFBRTtvQkFDVCxJQUFJLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsV0FBVztvQkFDeEQsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxZQUFZO2lCQUN4RDtnQkFDRCxNQUFNLEVBQUUsSUFBSTtnQkFDWixZQUFZLEVBQUUsRUFBRTthQUNoQixDQUFDO1NBQ0Y7S0FDRDtJQUNEO1FBQ0MsT0FBTyxFQUFFLG9CQUFvQjtRQUM3QixNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUM7UUFDaEIsV0FBVyxFQUFFLENBQUMsSUFBQSwrQkFBd0IsRUFBQyx5Q0FBNEIsQ0FBQyxDQUFDO0tBQ3JFO0lBQ0Q7UUFDQyxPQUFPLEVBQUUsb0JBQW9CO1FBQzdCLE1BQU0sRUFBRSxDQUFDLFFBQVEsQ0FBQztRQUNsQixXQUFXLEVBQUUsQ0FBQyxJQUFBLCtCQUF3QixFQUFDLDBDQUE2QixDQUFDLENBQUM7S0FDdEU7SUFDRDtRQUNDLE9BQU8sRUFBRSx3QkFBd0I7UUFDakMsTUFBTSxFQUFFLENBQUMsS0FBSyxDQUFDO1FBQ2YsV0FBVyxFQUFFO1lBQ1osSUFBQSxnQ0FBeUIsRUFBQyxzQ0FBeUIsRUFBRTtnQkFDcEQsUUFBUSxFQUFFO29CQUNULElBQUksRUFBRSxNQUFNLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxXQUFXO29CQUN4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