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
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.POST = void 0;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ const reorder_workflow_1 = require("../../../../../workflows/reorder-workflow");
6
+ const POST = async (req, res) => {
7
+ const { order_id } = req.params;
8
+ if (!order_id) {
9
+ res.status(400).json({
10
+ message: "order_id is required in path parameter",
11
+ });
12
+ return;
13
+ }
14
+ // Type-safe access to auth_context
15
+ const authContext = req.auth_context;
16
+ const customerId = authContext?.actor_id;
17
+ // Detailed logging: Authentication customer ID
18
+ console.log("[Order Management] Authentication check:", {
19
+ order_id,
20
+ auth_customer_id: customerId,
21
+ auth_actor_type: authContext?.actor_type,
22
+ has_auth_context: !!authContext,
23
+ timestamp: new Date().toISOString(),
24
+ });
25
+ if (!customerId || authContext?.actor_type !== "customer") {
26
+ console.warn("[Order Management] Authentication failed:", {
27
+ order_id,
28
+ customer_id: customerId,
29
+ actor_type: authContext?.actor_type,
30
+ reason: !customerId ? "Missing customer_id" : "Invalid actor_type",
31
+ });
32
+ res.status(401).json({
33
+ message: "Unauthorized: Customer authentication is required",
34
+ });
35
+ return;
36
+ }
37
+ try {
38
+ const { result } = await (0, reorder_workflow_1.reorderWorkflow)(req.scope).run({
39
+ input: {
40
+ order_id,
41
+ customer_id: customerId,
42
+ },
43
+ });
44
+ res.json(result);
45
+ }
46
+ catch (error) {
47
+ // Log error for debugging
48
+ console.error("Reorder workflow error:", error);
49
+ if (error instanceof utils_1.MedusaError) {
50
+ res.status(error.type === utils_1.MedusaError.Types.NOT_FOUND ? 404 : 400).json({
51
+ message: error.message,
52
+ type: error.type,
53
+ });
54
+ return;
55
+ }
56
+ // Return detailed error information
57
+ const errorMessage = error instanceof Error ? error.message : "An error occurred";
58
+ const errorStack = error instanceof Error ? error.stack : undefined;
59
+ res.status(500).json({
60
+ message: errorMessage,
61
+ ...(process.env.NODE_ENV === "development" && { stack: errorStack }),
62
+ });
63
+ }
64
+ };
65
+ exports.POST = POST;
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL3N0b3JlL29yZGVycy9yZW9yZGVyL1tvcmRlcl9pZF0vcm91dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EscURBQXVEO0FBQ3ZELGdGQUEyRTtBQUVwRSxNQUFNLElBQUksR0FBRyxLQUFLLEVBQ3ZCLEdBQWtCLEVBQ2xCLEdBQW1CLEVBQ25CLEVBQUU7SUFDRixNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQTtJQUUvQixJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDZCxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQztZQUNuQixPQUFPLEVBQUUsd0NBQXdDO1NBQ2xELENBQUMsQ0FBQTtRQUNGLE9BQU07SUFDUixDQUFDO0lBRUQsbUNBQW1DO0lBQ25DLE1BQU0sV0FBVyxHQUFJLEdBRW5CLENBQUMsWUFBWSxDQUFBO0lBRWYsTUFBTSxVQUFVLEdBQUcsV0FBVyxFQUFFLFFBQVEsQ0FBQTtJQUV4QywrQ0FBK0M7SUFDL0MsT0FBTyxDQUFDLEdBQUcsQ0FBQywwQ0FBMEMsRUFBRTtRQUN0RCxRQUFRO1FBQ1IsZ0JBQWdCLEVBQUUsVUFBVTtRQUM1QixlQUFlLEVBQUUsV0FBVyxFQUFFLFVBQVU7UUFDeEMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDLFdBQVc7UUFDL0IsU0FBUyxFQUFFLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFO0tBQ3BDLENBQUMsQ0FBQTtJQUVGLElBQUksQ0FBQyxVQUFVLElBQUksV0FBVyxFQUFFLFVBQVUsS0FBSyxVQUFVLEVBQUUsQ0FBQztRQUMxRCxPQUFPLENBQUMsSUFBSSxDQUFDLDJDQUEyQyxFQUFFO1lBQ3hELFFBQVE7WUFDUixXQUFXLEVBQUUsVUFBVTtZQUN2QixVQUFVLEVBQUUsV0FBVyxFQUFFLFVBQVU7WUFDbkMsTUFBTSxFQUFFLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDLENBQUMsb0JBQW9CO1NBQ25FLENBQUMsQ0FBQTtRQUNGLEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDO1lBQ25CLE9BQU8sRUFBRSxtREFBbUQ7U0FDN0QsQ0FBQyxDQUFBO1FBQ0YsT0FBTTtJQUNSLENBQUM7SUFFRCxJQUFJLENBQUM7UUFDSCxNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsTUFBTSxJQUFBLGtDQUFlLEVBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsQ0FBQztZQUN0RCxLQUFLLEVBQUU7Z0JBQ0wsUUFBUTtnQkFDUixXQUFXLEVBQUUsVUFBVTthQUN4QjtTQUNGLENBQUMsQ0FBQTtRQUVGLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDbEIsQ0FBQztJQUFDLE9BQU8sS0FBSyxFQUFFLENBQUM7UUFDZiwwQkFBMEI7UUFDMUIsT0FBTyxDQUFDLEtBQUssQ0FBQyx5QkFBeUIsRUFBRSxLQUFLLENBQUMsQ0FBQTtRQUUvQyxJQUFJLEtBQUssWUFBWSxtQkFBVyxFQUFFLENBQUM7WUFDakMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLG1CQUFXLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUM7Z0JBQ3RFLE9BQU8sRUFBRSxLQUFLLENBQUMsT0FBTztnQkFDdEIsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJO2FBQ2pCLENBQUMsQ0FBQTtZQUNGLE9BQU07UUFDUixDQUFDO1FBRUQsb0NBQW9DO1FBQ3BDLE1BQU0sWUFBWSxHQUFHLEtBQUssWUFBWSxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLG1CQUFtQixDQUFBO1FBQ2pGLE1BQU0sVUFBVSxHQUFHLEtBQUssWUFBWSxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQTtRQUVuRSxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQztZQUNuQixPQUFPLEVBQUUsWUFBWTtZQUNyQixHQUFHLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEtBQUssYUFBYSxJQUFJLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxDQUFDO1NBQ3JFLENBQUMsQ0FBQTtJQUNKLENBQUM7QUFDSCxDQUFDLENBQUE7QUF4RVksUUFBQSxJQUFJLFFBd0VoQiJ9
@@ -1,11 +1,6 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.default = exports.processCodRefundWorkflow = void 0;
7
- var process_cod_refund_workflow_1 = require("./process-cod-refund-workflow");
8
- Object.defineProperty(exports, "processCodRefundWorkflow", { enumerable: true, get: function () { return process_cod_refund_workflow_1.processCodRefundWorkflow; } });
9
- var process_cod_refund_workflow_2 = require("./process-cod-refund-workflow");
10
- Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(process_cod_refund_workflow_2).default; } });
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvd29ya2Zsb3dzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLDZFQUF3RTtBQUEvRCx1SUFBQSx3QkFBd0IsT0FBQTtBQUNqQyw2RUFBdUQ7QUFBOUMsdUlBQUEsT0FBTyxPQUFBIn0=
3
+ exports.reorderWorkflow = void 0;
4
+ var reorder_workflow_1 = require("./reorder-workflow");
5
+ Object.defineProperty(exports, "reorderWorkflow", { enumerable: true, get: function () { return reorder_workflow_1.reorderWorkflow; } });
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvd29ya2Zsb3dzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHVEQUFvRDtBQUEzQyxtSEFBQSxlQUFlLE9BQUEifQ==
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvd29ya2Zsb3dzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvd29ya2Zsb3dzL3Jlb3JkZXIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.reorderWorkflow = void 0;
4
+ const workflows_sdk_1 = require("@medusajs/framework/workflows-sdk");
5
+ const steps_1 = require("./steps");
6
+ exports.reorderWorkflow = (0, workflows_sdk_1.createWorkflow)("reorder", (input) => {
7
+ const { order_id, customer_id } = input;
8
+ // Step 1: Retrieve and validate order
9
+ const { order } = (0, steps_1.retrieveOrderStep)({
10
+ order_id,
11
+ customer_id,
12
+ });
13
+ // Step 2: Transform order to cart input
14
+ const { cartInput } = (0, steps_1.transformOrderToCartStep)({
15
+ order,
16
+ });
17
+ // Step 3: Create cart from order
18
+ const { cart } = (0, steps_1.createCartFromOrderStep)({
19
+ cartInput,
20
+ });
21
+ // Return only cart ID (no order creation)
22
+ return new workflows_sdk_1.WorkflowResponse({
23
+ cart_id: cart.id,
24
+ });
25
+ });
26
+ exports.default = exports.reorderWorkflow;
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVvcmRlci13b3JrZmxvdy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy93b3JrZmxvd3MvcmVvcmRlci13b3JrZmxvdy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxRUFHMEM7QUFDMUMsbUNBSWdCO0FBTUgsUUFBQSxlQUFlLEdBQUcsSUFBQSw4QkFBYyxFQUMzQyxTQUFTLEVBQ1QsQ0FDRSxLQUEyQixFQUNjLEVBQUU7SUFDM0MsTUFBTSxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsR0FBRyxLQUFLLENBQUE7SUFFdkMsc0NBQXNDO0lBQ3RDLE1BQU0sRUFBRSxLQUFLLEVBQUUsR0FBRyxJQUFBLHlCQUFpQixFQUFDO1FBQ2xDLFFBQVE7UUFDUixXQUFXO0tBQ1osQ0FBQyxDQUFBO0lBRUYsd0NBQXdDO0lBQ3hDLE1BQU0sRUFBRSxTQUFTLEVBQUUsR0FBRyxJQUFBLGdDQUF3QixFQUFDO1FBQzdDLEtBQUs7S0FDTixDQUFDLENBQUE7SUFFRixpQ0FBaUM7SUFDakMsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLElBQUEsK0JBQXVCLEVBQUM7UUFDdkMsU0FBUztLQUNWLENBQUMsQ0FBQTtJQUVGLDBDQUEwQztJQUMxQyxPQUFPLElBQUksZ0NBQWdCLENBQUM7UUFDMUIsT0FBTyxFQUFFLElBQUksQ0FBQyxFQUFFO0tBQ2pCLENBQUMsQ0FBQTtBQUNKLENBQUMsQ0FDRixDQUFBO0FBRUQsa0JBQWUsdUJBQWUsQ0FBQSJ9
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createCartFromOrderStep = void 0;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ const workflows_sdk_1 = require("@medusajs/framework/workflows-sdk");
6
+ const core_flows_1 = require("@medusajs/medusa/core-flows");
7
+ exports.createCartFromOrderStep = (0, workflows_sdk_1.createStep)("create-cart-from-order", async (input, { container }) => {
8
+ const { cartInput } = input;
9
+ if (!cartInput.region_id) {
10
+ throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "region_id is required to create a cart");
11
+ }
12
+ const { result: cart } = await (0, core_flows_1.createCartWorkflow)(container).run({
13
+ input: cartInput,
14
+ });
15
+ if (!cart) {
16
+ throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNEXPECTED_STATE, "Failed to create cart");
17
+ }
18
+ // Trust the cart object returned by createCartWorkflow
19
+ // Investigation showed that the raw cart object is clean (no payment collection)
20
+ // The remote query was incorrectly returning a different cart, causing false positives
21
+ // Payment collection will be created fresh in create-order-conditionally-step when needed
22
+ return new workflows_sdk_1.StepResponse({
23
+ cart: cart,
24
+ });
25
+ });
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWNhcnQtZnJvbS1vcmRlci1zdGVwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL3dvcmtmbG93cy9zdGVwcy9jcmVhdGUtY2FydC1mcm9tLW9yZGVyLXN0ZXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscURBQXVEO0FBQ3ZELHFFQUE0RTtBQUM1RSw0REFBZ0U7QUFjbkQsUUFBQSx1QkFBdUIsR0FBRyxJQUFBLDBCQUFVLEVBQy9DLHdCQUF3QixFQUN4QixLQUFLLEVBQ0gsS0FBbUMsRUFDbkMsRUFBRSxTQUFTLEVBQUUsRUFDeUMsRUFBRTtJQUN4RCxNQUFNLEVBQUUsU0FBUyxFQUFFLEdBQUcsS0FBSyxDQUFBO0lBRTNCLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDekIsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLFlBQVksRUFDOUIsd0NBQXdDLENBQ3pDLENBQUE7SUFDSCxDQUFDO0lBRUQsTUFBTSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxNQUFNLElBQUEsK0JBQWtCLEVBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxDQUFDO1FBQy9ELEtBQUssRUFBRSxTQUFTO0tBQ2pCLENBQUMsQ0FBQTtJQUVGLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNWLE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsRUFDbEMsdUJBQXVCLENBQ3hCLENBQUE7SUFDSCxDQUFDO0lBRUQsdURBQXVEO0lBQ3ZELGlGQUFpRjtJQUNqRix1RkFBdUY7SUFDdkYsMEZBQTBGO0lBRTFGLE9BQU8sSUFBSSw0QkFBWSxDQUFnQztRQUNyRCxJQUFJLEVBQUUsSUFBd0Q7S0FDL0QsQ0FBQyxDQUFBO0FBQ0osQ0FBQyxDQUNGLENBQUEifQ==
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createCartFromOrderStep = exports.transformOrderToCartStep = exports.retrieveOrderStep = void 0;
4
+ var retrieve_order_step_1 = require("./retrieve-order-step");
5
+ Object.defineProperty(exports, "retrieveOrderStep", { enumerable: true, get: function () { return retrieve_order_step_1.retrieveOrderStep; } });
6
+ var transform_order_to_cart_step_1 = require("./transform-order-to-cart-step");
7
+ Object.defineProperty(exports, "transformOrderToCartStep", { enumerable: true, get: function () { return transform_order_to_cart_step_1.transformOrderToCartStep; } });
8
+ var create_cart_from_order_step_1 = require("./create-cart-from-order-step");
9
+ Object.defineProperty(exports, "createCartFromOrderStep", { enumerable: true, get: function () { return create_cart_from_order_step_1.createCartFromOrderStep; } });
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvd29ya2Zsb3dzL3N0ZXBzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZEQUF5RDtBQUFoRCx3SEFBQSxpQkFBaUIsT0FBQTtBQUMxQiwrRUFBeUU7QUFBaEUsd0lBQUEsd0JBQXdCLE9BQUE7QUFDakMsNkVBQXVFO0FBQTlELHNJQUFBLHVCQUF1QixPQUFBIn0=
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.retrieveOrderStep = void 0;
4
+ const utils_1 = require("@medusajs/framework/utils");
5
+ const workflows_sdk_1 = require("@medusajs/framework/workflows-sdk");
6
+ const utils_2 = require("@medusajs/framework/utils");
7
+ exports.retrieveOrderStep = (0, workflows_sdk_1.createStep)("retrieve-order", async (input, { container }) => {
8
+ const { order_id, customer_id } = input;
9
+ if (!order_id) {
10
+ throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "order_id is required");
11
+ }
12
+ if (!customer_id) {
13
+ throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNAUTHORIZED, "Customer authentication is required");
14
+ }
15
+ const remoteQuery = container.resolve(utils_2.ContainerRegistrationKeys.REMOTE_QUERY);
16
+ let orders;
17
+ try {
18
+ const queryObject = (0, utils_2.remoteQueryObjectFromString)({
19
+ entryPoint: "order",
20
+ fields: [
21
+ "id",
22
+ "items.*",
23
+ "shipping_address.*",
24
+ "billing_address.*",
25
+ "region_id",
26
+ "sales_channel_id",
27
+ "customer_id",
28
+ "email",
29
+ ],
30
+ filters: {
31
+ id: order_id,
32
+ },
33
+ });
34
+ orders = await remoteQuery(queryObject);
35
+ }
36
+ catch (queryError) {
37
+ console.error("Remote query error:", queryError);
38
+ throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNEXPECTED_STATE, `Failed to retrieve order: ${queryError instanceof Error ? queryError.message : "Unknown error"}`);
39
+ }
40
+ const order = Array.isArray(orders) ? orders[0] : orders;
41
+ if (!order) {
42
+ throw new utils_1.MedusaError(utils_1.MedusaError.Types.NOT_FOUND, `Order with id ${order_id} not found`);
43
+ }
44
+ // Detailed logging: Order customer ID vs Authentication customer ID
45
+ const orderCustomerId = order.customer_id;
46
+ const authCustomerId = customer_id;
47
+ const customerIdsMatch = orderCustomerId === authCustomerId;
48
+ console.log("[Order Management] Customer ID comparison:", {
49
+ order_id,
50
+ order_customer_id: orderCustomerId,
51
+ authentication_customer_id: authCustomerId,
52
+ match: customerIdsMatch,
53
+ order_customer_id_type: typeof orderCustomerId,
54
+ auth_customer_id_type: typeof authCustomerId,
55
+ order_customer_id_null_or_undefined: orderCustomerId == null,
56
+ auth_customer_id_null_or_undefined: authCustomerId == null,
57
+ timestamp: new Date().toISOString(),
58
+ });
59
+ // Validate customer ownership
60
+ if (!customerIdsMatch) {
61
+ console.warn("[Order Management] Customer ID mismatch - Access denied:", {
62
+ order_id,
63
+ order_customer_id: orderCustomerId,
64
+ authentication_customer_id: authCustomerId,
65
+ reason: "Order customer_id does not match authenticated customer_id",
66
+ timestamp: new Date().toISOString(),
67
+ });
68
+ throw new utils_1.MedusaError(utils_1.MedusaError.Types.NOT_ALLOWED, "You can only reorder your own orders");
69
+ }
70
+ console.log("[Order Management] Customer ID validation passed:", {
71
+ order_id,
72
+ customer_id: authCustomerId,
73
+ timestamp: new Date().toISOString(),
74
+ });
75
+ return new workflows_sdk_1.StepResponse({
76
+ order: order,
77
+ });
78
+ });
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmV0cmlldmUtb3JkZXItc3RlcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy93b3JrZmxvd3Mvc3RlcHMvcmV0cmlldmUtb3JkZXItc3RlcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxREFBdUQ7QUFDdkQscUVBQTRFO0FBQzVFLHFEQUFrRztBQWtEckYsUUFBQSxpQkFBaUIsR0FBRyxJQUFBLDBCQUFVLEVBQ3pDLGdCQUFnQixFQUNoQixLQUFLLEVBQ0gsS0FBNkIsRUFDN0IsRUFBRSxTQUFTLEVBQUUsRUFDbUMsRUFBRTtJQUNsRCxNQUFNLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFBRSxHQUFHLEtBQUssQ0FBQTtJQUV2QyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDZCxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5QixzQkFBc0IsQ0FDdkIsQ0FBQTtJQUNILENBQUM7SUFFRCxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDakIsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLFlBQVksRUFDOUIscUNBQXFDLENBQ3RDLENBQUE7SUFDSCxDQUFDO0lBRUQsTUFBTSxXQUFXLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FDbkMsaUNBQXlCLENBQUMsWUFBWSxDQUN2QyxDQUFBO0lBRUQsSUFBSSxNQUFNLENBQUE7SUFDVixJQUFJLENBQUM7UUFDSCxNQUFNLFdBQVcsR0FBRyxJQUFBLG1DQUEyQixFQUFDO1lBQzlDLFVBQVUsRUFBRSxPQUFPO1lBQ25CLE1BQU0sRUFBRTtnQkFDTixJQUFJO2dCQUNKLFNBQVM7Z0JBQ1Qsb0JBQW9CO2dCQUNwQixtQkFBbUI7Z0JBQ25CLFdBQVc7Z0JBQ1gsa0JBQWtCO2dCQUNsQixhQUFhO2dCQUNiLE9BQU87YUFDUjtZQUNELE9BQU8sRUFBRTtnQkFDUCxFQUFFLEVBQUUsUUFB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
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.transformOrderToCartStep = void 0;
4
+ const workflows_sdk_1 = require("@medusajs/framework/workflows-sdk");
5
+ exports.transformOrderToCartStep = (0, workflows_sdk_1.createStep)("transform-order-to-cart", async (input) => {
6
+ const { order } = input;
7
+ // Map order items to cart items
8
+ const items = (order.items || []).map((item) => ({
9
+ variant_id: item.variant_id,
10
+ quantity: item.quantity,
11
+ }));
12
+ // Extract billing address
13
+ const billingAddress = order.billing_address
14
+ ? {
15
+ first_name: order.billing_address.first_name,
16
+ last_name: order.billing_address.last_name,
17
+ address_1: order.billing_address.address_1,
18
+ address_2: order.billing_address.address_2,
19
+ city: order.billing_address.city,
20
+ country_code: order.billing_address.country_code,
21
+ province: order.billing_address.province,
22
+ postal_code: order.billing_address.postal_code,
23
+ phone: order.billing_address.phone,
24
+ }
25
+ : undefined;
26
+ // Extract shipping address
27
+ const shippingAddress = order.shipping_address
28
+ ? {
29
+ first_name: order.shipping_address.first_name,
30
+ last_name: order.shipping_address.last_name,
31
+ address_1: order.shipping_address.address_1,
32
+ address_2: order.shipping_address.address_2,
33
+ city: order.shipping_address.city,
34
+ country_code: order.shipping_address.country_code,
35
+ province: order.shipping_address.province,
36
+ postal_code: order.shipping_address.postal_code,
37
+ phone: order.shipping_address.phone,
38
+ }
39
+ : undefined;
40
+ const cartInput = {
41
+ region_id: order.region_id,
42
+ sales_channel_id: order.sales_channel_id,
43
+ customer_id: order.customer_id,
44
+ email: order.email,
45
+ billing_address: billingAddress,
46
+ shipping_address: shippingAddress,
47
+ items,
48
+ };
49
+ return new workflows_sdk_1.StepResponse({
50
+ cartInput,
51
+ });
52
+ });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmb3JtLW9yZGVyLXRvLWNhcnQtc3RlcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy93b3JrZmxvd3Mvc3RlcHMvdHJhbnNmb3JtLW9yZGVyLXRvLWNhcnQtc3RlcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxRUFBNEU7QUEwQy9ELFFBQUEsd0JBQXdCLEdBQUcsSUFBQSwwQkFBVSxFQUNoRCx5QkFBeUIsRUFDekIsS0FBSyxFQUNILEtBQW9DLEVBQ21CLEVBQUU7SUFDekQsTUFBTSxFQUFFLEtBQUssRUFBRSxHQUFHLEtBQUssQ0FBQTtJQUV2QixnQ0FBZ0M7SUFDaEMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMvQyxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7UUFDM0IsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO0tBQ3hCLENBQUMsQ0FBQyxDQUFBO0lBRUgsMEJBQTBCO0lBQzFCLE1BQU0sY0FBYyxHQUFHLEtBQUssQ0FBQyxlQUFlO1FBQzFDLENBQUMsQ0FBQztZQUNFLFVBQVUsRUFBRSxLQUFLLENBQUMsZUFBZSxDQUFDLFVBQVU7WUFDNUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxlQUFlLENBQUMsU0FBUztZQUMxQyxTQUFTLEVBQUUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxTQUFTO1lBQzFDLFNBQVMsRUFBRSxLQUFLLENBQUMsZUFBZSxDQUFDLFNBQVM7WUFDMUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxlQUFlLENBQUMsSUFBSTtZQUNoQyxZQUFZLEVBQUUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxZQUFZO1lBQ2hELFFBQVEsRUFBRSxLQUFLLENBQUMsZUFBZSxDQUFDLFFBQVE7WUFDeEMsV0FBVyxFQUFFLEtBQUssQ0FBQyxlQUFlLENBQUMsV0FBVztZQUM5QyxLQUFLLEVBQUUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxLQUFLO1NBQ25DO1FBQ0gsQ0FBQyxDQUFDLFNBQVMsQ0FBQTtJQUViLDJCQUEyQjtJQUMzQixNQUFNLGVBQWUsR0FBRyxLQUFLLENBQUMsZ0JBQWdCO1FBQzVDLENBQUMsQ0FBQztZQUNFLFVBQVUsRUFBRSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsVUFBVTtZQUM3QyxTQUFTLEVBQUUsS0FBSyxDQUFDLGdCQUFnQixDQUFDLFNBQVM7WUFDM0MsU0FBUyxFQUFFLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTO1lBQzNDLFNBQVMsRUFBRSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsU0FBUztZQUMzQyxJQUFJLEVBQUUsS0FBSyxDQUFDLGdCQUFnQixDQUFDLElBQUk7WUFDakMsWUFBWSxFQUFFLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZO1lBQ2pELFFBQVEsRUFBRSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsUUFBUTtZQUN6QyxXQUFXLEVBQUUsS0FBSyxDQUFDLGdCQUFnQixDQUFDLFdBQVc7WUFDL0MsS0FBSyxFQUFFLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLO1NBQ3BDO1FBQ0gsQ0FBQyxDQUFDLFNBQVMsQ0FBQTtJQUViLE1BQU0sU0FBUyxHQUFnRDtRQUM3RCxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7UUFDMUIsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQjtRQUN4QyxXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7UUFDOUIsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLO1FBQ2xCLGVBQWUsRUFBRSxjQUFjO1FBQy9CLGdCQUFnQixFQUFFLGVBQWU7UUFDakMsS0FBSztLQUNOLENBQUE7SUFFRCxPQUFPLElBQUksNEJBQVksQ0FBaUM7UUFDdEQsU0FBUztLQUNWLENBQUMsQ0FBQTtBQUNKLENBQUMsQ0FDRixDQUFBIn0=
package/README.md CHANGED
@@ -1,78 +1,64 @@
1
- # Order Management Plugin
2
-
3
- A Medusa v2 plugin for automated COD (Cash on Delivery) refund processing with multi-currency support.
4
-
5
- ## Features
6
-
7
- - Automatic COD refund processing when return is marked as "received"
8
- - Multi-currency support (INR, USD, EUR, GBP, etc.)
9
- - Multiple payment methods (UPI, Bank Transfer, Digital Wallets)
10
- - Configurable payment providers (Razorpay, Stripe)
11
- - Customer payment details collection
12
- - Integration with Medusa's built-in refund flow
13
-
14
- ## Quick Start
15
-
16
- ### Installation
17
-
18
- ```bash
19
- npm install order-management
20
- ```
21
-
22
- ### Configuration
23
-
24
- Add to `medusa-config.ts`:
25
-
26
- ```typescript
27
- import { defineConfig } from "@medusajs/framework/utils"
28
-
29
- export default defineConfig({
30
- plugins: [
31
- {
32
- resolve: "order-management",
33
- options: {
34
- refundProviders: {
35
- enabled: ["razorpay", "stripe"],
36
- credentials: {
37
- razorpay: {
38
- keyId: process.env.RAZORPAY_KEY_ID,
39
- keySecret: process.env.RAZORPAY_KEY_SECRET,
40
- },
41
- stripe: {
42
- apiKey: process.env.STRIPE_API_KEY,
43
- },
44
- },
45
- },
46
- },
47
- },
48
- ],
49
- })
50
- ```
51
-
52
- ## Documentation
53
-
54
- For complete implementation guide including:
55
- - Backend setup and configuration
56
- - Frontend integration examples
57
- - API reference
58
- - Complete code examples
59
-
60
- See **[IMPLEMENTATION_GUIDE.md](./IMPLEMENTATION_GUIDE.md)**
61
-
62
- ## How It Works
63
-
64
- 1. Customer creates return request and provides payment details
65
- 2. Admin marks return as "received" in Medusa admin
66
- 3. Plugin automatically:
67
- - Detects COD order
68
- - Processes refund via payment gateway
69
- - Transfers money to customer
70
- - Creates/updates refund record
1
+ <p align="center">
2
+ <a href="https://www.medusajs.com">
3
+ <picture>
4
+ <source media="(prefers-color-scheme: dark)" srcset="https://user-images.githubusercontent.com/59018053/229103275-b5e482bb-4601-46e6-8142-244f531cebdb.svg">
5
+ <source media="(prefers-color-scheme: light)" srcset="https://user-images.githubusercontent.com/59018053/229103726-e5b529a3-9b3f-4970-8a1f-c6af37f087bf.svg">
6
+ <img alt="Medusa logo" src="https://user-images.githubusercontent.com/59018053/229103726-e5b529a3-9b3f-4970-8a1f-c6af37f087bf.svg">
7
+ </picture>
8
+ </a>
9
+ </p>
10
+ <h1 align="center">
11
+ Medusa Plugin Starter
12
+ </h1>
13
+
14
+ <h4 align="center">
15
+ <a href="https://docs.medusajs.com">Documentation</a> |
16
+ <a href="https://www.medusajs.com">Website</a>
17
+ </h4>
18
+
19
+ <p align="center">
20
+ Building blocks for digital commerce
21
+ </p>
22
+ <p align="center">
23
+ <a href="https://github.com/medusajs/medusa/blob/master/CONTRIBUTING.md">
24
+ <img src="https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat" alt="PRs welcome!" />
25
+ </a>
26
+ <a href="https://www.producthunt.com/posts/medusa"><img src="https://img.shields.io/badge/Product%20Hunt-%231%20Product%20of%20the%20Day-%23DA552E" alt="Product Hunt"></a>
27
+ <a href="https://discord.gg/xpCwq3Kfn8">
28
+ <img src="https://img.shields.io/badge/chat-on%20discord-7289DA.svg" alt="Discord Chat" />
29
+ </a>
30
+ <a href="https://twitter.com/intent/follow?screen_name=medusajs">
31
+ <img src="https://img.shields.io/twitter/follow/medusajs.svg?label=Follow%20@medusajs" alt="Follow @medusajs" />
32
+ </a>
33
+ </p>
71
34
 
72
35
  ## Compatibility
73
36
 
74
- Compatible with Medusa v2.4.0 and above.
37
+ This starter is compatible with versions >= 2.4.0 of `@medusajs/medusa`.
75
38
 
76
- ## License
39
+ ## Getting Started
77
40
 
78
- MIT
41
+ Visit the [Quickstart Guide](https://docs.medusajs.com/learn/installation) to set up a server.
42
+
43
+ Visit the [Plugins documentation](https://docs.medusajs.com/learn/fundamentals/plugins) to learn more about plugins and how to create them.
44
+
45
+ Visit the [Docs](https://docs.medusajs.com/learn/installation#get-started) to learn more about our system requirements.
46
+
47
+ ## What is Medusa
48
+
49
+ Medusa is a set of commerce modules and tools that allow you to build rich, reliable, and performant commerce applications without reinventing core commerce logic. The modules can be customized and used to build advanced ecommerce stores, marketplaces, or any product that needs foundational commerce primitives. All modules are open-source and freely available on npm.
50
+
51
+ Learn more about [Medusa’s architecture](https://docs.medusajs.com/learn/introduction/architecture) and [commerce modules](https://docs.medusajs.com/learn/fundamentals/modules/commerce-modules) in the Docs.
52
+
53
+ ## Community & Contributions
54
+
55
+ The community and core team are available in [GitHub Discussions](https://github.com/medusajs/medusa/discussions), where you can ask for support, discuss roadmap, and share ideas.
56
+
57
+ Join our [Discord server](https://discord.com/invite/medusajs) to meet other community members.
58
+
59
+ ## Other channels
60
+
61
+ - [GitHub Issues](https://github.com/medusajs/medusa/issues)
62
+ - [Twitter](https://twitter.com/medusajs)
63
+ - [LinkedIn](https://www.linkedin.com/company/medusajs)
64
+ - [Medusa Blog](https://medusajs.com/blog/)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "order-management",
3
- "version": "0.0.2",
3
+ "version": "0.0.4",
4
4
  "description": "A starter for Medusa plugins.",
5
5
  "author": "Medusa (https://medusajs.com)",
6
6
  "license": "MIT",
@@ -1,84 +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 = 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
- * Helper function to find return by ID
12
- * Reused from payment-details route - consider extracting to shared utility
13
- */
14
- async function findReturnById(orderService, returnId) {
15
- try {
16
- const orders = await orderService.listOrders({});
17
- for (const order of orders) {
18
- const orderWithReturns = order;
19
- const returns = orderWithReturns.returns || [];
20
- const returnRecord = returns.find((ret) => ret.id === returnId);
21
- if (returnRecord) {
22
- return returnRecord;
23
- }
24
- }
25
- }
26
- catch (error) {
27
- console.error("Error finding return:", error);
28
- }
29
- return null;
30
- }
31
- /**
32
- * Admin API endpoint to retry a failed refund
33
- *
34
- * POST /admin/returns/[id]/retry-refund
35
- *
36
- * Retries processing a refund for a return that previously failed.
37
- * Increments retry_count and attempts payment processing again.
38
- */
39
- const POST = async (req, res) => {
40
- const { id: return_id } = req.params;
41
- if (!return_id) {
42
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "Return ID is required");
43
- }
44
- const orderService = req.scope.resolve(utils_2.Modules.ORDER);
45
- // Find return to get order_id
46
- const returnRecord = await findReturnById(orderService, return_id);
47
- if (!returnRecord) {
48
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.NOT_FOUND, `Return with ID ${return_id} not found`);
49
- }
50
- const orderId = returnRecord.order_id;
51
- if (!orderId) {
52
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Return ${return_id} does not have an associated order_id`);
53
- }
54
- // Execute refund workflow (will handle retry logic internally)
55
- try {
56
- const { result } = await (0, process_cod_refund_workflow_1.default)(req.scope).run({
57
- input: {
58
- return_id,
59
- order_id: orderId,
60
- },
61
- });
62
- return res.json({
63
- success: true,
64
- message: "Refund retry initiated successfully",
65
- refund_id: result.refund_id,
66
- amount: result.amount,
67
- currency_code: result.currency_code,
68
- order_id: result.order_id,
69
- });
70
- }
71
- catch (error) {
72
- const errorMessage = error instanceof Error ? error.message : "Unknown error";
73
- // Return error response instead of throwing to provide better API response
74
- return res.status(500).json({
75
- success: false,
76
- message: "Refund retry failed",
77
- error: errorMessage,
78
- return_id,
79
- order_id: orderId,
80
- });
81
- }
82
- };
83
- exports.POST = POST;
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL2FkbWluL3JldHVybnMvW2lkXS9yZXRyeS1yZWZ1bmQvcm91dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EscURBQXVEO0FBQ3ZELHFEQUFtRDtBQUVuRCx1SEFBMkY7QUFFM0Y7OztHQUdHO0FBQ0gsS0FBSyxVQUFVLGNBQWMsQ0FDM0IsWUFBaUMsRUFDakMsUUFBZ0I7SUFFaEIsSUFBSSxDQUFDO1FBQ0gsTUFBTSxNQUFNLEdBQUcsTUFBTSxZQUFZLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxDQUFBO1FBRWhELEtBQUssTUFBTSxLQUFLLElBQUksTUFBTSxFQUFFLENBQUM7WUFDM0IsTUFBTSxnQkFBZ0IsR0FBRyxLQUEyQyxDQUFBO1lBQ3BFLE1BQU0sT0FBTyxHQUFJLGdCQUFnQixDQUFDLE9BQXFCLElBQUksRUFBRSxDQUFBO1lBQzdELE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQy9CLENBQUMsR0FBbUIsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsS0FBSyxRQUFRLENBQzdDLENBQUE7WUFDRCxJQUFJLFlBQVksRUFBRSxDQUFDO2dCQUNqQixPQUFPLFlBQVksQ0FBQTtZQUNyQixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEtBQUssQ0FBQyx1QkFBdUIsRUFBRSxLQUFLLENBQUMsQ0FBQTtJQUMvQyxDQUFDO0lBRUQsT0FBTyxJQUFJLENBQUE7QUFDYixDQUFDO0FBRUQ7Ozs7Ozs7R0FPRztBQUNJLE1BQU0sSUFBSSxHQUFHLEtBQUssRUFDdkIsR0FBa0IsRUFDbEIsR0FBbUIsRUFDbkIsRUFBRTtJQUNGLE1BQU0sRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQTtJQUVwQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDZixNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5Qix1QkFBdUIsQ0FDeEIsQ0FBQTtJQUNILENBQUM7SUFFRCxNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBc0IsZUFBTyxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBRTFFLDhCQUE4QjtJQUM5QixNQUFNLFlBQVksR0FBRyxNQUFNLGNBQWMsQ0FBQyxZQUFZLEVBQUUsU0FBUyxDQUFDLENBQUE7SUFFbEUsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ2xCLE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQzNCLGtCQUFrQixTQUFTLFlBQVksQ0FDeEMsQ0FBQTtJQUNILENBQUM7SUFFRCxNQUFNLE9BQU8sR0FBSSxZQUFxQyxDQUFDLFFBQVEsQ0FBQTtJQUUvRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDYixNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5QixVQUFVLFNBQVMsdUNBQXVDLENBQzNELENBQUE7SUFDSCxDQUFDO0lBRUQsK0RBQStEO0lBQy9ELElBQUksQ0FBQztRQUNILE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLElBQUEscUNBQXdCLEVBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsQ0FBQztZQUMvRCxLQUFLLEVBQUU7Z0JBQ0wsU0FBUztnQkFDVCxRQUFRLEVBQUUsT0FBTzthQUNsQjtTQUNGLENBQUMsQ0FBQTtRQUVGLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQztZQUNkLE9BQU8sRUFBRSxJQUFJO1lBQ2IsT0FBTyxFQUFFLHFDQUFxQztZQUM5QyxTQUFTLEVBQUUsTUFBTSxDQUFDLFNBQVM7WUFDM0IsTUFBTSxFQUFFLE1BQU0sQ0FBQyxNQUFNO1lBQ3JCLGFBQWEsRUFBRSxNQUFNLENBQUMsYUFBYTtZQUNuQyxRQUFRLEVBQUUsTUFBTSxDQUFDLFFBQVE7U0FDMUIsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUFDLE9BQU8sS0FBSyxFQUFFLENBQUM7UUFDZixNQUFNLFlBQVksR0FDaEIsS0FBSyxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsZUFBZSxDQUFBO1FBRTFELDJFQUEyRTtRQUMzRSxPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDO1lBQzFCLE9BQU8sRUFBRSxLQUFLO1lBQ2QsT0FBTyxFQUFFLHFCQUFxQjtZQUM5QixLQUFLLEVBQUUsWUFBWTtZQUNuQixTQUFTO1lBQ1QsUUFBUSxFQUFFLE9BQU87U0FDbEIsQ0FBQyxDQUFBO0lBQ0osQ0FBQztBQUNILENBQUMsQ0FBQTtBQWhFWSxRQUFBLElBQUksUUFnRWhCIn0=