ghost 6.0.6 → 6.0.7
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/components/tryghost-i18n-6.0.7.tgz +0 -0
- package/core/built/admin/assets/admin-x-activitypub/admin-x-activitypub.js +1 -1
- package/core/built/admin/assets/admin-x-activitypub/{index-BRzGrD-C.mjs → index-B-ckGCDl.mjs} +19762 -16495
- package/core/built/admin/assets/admin-x-activitypub/{index-Co80faUx.mjs → index-C81KQoIh.mjs} +2 -2
- package/core/built/admin/assets/admin-x-settings/{CodeEditorView-B4W7CQcA.mjs → CodeEditorView-BfL5FINN.mjs} +2 -2
- package/core/built/admin/assets/admin-x-settings/admin-x-settings.js +1 -1
- package/core/built/admin/assets/admin-x-settings/{index-jv9DN3ZO.mjs → index-C_ZS-INP.mjs} +2 -2
- package/core/built/admin/assets/admin-x-settings/{index-CuwMM9FM.mjs → index-DiNZ3HQD.mjs} +12 -4
- package/core/built/admin/assets/admin-x-settings/{modals-CUGEPPYA.mjs → modals-BEiWgHsk.mjs} +8807 -8799
- package/core/built/admin/assets/{chunk.524.56bb70d3e8660d34aef1.js → chunk.524.9f989b3664418d6271a7.js} +6 -6
- package/core/built/admin/assets/{chunk.582.ae0341229e71a85d0b2d.js → chunk.582.2421014e45b977b43b68.js} +10 -10
- package/core/built/admin/assets/{ghost-2bcbd118a8ad45fed5401e84a7e87c9a.js → ghost-182ed60de3f37fff8a40cdd65d3bd2ef.js} +25 -23
- package/core/built/admin/assets/{ghost-2c537ee89c36199137eafc1768fd7de8.css → ghost-a7a53bf80dc45c37ae9c174a0d02a882.css} +1 -1
- package/core/built/admin/assets/{ghost-dark-ad23efc1d702e3643a8ee90d089df5d6.css → ghost-dark-6e0062029f988d8676e87f22d8e7f4a3.css} +1 -1
- package/core/built/admin/assets/posts/posts.js +78865 -77973
- package/core/built/admin/assets/stats/stats.js +15467 -15442
- package/core/built/admin/index.html +4 -4
- package/core/server/data/tinybird/endpoints/api_top_utm_campaigns.pipe +31 -0
- package/core/server/data/tinybird/endpoints/api_top_utm_contents.pipe +31 -0
- package/core/server/data/tinybird/endpoints/api_top_utm_mediums.pipe +31 -0
- package/core/server/data/tinybird/endpoints/api_top_utm_sources.pipe +31 -0
- package/core/server/data/tinybird/endpoints/api_top_utm_terms.pipe +31 -0
- package/core/server/data/tinybird/tests/api_top_utm_campaigns.yaml +108 -0
- package/core/server/data/tinybird/tests/api_top_utm_contents.yaml +108 -0
- package/core/server/data/tinybird/tests/api_top_utm_mediums.yaml +108 -0
- package/core/server/data/tinybird/tests/api_top_utm_sources.yaml +108 -0
- package/core/server/data/tinybird/tests/api_top_utm_terms.yaml +108 -0
- package/core/server/services/lib/magic-link/MagicLink.js +17 -11
- package/core/server/services/members/MembersConfigProvider.js +11 -1
- package/core/server/services/members/SingleUseTokenProvider.js +159 -6
- package/core/server/services/members/api.js +1 -1
- package/core/server/services/members/emails/signin.js +8 -5
- package/core/server/services/members/members-api/controllers/RouterController.js +95 -19
- package/core/server/services/members/members-api/members-api.js +8 -4
- package/core/server/services/members/members-ssr.js +5 -3
- package/core/server/services/members/middleware.js +2 -2
- package/core/server/web/members/app.js +12 -3
- package/core/shared/config/defaults.json +1 -1
- package/core/shared/labs.js +3 -1
- package/package.json +6 -6
- package/tsconfig.tsbuildinfo +1 -1
- package/yarn.lock +57 -63
- package/components/tryghost-i18n-6.0.6.tgz +0 -0
|
@@ -235,12 +235,12 @@ module.exports = function MembersAPI({
|
|
|
235
235
|
});
|
|
236
236
|
}
|
|
237
237
|
|
|
238
|
-
async function getTokenDataFromMagicLinkToken(token) {
|
|
239
|
-
return await magicLinkService.getDataFromToken(token);
|
|
238
|
+
async function getTokenDataFromMagicLinkToken(token, otcVerification) {
|
|
239
|
+
return await magicLinkService.getDataFromToken(token, otcVerification);
|
|
240
240
|
}
|
|
241
241
|
|
|
242
|
-
async function getMemberDataFromMagicLinkToken(token) {
|
|
243
|
-
const {email, labels = [], name = '', oldEmail, newsletters, attribution, reqIp, type} = await getTokenDataFromMagicLinkToken(token);
|
|
242
|
+
async function getMemberDataFromMagicLinkToken(token, otcVerification) {
|
|
243
|
+
const {email, labels = [], name = '', oldEmail, newsletters, attribution, reqIp, type} = await getTokenDataFromMagicLinkToken(token, otcVerification);
|
|
244
244
|
if (!email) {
|
|
245
245
|
return null;
|
|
246
246
|
}
|
|
@@ -340,6 +340,10 @@ module.exports = function MembersAPI({
|
|
|
340
340
|
body.json(),
|
|
341
341
|
forwardError((req, res) => routerController.sendMagicLink(req, res))
|
|
342
342
|
),
|
|
343
|
+
verifyOTC: Router().use(
|
|
344
|
+
body.json(),
|
|
345
|
+
forwardError((req, res) => routerController.verifyOTC(req, res))
|
|
346
|
+
),
|
|
343
347
|
createCheckoutSession: Router().use(
|
|
344
348
|
body.json(),
|
|
345
349
|
forwardError((req, res) => routerController.createCheckoutSession(req, res))
|
|
@@ -156,12 +156,13 @@ class MembersSSR {
|
|
|
156
156
|
* @method _getMemberDataFromToken
|
|
157
157
|
*
|
|
158
158
|
* @param {JWT} token
|
|
159
|
+
* @param {string} [otcVerification]
|
|
159
160
|
*
|
|
160
161
|
* @returns {Promise<Member>} member
|
|
161
162
|
*/
|
|
162
|
-
async _getMemberDataFromToken(token) {
|
|
163
|
+
async _getMemberDataFromToken(token, otcVerification) {
|
|
163
164
|
const api = await this._getMembersApi();
|
|
164
|
-
return api.getMemberDataFromMagicLinkToken(token);
|
|
165
|
+
return api.getMemberDataFromMagicLinkToken(token, otcVerification);
|
|
165
166
|
}
|
|
166
167
|
|
|
167
168
|
/**
|
|
@@ -234,7 +235,8 @@ class MembersSSR {
|
|
|
234
235
|
}
|
|
235
236
|
|
|
236
237
|
const token = Array.isArray(query.token) ? query.token[0] : query.token;
|
|
237
|
-
const
|
|
238
|
+
const otcVerification = Array.isArray(query.otc_verification) ? query.otc_verification[0] : query.otc_verification;
|
|
239
|
+
const member = await this._getMemberDataFromToken(token, otcVerification);
|
|
238
240
|
|
|
239
241
|
if (!member) {
|
|
240
242
|
// The member doesn't exist any longer (could be a sign in token for a member that was deleted)
|
|
@@ -332,8 +332,8 @@ const createSessionFromMagicLink = async function createSessionFromMagicLink(req
|
|
|
332
332
|
// req.query is a plain object, copy it to a URLSearchParams object so we can call toString()
|
|
333
333
|
const searchParams = new URLSearchParams('');
|
|
334
334
|
Object.keys(req.query).forEach((param) => {
|
|
335
|
-
// don't copy the "token" or "
|
|
336
|
-
if (param !== 'token' && param !== 'r') {
|
|
335
|
+
// don't copy the "token", "r", or "otc_verification" params
|
|
336
|
+
if (param !== 'token' && param !== 'r' && param !== 'otc_verification') {
|
|
337
337
|
searchParams.set(param, req.query[param]);
|
|
338
338
|
}
|
|
339
339
|
});
|
|
@@ -41,7 +41,7 @@ module.exports = function setupMembersApp() {
|
|
|
41
41
|
// We don't want to add global bodyParser middleware as that interferes with stripe webhook requests on - `/webhooks`.
|
|
42
42
|
|
|
43
43
|
// Manage newsletter subscription via unsubscribe link - these should be authenticated by uuid and hashed key
|
|
44
|
-
membersApp.get('/api/member/newsletters',
|
|
44
|
+
membersApp.get('/api/member/newsletters',
|
|
45
45
|
middleware.authMemberByUuid,
|
|
46
46
|
middleware.getMemberNewsletters
|
|
47
47
|
);
|
|
@@ -59,7 +59,7 @@ module.exports = function setupMembersApp() {
|
|
|
59
59
|
} else {
|
|
60
60
|
membersApp.get('/api/member', middleware.getMemberData);
|
|
61
61
|
}
|
|
62
|
-
|
|
62
|
+
|
|
63
63
|
membersApp.put('/api/member', bodyParser.json({limit: '50mb'}), middleware.updateMemberData);
|
|
64
64
|
membersApp.post('/api/member/email', bodyParser.json({limit: '50mb'}), (req, res, next) => membersService.api.middleware.updateEmailAddress(req, res, next));
|
|
65
65
|
|
|
@@ -72,7 +72,6 @@ module.exports = function setupMembersApp() {
|
|
|
72
72
|
|
|
73
73
|
membersApp.get('/api/integrity-token', middleware.createIntegrityToken);
|
|
74
74
|
|
|
75
|
-
// NOTE: this is wrapped in a function to ensure we always go via the getter
|
|
76
75
|
membersApp.post(
|
|
77
76
|
'/api/send-magic-link',
|
|
78
77
|
bodyParser.json(),
|
|
@@ -81,10 +80,20 @@ module.exports = function setupMembersApp() {
|
|
|
81
80
|
shared.middleware.brute.membersAuthEnumeration,
|
|
82
81
|
// Prevent brute forcing passwords for the same email address
|
|
83
82
|
shared.middleware.brute.membersAuth,
|
|
83
|
+
// NOTE: this is wrapped in a function to ensure we always go via the getter
|
|
84
84
|
function lazySendMagicLinkMw(req, res, next) {
|
|
85
85
|
return membersService.api.middleware.sendMagicLink(req, res, next);
|
|
86
86
|
}
|
|
87
87
|
);
|
|
88
|
+
membersApp.post(
|
|
89
|
+
'/api/verify-otc',
|
|
90
|
+
bodyParser.json(),
|
|
91
|
+
middleware.verifyIntegrityToken,
|
|
92
|
+
// NOTE: this is wrapped in a function to ensure we always go via the getter
|
|
93
|
+
function lazyVerifyOTCMw(req, res, next) {
|
|
94
|
+
return membersService.api.middleware.verifyOTC(req, res, next);
|
|
95
|
+
}
|
|
96
|
+
);
|
|
88
97
|
membersApp.post('/api/create-stripe-checkout-session', function lazyCreateCheckoutSessionMw(req, res, next) {
|
|
89
98
|
return membersService.api.middleware.createCheckoutSession(req, res, next);
|
|
90
99
|
});
|
|
@@ -212,7 +212,7 @@
|
|
|
212
212
|
},
|
|
213
213
|
"portal": {
|
|
214
214
|
"url": "https://cdn.jsdelivr.net/ghost/portal@~{version}/umd/portal.min.js",
|
|
215
|
-
"version": "2.
|
|
215
|
+
"version": "2.53"
|
|
216
216
|
},
|
|
217
217
|
"sodoSearch": {
|
|
218
218
|
"url": "https://cdn.jsdelivr.net/ghost/sodo-search@~{version}/umd/sodo-search.min.js",
|
package/core/shared/labs.js
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ghost",
|
|
3
|
-
"version": "6.0.
|
|
3
|
+
"version": "6.0.7",
|
|
4
4
|
"description": "The professional publishing platform",
|
|
5
5
|
"author": "Ghost Foundation",
|
|
6
6
|
"homepage": "https://ghost.org",
|
|
@@ -86,7 +86,7 @@
|
|
|
86
86
|
"@tryghost/helpers": "1.1.97",
|
|
87
87
|
"@tryghost/html-to-plaintext": "1.0.4",
|
|
88
88
|
"@tryghost/http-cache-utils": "0.1.20",
|
|
89
|
-
"@tryghost/i18n": "file:components/tryghost-i18n-6.0.
|
|
89
|
+
"@tryghost/i18n": "file:components/tryghost-i18n-6.0.7.tgz",
|
|
90
90
|
"@tryghost/image-transform": "1.4.6",
|
|
91
91
|
"@tryghost/job-manager": "1.0.3",
|
|
92
92
|
"@tryghost/kg-card-factory": "5.1.2",
|
|
@@ -181,7 +181,7 @@
|
|
|
181
181
|
"knex-migrator": "5.3.2",
|
|
182
182
|
"leaky-bucket": "2.2.0",
|
|
183
183
|
"lodash": "4.17.21",
|
|
184
|
-
"luxon": "3.7.
|
|
184
|
+
"luxon": "3.7.2",
|
|
185
185
|
"mailgun.js": "10.4.0",
|
|
186
186
|
"metascraper": "5.45.15",
|
|
187
187
|
"metascraper-author": "5.45.10",
|
|
@@ -232,7 +232,7 @@
|
|
|
232
232
|
"@types/bookshelf": "1.2.9",
|
|
233
233
|
"@types/common-tags": "1.8.4",
|
|
234
234
|
"@types/jsonwebtoken": "9.0.10",
|
|
235
|
-
"@types/node": "22.18.
|
|
235
|
+
"@types/node": "22.18.1",
|
|
236
236
|
"@types/node-jose": "1.1.13",
|
|
237
237
|
"@types/nodemailer": "6.4.19",
|
|
238
238
|
"@types/sinon": "17.0.4",
|
|
@@ -250,7 +250,7 @@
|
|
|
250
250
|
"inquirer": "8.2.7",
|
|
251
251
|
"jwk-to-pem": "2.0.7",
|
|
252
252
|
"jwks-rsa": "3.2.0",
|
|
253
|
-
"mocha": "11.7.
|
|
253
|
+
"mocha": "11.7.2",
|
|
254
254
|
"mocha-slow-test-reporter": "0.1.2",
|
|
255
255
|
"mock-knex": "TryGhost/mock-knex#68948e11b0ea4fe63456098dfdc169bea7f62009",
|
|
256
256
|
"nock": "13.5.6",
|
|
@@ -273,7 +273,7 @@
|
|
|
273
273
|
"jackspeak": "2.3.6",
|
|
274
274
|
"moment": "2.24.0",
|
|
275
275
|
"moment-timezone": "0.5.45",
|
|
276
|
-
"@tryghost/i18n": "file:components/tryghost-i18n-6.0.
|
|
276
|
+
"@tryghost/i18n": "file:components/tryghost-i18n-6.0.7.tgz"
|
|
277
277
|
},
|
|
278
278
|
"nx": {
|
|
279
279
|
"targets": {
|