medusa-contact-us 0.0.11 → 0.0.20
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.
- package/.medusa/server/src/admin/index.js +4 -494
- package/.medusa/server/src/admin/index.mjs +6 -496
- package/.medusa/server/src/api/admin/contact-email-subscriptions/route.js +3 -3
- package/.medusa/server/src/api/admin/contact-requests/[id]/route.js +10 -34
- package/.medusa/server/src/api/admin/contact-requests/[id]/status/route.js +24 -0
- package/.medusa/server/src/api/admin/contact-requests/route.js +47 -11
- package/.medusa/server/src/api/admin/contact-requests/validators.js +22 -12
- package/.medusa/server/src/api/store/contact-email-subscriptions/route.js +3 -3
- package/.medusa/server/src/api/store/contact-email-subscriptions/validators.js +2 -2
- package/.medusa/server/src/api/store/contact-requests/route.js +4 -10
- package/.medusa/server/src/api/store/contact-requests/validators.js +4 -8
- package/.medusa/server/src/constants.js +10 -4
- package/.medusa/server/src/helpers/contact-request.js +52 -0
- package/.medusa/server/src/helpers/contact-subscription.js +15 -4
- package/.medusa/server/src/helpers/index.js +5 -4
- package/.medusa/server/src/index.js +16 -13
- package/.medusa/server/src/modules/contact-requests/index.js +4 -5
- package/.medusa/server/src/modules/contact-requests/migrations/Migration20241129163317.js +47 -0
- package/.medusa/server/src/modules/contact-requests/models/contact-request.js +4 -3
- package/.medusa/server/src/modules/contact-requests/service.js +191 -141
- package/.medusa/server/src/modules/contact-requests/utils/resolve-options.js +48 -0
- package/.medusa/server/src/modules/contact-subscriptions/index.js +4 -5
- package/.medusa/server/src/modules/contact-subscriptions/service.js +20 -12
- package/.medusa/server/src/types/contact-request.js +3 -0
- package/.medusa/server/src/types.js +1 -208
- package/.medusa/server/src/workflows/create-contact-request-workflow.js +13 -0
- package/.medusa/server/src/workflows/index.js +5 -5
- package/.medusa/server/src/workflows/steps/create-contact-request-step.js +3 -7
- package/.medusa/server/src/workflows/steps/resolve-status-transition-step.js +15 -0
- package/.medusa/server/src/workflows/steps/send-status-notification-step.js +56 -0
- package/.medusa/server/src/workflows/steps/update-contact-request-status-step.js +7 -7
- package/.medusa/server/src/workflows/update-contact-request-status-workflow.js +33 -0
- package/README.md +329 -211
- package/package.json +2 -2
- package/.medusa/server/src/api/admin/contact-requests/[id]/comments/route.js +0 -22
- package/.medusa/server/src/api/admin/plugin/route.js +0 -11
- package/.medusa/server/src/api/store/plugin/route.js +0 -11
- package/.medusa/server/src/helpers/__tests__/submit-contact-request.test.js +0 -125
- package/.medusa/server/src/helpers/submit-contact-request.js +0 -45
- package/.medusa/server/src/modules/contact-requests/migrations/Migration20241124090000.js +0 -51
- package/.medusa/server/src/modules/contact-requests/models/contact-request-comment.js +0 -11
- package/.medusa/server/src/plugin-options.js +0 -16
- package/.medusa/server/src/types/__tests__/contact-options.test.js +0 -83
- package/.medusa/server/src/utils/__tests__/payload-validator.test.js +0 -81
- package/.medusa/server/src/utils/payload.js +0 -127
- package/.medusa/server/src/workflows/create-contact-request.js +0 -30
- package/.medusa/server/src/workflows/steps/send-contact-notification-step.js +0 -48
- package/.medusa/server/src/workflows/update-contact-request-status.js +0 -32
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "medusa-contact-us",
|
|
3
|
-
"version": "0.0.
|
|
4
|
-
"description": "
|
|
3
|
+
"version": "0.0.20",
|
|
4
|
+
"description": "Manage storefront email subscriptions (opt-ins and opt-outs) in Medusa Admin.",
|
|
5
5
|
"author": "Medusa (https://medusajs.com)",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"files": [
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.POST = void 0;
|
|
4
|
-
const constants_1 = require("../../../../../constants");
|
|
5
|
-
const validators_1 = require("../../validators");
|
|
6
|
-
const POST = async (req, res) => {
|
|
7
|
-
const body = validators_1.AdminAddCommentSchema.parse(req.body ?? {});
|
|
8
|
-
const service = req.scope.resolve(constants_1.CONTACT_REQUEST_MODULE);
|
|
9
|
-
const actorId = req.auth_context?.actor_id ||
|
|
10
|
-
req.auth_context?.user_id ||
|
|
11
|
-
"admin";
|
|
12
|
-
const comment = await service.addComment({
|
|
13
|
-
request_id: req.params.id,
|
|
14
|
-
comment: body.comment,
|
|
15
|
-
actor_id: actorId,
|
|
16
|
-
});
|
|
17
|
-
res.status(201).json({
|
|
18
|
-
comment,
|
|
19
|
-
});
|
|
20
|
-
};
|
|
21
|
-
exports.POST = POST;
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL2FkbWluL2NvbnRhY3QtcmVxdWVzdHMvW2lkXS9jb21tZW50cy9yb3V0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSx3REFBaUU7QUFFakUsaURBQXdEO0FBRWpELE1BQU0sSUFBSSxHQUFHLEtBQUssRUFBRSxHQUFrQixFQUFFLEdBQW1CLEVBQUUsRUFBRTtJQUNwRSxNQUFNLElBQUksR0FBRyxrQ0FBcUIsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQTtJQUN4RCxNQUFNLE9BQU8sR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FDL0Isa0NBQXNCLENBQ3ZCLENBQUE7SUFDRCxNQUFNLE9BQU8sR0FDVixHQUFXLENBQUMsWUFBWSxFQUFFLFFBQVE7UUFDbEMsR0FBVyxDQUFDLFlBQVksRUFBRSxPQUFPO1FBQ2xDLE9BQU8sQ0FBQTtJQUVULE1BQU0sT0FBTyxHQUFHLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQztRQUN2QyxVQUFVLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1FBQ3pCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztRQUNyQixRQUFRLEVBQUUsT0FBTztLQUNsQixDQUFDLENBQUE7SUFFRixHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQztRQUNuQixPQUFPO0tBQ1IsQ0FBQyxDQUFBO0FBQ0osQ0FBQyxDQUFBO0FBbkJZLFFBQUEsSUFBSSxRQW1CaEIifQ==
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.GET = GET;
|
|
4
|
-
const constants_1 = require("../../../constants");
|
|
5
|
-
async function GET(req, res) {
|
|
6
|
-
const service = req.scope.resolve(constants_1.CONTACT_REQUEST_MODULE);
|
|
7
|
-
res.status(200).json({
|
|
8
|
-
contact_us: service.getOptions(),
|
|
9
|
-
});
|
|
10
|
-
}
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL2FkbWluL3BsdWdpbi9yb3V0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUlBLGtCQVdDO0FBZEQsa0RBQTJEO0FBR3BELEtBQUssVUFBVSxHQUFHLENBQ3ZCLEdBQWtCLEVBQ2xCLEdBQW1CO0lBRW5CLE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUMvQixrQ0FBc0IsQ0FDdkIsQ0FBQTtJQUVELEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQ25CLFVBQVUsRUFBRSxPQUFPLENBQUMsVUFBVSxFQUFFO0tBQ2pDLENBQUMsQ0FBQTtBQUNKLENBQUMifQ==
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.GET = GET;
|
|
4
|
-
const constants_1 = require("../../../constants");
|
|
5
|
-
async function GET(req, res) {
|
|
6
|
-
const service = req.scope.resolve(constants_1.CONTACT_REQUEST_MODULE);
|
|
7
|
-
res.status(200).json({
|
|
8
|
-
contact_us: service.getOptions(),
|
|
9
|
-
});
|
|
10
|
-
}
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL3N0b3JlL3BsdWdpbi9yb3V0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUlBLGtCQVdDO0FBZEQsa0RBQTJEO0FBR3BELEtBQUssVUFBVSxHQUFHLENBQ3ZCLEdBQWtCLEVBQ2xCLEdBQW1CO0lBRW5CLE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUMvQixrQ0FBc0IsQ0FDdkIsQ0FBQTtJQUVELEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQ25CLFVBQVUsRUFBRSxPQUFPLENBQUMsVUFBVSxFQUFFO0tBQ2pDLENBQUMsQ0FBQTtBQUNKLENBQUMifQ==
|
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const vitest_1 = require("vitest");
|
|
4
|
-
const submit_contact_request_1 = require("../submit-contact-request");
|
|
5
|
-
const buildPayload = () => ({
|
|
6
|
-
email: "test@example.com",
|
|
7
|
-
payload: { subject: "Need help" },
|
|
8
|
-
metadata: { store_id: "store" },
|
|
9
|
-
source: "storefront",
|
|
10
|
-
});
|
|
11
|
-
(0, vitest_1.describe)("submitContactRequest helper", () => {
|
|
12
|
-
const fetchCases = [
|
|
13
|
-
{
|
|
14
|
-
name: "uses provided fetch implementation when no client exists",
|
|
15
|
-
setup: () => {
|
|
16
|
-
const mockFetch = vitest_1.vi.fn().mockResolvedValue({
|
|
17
|
-
ok: true,
|
|
18
|
-
json: () => Promise.resolve({
|
|
19
|
-
contact_request: { id: "req_1" },
|
|
20
|
-
}),
|
|
21
|
-
});
|
|
22
|
-
return {
|
|
23
|
-
fetchImpl: mockFetch,
|
|
24
|
-
expectedUrl: "https://demo.store/store/contact-requests",
|
|
25
|
-
};
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
{
|
|
29
|
-
name: "throws when response is not ok",
|
|
30
|
-
setup: () => {
|
|
31
|
-
const mockFetch = vitest_1.vi.fn().mockResolvedValue({
|
|
32
|
-
ok: false,
|
|
33
|
-
status: 500,
|
|
34
|
-
text: () => Promise.resolve("boom"),
|
|
35
|
-
});
|
|
36
|
-
return {
|
|
37
|
-
fetchImpl: mockFetch,
|
|
38
|
-
expectedError: /boom/i,
|
|
39
|
-
};
|
|
40
|
-
},
|
|
41
|
-
},
|
|
42
|
-
];
|
|
43
|
-
fetchCases.forEach(({ name, setup }) => {
|
|
44
|
-
(0, vitest_1.it)(name, async () => {
|
|
45
|
-
const config = setup();
|
|
46
|
-
const { fetchImpl } = config;
|
|
47
|
-
if ("expectedError" in config) {
|
|
48
|
-
await (0, vitest_1.expect)((0, submit_contact_request_1.submitContactRequest)(buildPayload(), {
|
|
49
|
-
fetchImpl,
|
|
50
|
-
baseUrl: "https://demo.store",
|
|
51
|
-
})).rejects.toMatchObject({
|
|
52
|
-
message: vitest_1.expect.stringMatching(config.expectedError),
|
|
53
|
-
});
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
const result = await (0, submit_contact_request_1.submitContactRequest)(buildPayload(), {
|
|
57
|
-
fetchImpl,
|
|
58
|
-
baseUrl: "https://demo.store",
|
|
59
|
-
});
|
|
60
|
-
(0, vitest_1.expect)(result).toEqual({ contact_request: { id: "req_1" } });
|
|
61
|
-
(0, vitest_1.expect)(fetchImpl).toHaveBeenCalledWith(config.expectedUrl, vitest_1.expect.anything());
|
|
62
|
-
});
|
|
63
|
-
});
|
|
64
|
-
(0, vitest_1.it)("uses medusa client when provided", async () => {
|
|
65
|
-
const mockClient = {
|
|
66
|
-
request: vitest_1.vi.fn().mockResolvedValue({
|
|
67
|
-
contact_request: { id: "req_2" },
|
|
68
|
-
}),
|
|
69
|
-
};
|
|
70
|
-
const result = await (0, submit_contact_request_1.submitContactRequest)(buildPayload(), {
|
|
71
|
-
client: mockClient,
|
|
72
|
-
});
|
|
73
|
-
(0, vitest_1.expect)(result.contact_request.id).toBe("req_2");
|
|
74
|
-
(0, vitest_1.expect)(mockClient.request).toHaveBeenCalledWith("/store/contact-requests", vitest_1.expect.objectContaining({
|
|
75
|
-
method: "POST",
|
|
76
|
-
}));
|
|
77
|
-
});
|
|
78
|
-
(0, vitest_1.it)("applies publishable API key to fetch headers", async () => {
|
|
79
|
-
const mockFetch = vitest_1.vi.fn().mockResolvedValue({
|
|
80
|
-
ok: true,
|
|
81
|
-
json: () => Promise.resolve({
|
|
82
|
-
contact_request: { id: "req_4" },
|
|
83
|
-
}),
|
|
84
|
-
});
|
|
85
|
-
await (0, submit_contact_request_1.submitContactRequest)(buildPayload(), {
|
|
86
|
-
fetchImpl: mockFetch,
|
|
87
|
-
baseUrl: "https://demo.store",
|
|
88
|
-
publishableApiKey: "pk_test_header",
|
|
89
|
-
});
|
|
90
|
-
const [, init] = mockFetch.mock.calls[0];
|
|
91
|
-
(0, vitest_1.expect)(init?.headers).toMatchObject({
|
|
92
|
-
"x-publishable-api-key": "pk_test_header",
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
(0, vitest_1.it)("applies publishable API key when invoking client request", async () => {
|
|
96
|
-
const mockClient = {
|
|
97
|
-
request: vitest_1.vi.fn().mockResolvedValue({
|
|
98
|
-
contact_request: { id: "req_5" },
|
|
99
|
-
}),
|
|
100
|
-
};
|
|
101
|
-
await (0, submit_contact_request_1.submitContactRequest)(buildPayload(), {
|
|
102
|
-
client: mockClient,
|
|
103
|
-
publishableApiKey: "pk_client",
|
|
104
|
-
});
|
|
105
|
-
const [, init] = mockClient.request.mock.calls[0];
|
|
106
|
-
(0, vitest_1.expect)(init?.headers).toMatchObject({
|
|
107
|
-
"x-publishable-api-key": "pk_client",
|
|
108
|
-
});
|
|
109
|
-
});
|
|
110
|
-
(0, vitest_1.it)("allows preconfigured helper via factory", async () => {
|
|
111
|
-
const mockFetch = vitest_1.vi.fn().mockResolvedValue({
|
|
112
|
-
ok: true,
|
|
113
|
-
json: () => Promise.resolve({
|
|
114
|
-
contact_request: { id: "req_3" },
|
|
115
|
-
}),
|
|
116
|
-
});
|
|
117
|
-
const submit = (0, submit_contact_request_1.createSubmitContactRequest)({
|
|
118
|
-
fetchImpl: mockFetch,
|
|
119
|
-
baseUrl: "https://demo.store",
|
|
120
|
-
});
|
|
121
|
-
const result = await submit(buildPayload());
|
|
122
|
-
(0, vitest_1.expect)(result.contact_request.id).toBe("req_3");
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VibWl0LWNvbnRhY3QtcmVxdWVzdC50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2hlbHBlcnMvX190ZXN0c19fL3N1Ym1pdC1jb250YWN0LXJlcXVlc3QudGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG1DQUFpRDtBQUNqRCxzRUFHa0M7QUFFbEMsTUFBTSxZQUFZLEdBQUcsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUMxQixLQUFLLEVBQUUsa0JBQWtCO0lBQ3pCLE9BQU8sRUFBRSxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUU7SUFDakMsUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRTtJQUMvQixNQUFNLEVBQUUsWUFBWTtDQUNyQixDQUFDLENBQUE7QUFFRixJQUFBLGlCQUFRLEVBQUMsNkJBQTZCLEVBQUUsR0FBRyxFQUFFO0lBQzNDLE1BQU0sVUFBVSxHQUFHO1FBQ2pCO1lBQ0UsSUFBSSxFQUFFLDBEQUEwRDtZQUNoRSxLQUFLLEVBQUUsR0FBRyxFQUFFO2dCQUNWLE1BQU0sU0FBUyxHQUFHLFdBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDMUMsRUFBRSxFQUFFLElBQUk7b0JBQ1IsSUFBSSxFQUFFLEdBQUcsRUFBRSxDQUNULE9BQU8sQ0FBQyxPQUFPLENBQUM7d0JBQ2QsZUFBZSxFQUFFLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRTtxQkFDakMsQ0FBQztpQkFDTCxDQUFDLENBQUE7Z0JBQ0YsT0FBTztvQkFDTCxTQUFTLEVBQUUsU0FBUztvQkFDcEIsV0FBVyxFQUFFLDJDQUEyQztpQkFDekQsQ0FBQTtZQUNILENBQUM7U0FDRjtRQUNEO1lBQ0UsSUFBSSxFQUFFLGdDQUFnQztZQUN0QyxLQUFLLEVBQUUsR0FBRyxFQUFFO2dCQUNWLE1BQU0sU0FBUyxHQUFHLFdBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFD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
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createSubmitContactRequest = exports.submitContactRequest = void 0;
|
|
4
|
-
const base_client_1 = require("./base-client");
|
|
5
|
-
const CONTACT_ENDPOINT = "/store/contact-requests";
|
|
6
|
-
const resolveEndpoint = (endpoint) => endpoint?.startsWith("/") ? endpoint : CONTACT_ENDPOINT;
|
|
7
|
-
const submitContactRequest = async (input, options = {}) => {
|
|
8
|
-
const endpoint = resolveEndpoint(input.endpoint);
|
|
9
|
-
const payload = {
|
|
10
|
-
email: input.email,
|
|
11
|
-
payload: input.payload ?? {},
|
|
12
|
-
metadata: input.metadata,
|
|
13
|
-
source: input.source,
|
|
14
|
-
};
|
|
15
|
-
const clientRequest = (0, base_client_1.getClientRequest)(options.client);
|
|
16
|
-
if (clientRequest) {
|
|
17
|
-
const headers = (0, base_client_1.buildHeaders)(options);
|
|
18
|
-
const raw = (await clientRequest(endpoint, {
|
|
19
|
-
method: "POST",
|
|
20
|
-
body: JSON.stringify(payload),
|
|
21
|
-
headers,
|
|
22
|
-
}));
|
|
23
|
-
return raw;
|
|
24
|
-
}
|
|
25
|
-
const fetchImpl = options.fetchImpl ?? globalThis.fetch;
|
|
26
|
-
if (!fetchImpl) {
|
|
27
|
-
throw new Error("No fetch implementation available. Provide `fetchImpl` or a Medusa client.");
|
|
28
|
-
}
|
|
29
|
-
const url = `${(0, base_client_1.normalizeBaseUrl)(options.baseUrl)}${endpoint}`;
|
|
30
|
-
const headers = (0, base_client_1.buildHeaders)(options);
|
|
31
|
-
const response = await fetchImpl(url || endpoint, {
|
|
32
|
-
method: "POST",
|
|
33
|
-
headers,
|
|
34
|
-
body: JSON.stringify(payload),
|
|
35
|
-
});
|
|
36
|
-
if (!response.ok) {
|
|
37
|
-
const body = await response.text();
|
|
38
|
-
throw new Error(body || `Failed to submit contact request (status ${response.status})`);
|
|
39
|
-
}
|
|
40
|
-
return (await response.json());
|
|
41
|
-
};
|
|
42
|
-
exports.submitContactRequest = submitContactRequest;
|
|
43
|
-
const createSubmitContactRequest = (options = {}) => (input) => (0, exports.submitContactRequest)(input, options);
|
|
44
|
-
exports.createSubmitContactRequest = createSubmitContactRequest;
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VibWl0LWNvbnRhY3QtcmVxdWVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9oZWxwZXJzL3N1Ym1pdC1jb250YWN0LXJlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsK0NBS3NCO0FBRXRCLE1BQU0sZ0JBQWdCLEdBQUcseUJBQXlCLENBQUE7QUFZbEQsTUFBTSxlQUFlLEdBQUcsQ0FBQyxRQUFpQixFQUFFLEVBQUUsQ0FDNUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQTtBQUVsRCxNQUFNLG9CQUFvQixHQUFHLEtBQUssRUFDdkMsS0FBZ0MsRUFDaEMsVUFBdUMsRUFBRSxFQUNGLEVBQUU7SUFDekMsTUFBTSxRQUFRLEdBQUcsZUFBZSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTtJQUNoRCxNQUFNLE9BQU8sR0FBRztRQUNkLEtBQUssRUFBRSxLQUFLLENBQUMsS0FBSztRQUNsQixPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU8sSUFBSSxFQUFFO1FBQzVCLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUTtRQUN4QixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07S0FDckIsQ0FBQTtJQUVELE1BQU0sYUFBYSxHQUFHLElBQUEsOEJBQWdCLEVBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ3RELElBQUksYUFBYSxFQUFFLENBQUM7UUFDbEIsTUFBTSxPQUFPLEdBQUcsSUFBQSwwQkFBWSxFQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQ3JDLE1BQU0sR0FBRyxHQUFHLENBQUMsTUFBTSxhQUFhLENBQUMsUUFBUSxFQUFFO1lBQ3pDLE1BQU0sRUFBRSxNQUFNO1lBQ2QsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDO1lBQzdCLE9BQU87U0FDUixDQUFDLENBQWlDLENBQUE7UUFFbkMsT0FBTyxHQUFHLENBQUE7SUFDWixDQUFDO0lBRUQsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLFNBQVMsSUFBSSxVQUFVLENBQUMsS0FBSyxDQUFBO0lBQ3ZELElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNmLE1BQU0sSUFBSSxLQUFLLENBQ2IsNEVBQTRFLENBQzdFLENBQUE7SUFDSCxDQUFDO0lBRUQsTUFBTSxHQUFHLEdBQUcsR0FBRyxJQUFBLDhCQUFnQixFQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxRQUFRLEVBQUUsQ0FBQTtJQUM3RCxNQUFNLE9BQU8sR0FBRyxJQUFBLDBCQUFZLEVBQUMsT0FBTyxDQUFDLENBQUE7SUFFckMsTUFBTSxRQUFRLEdBQUcsTUFBTSxTQUFTLENBQUMsR0FBRyxJQUFJLFFBQVEsRUFBRTtRQUNoRCxNQUFNLEVBQUUsTUFBTTtRQUNkLE9BQU87UUFDUCxJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7S0FDOUIsQ0FBQyxDQUFBO0lBRUYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUNqQixNQUFNLElBQUksR0FBRyxNQUFNLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQTtRQUNsQyxNQUFNLElBQUksS0FBSyxDQUNiLElBQUksSUFBSSw0Q0FBNEMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUN2RSxDQUFBO0lBQ0gsQ0FBQztJQUVELE9BQU8sQ0FBQyxNQUFNLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBaUMsQ0FBQTtBQUNoRSxDQUFDLENBQUE7QUFoRFksUUFBQSxvQkFBb0Isd0JBZ0RoQztBQUVNLE1BQU0sMEJBQTBCLEdBQ3JDLENBQUMsVUFBdUMsRUFBRSxFQUFFLEVBQUUsQ0FDOUMsQ0FBQyxLQUFnQyxFQUFFLEVBQUUsQ0FDbkMsSUFBQSw0QkFBb0IsRUFBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUE7QUFIM0IsUUFBQSwwQkFBMEIsOEJBR0MifQ==
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Migration20241124090000 = void 0;
|
|
4
|
-
const migrations_1 = require("@mikro-orm/migrations");
|
|
5
|
-
class Migration20241124090000 extends migrations_1.Migration {
|
|
6
|
-
async up() {
|
|
7
|
-
this.addSql(`
|
|
8
|
-
CREATE TABLE IF NOT EXISTS "contact_request" (
|
|
9
|
-
"id" text PRIMARY KEY,
|
|
10
|
-
"email" text NOT NULL,
|
|
11
|
-
"payload" jsonb NOT NULL DEFAULT '{}'::jsonb,
|
|
12
|
-
"status" text NOT NULL,
|
|
13
|
-
"status_history" jsonb NOT NULL DEFAULT '[]'::jsonb,
|
|
14
|
-
"metadata" jsonb NULL,
|
|
15
|
-
"source" text NULL,
|
|
16
|
-
"created_at" timestamptz NOT NULL DEFAULT now(),
|
|
17
|
-
"updated_at" timestamptz NOT NULL DEFAULT now(),
|
|
18
|
-
"deleted_at" timestamptz NULL
|
|
19
|
-
);
|
|
20
|
-
`);
|
|
21
|
-
this.addSql(`
|
|
22
|
-
CREATE INDEX IF NOT EXISTS "IDX_contact_request_email" ON "contact_request" ("email");
|
|
23
|
-
`);
|
|
24
|
-
this.addSql(`
|
|
25
|
-
CREATE INDEX IF NOT EXISTS "IDX_contact_request_status" ON "contact_request" ("status");
|
|
26
|
-
`);
|
|
27
|
-
this.addSql(`
|
|
28
|
-
CREATE TABLE IF NOT EXISTS "contact_request_comment" (
|
|
29
|
-
"id" text PRIMARY KEY,
|
|
30
|
-
"contact_request_id" text NOT NULL REFERENCES "contact_request" ("id") ON DELETE CASCADE,
|
|
31
|
-
"actor_id" text NULL,
|
|
32
|
-
"comment" text NOT NULL,
|
|
33
|
-
"created_at" timestamptz NOT NULL DEFAULT now()
|
|
34
|
-
);
|
|
35
|
-
`);
|
|
36
|
-
this.addSql(`
|
|
37
|
-
CREATE INDEX IF NOT EXISTS "IDX_contact_request_comment_request_id"
|
|
38
|
-
ON "contact_request_comment" ("contact_request_id");
|
|
39
|
-
`);
|
|
40
|
-
this.addSql(`
|
|
41
|
-
CREATE INDEX IF NOT EXISTS "IDX_contact_request_deleted_at"
|
|
42
|
-
ON "contact_request" ("deleted_at");
|
|
43
|
-
`);
|
|
44
|
-
}
|
|
45
|
-
async down() {
|
|
46
|
-
this.addSql(`DROP TABLE IF EXISTS "contact_request_comment";`);
|
|
47
|
-
this.addSql(`DROP TABLE IF EXISTS "contact_request";`);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
exports.Migration20241124090000 = Migration20241124090000;
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWlncmF0aW9uMjAyNDExMjQwOTAwMDAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbW9kdWxlcy9jb250YWN0LXJlcXVlc3RzL21pZ3JhdGlvbnMvTWlncmF0aW9uMjAyNDExMjQwOTAwMDAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsc0RBQWlEO0FBRWpELE1BQWEsdUJBQXdCLFNBQVEsc0JBQVM7SUFDcEQsS0FBSyxDQUFDLEVBQUU7UUFDTixJQUFJLENBQUMsTUFBTSxDQUFDOzs7Ozs7Ozs7Ozs7O0tBYVgsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLE1BQU0sQ0FBQzs7S0FFWCxDQUFDLENBQUE7UUFFRixJQUFJLENBQUMsTUFBTSxDQUFDOztLQUVYLENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxNQUFNLENBQUM7Ozs7Ozs7O0tBUVgsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLE1BQU0sQ0FBQzs7O0tBR1gsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLE1BQU0sQ0FBQzs7O0tBR1gsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVELEtBQUssQ0FBQyxJQUFJO1FBQ1IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxpREFBaUQsQ0FBQyxDQUFBO1FBQzlELElBQUksQ0FBQyxNQUFNLENBQUMseUNBQXlDLENBQUMsQ0FBQTtJQUN4RCxDQUFDO0NBQ0Y7QUFsREQsMERBa0RDIn0=
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ContactRequestComment = void 0;
|
|
4
|
-
const utils_1 = require("@medusajs/framework/utils");
|
|
5
|
-
exports.ContactRequestComment = utils_1.model.define("contact_request_comment", {
|
|
6
|
-
id: utils_1.model.id().primaryKey(),
|
|
7
|
-
contact_request_id: utils_1.model.text().searchable(),
|
|
8
|
-
actor_id: utils_1.model.text().nullable(),
|
|
9
|
-
comment: utils_1.model.text(),
|
|
10
|
-
});
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFjdC1yZXF1ZXN0LWNvbW1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbW9kdWxlcy9jb250YWN0LXJlcXVlc3RzL21vZGVscy9jb250YWN0LXJlcXVlc3QtY29tbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxREFBaUQ7QUFFcEMsUUFBQSxxQkFBcUIsR0FBRyxhQUFLLENBQUMsTUFBTSxDQUFDLHlCQUF5QixFQUFFO0lBQzNFLEVBQUUsRUFBRSxhQUFLLENBQUMsRUFBRSxFQUFFLENBQUMsVUFBVSxFQUFFO0lBQzNCLGtCQUFrQixFQUFFLGFBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQyxVQUFVLEVBQUU7SUFDN0MsUUFBUSxFQUFFLGFBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQyxRQUFRLEVBQUU7SUFDakMsT0FBTyxFQUFFLGFBQUssQ0FBQyxJQUFJLEVBQUU7Q0FDdEIsQ0FBQyxDQUFBIn0=
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.defineContactUsPluginOptions = void 0;
|
|
4
|
-
const types_1 = require("./types");
|
|
5
|
-
/**
|
|
6
|
-
* Helper used in `medusa-config.ts` so integrators get autocomplete and
|
|
7
|
-
* validation when defining plugin options.
|
|
8
|
-
*/
|
|
9
|
-
const defineContactUsPluginOptions = (options) => {
|
|
10
|
-
if (!options) {
|
|
11
|
-
return types_1.DEFAULT_CONTACT_US_OPTIONS;
|
|
12
|
-
}
|
|
13
|
-
return (0, types_1.resolveContactUsOptions)(options);
|
|
14
|
-
};
|
|
15
|
-
exports.defineContactUsPluginOptions = defineContactUsPluginOptions;
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLW9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGx1Z2luLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBSWdCO0FBRWhCOzs7R0FHRztBQUNJLE1BQU0sNEJBQTRCLEdBQUcsQ0FDMUMsT0FBeUMsRUFDakIsRUFBRTtJQUMxQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDYixPQUFPLGtDQUEwQixDQUFBO0lBQ25DLENBQUM7SUFFRCxPQUFPLElBQUEsK0JBQXVCLEVBQUMsT0FBTyxDQUFDLENBQUE7QUFDekMsQ0FBQyxDQUFBO0FBUlksUUFBQSw0QkFBNEIsZ0NBUXhDIn0=
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const vitest_1 = require("vitest");
|
|
4
|
-
const types_1 = require("../../types");
|
|
5
|
-
const baseStatuses = {
|
|
6
|
-
initial: "new",
|
|
7
|
-
final: "closed",
|
|
8
|
-
intermediates: ["in_review"],
|
|
9
|
-
transitions: {
|
|
10
|
-
new: ["in_review"],
|
|
11
|
-
in_review: ["closed"],
|
|
12
|
-
},
|
|
13
|
-
};
|
|
14
|
-
const baseStatusOptions = [
|
|
15
|
-
{ code: "new", label: "New", notify_customer: true },
|
|
16
|
-
{ code: "in_review", label: "In Review", notify_customer: false },
|
|
17
|
-
{ code: "closed", label: "Closed", notify_customer: true },
|
|
18
|
-
];
|
|
19
|
-
(0, vitest_1.describe)("resolveContactUsOptions", () => {
|
|
20
|
-
const cases = [
|
|
21
|
-
{
|
|
22
|
-
name: "merges partial overrides with defaults",
|
|
23
|
-
input: {
|
|
24
|
-
statuses: baseStatuses,
|
|
25
|
-
status_options: baseStatusOptions,
|
|
26
|
-
form: {
|
|
27
|
-
additional_fields: [
|
|
28
|
-
{
|
|
29
|
-
key: "subject",
|
|
30
|
-
label: "Subject",
|
|
31
|
-
type: "text",
|
|
32
|
-
required: true,
|
|
33
|
-
},
|
|
34
|
-
],
|
|
35
|
-
max_payload_kb: 64,
|
|
36
|
-
},
|
|
37
|
-
},
|
|
38
|
-
assert: (options) => {
|
|
39
|
-
(0, vitest_1.expect)(options.form.max_payload_kb).toBe(types_1.DEFAULT_CONTACT_US_OPTIONS.form.max_payload_kb);
|
|
40
|
-
(0, vitest_1.expect)(options.form.additional_fields[0].key).toBe("subject");
|
|
41
|
-
},
|
|
42
|
-
},
|
|
43
|
-
{
|
|
44
|
-
name: "throws when statuses missing option definitions",
|
|
45
|
-
input: {
|
|
46
|
-
statuses: {
|
|
47
|
-
...baseStatuses,
|
|
48
|
-
},
|
|
49
|
-
status_options: [
|
|
50
|
-
{ code: "new", label: "New", notify_customer: true },
|
|
51
|
-
{ code: "in_review", label: "In Review", notify_customer: false },
|
|
52
|
-
// missing closed on purpose
|
|
53
|
-
],
|
|
54
|
-
form: {
|
|
55
|
-
additional_fields: [],
|
|
56
|
-
max_payload_kb: 64,
|
|
57
|
-
},
|
|
58
|
-
},
|
|
59
|
-
expectErrorSnapshot: `
|
|
60
|
-
[ZodError: [
|
|
61
|
-
{
|
|
62
|
-
"code": "custom",
|
|
63
|
-
"message": "Status code \\"closed\\" is missing in status_options",
|
|
64
|
-
"path": [
|
|
65
|
-
"status_options"
|
|
66
|
-
]
|
|
67
|
-
}
|
|
68
|
-
]]
|
|
69
|
-
`,
|
|
70
|
-
},
|
|
71
|
-
];
|
|
72
|
-
cases.forEach(({ name, input, expectErrorSnapshot, assert }) => {
|
|
73
|
-
(0, vitest_1.it)(name, () => {
|
|
74
|
-
if (expectErrorSnapshot) {
|
|
75
|
-
(0, vitest_1.expect)(() => (0, types_1.resolveContactUsOptions)(input)).toThrowErrorMatchingInlineSnapshot(expectErrorSnapshot);
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
const result = (0, types_1.resolveContactUsOptions)(input);
|
|
79
|
-
assert?.(result);
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFjdC1vcHRpb25zLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvdHlwZXMvX190ZXN0c19fL2NvbnRhY3Qtb3B0aW9ucy50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsbUNBQTZDO0FBQzdDLHVDQUlvQjtBQUVwQixNQUFNLFlBQVksR0FBdUM7SUFDdkQsT0FBTyxFQUFFLEtBQUs7SUFDZCxLQUFLLEVBQUUsUUFBUTtJQUNmLGFBQWEsRUFBRSxDQUFDLFdBQVcsQ0FBQztJQUM1QixXQUFXLEVBQUU7UUFDWCxHQUFHLEVBQUUsQ0FBQyxXQUFXLENBQUM7UUFDbEIsU0FBUyxFQUFFLENBQUMsUUFBUSxDQUFDO0tBQ3RCO0NBQ0YsQ0FBQTtBQUVELE1BQU0saUJBQWlCLEdBQTZDO0lBQ2xFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUU7SUFDcEQsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBRTtJQUNqRSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFO0NBQzNELENBQUE7QUFFRCxJQUFBLGlCQUFRLEVBQUMseUJBQXlCLEVBQUUsR0FBRyxFQUFFO0lBQ3ZDLE1BQU0sS0FBSyxHQUFHO1FBQ1o7WUFDRSxJQUFJLEVBQUUsd0NBQXdDO1lBQzlDLEtBQUssRUFBRTtnQkFDTCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIsY0FBYyxFQUFFLGlCQUFpQjtnQkFDakMsSUFBSSxFQUFFO29CQUNKLGlCQUFpQixFQUFFO3dCQUNqQjs0QkFDRSxHQUFHLEVBQUUsU0FBUzs0QkFDZCxLQUFLLEVBQUUsU0FBUzs0QkFDaEIsSUFBSSxFQUFFLE1BQWU7NEJBQ3JCLFFBQVEsRUFBRSxJQUFJO3lCQUNmO3FCQUNGO29CQUNELGNBQWMsRUFBRSxFQUFFO2lCQUNuQjthQUNGO1lBQ0QsTUFBTSxFQUFFLENBQUMsT0FBK0IsRUFBRSxFQUFFO2dCQUMxQyxJQUFBLGVBQU0sRUFBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLElBQUksQ0FDdEMsa0NBQTBCLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FDL0MsQ0FBQTtnQkFDRCxJQUFBLGVBQU0sRUFBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQTtZQUMvRCxDQUFDO1NBQ0Y7UUFDRDtZQUNFLElBQUksRUFBRSxpREFBaUQ7WUFDdkQsS0FBSyxFQUFFO2dCQUNMLFFBQVEsRUFBRTtvQkFDUixHQUFHLFlBQVk7aUJBQ2hCO2dCQUNELGNBQWMsRUFBRTtvQkFDZCxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFO29CQUNwRCxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxlQUFlLEVBQUUsS0FBSyxFQUFFO29CQUNqRSw0QkFBNEI7aUJBQzdCO2dCQUNELElBQUksRUFBRTtvQkFDSixpQkFBaUIsRUFBRSxFQUF5RDtvQkFDNUUsY0FBYyxFQUFFLEVBQUU7aUJBQ25CO2FBQ0Y7WUFDRCxtQkFBbUIsRUFBRTs7Ozs7Ozs7OztDQVUxQjtTQUNJO0tBQ0YsQ0FBQTtJQUVELEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRTtRQUM3RCxJQUFBLFdBQUUsRUFBQyxJQUFJLEVBQUUsR0FBRyxFQUFFO1lBQ1osSUFBSSxtQkFBbUIsRUFBRSxDQUFDO2dCQUN4QixJQUFBLGVBQU0sRUFBQyxHQUFHLEVBQUUsQ0FBQyxJQUFBLCtCQUF1QixFQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsa0NBQWtDLENBQzdFLG1CQUFtQixDQUNwQixDQUFBO2dCQUNELE9BQU07WUFDUixDQUFDO1lBRUQsTUFBTSxNQUFNLEdBQUcsSUFBQSwrQkFBdUIsRUFBQyxLQUFLLENBQUMsQ0FBQTtZQUM3QyxNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQTtRQUNsQixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUMsQ0FBQyxDQUFBO0FBQ0osQ0FBQyxDQUFDLENBQUEifQ==
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const vitest_1 = require("vitest");
|
|
4
|
-
const types_1 = require("../../types");
|
|
5
|
-
const payload_1 = require("../payload");
|
|
6
|
-
const buildOptions = () => (0, types_1.resolveContactUsOptions)({
|
|
7
|
-
...types_1.DEFAULT_CONTACT_US_OPTIONS,
|
|
8
|
-
form: {
|
|
9
|
-
additional_fields: [
|
|
10
|
-
{
|
|
11
|
-
key: "subject",
|
|
12
|
-
label: "Subject",
|
|
13
|
-
type: "text",
|
|
14
|
-
required: true,
|
|
15
|
-
},
|
|
16
|
-
{
|
|
17
|
-
key: "priority",
|
|
18
|
-
label: "Priority",
|
|
19
|
-
type: "select",
|
|
20
|
-
required: false,
|
|
21
|
-
options: [
|
|
22
|
-
{ value: "low", label: "Low" },
|
|
23
|
-
{ value: "high", label: "High" },
|
|
24
|
-
],
|
|
25
|
-
},
|
|
26
|
-
{
|
|
27
|
-
key: "notify",
|
|
28
|
-
label: "Notify me",
|
|
29
|
-
type: "boolean",
|
|
30
|
-
required: false,
|
|
31
|
-
},
|
|
32
|
-
],
|
|
33
|
-
max_payload_kb: 64,
|
|
34
|
-
},
|
|
35
|
-
status_options: [
|
|
36
|
-
{ code: "new", label: "New", notify_customer: true },
|
|
37
|
-
{ code: "in_review", label: "In review", notify_customer: false },
|
|
38
|
-
{ code: "closed", label: "Closed", notify_customer: true },
|
|
39
|
-
],
|
|
40
|
-
});
|
|
41
|
-
(0, vitest_1.describe)("sanitizeContactPayload", () => {
|
|
42
|
-
const options = buildOptions();
|
|
43
|
-
const cases = [
|
|
44
|
-
{
|
|
45
|
-
name: "returns sanitized payload for valid input",
|
|
46
|
-
payload: {
|
|
47
|
-
subject: "Need help",
|
|
48
|
-
priority: "high",
|
|
49
|
-
notify: "true",
|
|
50
|
-
},
|
|
51
|
-
expected: {
|
|
52
|
-
subject: "Need help",
|
|
53
|
-
priority: "high",
|
|
54
|
-
notify: true,
|
|
55
|
-
},
|
|
56
|
-
},
|
|
57
|
-
{
|
|
58
|
-
name: "trims whitespace for text fields",
|
|
59
|
-
payload: {
|
|
60
|
-
subject: " Pricing question ",
|
|
61
|
-
priority: "low",
|
|
62
|
-
},
|
|
63
|
-
expected: {
|
|
64
|
-
subject: "Pricing question",
|
|
65
|
-
priority: "low",
|
|
66
|
-
},
|
|
67
|
-
},
|
|
68
|
-
];
|
|
69
|
-
cases.forEach(({ name, payload, expected }) => {
|
|
70
|
-
(0, vitest_1.it)(name, () => {
|
|
71
|
-
(0, vitest_1.expect)((0, payload_1.sanitizeContactPayload)(payload, options)).toEqual(expected);
|
|
72
|
-
});
|
|
73
|
-
});
|
|
74
|
-
(0, vitest_1.it)("throws when required field is missing", () => {
|
|
75
|
-
(0, vitest_1.expect)(() => (0, payload_1.sanitizeContactPayload)({ priority: "low" }, options)).toThrow(/subject/i);
|
|
76
|
-
});
|
|
77
|
-
(0, vitest_1.it)("throws when select value is invalid", () => {
|
|
78
|
-
(0, vitest_1.expect)(() => (0, payload_1.sanitizeContactPayload)({ subject: "hello", priority: "urgent" }, options)).toThrow(/priority/i);
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bG9hZC12YWxpZGF0b3IudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy91dGlscy9fX3Rlc3RzX18vcGF5bG9hZC12YWxpZGF0b3IudGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG1DQUE2QztBQUM3Qyx1Q0FHb0I7QUFDcEIsd0NBQW1EO0FBRW5ELE1BQU0sWUFBWSxHQUFHLEdBQUcsRUFBRSxDQUN4QixJQUFBLCtCQUF1QixFQUFDO0lBQ3RCLEdBQUcsa0NBQTBCO0lBQzdCLElBQUksRUFBRTtRQUNKLGlCQUFpQixFQUFFO1lBQ2pCO2dCQUNFLEdBQUcsRUFBRSxTQUFTO2dCQUNkLEtBQUssRUFBRSxTQUFTO2dCQUNoQixJQUFJLEVBQUUsTUFBTTtnQkFDWixRQUFRLEVBQUUsSUFBSTthQUNmO1lBQ0Q7Z0JBQ0UsR0FBRyxFQUFFLFVBQVU7Z0JBQ2YsS0FBSyxFQUFFLFVBQVU7Z0JBQ2pCLElBQUksRUFBRSxRQUFRO2dCQUNkLFFBQVEsRUFBRSxLQUFLO2dCQUNmLE9BQU8sRUFBRTtvQkFDUCxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRTtvQkFDOUIsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7aUJBQ2pDO2FBQ0Y7WUFDRDtnQkFDRSxHQUFHLEVBQUUsUUFBUTtnQkFDYixLQUFLLEVBQUUsV0FBVztnQkFDbEIsSUFBSSxFQUFFLFNBQVM7Z0JBQ2YsUUFBUSxFQUFFLEtBQUs7YUFDaEI7U0FDRjtRQUNELGNBQWMsRUFBRSxFQUFFO0tBQ25CO0lBQ0QsY0FBYyxFQUFFO1FBQ2QsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRTtRQUNwRCxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxlQUFlLEVBQUUsS0FBSyxFQUFFO1FBQ2pFLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUU7S0FDM0Q7Q0FDRixDQUFDLENBQUE7QUFFSixJQUFBLGlCQUFRLEVBQUMsd0JBQXdCLEVBQUUsR0FBRyxFQUFFO0lBQ3RDLE1BQU0sT0FBTyxHQUFHLFlBQVksRUFBRSxDQUFBO0lBRTlCLE1BQU0sS0FBSyxHQUFHO1FBQ1o7WUFDRSxJQUFJLEVBQUUsMkNBQTJDO1lBQ2pELE9BQU8sRUFBRTtnQkFDUCxPQUFPLEVBQUUsV0FBVztnQkFDcEIsUUFBUSxFQUFFLE1BQU07Z0JBQ2hCLE1BQU0sRUFBRSxNQUFNO2FBQ2Y7WUFDRCxRQUFRLEVBQUU7Z0JBQ1IsT0FBTyxFQUFFLFdBQVc7Z0JBQ3BCLFFBQVEsRUFBRSxNQUFNO2dCQUNoQixNQUFNLEVBQUUsSUFBSTthQUNiO1NBQ0Y7UUFDRDtZQUNFLElBQUksRUFBRSxrQ0FBa0M7WUFDeEMsT0FBTyxFQUFFO2dCQUNQLE9BQU8sRUFBRSxzQkFBc0I7Z0JBQy9CLFFBQVEsRUFBRSxLQUFLO2FBQ2hCO1lBQ0QsUUFBUSxFQUFFO2dCQUNSLE9BQU8sRUFBRSxrQkFBa0I7Z0JBQzNCLFFBQVEsRUFBRSxLQUFLO2FBQ2hCO1NBQ0Y7S0FDRixDQUFBO0lBRUQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFO1FBQzVDLElBQUEsV0FBRSxFQUFDLElBQUksRUFBRSxHQUFHLEVBQUU7WUFDWixJQUFBLGVBQU0sRUFBQyxJQUFBLGdDQUFzQixFQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQTtRQUNwRSxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUMsQ0FBQyxDQUFBO0lBRUYsSUFBQSxXQUFFLEVBQUMsdUNBQXVDLEVBQUUsR0FBRyxFQUFFO1FBQy9DLElBQUEsZUFBTSxFQUFDLEdBQUcsRUFBRSxDQUNWLElBQUEsZ0NBQXNCLEVBQUMsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQ3JELENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFBO0lBQ3ZCLENBQUMsQ0FBQyxDQUFBO0lBRUYsSUFBQSxXQUFFLEVBQUMscUNBQXFDLEVBQUUsR0FBRyxFQUFFO1FBQzdDLElBQUEsZUFBTSxFQUFDLEdBQUcsRUFBRSxDQUNWLElBQUEsZ0NBQXNCLEVBQ3BCLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLEVBQ3hDLE9BQU8sQ0FDUixDQUNGLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFBO0lBQ3hCLENBQUMsQ0FBQyxDQUFBO0FBQ0osQ0FBQyxDQUFDLENBQUEifQ==
|
|
@@ -1,127 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.sanitizeContactPayload = void 0;
|
|
4
|
-
const utils_1 = require("@medusajs/framework/utils");
|
|
5
|
-
const assertOptionsProvided = (field) => {
|
|
6
|
-
if (!field.options || field.options.length === 0) {
|
|
7
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" requires options to be provided.`);
|
|
8
|
-
}
|
|
9
|
-
};
|
|
10
|
-
const sanitizeText = (value, field) => {
|
|
11
|
-
if (typeof value !== "string") {
|
|
12
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" must be a string.`);
|
|
13
|
-
}
|
|
14
|
-
return value.trim();
|
|
15
|
-
};
|
|
16
|
-
const sanitizeNumber = (value, field) => {
|
|
17
|
-
if (typeof value === "number") {
|
|
18
|
-
return value;
|
|
19
|
-
}
|
|
20
|
-
if (typeof value === "string" && value.trim().length > 0) {
|
|
21
|
-
const parsed = Number(value);
|
|
22
|
-
if (Number.isFinite(parsed)) {
|
|
23
|
-
return parsed;
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" must be a valid number.`);
|
|
27
|
-
};
|
|
28
|
-
const sanitizeBoolean = (value, field) => {
|
|
29
|
-
if (typeof value === "boolean") {
|
|
30
|
-
return value;
|
|
31
|
-
}
|
|
32
|
-
if (typeof value === "string") {
|
|
33
|
-
const normalized = value.toLowerCase().trim();
|
|
34
|
-
if (["true", "1", "yes"].includes(normalized)) {
|
|
35
|
-
return true;
|
|
36
|
-
}
|
|
37
|
-
if (["false", "0", "no"].includes(normalized)) {
|
|
38
|
-
return false;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" must be a boolean.`);
|
|
42
|
-
};
|
|
43
|
-
const sanitizeSelect = (value, field) => {
|
|
44
|
-
assertOptionsProvided(field);
|
|
45
|
-
if (typeof value !== "string") {
|
|
46
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" must be a string.`);
|
|
47
|
-
}
|
|
48
|
-
const normalized = value.trim();
|
|
49
|
-
const options = field.options.map((option) => option.value);
|
|
50
|
-
if (!options.includes(normalized)) {
|
|
51
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" must be one of: ${options.join(", ")}`);
|
|
52
|
-
}
|
|
53
|
-
return normalized;
|
|
54
|
-
};
|
|
55
|
-
const sanitizeMultiSelect = (value, field) => {
|
|
56
|
-
assertOptionsProvided(field);
|
|
57
|
-
if (!Array.isArray(value)) {
|
|
58
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" must be an array of strings.`);
|
|
59
|
-
}
|
|
60
|
-
const options = field.options.map((option) => option.value);
|
|
61
|
-
return value.map((entry) => {
|
|
62
|
-
if (typeof entry !== "string") {
|
|
63
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" entries must be strings.`);
|
|
64
|
-
}
|
|
65
|
-
const normalized = entry.trim();
|
|
66
|
-
if (!options.includes(normalized)) {
|
|
67
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" entries must be one of: ${options.join(", ")}`);
|
|
68
|
-
}
|
|
69
|
-
return normalized;
|
|
70
|
-
});
|
|
71
|
-
};
|
|
72
|
-
const sanitizeDate = (value, field) => {
|
|
73
|
-
if (value instanceof Date) {
|
|
74
|
-
return value.toISOString();
|
|
75
|
-
}
|
|
76
|
-
if (typeof value === "string") {
|
|
77
|
-
const date = new Date(value);
|
|
78
|
-
if (!Number.isNaN(date.getTime())) {
|
|
79
|
-
return date.toISOString();
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" must be a valid date string.`);
|
|
83
|
-
};
|
|
84
|
-
const ensureObjectPayload = (payload) => {
|
|
85
|
-
if (payload === null || payload === undefined) {
|
|
86
|
-
return {};
|
|
87
|
-
}
|
|
88
|
-
if (typeof payload !== "object" || Array.isArray(payload)) {
|
|
89
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "Payload must be a JSON object.");
|
|
90
|
-
}
|
|
91
|
-
return payload;
|
|
92
|
-
};
|
|
93
|
-
const validators = {
|
|
94
|
-
text: sanitizeText,
|
|
95
|
-
textarea: sanitizeText,
|
|
96
|
-
number: sanitizeNumber,
|
|
97
|
-
select: sanitizeSelect,
|
|
98
|
-
multi_select: sanitizeMultiSelect,
|
|
99
|
-
boolean: sanitizeBoolean,
|
|
100
|
-
date: sanitizeDate,
|
|
101
|
-
};
|
|
102
|
-
const sanitizeContactPayload = (payload, options) => {
|
|
103
|
-
const normalized = ensureObjectPayload(payload);
|
|
104
|
-
const sanitized = {};
|
|
105
|
-
const fieldMap = new Map(options.form.additional_fields.map((f) => [f.key, f]));
|
|
106
|
-
const allowedKeys = new Set(fieldMap.keys());
|
|
107
|
-
Object.keys(normalized).forEach((key) => {
|
|
108
|
-
if (!allowedKeys.has(key)) {
|
|
109
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${key}" is not allowed.`);
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
fieldMap.forEach((field) => {
|
|
113
|
-
const value = normalized[field.key];
|
|
114
|
-
if ((value === undefined || value === null || value === "") &&
|
|
115
|
-
field.required) {
|
|
116
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Field "${field.key}" is required.`);
|
|
117
|
-
}
|
|
118
|
-
if (value === undefined || value === null || value === "") {
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
const validator = validators[field.type] ?? sanitizeText;
|
|
122
|
-
sanitized[field.key] = validator(value, field);
|
|
123
|
-
});
|
|
124
|
-
return sanitized;
|
|
125
|
-
};
|
|
126
|
-
exports.sanitizeContactPayload = sanitizeContactPayload;
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bG9hZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlscy9wYXlsb2FkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFEQUF1RDtBQU92RCxNQUFNLHFCQUFxQixHQUFHLENBQUMsS0FBNkIsRUFBRSxFQUFFO0lBQzlELElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ2pELE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQzlCLFVBQVUsS0FBSyxDQUFDLEdBQUcsb0NBQW9DLENBQ3hELENBQUE7SUFDSCxDQUFDO0FBQ0gsQ0FBQyxDQUFBO0FBRUQsTUFBTSxZQUFZLEdBQUcsQ0FBQyxLQUFjLEVBQUUsS0FBNkIsRUFBRSxFQUFFO0lBQ3JFLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDOUIsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLFlBQVksRUFDOUIsVUFBVSxLQUFLLENBQUMsR0FBRyxxQkFBcUIsQ0FDekMsQ0FBQTtJQUNILENBQUM7SUFDRCxPQUFPLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQTtBQUNyQixDQUFDLENBQUE7QUFFRCxNQUFNLGNBQWMsR0FBRyxDQUFDLEtBQWMsRUFBRSxLQUE2QixFQUFFLEVBQUU7SUFDdkUsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztRQUM5QixPQUFPLEtBQUssQ0FBQTtJQUNkLENBQUM7SUFDRCxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsSUFBSSxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3pELE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUM1QixJQUFJLE1B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
|