ghost 4.41.2 → 4.42.1
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/core/boot.js +24 -6
- package/core/built/assets/ghost-dark-a93afb20027060d760ac6d78f115a76f.css +1 -0
- package/core/built/assets/{ghost.min-8e2e6c7a01fde044c566c1650a36bfc2.js → ghost.min-20096eef632760c3a2906e243adbd24b.js} +1035 -841
- package/core/built/assets/ghost.min-ce35ef1b76d9a943ab912c076773b132.css +1 -0
- package/core/built/assets/{vendor.min-9094db77ba3190cb10876f8e42e1d90d.js → vendor.min-21f79c68a284acb1b70039f3f63e5507.js} +68 -68
- package/core/built/assets/{vendor.min-2c8ad32b7960bb605ebc20097fee5ebd.css → vendor.min-ba66b98f7c24fa40e061c7ffc94f4e23.css} +214 -0
- package/core/frontend/helpers/price.js +1 -0
- package/core/frontend/web/middleware/error-handler.js +5 -3
- package/core/server/api/canary/email-preview.js +2 -1
- package/core/server/api/canary/{email.js → emails.js} +0 -0
- package/core/server/api/canary/index.js +11 -3
- package/core/server/api/canary/{memberSigninUrls.js → member-signin-urls.js} +0 -1
- package/core/server/api/canary/{membersStripeConnect.js → members-stripe-connect.js} +0 -0
- package/core/server/api/canary/members.js +0 -45
- package/core/server/api/canary/newsletters.js +45 -0
- package/core/server/api/canary/stats.js +14 -0
- package/core/server/api/canary/utils/serializers/output/authentication.js +4 -0
- package/core/server/api/canary/utils/serializers/output/default.js +35 -0
- package/core/server/api/canary/utils/serializers/output/email-previews.js +7 -0
- package/core/server/api/canary/utils/serializers/output/index.js +18 -42
- package/core/server/api/canary/utils/serializers/output/mappers/authors.js +1 -0
- package/core/server/api/canary/utils/serializers/output/mappers/index.js +2 -1
- package/core/server/api/canary/utils/serializers/output/mappers/integrations.js +1 -1
- package/core/server/api/canary/utils/serializers/output/mappers/snippets.js +36 -0
- package/core/server/api/canary/utils/serializers/output/members-stripe-connect.js +6 -0
- package/core/server/api/canary/utils/serializers/output/members.js +2 -2
- package/core/server/api/canary/utils/serializers/output/oembed.js +2 -2
- package/core/server/api/canary/utils/serializers/output/offers.js +8 -0
- package/core/server/api/canary/utils/serializers/output/redirects.js +2 -2
- package/core/server/api/canary/utils/serializers/output/schedules.js +2 -2
- package/core/server/api/canary/utils/serializers/output/session.js +9 -0
- package/core/server/api/canary/utils/serializers/output/settings.js +64 -37
- package/core/server/api/canary/utils/serializers/output/slack.js +9 -0
- package/core/server/api/canary/utils/serializers/output/themes.js +3 -24
- package/core/server/api/canary/utils/serializers/output/users.js +0 -23
- package/core/server/api/shared/serializers/handle.js +25 -11
- package/core/server/data/exporter/table-lists.js +1 -0
- package/core/server/data/migrations/utils.js +1 -1
- package/core/server/data/migrations/versions/4.42/2022-03-21-17-17-add.js +20 -0
- package/core/server/data/migrations/versions/4.42/2022-03-30-15-44-add-newsletter-permissions.js +28 -0
- package/core/server/data/schema/commands.js +13 -13
- package/core/server/data/schema/schema.js +18 -0
- package/core/server/models/newsletter.js +9 -0
- package/core/server/services/mega/template.js +25 -13
- package/core/server/services/members/service.js +2 -1
- package/core/server/services/offers/service.js +11 -8
- package/core/server/services/stats/index.js +1 -0
- package/core/server/services/stats/lib/members-stats-service.js +165 -0
- package/core/server/services/stats/service.js +6 -0
- package/core/server/services/themes/validate.js +4 -3
- package/core/server/services/webhooks/webhooks-service.js +3 -1
- package/core/server/web/admin/app.js +8 -0
- package/core/server/web/admin/views/default-prod.html +5 -5
- package/core/server/web/admin/views/default.html +5 -5
- package/core/server/web/api/canary/admin/routes.js +8 -2
- package/core/shared/config/defaults.json +2 -2
- package/core/shared/config/env/config.development.json +26 -0
- package/core/shared/config/env/config.production.json +21 -0
- package/core/shared/config/env/config.testing-mysql.json +59 -0
- package/core/shared/config/env/config.testing.json +58 -0
- package/core/shared/labs.js +3 -1
- package/core/shared/settings-cache/cache.js +1 -1
- package/package.json +62 -62
- package/yarn.lock +1586 -1757
- package/.c8rc.json +0 -34
- package/.eslintrc.js +0 -118
- package/core/built/assets/ghost-dark-6fbe502f2bb2cde92e15b2f1a9da57a0.css +0 -1
- package/core/built/assets/ghost.min-09301e5bd933cf6d24368e98a4d898a9.css +0 -1
- package/core/server/api/canary/utils/serializers/output/actions.js +0 -13
- package/core/server/api/canary/utils/serializers/output/authors.js +0 -21
- package/core/server/api/canary/utils/serializers/output/email-preview.js +0 -7
- package/core/server/api/canary/utils/serializers/output/emails.js +0 -22
- package/core/server/api/canary/utils/serializers/output/identities.js +0 -7
- package/core/server/api/canary/utils/serializers/output/integrations.js +0 -34
- package/core/server/api/canary/utils/serializers/output/invites.js +0 -24
- package/core/server/api/canary/utils/serializers/output/labels.js +0 -25
- package/core/server/api/canary/utils/serializers/output/mappers/labels.js +0 -4
- package/core/server/api/canary/utils/serializers/output/member-signin_urls.js +0 -7
- package/core/server/api/canary/utils/serializers/output/snippets.js +0 -97
- package/core/server/api/canary/utils/serializers/output/tags.js +0 -25
- package/core/server/api/canary/utils/serializers/output/webhooks.js +0 -15
- package/jsconfig.json +0 -13
package/core/boot.js
CHANGED
|
@@ -25,9 +25,18 @@ class BootLogger {
|
|
|
25
25
|
let {logging, startTime} = this;
|
|
26
26
|
logging.info(`Ghost ${message} in ${(Date.now() - startTime) / 1000}s`);
|
|
27
27
|
}
|
|
28
|
-
|
|
28
|
+
/**
|
|
29
|
+
* @param {string} name
|
|
30
|
+
* @param {number} [initialTime]
|
|
31
|
+
*/
|
|
32
|
+
metric(name, initialTime) {
|
|
29
33
|
let {metrics, startTime} = this;
|
|
30
|
-
|
|
34
|
+
|
|
35
|
+
if (!initialTime) {
|
|
36
|
+
initialTime = startTime;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
metrics.metric(name, Date.now() - initialTime);
|
|
31
40
|
}
|
|
32
41
|
}
|
|
33
42
|
|
|
@@ -126,8 +135,11 @@ async function initCore({ghostServer, config, bootLogger, frontend}) {
|
|
|
126
135
|
|
|
127
136
|
/**
|
|
128
137
|
* These are services required by Ghost's frontend.
|
|
138
|
+
* @param {object} options
|
|
139
|
+
* @param {object} options.bootLogger
|
|
140
|
+
|
|
129
141
|
*/
|
|
130
|
-
async function initServicesForFrontend() {
|
|
142
|
+
async function initServicesForFrontend({bootLogger}) {
|
|
131
143
|
debug('Begin: initServicesForFrontend');
|
|
132
144
|
|
|
133
145
|
debug('Begin: Routing Settings');
|
|
@@ -144,10 +156,18 @@ async function initServicesForFrontend() {
|
|
|
144
156
|
// customThemSettingsService.api must be initialized before any theme activation occurs
|
|
145
157
|
const customThemeSettingsService = require('./server/services/custom-theme-settings');
|
|
146
158
|
customThemeSettingsService.init();
|
|
159
|
+
|
|
147
160
|
const themeService = require('./server/services/themes');
|
|
161
|
+
const themeServiceStart = Date.now();
|
|
148
162
|
await themeService.init();
|
|
163
|
+
bootLogger.metric('theme-service-init', themeServiceStart);
|
|
149
164
|
debug('End: Themes');
|
|
150
165
|
|
|
166
|
+
debug('Begin: Offers');
|
|
167
|
+
const offers = require('./server/services/offers');
|
|
168
|
+
await offers.init();
|
|
169
|
+
debug('End: Offers');
|
|
170
|
+
|
|
151
171
|
debug('End: initServicesForFrontend');
|
|
152
172
|
}
|
|
153
173
|
|
|
@@ -239,7 +259,6 @@ async function initServices({config}) {
|
|
|
239
259
|
debug('Begin: Services');
|
|
240
260
|
const stripe = require('./server/services/stripe');
|
|
241
261
|
const members = require('./server/services/members');
|
|
242
|
-
const offers = require('./server/services/offers');
|
|
243
262
|
const permissions = require('./server/services/permissions');
|
|
244
263
|
const xmlrpc = require('./server/services/xmlrpc');
|
|
245
264
|
const slack = require('./server/services/slack');
|
|
@@ -258,7 +277,6 @@ async function initServices({config}) {
|
|
|
258
277
|
// NOTE: Members service depends on these
|
|
259
278
|
// so they are initialized before it.
|
|
260
279
|
await stripe.init();
|
|
261
|
-
await offers.init();
|
|
262
280
|
|
|
263
281
|
await Promise.all([
|
|
264
282
|
members.init(),
|
|
@@ -398,7 +416,7 @@ async function bootGhost({backend = true, frontend = true, server = true} = {})
|
|
|
398
416
|
// Step 4 - Load Ghost with all its services
|
|
399
417
|
debug('Begin: Load Ghost Services & Apps');
|
|
400
418
|
await initCore({ghostServer, config, bootLogger, frontend});
|
|
401
|
-
await initServicesForFrontend();
|
|
419
|
+
await initServicesForFrontend({bootLogger});
|
|
402
420
|
|
|
403
421
|
if (frontend) {
|
|
404
422
|
await initFrontend();
|