@paroicms/server 1.100.0 → 1.102.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/admin-backend/account/account.queries.js +15 -11
- package/dist/admin-backend/account/account.queries.js.map +1 -1
- package/dist/admin-backend/media/media-upload.controller.js +1 -1
- package/dist/admin-backend/media/media-upload.controller.js.map +1 -1
- package/dist/admin-backend/site-constants/site-constants.resolver.js +2 -2
- package/dist/admin-backend/site-constants/site-constants.resolver.js.map +1 -1
- package/dist/context.d.ts +1 -1
- package/dist/context.js +6 -5
- package/dist/context.js.map +1 -1
- package/dist/liquidjs-tools/liquidjs-filter.js +2 -1
- package/dist/liquidjs-tools/liquidjs-filter.js.map +1 -1
- package/dist/plugin-services/before-save-values-hook.js +2 -1
- package/dist/plugin-services/before-save-values-hook.js.map +1 -1
- package/dist/plugin-services/make-backend-plugin-service.d.ts +1 -1
- package/dist/plugin-services/make-backend-plugin-service.js +41 -16
- package/dist/plugin-services/make-backend-plugin-service.js.map +1 -1
- package/dist/rendered-site/liquidjs-filters/open-graph-filter.js +2 -1
- package/dist/rendered-site/liquidjs-filters/open-graph-filter.js.map +1 -1
- package/dist/rendered-site/liquidjs-tags/liquid-tag-wrapper.js +2 -4
- package/dist/rendered-site/liquidjs-tags/liquid-tag-wrapper.js.map +1 -1
- package/dist/rendering-payload/rendering-payload.types.d.ts +1 -4
- package/dist/rendering-payload/site-payload.js +7 -2
- package/dist/rendering-payload/site-payload.js.map +1 -1
- package/dist/site-context/core-plugin/core-hooks.d.ts +2 -0
- package/dist/site-context/core-plugin/core-hooks.js +17 -0
- package/dist/site-context/core-plugin/core-hooks.js.map +1 -0
- package/dist/site-context/core-plugin/create-core-plugin.d.ts +2 -0
- package/dist/site-context/core-plugin/create-core-plugin.js +160 -0
- package/dist/site-context/core-plugin/create-core-plugin.js.map +1 -0
- package/dist/site-context/core-plugin/normalize-typography-fr-FR.d.ts +1 -0
- package/dist/site-context/core-plugin/normalize-typography-fr-FR.js +48 -0
- package/dist/site-context/core-plugin/normalize-typography-fr-FR.js.map +1 -0
- package/dist/site-context/liquid-init.d.ts +2 -0
- package/dist/site-context/liquid-init.js +23 -0
- package/dist/site-context/liquid-init.js.map +1 -0
- package/dist/site-context/load-site-context.d.ts +1 -0
- package/dist/site-context/load-site-context.js +56 -119
- package/dist/site-context/load-site-context.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +13 -13
- package/dist/common/mail/sendMail.helpers.d.ts +0 -5
- package/dist/common/mail/sendMail.helpers.js +0 -53
- package/dist/common/mail/sendMail.helpers.js.map +0 -1
- package/dist/public-api/mail/validate-recaptcha-response.d.ts +0 -5
- package/dist/public-api/mail/validate-recaptcha-response.js +0 -21
- package/dist/public-api/mail/validate-recaptcha-response.js.map +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@paroicms/server",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.102.0",
|
|
4
4
|
"description": "The ParoiCMS server",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"cms",
|
|
@@ -26,8 +26,8 @@
|
|
|
26
26
|
"tsc:watch": "tsc --watch --preserveWatchOutput",
|
|
27
27
|
"dev": "turbo dev",
|
|
28
28
|
"clear": "rimraf dist/*",
|
|
29
|
-
"test": "vitest",
|
|
30
|
-
"test
|
|
29
|
+
"test:watch": "vitest",
|
|
30
|
+
"test": "vitest run",
|
|
31
31
|
"_pino-pretty": "pino-pretty -U false -x 'stats:25' -X 'stats:grey' -t 'yyyy-mm-dd HH:MM:ss.l' -i 'hostname,pid,fqdn' -o '{if fqdn}[{fqdn}] {end}{msg}'",
|
|
32
32
|
"graphql:generate-types": "npm run _graphql:generate-types && npm run _patch-graphql-types",
|
|
33
33
|
"_graphql:generate-types": "graphql-codegen --config scripts/codegen.ts",
|
|
@@ -36,16 +36,16 @@
|
|
|
36
36
|
"dependencies": {
|
|
37
37
|
"@apollo/server": "~4.12.2",
|
|
38
38
|
"@as-integrations/express5": "~1.1.0",
|
|
39
|
-
"@
|
|
40
|
-
"@paroicms/
|
|
41
|
-
"@paroicms/
|
|
42
|
-
"@paroicms/internal-
|
|
43
|
-
"@paroicms/
|
|
44
|
-
"@paroicms/public-
|
|
45
|
-
"@paroicms/
|
|
46
|
-
"@paroicms/server-database-media-storage": "1.
|
|
47
|
-
"@paroicms/server-image-cache-engine": "1.
|
|
48
|
-
"@paroicms/server-text-cache-system": "1.
|
|
39
|
+
"@paroicms/admin-ui": "1.79.0",
|
|
40
|
+
"@paroicms/connector": "0.47.0",
|
|
41
|
+
"@paroicms/internal-anywhere-lib": "1.33.0",
|
|
42
|
+
"@paroicms/internal-server-lib": "1.19.0",
|
|
43
|
+
"@paroicms/public-anywhere-lib": "0.34.0",
|
|
44
|
+
"@paroicms/public-server-lib": "0.43.0",
|
|
45
|
+
"@paroicms/script-lib": "0.2.0",
|
|
46
|
+
"@paroicms/server-database-media-storage": "1.22.0",
|
|
47
|
+
"@paroicms/server-image-cache-engine": "1.27.0",
|
|
48
|
+
"@paroicms/server-text-cache-system": "1.19.0",
|
|
49
49
|
"arktype": "~2.1.20",
|
|
50
50
|
"bcrypt": "~6.0.0",
|
|
51
51
|
"compression": "~1.8.0",
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { SESClient, SendEmailCommand } from "@aws-sdk/client-ses";
|
|
2
|
-
import { escapeHtml, htmlToRawText } from "@paroicms/public-server-lib";
|
|
3
|
-
import { appConf } from "../../context.js";
|
|
4
|
-
const sesClient = !appConf.awsSesMail || appConf.awsSesMail?.disabled
|
|
5
|
-
? undefined
|
|
6
|
-
: new SESClient({
|
|
7
|
-
region: appConf.awsSesMail.region,
|
|
8
|
-
credentials: {
|
|
9
|
-
accessKeyId: appConf.awsSesMail.accessKeyId,
|
|
10
|
-
secretAccessKey: appConf.awsSesMail.secretAccessKey,
|
|
11
|
-
},
|
|
12
|
-
});
|
|
13
|
-
export async function sendMail({ subject, html, replyTo, to }, { logger }) {
|
|
14
|
-
const text = htmlToRawText(html);
|
|
15
|
-
const replyToAddr = replyTo
|
|
16
|
-
? `"${escapeHtml(replyTo.name)}" <${escapeHtml(replyTo.email)}>`
|
|
17
|
-
: undefined;
|
|
18
|
-
logger.debug(`[sendMail] ${JSON.stringify({
|
|
19
|
-
from: appConf.awsSesMail?.from,
|
|
20
|
-
to,
|
|
21
|
-
replyToAddr,
|
|
22
|
-
subject,
|
|
23
|
-
html,
|
|
24
|
-
text,
|
|
25
|
-
})}`);
|
|
26
|
-
if (!sesClient || !appConf.awsSesMail)
|
|
27
|
-
return;
|
|
28
|
-
const command = new SendEmailCommand({
|
|
29
|
-
Source: appConf.awsSesMail.from,
|
|
30
|
-
Destination: {
|
|
31
|
-
ToAddresses: [to],
|
|
32
|
-
},
|
|
33
|
-
ReplyToAddresses: replyToAddr ? [replyToAddr] : undefined,
|
|
34
|
-
Message: {
|
|
35
|
-
Subject: {
|
|
36
|
-
Charset: "UTF-8",
|
|
37
|
-
Data: subject,
|
|
38
|
-
},
|
|
39
|
-
Body: {
|
|
40
|
-
Html: {
|
|
41
|
-
Charset: "UTF-8",
|
|
42
|
-
Data: html,
|
|
43
|
-
},
|
|
44
|
-
Text: {
|
|
45
|
-
Charset: "UTF-8",
|
|
46
|
-
Data: text,
|
|
47
|
-
},
|
|
48
|
-
},
|
|
49
|
-
},
|
|
50
|
-
});
|
|
51
|
-
await sesClient.send(command);
|
|
52
|
-
}
|
|
53
|
-
//# sourceMappingURL=sendMail.helpers.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sendMail.helpers.js","sourceRoot":"","sources":["../../../src/common/mail/sendMail.helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAElE,OAAO,EAAE,UAAU,EAAE,aAAa,EAAiB,MAAM,6BAA6B,CAAC;AACvF,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,MAAM,SAAS,GACb,CAAC,OAAO,CAAC,UAAU,IAAI,OAAO,CAAC,UAAU,EAAE,QAAQ;IACjD,CAAC,CAAC,SAAS;IACX,CAAC,CAAC,IAAI,SAAS,CAAC;QACZ,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM;QACjC,WAAW,EAAE;YACX,WAAW,EAAE,OAAO,CAAC,UAAU,CAAC,WAAW;YAC3C,eAAe,EAAE,OAAO,CAAC,UAAU,CAAC,eAAe;SACpD;KACF,CAAC,CAAC;AAET,MAAM,CAAC,KAAK,UAAU,QAAQ,CAC5B,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAY,EACxC,EAAE,MAAM,EAA8B;IAEtC,MAAM,IAAI,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IACjC,MAAM,WAAW,GAAG,OAAO;QACzB,CAAC,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG;QAChE,CAAC,CAAC,SAAS,CAAC;IAEd,MAAM,CAAC,KAAK,CACV,cAAc,IAAI,CAAC,SAAS,CAAC;QAC3B,IAAI,EAAE,OAAO,CAAC,UAAU,EAAE,IAAI;QAC9B,EAAE;QACF,WAAW;QACX,OAAO;QACP,IAAI;QACJ,IAAI;KACL,CAAC,EAAE,CACL,CAAC;IAEF,IAAI,CAAC,SAAS,IAAI,CAAC,OAAO,CAAC,UAAU;QAAE,OAAO;IAE9C,MAAM,OAAO,GAAG,IAAI,gBAAgB,CAAC;QACnC,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,IAAI;QAC/B,WAAW,EAAE;YACX,WAAW,EAAE,CAAC,EAAE,CAAC;SAClB;QACD,gBAAgB,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,SAAS;QACzD,OAAO,EAAE;YACP,OAAO,EAAE;gBACP,OAAO,EAAE,OAAO;gBAChB,IAAI,EAAE,OAAO;aACd;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE;oBACJ,OAAO,EAAE,OAAO;oBAChB,IAAI,EAAE,IAAI;iBACX;gBACD,IAAI,EAAE;oBACJ,OAAO,EAAE,OAAO;oBAChB,IAAI,EAAE,IAAI;iBACX;aACF;SACF;KACF,CAAC,CAAC;IAEH,MAAM,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AAChC,CAAC"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import type { SiteContext } from "../../site-context/site-context.types.js";
|
|
2
|
-
export declare function validateRecaptchaResponse(siteContext: Pick<SiteContext, "fqdn">, { gRecaptchaResponse, secretKey, }: {
|
|
3
|
-
gRecaptchaResponse: string | undefined;
|
|
4
|
-
secretKey: string;
|
|
5
|
-
}): Promise<boolean>;
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { ApiError } from "@paroicms/public-server-lib";
|
|
2
|
-
export async function validateRecaptchaResponse(siteContext, { gRecaptchaResponse, secretKey, }) {
|
|
3
|
-
if (!gRecaptchaResponse)
|
|
4
|
-
throw new ApiError("Missing gRecaptchaResponse", 400);
|
|
5
|
-
if (!secretKey) {
|
|
6
|
-
throw new Error("Invalid configuration, missing 'recaptchaPrivateKey'");
|
|
7
|
-
}
|
|
8
|
-
const url = `https://www.google.com/recaptcha/api/siteverify?secret=${secretKey}&response=${gRecaptchaResponse}`;
|
|
9
|
-
const response = await fetch(url, {
|
|
10
|
-
method: "post",
|
|
11
|
-
});
|
|
12
|
-
if (response.status < 200 || response.status >= 300) {
|
|
13
|
-
throw new Error("Failed to call the Google Recaptcha API");
|
|
14
|
-
}
|
|
15
|
-
const result = (await response.json());
|
|
16
|
-
if (result.hostname !== siteContext.fqdn) {
|
|
17
|
-
throw new ApiError("Unauthorized", 401);
|
|
18
|
-
}
|
|
19
|
-
return result.success;
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=validate-recaptcha-response.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validate-recaptcha-response.js","sourceRoot":"","sources":["../../../src/public-api/mail/validate-recaptcha-response.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAgBvD,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAC7C,WAAsC,EACtC,EACE,kBAAkB,EAClB,SAAS,GAIV;IAED,IAAI,CAAC,kBAAkB;QAAE,MAAM,IAAI,QAAQ,CAAC,4BAA4B,EAAE,GAAG,CAAC,CAAC;IAC/E,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;IAC1E,CAAC;IACD,MAAM,GAAG,GAAG,0DAA0D,SAAS,aAAa,kBAAkB,EAAE,CAAC;IACjH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;QAChC,MAAM,EAAE,MAAM;KACf,CAAC,CAAC;IACH,IAAI,QAAQ,CAAC,MAAM,GAAG,GAAG,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,EAAE,CAAC;QACpD,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAC7D,CAAC;IACD,MAAM,MAAM,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAsC,CAAC;IAC5E,IAAI,MAAM,CAAC,QAAQ,KAAK,WAAW,CAAC,IAAI,EAAE,CAAC;QACzC,MAAM,IAAI,QAAQ,CAAC,cAAc,EAAE,GAAG,CAAC,CAAC;IAC1C,CAAC;IACD,OAAO,MAAM,CAAC,OAAO,CAAC;AACxB,CAAC"}
|