order-management 0.0.2 → 0.0.4

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 (33) hide show
  1. package/.medusa/server/src/admin/index.js +4 -639
  2. package/.medusa/server/src/admin/index.mjs +4 -639
  3. package/.medusa/server/src/api/store/orders/reorder/[order_id]/route.js +66 -0
  4. package/.medusa/server/src/workflows/index.js +4 -9
  5. package/.medusa/server/src/workflows/{types.js → reorder/types.js} +1 -1
  6. package/.medusa/server/src/workflows/reorder-workflow.js +27 -0
  7. package/.medusa/server/src/workflows/steps/create-cart-from-order-step.js +26 -0
  8. package/.medusa/server/src/workflows/steps/index.js +10 -0
  9. package/.medusa/server/src/workflows/steps/retrieve-order-step.js +79 -0
  10. package/.medusa/server/src/workflows/steps/transform-order-to-cart-step.js +53 -0
  11. package/README.md +59 -73
  12. package/package.json +1 -1
  13. package/.medusa/server/src/api/admin/returns/[id]/retry-refund/route.js +0 -84
  14. package/.medusa/server/src/api/admin/returns/failed-refunds/route.js +0 -137
  15. package/.medusa/server/src/api/store/returns/[id]/payment-details/route.js +0 -326
  16. package/.medusa/server/src/config/plugin-options.js +0 -61
  17. package/.medusa/server/src/providers/refund-payment/base-refund-provider.js +0 -80
  18. package/.medusa/server/src/providers/refund-payment/index.js +0 -38
  19. package/.medusa/server/src/providers/refund-payment/razorpay-provider.js +0 -96
  20. package/.medusa/server/src/providers/refund-payment/stripe-provider.js +0 -82
  21. package/.medusa/server/src/subscribers/return-received.js +0 -103
  22. package/.medusa/server/src/types/plugin-options.js +0 -3
  23. package/.medusa/server/src/types/refund-payment.js +0 -3
  24. package/.medusa/server/src/workflows/process-cod-refund-workflow.js +0 -99
  25. package/.medusa/server/src/workflows/steps/calculate-refund-amount-step.js +0 -51
  26. package/.medusa/server/src/workflows/steps/create-refund-record-step.js +0 -243
  27. package/.medusa/server/src/workflows/steps/process-refund-payment-step.js +0 -86
  28. package/.medusa/server/src/workflows/steps/retrieve-order-and-payment-step.js +0 -44
  29. package/.medusa/server/src/workflows/steps/retrieve-return-payment-details-step.js +0 -56
  30. package/.medusa/server/src/workflows/steps/select-payment-method-step.js +0 -61
  31. package/.medusa/server/src/workflows/steps/update-payment-status-step.js +0 -45
  32. package/.medusa/server/src/workflows/steps/validate-payment-details-step.js +0 -90
  33. package/.medusa/server/src/workflows/steps/verify-cod-order-step.js +0 -39
@@ -1,137 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.GET = void 0;
4
- const utils_1 = require("@medusajs/framework/utils");
5
- const utils_2 = require("@medusajs/framework/utils");
6
- /**
7
- * Admin API endpoint to list failed refunds
8
- *
9
- * GET /admin/returns/failed-refunds
10
- *
11
- * Returns a list of all refunds with "failed" status.
12
- * Useful for admin dashboard to see refunds that need attention.
13
- */
14
- const GET = async (req, res) => {
15
- const paymentService = req.scope.resolve(utils_2.Modules.PAYMENT);
16
- try {
17
- // Get query parameters for pagination/filtering
18
- const limit = req.query.limit
19
- ? parseInt(req.query.limit, 10)
20
- : 50;
21
- const offset = req.query.offset
22
- ? parseInt(req.query.offset, 10)
23
- : 0;
24
- const currencyCodeFilter = req.query.currency_code;
25
- const errorCodeFilter = req.query.error_code;
26
- const returnIdFilter = req.query.return_id;
27
- const orderIdFilter = req.query.order_id;
28
- // List all payment collections
29
- // Note: This is a simplified approach. In production, you might want
30
- // to use a more efficient query method or create a custom service
31
- // We fetch more than needed to allow filtering before pagination
32
- const paymentCollections = await paymentService.listPaymentCollections?.({ limit: 1000, offset: 0 });
33
- const failedRefunds = [];
34
- if (paymentCollections && Array.isArray(paymentCollections)) {
35
- for (const collection of paymentCollections) {
36
- const collectionWithRefunds = collection;
37
- // Check refunds in collection
38
- const refunds = collectionWithRefunds.refunds || [];
39
- for (const refund of refunds) {
40
- const refundData = refund;
41
- const metadata = refundData.metadata || {};
42
- // Check if refund has failed status
43
- if (metadata.refund_status === "failed") {
44
- const refundRecord = {
45
- refund_id: refundData.id,
46
- amount: refundData.amount,
47
- currency_code: refundData.currency_code,
48
- payment_error: metadata.payment_error,
49
- payment_error_code: metadata.payment_error_code,
50
- failed_at: metadata.failed_at,
51
- retry_count: metadata.retry_count || 0,
52
- last_retry_at: metadata.last_retry_at,
53
- return_id: metadata.return_id,
54
- order_id: metadata.order_id,
55
- created_at: refundData.created_at,
56
- };
57
- // Apply filters
58
- if (currencyCodeFilter &&
59
- refundRecord.currency_code !== currencyCodeFilter) {
60
- continue;
61
- }
62
- if (errorCodeFilter &&
63
- refundRecord.payment_error_code !== errorCodeFilter) {
64
- continue;
65
- }
66
- if (returnIdFilter &&
67
- refundRecord.return_id !== returnIdFilter) {
68
- continue;
69
- }
70
- if (orderIdFilter &&
71
- refundRecord.order_id !== orderIdFilter) {
72
- continue;
73
- }
74
- failedRefunds.push(refundRecord);
75
- }
76
- // Also check payment collection metadata for fallback refunds
77
- const collectionMetadata = collectionWithRefunds.metadata || {};
78
- const refundsInMetadata = collectionMetadata.refunds || [];
79
- for (const metaRefund of refundsInMetadata) {
80
- const metaRefundData = metaRefund;
81
- if (metaRefundData.refund_status === "failed" &&
82
- !failedRefunds.find((r) => r.refund_id ===
83
- metaRefundData.id)) {
84
- const refundRecord = {
85
- refund_id: metaRefundData.id,
86
- payment_error: metaRefundData.payment_error,
87
- payment_error_code: metaRefundData.payment_error_code,
88
- refund_status: "failed",
89
- return_id: metaRefundData.return_id,
90
- order_id: metaRefundData.order_id,
91
- };
92
- // Apply filters
93
- if (returnIdFilter &&
94
- refundRecord.return_id !== returnIdFilter) {
95
- continue;
96
- }
97
- if (orderIdFilter &&
98
- refundRecord.order_id !== orderIdFilter) {
99
- continue;
100
- }
101
- failedRefunds.push(refundRecord);
102
- }
103
- }
104
- }
105
- }
106
- }
107
- // Sort by failed_at (most recent first) or created_at
108
- failedRefunds.sort((a, b) => {
109
- const dateA = a.failed_at
110
- ? new Date(a.failed_at).getTime()
111
- : a.created_at
112
- ? new Date(a.created_at).getTime()
113
- : 0;
114
- const dateB = b.failed_at
115
- ? new Date(b.failed_at).getTime()
116
- : b.created_at
117
- ? new Date(b.created_at).getTime()
118
- : 0;
119
- return dateB - dateA; // Descending order
120
- });
121
- const totalCount = failedRefunds.length;
122
- // Apply pagination
123
- const paginatedRefunds = failedRefunds.slice(offset, offset + limit);
124
- return res.json({
125
- failed_refunds: paginatedRefunds,
126
- count: totalCount,
127
- limit,
128
- offset,
129
- });
130
- }
131
- catch (error) {
132
- const errorMessage = error instanceof Error ? error.message : "Unknown error";
133
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNEXPECTED_STATE, `Failed to retrieve failed refunds: ${errorMessage}`);
134
- }
135
- };
136
- exports.GET = GET;
137
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL2FkbWluL3JldHVybnMvZmFpbGVkLXJlZnVuZHMvcm91dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EscURBQXVEO0FBQ3ZELHFEQUFtRDtBQUduRDs7Ozs7OztHQU9HO0FBQ0ksTUFBTSxHQUFHLEdBQUcsS0FBSyxFQUN0QixHQUFrQixFQUNsQixHQUFtQixFQUNuQixFQUFFO0lBQ0YsTUFBTSxjQUFjLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQ3RDLGVBQU8sQ0FBQyxPQUFPLENBQ2hCLENBQUE7SUFFRCxJQUFJLENBQUM7UUFDSCxnREFBZ0Q7UUFDaEQsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFLO1lBQzNCLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFlLEVBQUUsRUFBRSxDQUFDO1lBQ3pDLENBQUMsQ0FBQyxFQUFFLENBQUE7UUFDTixNQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU07WUFDN0IsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQWdCLEVBQUUsRUFBRSxDQUFDO1lBQzFDLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDTCxNQUFNLGtCQUFrQixHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsYUFBbUMsQ0FBQTtRQUN4RSxNQUFNLGVBQWUsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLFVBQWdDLENBQUE7UUFDbEUsTUFBTSxjQUFjLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxTQUErQixDQUFBO1FBQ2hFLE1BQU0sYUFBYSxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsUUFBOEIsQ0FBQTtRQUU5RCwrQkFBK0I7UUFDL0IscUVBQXFFO1FBQ3JFLGtFQUFrRTtRQUNsRSxpRUFBaUU7UUFD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
@@ -1,326 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.POST = exports.GET = void 0;
7
- const utils_1 = require("@medusajs/framework/utils");
8
- const utils_2 = require("@medusajs/framework/utils");
9
- const process_cod_refund_workflow_1 = __importDefault(require("../../../../../workflows/process-cod-refund-workflow"));
10
- /**
11
- * GET endpoint to retrieve current payment details and refund status
12
- *
13
- * GET /store/returns/[id]/payment-details
14
- */
15
- const GET = async (req, res) => {
16
- const { id: return_id } = req.params;
17
- if (!return_id) {
18
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "Return ID is required");
19
- }
20
- // Get order service to retrieve return
21
- const orderService = req.scope.resolve(utils_2.Modules.ORDER);
22
- const paymentService = req.scope.resolve(utils_2.Modules.PAYMENT);
23
- // Find return by ID
24
- const returnRecord = await findReturnById(orderService, return_id);
25
- if (!returnRecord) {
26
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.NOT_FOUND, `Return with ID ${return_id} not found`);
27
- }
28
- // Get order to verify customer ownership
29
- const orderId = returnRecord.order_id;
30
- const order = await orderService.retrieveOrder(orderId);
31
- // Verify customer ownership
32
- const authContext = req.auth_context;
33
- if (authContext?.actor_type === "customer") {
34
- const customerId = authContext.actor_id;
35
- if (order.customer_id !== customerId) {
36
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNAUTHORIZED, "You are not authorized to view this return");
37
- }
38
- }
39
- // Get current payment details from metadata
40
- const metadata = returnRecord.metadata || {};
41
- const paymentDetails = metadata.refund_payment_details;
42
- const lastUpdatedAt = metadata.payment_details_updated_at;
43
- const paymentDetailsHistory = metadata.payment_details_history || [];
44
- // Get refund status
45
- const refundStatus = await getRefundStatusForReturn(orderService, paymentService, return_id, orderId);
46
- const refundStatusValue = refundStatus.status;
47
- const canUpdate = refundStatusValue !== "succeeded";
48
- return res.json({
49
- payment_details: paymentDetails || null,
50
- refund_status: refundStatusValue,
51
- can_update: canUpdate,
52
- last_updated_at: lastUpdatedAt || null,
53
- payment_details_history_count: paymentDetailsHistory.length,
54
- });
55
- };
56
- exports.GET = GET;
57
- const POST = async (req, res) => {
58
- const { id: return_id } = req.params;
59
- const paymentDetails = req.body;
60
- if (!return_id) {
61
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "Return ID is required");
62
- }
63
- if (!paymentDetails) {
64
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "Payment details are required");
65
- }
66
- // Validate required fields
67
- if (!paymentDetails.method) {
68
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "Payment method is required");
69
- }
70
- if (!paymentDetails.currency_code) {
71
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "Currency code is required");
72
- }
73
- // Get order service to retrieve return
74
- const orderService = req.scope.resolve(utils_2.Modules.ORDER);
75
- const paymentService = req.scope.resolve(utils_2.Modules.PAYMENT);
76
- // Find return by ID
77
- // Note: In Medusa, returns are linked to orders, so we need to search through orders
78
- // This is a simplified approach - in production, you might want to use a more efficient query
79
- const returnRecord = await findReturnById(orderService, return_id);
80
- if (!returnRecord) {
81
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.NOT_FOUND, `Return with ID ${return_id} not found`);
82
- }
83
- // Get order to verify customer ownership (if needed)
84
- const orderId = returnRecord.order_id;
85
- const order = await orderService.retrieveOrder(orderId);
86
- // Verify customer ownership (optional - depends on your security requirements)
87
- const authContext = req.auth_context;
88
- if (authContext?.actor_type === "customer") {
89
- const customerId = authContext.actor_id;
90
- if (order.customer_id !== customerId) {
91
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNAUTHORIZED, "You are not authorized to update this return");
92
- }
93
- }
94
- // Check refund status before allowing update
95
- const refundStatus = await getRefundStatusForReturn(orderService, paymentService, return_id, orderId);
96
- // Reject update if refund is already succeeded
97
- if (refundStatus.status === "succeeded") {
98
- return res.status(400).json({
99
- success: false,
100
- error: "Payment details cannot be updated after refund is successful",
101
- refund_status: "succeeded",
102
- refund_id: refundStatus.refund_id,
103
- });
104
- }
105
- // Get current metadata
106
- const currentMetadata = returnRecord.metadata || {};
107
- // Get current payment details for history
108
- const currentPaymentDetails = currentMetadata.refund_payment_details;
109
- // Build payment details history
110
- const paymentDetailsHistory = currentMetadata.payment_details_history || [];
111
- // Add current payment details to history if they exist
112
- if (currentPaymentDetails) {
113
- const historyEntry = {
114
- payment_details: currentPaymentDetails,
115
- updated_at: currentMetadata.payment_details_updated_at ||
116
- new Date().toISOString(),
117
- reason: refundStatus.status === "failed" ? "refund_failed" : "user_update",
118
- };
119
- // Add to history (limit to last 10 entries)
120
- paymentDetailsHistory.push(historyEntry);
121
- if (paymentDetailsHistory.length > 10) {
122
- paymentDetailsHistory.shift(); // Remove oldest entry
123
- }
124
- }
125
- // Update return metadata with payment details
126
- const updatedMetadata = {
127
- ...currentMetadata,
128
- refund_payment_details: paymentDetails,
129
- payment_details_updated_at: new Date().toISOString(),
130
- payment_details_history: paymentDetailsHistory,
131
- // Cache refund status for quick access
132
- refund_status: refundStatus.status,
133
- };
134
- // Store previous refund status to check if we need to trigger retry
135
- const previousRefundStatus = refundStatus.status;
136
- // Attempt to update return metadata via order service
137
- // Note: Medusa v2 may not expose direct return update API
138
- // We'll try to update through the order service if available
139
- try {
140
- // Try to update the return through order service
141
- // Check if orderService has an updateReturn or similar method
142
- const orderServiceWithReturns = orderService;
143
- if (orderServiceWithReturns.updateReturn) {
144
- await orderServiceWithReturns.updateReturn(return_id, {
145
- metadata: updatedMetadata,
146
- });
147
- }
148
- else {
149
- // If direct return update is not available, try updating through order
150
- // This is a workaround - in production, you may need a custom module
151
- const orderWithReturns = order;
152
- const returns = orderWithReturns.returns || [];
153
- const returnIndex = returns.findIndex((ret) => ret.id === return_id);
154
- if (returnIndex >= 0) {
155
- returns[returnIndex] = {
156
- ...returns[returnIndex],
157
- metadata: updatedMetadata,
158
- };
159
- // Try to update order with modified returns
160
- const orderServiceWithUpdate = orderService;
161
- if (orderServiceWithUpdate.updateOrder) {
162
- await orderServiceWithUpdate.updateOrder(orderId, {
163
- returns: returns,
164
- });
165
- }
166
- else {
167
- // If update methods are not available, log warning
168
- console.warn(`[payment-details] Unable to persist return metadata for return ${return_id}. ` +
169
- `Order service does not expose return update methods. ` +
170
- `Payment details structure is correct but may not be persisted. ` +
171
- `Consider implementing a custom return module or extending Medusa's return service.`);
172
- }
173
- }
174
- }
175
- }
176
- catch (error) {
177
- // Log error but don't fail the request - metadata structure is correct
178
- // The limitation is in Medusa's API, not our implementation
179
- console.error(`[payment-details] Error updating return metadata for return ${return_id}:`, error instanceof Error ? error.message : error);
180
- console.warn(`[payment-details] Payment details metadata structure is correct but may not be persisted. ` +
181
- `This is a known limitation when Medusa's return update API is not available.`);
182
- }
183
- // If refund was failed and payment details are updated, trigger auto-retry
184
- if (previousRefundStatus === "failed") {
185
- // Trigger refund retry asynchronously (don't await)
186
- triggerRefundRetry(req.scope, return_id, orderId).catch((error) => {
187
- console.error(`[payment-details] Error triggering refund retry for return ${return_id}:`, error instanceof Error ? error.message : error);
188
- });
189
- }
190
- return res.json({
191
- success: true,
192
- message: "Payment details saved successfully",
193
- return_id,
194
- refund_status: refundStatus.status,
195
- can_update: refundStatus.status !== "succeeded",
196
- payment_details_history_count: paymentDetailsHistory.length,
197
- ...(previousRefundStatus === "failed" && {
198
- note: "Refund retry has been automatically initiated with updated payment details",
199
- }),
200
- ...(previousRefundStatus !== "failed" && {
201
- note: "Payment details have been processed. If return update API is not available in your Medusa version, " +
202
- "you may need to implement a custom return module to persist metadata.",
203
- }),
204
- });
205
- };
206
- exports.POST = POST;
207
- // Helper function to find return by ID
208
- async function findReturnById(orderService, returnId) {
209
- // This is a simplified implementation
210
- // In production, you might want to use a more efficient query method
211
- // or extend Medusa's return service
212
- // For now, we'll need to search through orders
213
- // This is not ideal for performance but works for the initial implementation
214
- try {
215
- // Try to retrieve via order relations
216
- // Note: This assumes returns are accessible via order relations
217
- // You may need to adjust based on your Medusa version and setup
218
- const orders = await orderService.listOrders({
219
- // Query to find order with this return
220
- });
221
- for (const order of orders) {
222
- const orderWithReturns = order;
223
- const returns = orderWithReturns.returns || [];
224
- const returnRecord = returns.find((ret) => ret.id === returnId);
225
- if (returnRecord) {
226
- return returnRecord;
227
- }
228
- }
229
- }
230
- catch (error) {
231
- console.error("Error finding return:", error);
232
- }
233
- return null;
234
- }
235
- /**
236
- * Helper function to get refund status for a return
237
- * Checks payment collection refunds to find refund linked to return_id
238
- */
239
- async function getRefundStatusForReturn(orderService, paymentService, return_id, order_id) {
240
- try {
241
- // Retrieve order with payment collection
242
- const order = await orderService.retrieveOrder(order_id, {
243
- relations: ["payment_collection"],
244
- });
245
- if (!order) {
246
- return { status: null };
247
- }
248
- // Get payment collection ID
249
- const orderWithPayment = order;
250
- const paymentCollectionId = orderWithPayment.payment_collection_id;
251
- if (!paymentCollectionId) {
252
- return { status: null };
253
- }
254
- // Retrieve payment collection with refunds
255
- const paymentCollection = await paymentService.retrievePaymentCollection(paymentCollectionId, {
256
- relations: ["refunds"],
257
- });
258
- if (!paymentCollection) {
259
- return { status: null };
260
- }
261
- // Check refunds in collection
262
- const paymentCollectionWithRefunds = paymentCollection;
263
- const refunds = paymentCollectionWithRefunds.refunds || [];
264
- // Find refund linked to this return
265
- for (const refund of refunds) {
266
- const refundData = refund;
267
- const metadata = refundData.metadata || {};
268
- // Check if refund is linked to this return
269
- if (metadata.return_id === return_id) {
270
- const refundStatus = metadata.refund_status;
271
- return {
272
- status: refundStatus || null,
273
- refund_id: refundData.id,
274
- };
275
- }
276
- }
277
- // Also check payment collection metadata for fallback refunds
278
- const collectionMetadata = paymentCollectionWithRefunds.metadata || {};
279
- const refundTransactions = collectionMetadata.refund_transactions || {};
280
- // Check each refund transaction
281
- for (const [refundId, refundData] of Object.entries(refundTransactions)) {
282
- const refundInfo = refundData;
283
- if (refundInfo.return_id === return_id) {
284
- return {
285
- status: refundInfo.refund_status || null,
286
- refund_id: refundId,
287
- };
288
- }
289
- }
290
- return { status: null };
291
- }
292
- catch (error) {
293
- console.error(`[getRefundStatusForReturn] Error checking refund status for return ${return_id}:`, error instanceof Error ? error.message : error);
294
- return { status: null };
295
- }
296
- }
297
- /**
298
- * Helper function to trigger refund retry when payment details are updated
299
- * Executes workflow asynchronously without blocking the response
300
- */
301
- async function triggerRefundRetry(scope, return_id, order_id) {
302
- try {
303
- // Execute workflow asynchronously (don't await to avoid blocking)
304
- (0, process_cod_refund_workflow_1.default)(scope)
305
- .run({
306
- input: {
307
- return_id,
308
- order_id,
309
- },
310
- })
311
- .then(({ result }) => {
312
- console.log(`[triggerRefundRetry] Refund retry initiated successfully for return ${return_id}`, {
313
- refund_id: result.refund_id,
314
- amount: result.amount,
315
- currency_code: result.currency_code,
316
- });
317
- })
318
- .catch((error) => {
319
- console.error(`[triggerRefundRetry] Refund retry failed for return ${return_id}:`, error instanceof Error ? error.message : error);
320
- });
321
- }
322
- catch (error) {
323
- console.error(`[triggerRefundRetry] Error initiating refund retry for return ${return_id}:`, error instanceof Error ? error.message : error);
324
- }
325
- }
326
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL3N0b3JlL3JldHVybnMvW2lkXS9wYXltZW50LWRldGFpbHMvcm91dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EscURBQXVEO0FBQ3ZELHFEQUFtRDtBQU1uRCx1SEFBMkY7QUFFM0Y7Ozs7R0FJRztBQUNJLE1BQU0sR0FBRyxHQUFHLEtBQUssRUFDdEIsR0FBa0IsRUFDbEIsR0FBbUIsRUFDbkIsRUFBRTtJQUNGLE1BQU0sRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQTtJQUVwQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDZixNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5Qix1QkFBdUIsQ0FDeEIsQ0FBQTtJQUNILENBQUM7SUFFRCx1Q0FBdUM7SUFDdkMsTUFBTSxZQUFZLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQXNCLGVBQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUMxRSxNQUFNLGNBQWMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FDdEMsZUFBTyxDQUFDLE9BQU8sQ0FDaEIsQ0FBQTtJQUVELG9CQUFvQjtJQUNwQixNQUFNLFlBQVksR0FBRyxNQUFNLGNBQWMsQ0FBQyxZQUFZLEVBQUUsU0FBUyxDQUFDLENBQUE7SUFFbEUsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ2xCLE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQzNCLGtCQUFrQixTQUFTLFlBQVksQ0FDeEMsQ0FBQTtJQUNILENBQUM7SUFFRCx5Q0FBeUM7SUFDekMsTUFBTSxPQUFPLEdBQUksWUFBcUMsQ0FBQyxRQUFRLENBQUE7SUFDL0QsTUFBTSxLQUFLLEdBQUcs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
@@ -1,61 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DEFAULT_ORDER_MANAGEMENT_OPTIONS = void 0;
4
- exports.normalizeOrderManagementOptions = normalizeOrderManagementOptions;
5
- exports.resolveOrderManagementOptions = resolveOrderManagementOptions;
6
- const utils_1 = require("@medusajs/framework/utils");
7
- const zod_1 = require("zod");
8
- const RefundProviderCredentialsSchema = zod_1.z.object({
9
- razorpay: zod_1.z
10
- .object({
11
- keyId: zod_1.z.string().min(1),
12
- keySecret: zod_1.z.string().min(1),
13
- })
14
- .optional(),
15
- stripe: zod_1.z
16
- .object({
17
- apiKey: zod_1.z.string().min(1),
18
- })
19
- .optional(),
20
- });
21
- const OrderManagementPluginOptionsSchema = zod_1.z.object({
22
- refundProviders: zod_1.z
23
- .object({
24
- enabled: zod_1.z.array(zod_1.z.enum(["razorpay", "stripe"])).optional(),
25
- credentials: RefundProviderCredentialsSchema.optional(),
26
- providerSelection: zod_1.z.enum(["auto", "manual"]).default("auto"),
27
- })
28
- .optional(),
29
- paymentProcessing: zod_1.z.enum(["automatic", "manual"]).default("automatic"),
30
- });
31
- function normalizeOrderManagementOptions(input) {
32
- const parsed = OrderManagementPluginOptionsSchema.parse(input ?? {});
33
- return {
34
- refundProviders: parsed.refundProviders
35
- ? {
36
- enabled: parsed.refundProviders.enabled,
37
- credentials: parsed.refundProviders.credentials,
38
- providerSelection: parsed.refundProviders.providerSelection,
39
- }
40
- : undefined,
41
- paymentProcessing: parsed.paymentProcessing,
42
- };
43
- }
44
- exports.DEFAULT_ORDER_MANAGEMENT_OPTIONS = normalizeOrderManagementOptions({});
45
- const PLUGIN_NAME = "order-management";
46
- function resolveOrderManagementOptions(configModule) {
47
- const plugins = configModule?.plugins ?? [];
48
- for (const plugin of plugins) {
49
- if ((0, utils_1.isString)(plugin)) {
50
- if (plugin === PLUGIN_NAME) {
51
- break;
52
- }
53
- continue;
54
- }
55
- if (plugin?.resolve === PLUGIN_NAME) {
56
- return normalizeOrderManagementOptions(plugin.options);
57
- }
58
- }
59
- return exports.DEFAULT_ORDER_MANAGEMENT_OPTIONS;
60
- }
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLW9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29uZmlnL3BsdWdpbi1vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQThDQSwwRUFlQztBQU9ELHNFQW1CQztBQXZGRCxxREFBb0Q7QUFDcEQsNkJBQXVCO0FBTXZCLE1BQU0sK0JBQStCLEdBQUcsT0FBQyxDQUFDLE1BQU0sQ0FBQztJQUMvQyxRQUFRLEVBQUUsT0FBQztTQUNSLE1BQU0sQ0FBQztRQUNOLEtBQUssRUFBRSxPQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUN4QixTQUFTLEVBQUUsT0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7S0FDN0IsQ0FBQztTQUNELFFBQVEsRUFBRTtJQUNiLE1BQU0sRUFBRSxPQUFDO1NBQ04sTUFBTSxDQUFDO1FBQ04sTUFBTSxFQUFFLE9BQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0tBQzFCLENBQUM7U0FDRCxRQUFRLEVBQUU7Q0FDZCxDQUFDLENBQUE7QUFFRixNQUFNLGtDQUFrQyxHQUFHLE9BQUMsQ0FBQyxNQUFNLENBQUM7SUFDbEQsZUFBZSxFQUFFLE9BQUM7U0FDZixNQUFNLENBQUM7UUFDTixPQUFPLEVBQUUsT0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUU7UUFDM0QsV0FBVyxFQUFFLCtCQUErQixDQUFDLFFBQVEsRUFBRTtRQUN2RCxpQkFBaUIsRUFBRSxPQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztLQUM5RCxDQUFDO1NBQ0QsUUFBUSxFQUFFO0lBQ2IsaUJBQWlCLEVBQUUsT0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUM7Q0FDeEUsQ0FBQyxDQUFBO0FBZ0JGLFNBQWdCLCtCQUErQixDQUM3QyxLQUE4QztJQUU5QyxNQUFNLE1BQU0sR0FBRyxrQ0FBa0MsQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQyxDQUFBO0lBRXBFLE9BQU87UUFDTCxlQUFlLEVBQUUsTUFBTSxDQUFDLGVBQWU7WUFDckMsQ0FBQyxDQUFDO2dCQUNFLE9BQU8sRUFBRSxNQUFNLENBQUMsZUFBZSxDQUFDLE9BQU87Z0JBQ3ZDLFdBQVcsRUFBRSxNQUFNLENBQUMsZUFBZSxDQUFDLFdBQVc7Z0JBQy9DLGlCQUFpQixFQUFFLE1BQU0sQ0FBQyxlQUFlLENBQUMsaUJBQWlCO2FBQzVEO1lBQ0gsQ0FBQyxDQUFDLFNBQVM7UUFDYixpQkFBaUIsRUFBRSxNQUFNLENBQUMsaUJBQWlCO0tBQzVDLENBQUE7QUFDSCxDQUFDO0FBRVksUUFBQSxnQ0FBZ0MsR0FDM0MsK0JBQStCLENBQUMsRUFBRSxDQUFDLENBQUE7QUFFckMsTUFBTSxXQUFXLEdBQUcsa0JBQWtCLENBQUE7QUFFdEMsU0FBZ0IsNkJBQTZCLENBQzNDLFlBQWdDO0lBRWhDLE1BQU0sT0FBTyxHQUFHLFlBQVksRUFBRSxPQUFPLElBQUksRUFBRSxDQUFBO0lBRTNDLEtBQUssTUFBTSxNQUFNLElBQUksT0FBTyxFQUFFLENBQUM7UUFDN0IsSUFBSSxJQUFBLGdCQUFRLEVBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUNyQixJQUFJLE1BQU0sS0FBSyxXQUFXLEVBQUUsQ0FBQztnQkFDM0IsTUFBSztZQUNQLENBQUM7WUFDRCxTQUFRO1FBQ1YsQ0FBQztRQUVELElBQUksTUFBTSxFQUFFLE9BQU8sS0FBSyxXQUFXLEVBQUUsQ0FBQztZQUNwQyxPQUFPLCtCQUErQixDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQTtRQUN4RCxDQUFDO0lBQ0gsQ0FBQztJQUVELE9BQU8sd0NBQWdDLENBQUE7QUFDekMsQ0FBQyJ9
@@ -1,80 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BaseRefundProvider = void 0;
4
- class BaseRefundProvider {
5
- constructor(providerName) {
6
- this.providerName = providerName;
7
- }
8
- getName() {
9
- return this.providerName;
10
- }
11
- validatePaymentDetails(payment_details, requiredMethod) {
12
- if (payment_details.method !== requiredMethod) {
13
- return {
14
- valid: false,
15
- error: `Payment method mismatch. Expected ${requiredMethod}, got ${payment_details.method}`,
16
- };
17
- }
18
- switch (requiredMethod) {
19
- case "bank_transfer":
20
- if (!payment_details.bank_account) {
21
- return {
22
- valid: false,
23
- error: "Bank account details are required for bank transfer",
24
- };
25
- }
26
- if (!payment_details.bank_account.account_number) {
27
- return {
28
- valid: false,
29
- error: "Bank account number is required",
30
- };
31
- }
32
- if (!payment_details.bank_account.account_holder_name) {
33
- return {
34
- valid: false,
35
- error: "Account holder name is required",
36
- };
37
- }
38
- break;
39
- case "upi":
40
- if (!payment_details.upi_id) {
41
- return {
42
- valid: false,
43
- error: "UPI ID is required for UPI refund",
44
- };
45
- }
46
- break;
47
- case "wallet":
48
- if (!payment_details.wallet) {
49
- return {
50
- valid: false,
51
- error: "Wallet details are required for wallet refund",
52
- };
53
- }
54
- if (!payment_details.wallet.wallet_id) {
55
- return {
56
- valid: false,
57
- error: "Wallet ID is required",
58
- };
59
- }
60
- break;
61
- }
62
- return { valid: true };
63
- }
64
- createErrorResult(errorMessage, errorCode) {
65
- return {
66
- success: false,
67
- error_message: errorMessage,
68
- error_code: errorCode,
69
- };
70
- }
71
- createSuccessResult(transactionId, gatewayResponse) {
72
- return {
73
- success: true,
74
- transaction_id: transactionId,
75
- gateway_response: gatewayResponse,
76
- };
77
- }
78
- }
79
- exports.BaseRefundProvider = BaseRefundProvider;
80
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1yZWZ1bmQtcHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvcHJvdmlkZXJzL3JlZnVuZC1wYXltZW50L2Jhc2UtcmVmdW5kLXByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQU9BLE1BQXNCLGtCQUFrQjtJQUd0QyxZQUFZLFlBQW9CO1FBQzlCLElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFBO0lBQ2xDLENBQUM7SUFpQkQsT0FBTztRQUNMLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQTtJQUMxQixDQUFDO0lBRVMsc0JBQXNCLENBQzlCLGVBQXFDLEVBQ3JDLGNBQTZCO1FBRTdCLElBQUksZUFBZSxDQUFDLE1BQU0sS0FBSyxjQUFjLEVBQUUsQ0FBQztZQUM5QyxPQUFPO2dCQUNMLEtBQUssRUFBRSxLQUFLO2dCQUNaLEtBQUssRUFBRSxxQ0FBcUMsY0FBYyxTQUFTLGVBQWUsQ0FBQyxNQUFNLEVBQUU7YUFDNUYsQ0FBQTtRQUNILENBQUM7UUFFRCxRQUFRLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLEtBQUssZUFBZTtnQkFDbEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxZQUFZLEVBQUUsQ0FBQztvQkFDbEMsT0FBTzt3QkFDTCxLQUFLLEVBQUUsS0FBSzt3QkFDWixLQUFLLEVBQUUscURBQXFEO3FCQUM3RCxDQUFBO2dCQUNILENBQUM7Z0JBQ0QsSUFBSSxDQUFDLGVBQWUsQ0FBQyxZQUFZLENBQUMsY0FBYyxFQUFFLENBQUM7b0JBQ2pELE9BQU87d0JBQ0wsS0FBSyxFQUFFLEtBQUs7d0JBQ1osS0FBSyxFQUFFLGlDQUFpQztxQkFDekMsQ0FBQTtnQkFDSCxDQUFDO2dCQUNELElBQUksQ0FBQyxlQUFlLENBQUMsWUFBWSxDQUFDLG1CQUFtQixFQUFFLENBQUM7b0JBQ3RELE9BQU87d0JBQ0wsS0FBSyxFQUFFLEtBQUs7d0JBQ1osS0FBSyxFQUFFLGlDQUFpQztxQkFDekMsQ0FBQTtnQkFDSCxDQUFDO2dCQUNELE1BQUs7WUFFUCxLQUFLLEtBQUs7Z0JBQ1IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztvQkFDNUIsT0FBTzt3QkFDTCxLQUFLLEVBQUUsS0FBSzt3QkFDWixLQUFLLEVBQUUsbUNBQW1DO3FCQUMzQyxDQUFBO2dCQUNILENBQUM7Z0JBQ0QsTUFBSztZQUVQLEtBQUssUUFBUTtnQkFDWCxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sRUFBRSxDQUFDO29CQUM1QixPQUFPO3dCQUNMLEtBQUssRUFBRSxLQUFLO3dCQUNaLEtBQUssRUFBRSwrQ0FBK0M7cUJBQ3ZELENBQUE7Z0JBQ0gsQ0FBQztnQkFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQztvQkFDdEMsT0FBTzt3QkFDTCxLQUFLLEVBQUUsS0FBSzt3QkFDWixLQUFLLEVBQUUsdUJBQXVCO3FCQUMvQixDQUFBO2dCQUNILENBQUM7Z0JBQ0QsTUFBSztRQUNULENBQUM7UUFFRCxPQUFPLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFBO0lBQ3hCLENBQUM7SUFFUyxpQkFBaUIsQ0FDekIsWUFBb0IsRUFDcEIsU0FBa0I7UUFFbEIsT0FBTztZQUNMLE9BQU8sRUFBRSxLQUFLO1lBQ2QsYUFBYSxFQUFFLFlBQVk7WUFDM0IsVUFBVSxFQUFFLFNBQVM7U0FDdEIsQ0FBQTtJQUNILENBQUM7SUFFUyxtQkFBbUIsQ0FDM0IsYUFBcUIsRUFDckIsZUFBeUI7UUFFekIsT0FBTztZQUNMLE9BQU8sRUFBRSxJQUFJO1lBQ2IsY0FBYyxFQUFFLGFBQWE7WUFDN0IsZ0JBQWdCLEVBQUUsZUFBZTtTQUNsQyxDQUFBO0lBQ0gsQ0FBQztDQUNGO0FBNUdELGdEQTRHQyJ9