ghost 4.47.4 → 5.0.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/Gruntfile.js +24 -24
- package/README.md +3 -2
- package/content/themes/casper/assets/built/global.css +1 -1
- package/content/themes/casper/assets/built/global.css.map +1 -1
- package/content/themes/casper/assets/built/screen.css +1 -1
- package/content/themes/casper/assets/built/screen.css.map +1 -1
- package/content/themes/casper/assets/css/global.css +2 -2
- package/content/themes/casper/assets/css/screen.css +412 -664
- package/content/themes/casper/author.hbs +48 -35
- package/content/themes/casper/default.hbs +5 -23
- package/content/themes/casper/error-404.hbs +1 -1
- package/content/themes/casper/index.hbs +29 -22
- package/content/themes/casper/package.json +25 -37
- package/content/themes/casper/page.hbs +12 -12
- package/content/themes/casper/partials/icons/facebook.hbs +1 -1
- package/content/themes/casper/partials/icons/twitter.hbs +1 -1
- package/content/themes/casper/partials/post-card.hbs +26 -40
- package/content/themes/casper/post.hbs +54 -50
- package/content/themes/casper/tag.hbs +42 -47
- package/core/boot.js +18 -15
- package/core/bridge.js +24 -25
- package/core/built/assets/ghost-dark-b6e3268bcae976a8675b0d9ae54540f2.css +1 -0
- package/core/built/assets/{ghost.min-a2a47979b0b61d15a3914042a7b1cd20.js → ghost.min-2cc3688ea6600a54e0cd83107a8577e8.js} +1138 -1212
- package/core/built/assets/ghost.min-a40c7b301c702bd84c2fae19366ab5d7.css +1 -0
- package/core/built/assets/icons/analytics.svg +14 -0
- package/core/built/assets/icons/calendar.svg +4 -1
- package/core/built/assets/icons/email-at.svg +1 -1
- package/core/built/assets/icons/email-name.svg +1 -1
- package/core/built/assets/icons/info.svg +1 -1
- package/core/built/assets/icons/twitter-logo.svg +3 -0
- package/core/built/assets/{vendor.min-97fd438f4772c5ec6bb30ad779b8530e.js → vendor.min-2bca41946dea27dc292428db605d466d.js} +99 -93
- package/core/cli/README.md +88 -0
- package/core/cli/command.js +129 -0
- package/core/cli/repl.js +32 -0
- package/core/cli/timetravel.js +87 -0
- package/core/frontend/apps/amp/lib/helpers/amp_content.js +10 -12
- package/core/frontend/apps/amp/lib/router.js +2 -3
- package/core/frontend/helpers/body_class.js +2 -2
- package/core/frontend/helpers/excerpt.js +0 -2
- package/core/frontend/helpers/get.js +23 -24
- package/core/frontend/helpers/ghost_head.js +104 -108
- package/core/frontend/helpers/navigation.js +0 -2
- package/core/frontend/helpers/prev_post.js +20 -26
- package/core/frontend/helpers/price.js +2 -2
- package/core/frontend/meta/author-url.js +2 -2
- package/core/frontend/meta/description.js +3 -3
- package/core/frontend/meta/excerpt.js +1 -2
- package/core/frontend/meta/generate-excerpt.js +2 -11
- package/core/frontend/meta/paginated-url.js +1 -1
- package/core/frontend/meta/rss-url.js +0 -1
- package/core/frontend/meta/url.js +4 -4
- package/core/frontend/services/data/entry-lookup.js +1 -1
- package/core/frontend/services/data/fetch-data.js +1 -1
- package/core/frontend/services/helpers/handlebars.js +11 -12
- package/core/frontend/services/proxy.js +11 -1
- package/core/frontend/services/rendering/context.js +1 -5
- package/core/frontend/services/rendering/format-response.js +9 -2
- package/core/frontend/services/rendering/index.js +0 -4
- package/core/frontend/services/rendering/render-entry.js +1 -1
- package/core/frontend/services/rendering/templates.js +15 -5
- package/core/frontend/services/routing/CollectionRouter.js +2 -2
- package/core/frontend/services/routing/EmailRouter.js +2 -2
- package/core/frontend/services/routing/ParentRouter.js +1 -1
- package/core/frontend/services/routing/PreviewRouter.js +3 -3
- package/core/frontend/services/routing/{config/v4.js → config.js} +3 -5
- package/core/frontend/services/routing/controllers/channel.js +0 -10
- package/core/frontend/services/routing/controllers/collection.js +0 -9
- package/core/frontend/services/routing/controllers/email-post.js +2 -7
- package/core/frontend/services/routing/controllers/entry.js +1 -3
- package/core/frontend/services/routing/controllers/index.js +2 -2
- package/core/frontend/services/routing/controllers/{preview.js → previews.js} +3 -8
- package/core/frontend/services/routing/controllers/static.js +1 -6
- package/core/frontend/services/routing/router-manager.js +38 -20
- package/core/frontend/services/rss/generate-feed.js +7 -9
- package/core/frontend/services/theme-engine/active.js +0 -8
- package/core/frontend/services/theme-engine/config/defaults.json +1 -3
- package/core/frontend/services/theme-engine/middleware/index.js +0 -1
- package/core/frontend/services/theme-engine/middleware/update-global-template-options.js +0 -69
- package/core/frontend/services/theme-engine/middleware/update-local-template-options.js +3 -6
- package/core/frontend/web/middleware/static-theme.js +14 -6
- package/core/frontend/web/routes.js +9 -9
- package/core/frontend/web/site.js +15 -18
- package/core/server/adapters/scheduling/post-scheduling/index.js +1 -1
- package/core/server/api/README.md +2 -6
- package/core/server/api/canary/authentication.js +4 -3
- package/core/server/api/canary/{email-preview.js → email-previews.js} +9 -8
- package/core/server/api/canary/index.js +14 -18
- package/core/server/api/canary/members.js +4 -24
- package/core/server/api/{v3/actions.js → canary/newsletters-public.js} +6 -6
- package/core/server/api/canary/newsletters.js +1 -13
- package/core/server/api/canary/notifications.js +17 -22
- package/core/server/api/canary/offers-public.js +28 -0
- package/core/server/api/canary/pages.js +1 -1
- package/core/server/api/canary/posts.js +4 -8
- package/core/server/api/canary/{preview.js → previews.js} +1 -1
- package/core/server/api/canary/schedules.js +1 -1
- package/core/server/api/canary/session.js +1 -1
- package/core/server/api/canary/settings-public.js +3 -1
- package/core/server/api/canary/settings.js +30 -16
- package/core/server/api/canary/utils/index.js +2 -4
- package/core/server/api/canary/utils/serializers/input/index.js +0 -4
- package/core/server/api/canary/utils/serializers/input/members.js +46 -17
- package/core/server/api/canary/utils/serializers/input/pages.js +0 -17
- package/core/server/api/canary/utils/serializers/input/posts.js +1 -28
- package/core/server/api/canary/utils/serializers/input/settings.js +61 -142
- package/core/server/api/canary/utils/serializers/input/tiers.js +56 -12
- package/core/server/api/canary/utils/serializers/output/authentication.js +2 -6
- package/core/server/api/canary/utils/serializers/output/index.js +2 -10
- package/core/server/api/canary/utils/serializers/output/mappers/index.js +1 -0
- package/core/server/api/canary/utils/serializers/output/mappers/newsletters.js +24 -0
- package/core/server/api/canary/utils/serializers/output/mappers/pages.js +1 -1
- package/core/server/api/canary/utils/serializers/output/mappers/posts.js +9 -7
- package/core/server/api/canary/utils/serializers/output/mappers/settings.js +5 -31
- package/core/server/api/canary/utils/serializers/output/members.js +21 -11
- package/core/server/api/canary/utils/serializers/output/offers.js +9 -1
- package/core/server/api/canary/utils/serializers/output/{preview.js → previews.js} +2 -2
- package/core/server/api/canary/utils/serializers/output/settings.js +6 -14
- package/core/server/api/canary/utils/serializers/output/site.js +0 -1
- package/core/server/api/canary/utils/serializers/output/tiers.js +35 -75
- package/core/server/api/canary/utils/serializers/output/utils/clean.js +5 -10
- package/core/server/api/canary/utils/serializers/output/utils/extra-attrs.js +0 -126
- package/core/server/api/canary/utils/serializers/output/utils/post-gating.js +1 -1
- package/core/server/api/canary/utils/serializers/output/utils/url.js +0 -5
- package/core/server/api/canary/utils/validators/input/index.js +2 -2
- package/core/server/api/canary/utils/validators/input/{passwordreset.js → password_reset.js} +2 -2
- package/core/server/api/canary/utils/validators/input/settings.js +2 -23
- package/core/server/api/canary/utils/validators/utils/json-schema.js +1 -2
- package/core/server/api/index.js +1 -7
- package/core/server/api/shared/serializers/input/utils/settings-key-group-mapper.js +2 -2
- package/core/server/api/shared/serializers/input/utils/settings-key-type-mapper.js +2 -4
- package/core/server/data/db/connection.js +0 -13
- package/core/server/data/exporter/index.js +4 -1
- package/core/server/data/exporter/table-lists.js +13 -15
- package/core/server/data/importer/importers/data/base.js +16 -7
- package/core/server/data/importer/importers/data/data-importer.js +38 -1
- package/core/server/data/importer/importers/data/newsletters.js +45 -0
- package/core/server/data/importer/importers/data/posts.js +40 -12
- package/core/server/data/importer/importers/data/products.js +68 -0
- package/core/server/data/importer/importers/data/settings.js +10 -10
- package/core/server/data/importer/importers/data/stripe-prices.js +59 -0
- package/core/server/data/importer/importers/data/stripe-products.js +61 -0
- package/core/server/data/migrations/utils/constants.js +3 -0
- package/core/server/data/migrations/utils/index.js +10 -0
- package/core/server/data/migrations/utils/migrations.js +156 -0
- package/core/server/data/migrations/utils/permissions.js +291 -0
- package/core/server/data/migrations/utils/schema.js +158 -0
- package/core/server/data/migrations/utils/settings.js +59 -0
- package/core/server/data/migrations/utils/tables.js +94 -0
- package/core/server/data/migrations/versions/1.25/01-final-v1.js +2 -0
- package/core/server/data/migrations/versions/1.25/02-noop.js +6 -0
- package/core/server/data/migrations/versions/2.37/01-final-v2.js +2 -0
- package/core/server/data/migrations/versions/3.41/01-final-v3.js +2 -0
- package/core/server/data/migrations/versions/4.0/22-solve-orphaned-webhooks.js +3 -9
- package/core/server/data/migrations/versions/4.0/23-regenerate-posts-html.js +2 -11
- package/core/server/data/migrations/versions/4.11/02-add-email-verification-required-setting.js +1 -1
- package/core/server/data/migrations/versions/4.12/02-fix-member-statuses.js +1 -1
- package/core/server/data/migrations/versions/4.14/02-fix-free-members-status-events.js +1 -1
- package/core/server/data/migrations/versions/4.22/01-add-is-launch-complete-setting.js +1 -1
- package/core/server/data/migrations/versions/4.22/02-update-launch-complete-setting-from-user-data.js +1 -1
- package/core/server/data/migrations/versions/4.35/2022-02-02-10-38-add-default-content-visibility-tiers-setting.js +1 -1
- package/core/server/data/migrations/versions/4.45/2022-04-21-02-55-add-notifications-key-entry-to-settings-table.js +1 -1
- package/core/server/data/migrations/versions/4.6/01-remove-comped-status.js +1 -1
- package/core/server/data/migrations/versions/4.7/03-add-labs-setting.js +1 -1
- package/core/server/data/migrations/versions/4.9/05-fix-missed-mobiledoc-url-transforms.js +1 -1
- package/core/server/data/migrations/versions/4.9/06-add-comped-status.js +1 -1
- package/core/server/data/migrations/versions/4.9/07-update-comped-members-status-events.js +1 -1
- package/core/server/data/migrations/versions/5.0/2022-03-14-12-33-delete-duplicate-offer-redemptions.js +36 -0
- package/core/server/data/migrations/versions/5.0/2022-03-28-15-25-backfill-mrr-adjustments-for-offers.js +108 -0
- package/core/server/data/migrations/versions/5.0/2022-04-25-10-32-backfill-mrr-for-discounted-subscriptions.js +44 -0
- package/core/server/data/migrations/versions/5.0/2022-04-26-15-44-backfill-mrr-events-for-canceled-subscriptions.js +73 -0
- package/core/server/data/migrations/versions/5.0/2022-04-27-11-26-backfill-mrr-for-canceled-subscriptions.js +31 -0
- package/core/server/data/migrations/versions/5.0/2022-04-28-03-26-remove-author-id-column-from-posts-table.js +7 -0
- package/core/server/data/migrations/versions/5.0/2022-05-03-09-39-drop-nullable-subscribe-event-newsletter-id.js +4 -0
- package/core/server/data/migrations/versions/5.0/2022-05-04-15-24-map-existing-emails-to-default-newsletter.js +44 -0
- package/core/server/data/migrations/versions/5.0/2022-05-05-13-13-migrate-legacy-recipient-filters.js +30 -0
- package/core/server/data/migrations/versions/5.0/2022-05-05-13-29-add-newsletters-admin-integration-permission-roles.js +20 -0
- package/core/server/data/migrations/versions/5.0/2022-05-05-15-17-drop-oauth-table.js +3 -0
- package/core/server/data/migrations/versions/5.0/2022-05-06-08-16-cleanup-client-subscriber-permissions.js +68 -0
- package/core/server/data/migrations/versions/5.0/2022-05-06-13-22-add-frontend-integration.js +68 -0
- package/core/server/data/migrations/versions/5.0/2022-05-09-10-00-drop-members-subscribed-column.js +18 -0
- package/core/server/data/migrations/versions/5.0/2022-05-09-14-17-cleanup-invalid-users-status.js +17 -0
- package/core/server/data/migrations/versions/5.0/2022-05-10-08-33-drop-members-analytics-table.js +3 -0
- package/core/server/data/migrations/versions/5.0/2022-05-10-14-57-cleanup-invalid-posts-status.js +17 -0
- package/core/server/data/migrations/versions/5.0/2022-05-11-12-08-drop-webhooks-status-column.js +18 -0
- package/core/server/data/migrations/versions/5.0/2022-05-11-13-12-rename-settings.js +51 -0
- package/core/server/data/migrations/versions/5.0/2022-05-11-16-36-remove-unused-settings.js +54 -0
- package/core/server/data/migrations/versions/5.0/2022-05-12-10-29-add-newsletter-permissions-for-editors-and-authors.js +20 -0
- package/core/server/data/migrations/versions/5.0/2022-05-12-13-51-add-label-permissions-for-authors.js +12 -0
- package/core/server/data/migrations/versions/5.0/2022-05-13-11-38-drop-none-email-recipient-filter.js +28 -0
- package/core/server/data/migrations/versions/5.0/2022-05-21-00-00-regenerate-posts-html.js +70 -0
- package/core/server/data/schema/commands.js +35 -3
- package/core/server/data/schema/default-settings/default-settings.json +2 -159
- package/core/server/data/schema/fixtures/fixture-manager.js +11 -2
- package/core/server/data/schema/fixtures/fixtures.json +16 -7
- package/core/server/data/schema/schema.js +26 -38
- package/core/server/data/schema/validator.js +2 -0
- package/core/server/ghost-server.js +34 -64
- package/core/server/lib/image/gravatar.js +25 -9
- package/core/server/models/api-key.js +3 -26
- package/core/server/models/base/plugins/bulk-operations.js +14 -6
- package/core/server/models/integration.js +17 -0
- package/core/server/models/member.js +8 -4
- package/core/server/models/newsletter.js +27 -0
- package/core/server/models/post.js +30 -32
- package/core/server/models/relations/authors.js +74 -100
- package/core/server/models/settings.js +6 -2
- package/core/server/models/webhook.js +2 -1
- package/core/server/run-update-check.js +1 -1
- package/core/server/services/api-version-compatibility/index.js +24 -18
- package/core/server/services/api-version-compatibility/legacy-api-path-match.js +23 -0
- package/core/server/services/api-version-compatibility/mw-version-rewrites.js +36 -0
- package/core/server/services/auth/api-key/admin.js +8 -7
- package/core/server/services/auth/passwordreset.js +3 -3
- package/core/server/services/auth/session/express-session.js +1 -1
- package/core/server/services/auth/session/index.js +1 -1
- package/core/server/services/auth/setup.js +8 -8
- package/core/server/services/bulk-email/bulk-email-processor.js +5 -1
- package/core/server/services/email-analytics/lib/event-processor.js +25 -14
- package/core/server/services/frontend-data-service/frontend-data-service.js +27 -0
- package/core/server/services/frontend-data-service/index.js +6 -0
- package/core/server/services/mail/index.js +14 -1
- package/core/server/services/mega/email-preview.js +14 -15
- package/core/server/services/mega/mega.js +37 -52
- package/core/server/services/mega/post-email-serializer.js +18 -28
- package/core/server/services/members/api.js +0 -3
- package/core/server/services/members/config.js +0 -49
- package/core/server/services/members/exporter/query.js +88 -0
- package/core/server/services/members/middleware.js +3 -135
- package/core/server/services/members/service.js +2 -29
- package/core/server/services/members/settings.js +3 -9
- package/core/server/services/newsletters/service.js +78 -10
- package/core/server/services/posts/post-scheduling-service.js +5 -17
- package/core/server/services/posts/posts-service.js +15 -62
- package/core/server/services/public-config/site.js +0 -6
- package/core/server/services/route-settings/index.js +0 -3
- package/core/server/services/route-settings/settings-loader.js +10 -34
- package/core/server/services/route-settings/validate.js +1 -7
- package/core/server/services/settings/index.js +1 -77
- package/core/server/services/settings/settings-service.js +184 -0
- package/core/server/services/themes/validate.js +1 -1
- package/core/server/services/url/Resources.js +1 -3
- package/core/server/services/url/UrlGenerator.js +1 -1
- package/core/server/services/url/UrlService.js +6 -20
- package/core/server/services/url/{configs/v2.js → config.js} +0 -0
- package/core/server/services/users.js +2 -2
- package/core/server/services/webhooks/listen.js +5 -2
- package/core/server/services/webhooks/serialize.js +6 -7
- package/core/server/services/webhooks/trigger.js +62 -47
- package/core/server/update-check.js +1 -1
- package/core/server/web/admin/app.js +1 -1
- package/core/server/web/admin/views/default-prod.html +4 -4
- package/core/server/web/admin/views/default.html +4 -4
- package/core/server/web/api/app.js +3 -15
- package/core/server/web/api/canary/admin/app.js +1 -1
- package/core/server/web/api/canary/admin/middleware.js +3 -1
- package/core/server/web/api/canary/admin/routes.js +7 -23
- package/core/server/web/api/canary/content/app.js +2 -3
- package/core/server/web/api/canary/content/routes.js +5 -4
- package/core/server/web/members/app.js +5 -4
- package/core/server/web/parent/backend.js +0 -1
- package/core/server/web/parent/frontend.js +5 -6
- package/core/server/web/parent/middleware/ghost-locals.js +0 -3
- package/core/server/web/well-known.js +14 -1
- package/core/shared/config/defaults.json +5 -2
- package/core/shared/config/overrides.json +1 -27
- package/core/shared/html-to-plaintext.js +78 -10
- package/core/shared/labs.js +4 -8
- package/core/shared/settings-cache/cache.js +38 -4
- package/core/shared/settings-cache/public.js +13 -7
- package/core/shared/url-utils.js +0 -2
- package/ghost.js +6 -0
- package/package.json +66 -64
- package/yarn.lock +765 -1300
- package/core/built/assets/ghost-dark-c94ae212747200ca4bafc37cfb0714d8.css +0 -1
- package/core/built/assets/ghost.min-4084931bc22e794fe3722139050a80b3.css +0 -1
- package/core/frontend/helpers/author.js +0 -41
- package/core/frontend/helpers/products.js +0 -65
- package/core/frontend/services/rendering/secure.js +0 -19
- package/core/frontend/services/routing/config/canary.js +0 -61
- package/core/frontend/services/routing/config/v2.js +0 -54
- package/core/frontend/services/routing/config/v3.js +0 -54
- package/core/frontend/services/theme-engine/engines/create.js +0 -45
- package/core/frontend/services/theme-engine/engines/index.js +0 -5
- package/core/frontend/services/theme-engine/middleware/update-local-template-data.js +0 -9
- package/core/server/api/canary/products-public.js +0 -34
- package/core/server/api/canary/products.js +0 -116
- package/core/server/api/canary/utils/serializers/input/products.js +0 -28
- package/core/server/api/canary/utils/serializers/output/email-previews.js +0 -7
- package/core/server/api/canary/utils/serializers/output/products.js +0 -213
- package/core/server/api/v2/actions.js +0 -38
- package/core/server/api/v2/authentication.js +0 -191
- package/core/server/api/v2/authors-public.js +0 -69
- package/core/server/api/v2/config.js +0 -12
- package/core/server/api/v2/db.js +0 -120
- package/core/server/api/v2/images.js +0 -20
- package/core/server/api/v2/index.js +0 -147
- package/core/server/api/v2/integrations.js +0 -144
- package/core/server/api/v2/invites.js +0 -126
- package/core/server/api/v2/mail.js +0 -66
- package/core/server/api/v2/notifications.js +0 -96
- package/core/server/api/v2/oembed.js +0 -186
- package/core/server/api/v2/pages-public.js +0 -78
- package/core/server/api/v2/pages.js +0 -197
- package/core/server/api/v2/posts-public.js +0 -78
- package/core/server/api/v2/posts.js +0 -192
- package/core/server/api/v2/preview.js +0 -46
- package/core/server/api/v2/redirects.js +0 -28
- package/core/server/api/v2/roles.js +0 -19
- package/core/server/api/v2/schedules.js +0 -77
- package/core/server/api/v2/session.js +0 -70
- package/core/server/api/v2/settings-public.js +0 -17
- package/core/server/api/v2/settings.js +0 -195
- package/core/server/api/v2/site.js +0 -14
- package/core/server/api/v2/slack.js +0 -12
- package/core/server/api/v2/slugs.js +0 -51
- package/core/server/api/v2/tags-public.js +0 -71
- package/core/server/api/v2/tags.js +0 -159
- package/core/server/api/v2/themes.js +0 -133
- package/core/server/api/v2/users.js +0 -179
- package/core/server/api/v2/utils/index.js +0 -34
- package/core/server/api/v2/utils/permissions.js +0 -112
- package/core/server/api/v2/utils/serializers/index.js +0 -9
- package/core/server/api/v2/utils/serializers/input/db.js +0 -20
- package/core/server/api/v2/utils/serializers/input/index.js +0 -33
- package/core/server/api/v2/utils/serializers/input/integrations.js +0 -33
- package/core/server/api/v2/utils/serializers/input/pages.js +0 -203
- package/core/server/api/v2/utils/serializers/input/posts.js +0 -218
- package/core/server/api/v2/utils/serializers/input/settings.js +0 -152
- package/core/server/api/v2/utils/serializers/input/tags.js +0 -35
- package/core/server/api/v2/utils/serializers/input/users.js +0 -26
- package/core/server/api/v2/utils/serializers/input/utils/url.js +0 -71
- package/core/server/api/v2/utils/serializers/input/webhooks.js +0 -12
- package/core/server/api/v2/utils/serializers/output/actions.js +0 -13
- package/core/server/api/v2/utils/serializers/output/all.js +0 -25
- package/core/server/api/v2/utils/serializers/output/authentication.js +0 -68
- package/core/server/api/v2/utils/serializers/output/authors.js +0 -21
- package/core/server/api/v2/utils/serializers/output/config.js +0 -21
- package/core/server/api/v2/utils/serializers/output/db.js +0 -40
- package/core/server/api/v2/utils/serializers/output/images.js +0 -19
- package/core/server/api/v2/utils/serializers/output/index.js +0 -107
- package/core/server/api/v2/utils/serializers/output/integrations.js +0 -35
- package/core/server/api/v2/utils/serializers/output/invites.js +0 -24
- package/core/server/api/v2/utils/serializers/output/mail.js +0 -19
- package/core/server/api/v2/utils/serializers/output/notifications.js +0 -29
- package/core/server/api/v2/utils/serializers/output/oembed.js +0 -8
- package/core/server/api/v2/utils/serializers/output/pages.js +0 -26
- package/core/server/api/v2/utils/serializers/output/posts.js +0 -26
- package/core/server/api/v2/utils/serializers/output/preview.js +0 -9
- package/core/server/api/v2/utils/serializers/output/redirects.js +0 -5
- package/core/server/api/v2/utils/serializers/output/roles.js +0 -29
- package/core/server/api/v2/utils/serializers/output/schedules.js +0 -5
- package/core/server/api/v2/utils/serializers/output/settings.js +0 -61
- package/core/server/api/v2/utils/serializers/output/site.js +0 -16
- package/core/server/api/v2/utils/serializers/output/slugs.js +0 -11
- package/core/server/api/v2/utils/serializers/output/tags.js +0 -25
- package/core/server/api/v2/utils/serializers/output/themes.js +0 -25
- package/core/server/api/v2/utils/serializers/output/users.js +0 -45
- package/core/server/api/v2/utils/serializers/output/utils/clean.js +0 -174
- package/core/server/api/v2/utils/serializers/output/utils/date.js +0 -21
- package/core/server/api/v2/utils/serializers/output/utils/extra-attrs.js +0 -161
- package/core/server/api/v2/utils/serializers/output/utils/mapper.js +0 -136
- package/core/server/api/v2/utils/serializers/output/utils/post-gating.js +0 -29
- package/core/server/api/v2/utils/serializers/output/utils/settings-type-group-mapper.js +0 -24
- package/core/server/api/v2/utils/serializers/output/utils/url.js +0 -67
- package/core/server/api/v2/utils/serializers/output/webhooks.js +0 -15
- package/core/server/api/v2/utils/validators/index.js +0 -9
- package/core/server/api/v2/utils/validators/input/images.js +0 -85
- package/core/server/api/v2/utils/validators/input/index.js +0 -45
- package/core/server/api/v2/utils/validators/input/invitations.js +0 -49
- package/core/server/api/v2/utils/validators/input/invites.js +0 -21
- package/core/server/api/v2/utils/validators/input/oembed.js +0 -17
- package/core/server/api/v2/utils/validators/input/pages.js +0 -46
- package/core/server/api/v2/utils/validators/input/passwordreset.js +0 -36
- package/core/server/api/v2/utils/validators/input/posts.js +0 -46
- package/core/server/api/v2/utils/validators/input/settings.js +0 -79
- package/core/server/api/v2/utils/validators/input/setup.js +0 -17
- package/core/server/api/v2/utils/validators/input/tags.js +0 -6
- package/core/server/api/v2/utils/validators/input/users.js +0 -21
- package/core/server/api/v2/utils/validators/output/index.js +0 -1
- package/core/server/api/v2/utils/validators/utils/json-schema.js +0 -17
- package/core/server/api/v2/webhooks.js +0 -163
- package/core/server/api/v3/authentication.js +0 -192
- package/core/server/api/v3/authors-public.js +0 -69
- package/core/server/api/v3/config.js +0 -12
- package/core/server/api/v3/db.js +0 -131
- package/core/server/api/v3/email-preview.js +0 -74
- package/core/server/api/v3/email.js +0 -65
- package/core/server/api/v3/identities.js +0 -36
- package/core/server/api/v3/images.js +0 -20
- package/core/server/api/v3/index.js +0 -179
- package/core/server/api/v3/integrations.js +0 -150
- package/core/server/api/v3/invites.js +0 -125
- package/core/server/api/v3/labels.js +0 -162
- package/core/server/api/v3/mail.js +0 -66
- package/core/server/api/v3/memberSigninUrls.js +0 -33
- package/core/server/api/v3/members.js +0 -412
- package/core/server/api/v3/membersStripeConnect.js +0 -29
- package/core/server/api/v3/notifications.js +0 -96
- package/core/server/api/v3/oembed.js +0 -23
- package/core/server/api/v3/pages-public.js +0 -77
- package/core/server/api/v3/pages.js +0 -199
- package/core/server/api/v3/posts-public.js +0 -76
- package/core/server/api/v3/posts.js +0 -200
- package/core/server/api/v3/preview.js +0 -44
- package/core/server/api/v3/redirects.js +0 -47
- package/core/server/api/v3/roles.js +0 -19
- package/core/server/api/v3/schedules.js +0 -77
- package/core/server/api/v3/session.js +0 -70
- package/core/server/api/v3/settings-public.js +0 -17
- package/core/server/api/v3/settings.js +0 -224
- package/core/server/api/v3/site.js +0 -14
- package/core/server/api/v3/slack.js +0 -12
- package/core/server/api/v3/slugs.js +0 -48
- package/core/server/api/v3/snippets.js +0 -115
- package/core/server/api/v3/tags-public.js +0 -71
- package/core/server/api/v3/tags.js +0 -159
- package/core/server/api/v3/themes.js +0 -131
- package/core/server/api/v3/users.js +0 -242
- package/core/server/api/v3/utils/index.js +0 -34
- package/core/server/api/v3/utils/permissions.js +0 -116
- package/core/server/api/v3/utils/serializers/index.js +0 -9
- package/core/server/api/v3/utils/serializers/input/authors.js +0 -31
- package/core/server/api/v3/utils/serializers/input/db.js +0 -20
- package/core/server/api/v3/utils/serializers/input/index.js +0 -41
- package/core/server/api/v3/utils/serializers/input/integrations.js +0 -33
- package/core/server/api/v3/utils/serializers/input/members.js +0 -62
- package/core/server/api/v3/utils/serializers/input/pages.js +0 -208
- package/core/server/api/v3/utils/serializers/input/posts.js +0 -242
- package/core/server/api/v3/utils/serializers/input/settings.js +0 -168
- package/core/server/api/v3/utils/serializers/input/tags.js +0 -42
- package/core/server/api/v3/utils/serializers/input/users.js +0 -26
- package/core/server/api/v3/utils/serializers/input/utils/slug-filter-order.js +0 -18
- package/core/server/api/v3/utils/serializers/input/utils/url.js +0 -71
- package/core/server/api/v3/utils/serializers/input/webhooks.js +0 -12
- package/core/server/api/v3/utils/serializers/output/actions.js +0 -13
- package/core/server/api/v3/utils/serializers/output/all.js +0 -25
- package/core/server/api/v3/utils/serializers/output/authentication.js +0 -69
- package/core/server/api/v3/utils/serializers/output/authors.js +0 -21
- package/core/server/api/v3/utils/serializers/output/config.js +0 -25
- package/core/server/api/v3/utils/serializers/output/db.js +0 -40
- package/core/server/api/v3/utils/serializers/output/email-preview.js +0 -7
- package/core/server/api/v3/utils/serializers/output/emails.js +0 -13
- package/core/server/api/v3/utils/serializers/output/identities.js +0 -7
- package/core/server/api/v3/utils/serializers/output/images.js +0 -19
- package/core/server/api/v3/utils/serializers/output/index.js +0 -135
- package/core/server/api/v3/utils/serializers/output/integrations.js +0 -35
- package/core/server/api/v3/utils/serializers/output/invites.js +0 -24
- package/core/server/api/v3/utils/serializers/output/labels.js +0 -25
- package/core/server/api/v3/utils/serializers/output/mail.js +0 -19
- package/core/server/api/v3/utils/serializers/output/member-signin_urls.js +0 -7
- package/core/server/api/v3/utils/serializers/output/members.js +0 -228
- package/core/server/api/v3/utils/serializers/output/notifications.js +0 -29
- package/core/server/api/v3/utils/serializers/output/oembed.js +0 -8
- package/core/server/api/v3/utils/serializers/output/pages.js +0 -26
- package/core/server/api/v3/utils/serializers/output/posts.js +0 -26
- package/core/server/api/v3/utils/serializers/output/preview.js +0 -10
- package/core/server/api/v3/utils/serializers/output/redirects.js +0 -5
- package/core/server/api/v3/utils/serializers/output/roles.js +0 -29
- package/core/server/api/v3/utils/serializers/output/schedules.js +0 -5
- package/core/server/api/v3/utils/serializers/output/settings.js +0 -65
- package/core/server/api/v3/utils/serializers/output/site.js +0 -19
- package/core/server/api/v3/utils/serializers/output/slugs.js +0 -11
- package/core/server/api/v3/utils/serializers/output/snippets.js +0 -97
- package/core/server/api/v3/utils/serializers/output/tags.js +0 -25
- package/core/server/api/v3/utils/serializers/output/themes.js +0 -25
- package/core/server/api/v3/utils/serializers/output/users.js +0 -74
- package/core/server/api/v3/utils/serializers/output/utils/clean.js +0 -166
- package/core/server/api/v3/utils/serializers/output/utils/date.js +0 -21
- package/core/server/api/v3/utils/serializers/output/utils/extra-attrs.js +0 -174
- package/core/server/api/v3/utils/serializers/output/utils/mapper.js +0 -197
- package/core/server/api/v3/utils/serializers/output/utils/post-gating.js +0 -39
- package/core/server/api/v3/utils/serializers/output/utils/settings-type-group-mapper.js +0 -24
- package/core/server/api/v3/utils/serializers/output/utils/url.js +0 -67
- package/core/server/api/v3/utils/serializers/output/webhooks.js +0 -15
- package/core/server/api/v3/utils/validators/index.js +0 -9
- package/core/server/api/v3/utils/validators/input/images.js +0 -85
- package/core/server/api/v3/utils/validators/input/index.js +0 -61
- package/core/server/api/v3/utils/validators/input/invitations.js +0 -49
- package/core/server/api/v3/utils/validators/input/invites.js +0 -21
- package/core/server/api/v3/utils/validators/input/labels.js +0 -6
- package/core/server/api/v3/utils/validators/input/members.js +0 -6
- package/core/server/api/v3/utils/validators/input/oembed.js +0 -17
- package/core/server/api/v3/utils/validators/input/pages.js +0 -46
- package/core/server/api/v3/utils/validators/input/passwordreset.js +0 -36
- package/core/server/api/v3/utils/validators/input/posts.js +0 -46
- package/core/server/api/v3/utils/validators/input/settings.js +0 -89
- package/core/server/api/v3/utils/validators/input/setup.js +0 -17
- package/core/server/api/v3/utils/validators/input/snippets.js +0 -6
- package/core/server/api/v3/utils/validators/input/tags.js +0 -6
- package/core/server/api/v3/utils/validators/input/users.js +0 -22
- package/core/server/api/v3/utils/validators/input/webhooks.js +0 -27
- package/core/server/api/v3/utils/validators/output/index.js +0 -1
- package/core/server/api/v3/utils/validators/utils/json-schema.js +0 -17
- package/core/server/api/v3/webhooks.js +0 -130
- package/core/server/data/migrations/utils.js +0 -571
- package/core/server/data/migrations/versions/1.13/1-custom-template-post.js +0 -7
- package/core/server/data/migrations/versions/1.13/2-theme-permissions.js +0 -58
- package/core/server/data/migrations/versions/1.18/1-add-webhooks-table.js +0 -2
- package/core/server/data/migrations/versions/1.19/1-webhook-permissions.js +0 -31
- package/core/server/data/migrations/versions/1.20/1-remove-settings-keys.js +0 -65
- package/core/server/data/migrations/versions/1.21/1-add-contributor-role.js +0 -58
- package/core/server/data/migrations/versions/1.22/1-multiple-authors-DDL.js +0 -2
- package/core/server/data/migrations/versions/1.22/1-multiple-authors-DML.js +0 -63
- package/core/server/data/migrations/versions/1.25/1-update-koenig-beta-html.js +0 -70
- package/core/server/data/migrations/versions/1.25/2-demo-post.js +0 -55
- package/core/server/data/migrations/versions/1.3/1-post-excerpt.js +0 -7
- package/core/server/data/migrations/versions/1.4/1-codeinjection-post.js +0 -14
- package/core/server/data/migrations/versions/1.5/1-og-twitter-post.js +0 -34
- package/core/server/data/migrations/versions/1.7/1-add-backup-client.js +0 -10
- package/core/server/data/migrations/versions/1.9/1-add-permissions-redirect.js +0 -23
- package/core/server/data/migrations/versions/2.0/1-rename-amp-column.js +0 -44
- package/core/server/data/migrations/versions/2.0/2-update-posts.js +0 -7
- package/core/server/data/migrations/versions/2.0/3-remove-koenig-labs.js +0 -42
- package/core/server/data/migrations/versions/2.0/4-permalink-setting.js +0 -85
- package/core/server/data/migrations/versions/2.0/5-remove-demo-post.js +0 -85
- package/core/server/data/migrations/versions/2.0/6-replace-fixture-posts.js +0 -10
- package/core/server/data/migrations/versions/2.13/1-remove-empty-strings.js +0 -5
- package/core/server/data/migrations/versions/2.14/1-add-actions-table.js +0 -2
- package/core/server/data/migrations/versions/2.14/2-add-actions-permissions.js +0 -12
- package/core/server/data/migrations/versions/2.15/1-add-type-column-to-integrations.js +0 -8
- package/core/server/data/migrations/versions/2.15/2-insert-zapier-integration.js +0 -69
- package/core/server/data/migrations/versions/2.16/1-add-members-perrmissions.js +0 -1
- package/core/server/data/migrations/versions/2.17/1-normalize-settings.js +0 -74
- package/core/server/data/migrations/versions/2.17/2-posts-add-canonical-url.js +0 -7
- package/core/server/data/migrations/versions/2.18/1-restore-settings-from-backup.js +0 -134
- package/core/server/data/migrations/versions/2.2/1-add-sessions-table.js +0 -2
- package/core/server/data/migrations/versions/2.2/2-add-integrations-and-api-key-tables.js +0 -6
- package/core/server/data/migrations/versions/2.2/3-insert-admin-integration-role.js +0 -83
- package/core/server/data/migrations/versions/2.2/4-insert-integration-and-api-key-permissions.js +0 -77
- package/core/server/data/migrations/versions/2.2/5-add-mobiledoc-revisions-table.js +0 -2
- package/core/server/data/migrations/versions/2.21/1-update-editor-permissions.js +0 -28
- package/core/server/data/migrations/versions/2.22/1-add-member-permissions-to-roles.js +0 -47
- package/core/server/data/migrations/versions/2.27/1-insert-ghost-db-backup-role.js +0 -83
- package/core/server/data/migrations/versions/2.27/2-insert-db-backup-integration.js +0 -69
- package/core/server/data/migrations/versions/2.27/3-add-subdirectory-to-relative-canonical-urls.js +0 -100
- package/core/server/data/migrations/versions/2.28/1-add-db-backup-content-permission.js +0 -9
- package/core/server/data/migrations/versions/2.28/2-add-db-backup-content-permission-to-roles.js +0 -15
- package/core/server/data/migrations/versions/2.28/3-insert-ghost-scheduler-role.js +0 -84
- package/core/server/data/migrations/versions/2.28/4-insert-scheduler-integration.js +0 -69
- package/core/server/data/migrations/versions/2.28/5-add-scheduler-permission-to-roles.js +0 -23
- package/core/server/data/migrations/versions/2.28/6-add-type-column.js +0 -6
- package/core/server/data/migrations/versions/2.28/7-populate-type-column.js +0 -6
- package/core/server/data/migrations/versions/2.28/8-remove-page-column.js +0 -6
- package/core/server/data/migrations/versions/2.29/1-add-post-page-column.js +0 -20
- package/core/server/data/migrations/versions/2.29/2-populate-post-page-column.js +0 -98
- package/core/server/data/migrations/versions/2.29/3-remove-page-type-column.js +0 -15
- package/core/server/data/migrations/versions/2.3/1-add-webhook-columns.js +0 -45
- package/core/server/data/migrations/versions/2.3/2-add-webhook-edit-permission.js +0 -9
- package/core/server/data/migrations/versions/2.31/1-remove-name-and-password-from-members-table.js +0 -15
- package/core/server/data/migrations/versions/2.32/01-add-members-stripe-customers-table.js +0 -4
- package/core/server/data/migrations/versions/2.32/02-add-name-to-members-table.js +0 -7
- package/core/server/data/migrations/versions/2.33/01-correct-members-stripe-customers-table.js +0 -37
- package/core/server/data/migrations/versions/2.34/01-add-stripe-customers-subscriptions-table.js +0 -2
- package/core/server/data/migrations/versions/2.34/02-add-email-to-members-stripe-customers-table.js +0 -7
- package/core/server/data/migrations/versions/2.34/03-add-name-to-members-stripe-customers-table.js +0 -7
- package/core/server/data/migrations/versions/2.35/01-add-note-to-members-table.js +0 -7
- package/core/server/data/migrations/versions/2.37/01-add-self-signup-and-from address-to-members-settings.js +0 -67
- package/core/server/data/migrations/versions/2.6/1-add-webhook-permission-roles.js +0 -31
- package/core/server/data/migrations/versions/2.8/1-add-members-table.js +0 -2
- package/core/server/data/migrations/versions/3.0/01-remove-user-ghost-auth-columns.js +0 -14
- package/core/server/data/migrations/versions/3.0/02-drop-token-auth-tables.js +0 -31
- package/core/server/data/migrations/versions/3.0/03-drop-client-auth-tables.js +0 -35
- package/core/server/data/migrations/versions/3.0/04-add-posts-meta-table.js +0 -2
- package/core/server/data/migrations/versions/3.0/05-populate-posts-meta-table.js +0 -83
- package/core/server/data/migrations/versions/3.0/06-remove-posts-meta-columns.js +0 -44
- package/core/server/data/migrations/versions/3.0/07-add-posts-type-column.js +0 -8
- package/core/server/data/migrations/versions/3.0/08-populate-posts-type-column.js +0 -94
- package/core/server/data/migrations/versions/3.0/09-remove-posts-page-column.js +0 -7
- package/core/server/data/migrations/versions/3.0/10-remove-empty-strings.js +0 -81
- package/core/server/data/migrations/versions/3.0/11-update-posts-html.js +0 -7
- package/core/server/data/migrations/versions/3.0/12-populate-members-table-from-subscribers.js +0 -54
- package/core/server/data/migrations/versions/3.0/13-drop-subscribers-table.js +0 -34
- package/core/server/data/migrations/versions/3.0/14-remove-subscribers-flag.js +0 -24
- package/core/server/data/migrations/versions/3.1/01-add-send-email-when-published-to-posts.js +0 -7
- package/core/server/data/migrations/versions/3.1/02-add-email-subject-to-posts-meta.js +0 -7
- package/core/server/data/migrations/versions/3.1/03-add-email-preview-permissions.js +0 -18
- package/core/server/data/migrations/versions/3.1/04-add-subscribed-flag-to-members.js +0 -7
- package/core/server/data/migrations/versions/3.1/05-add-emails-table.js +0 -2
- package/core/server/data/migrations/versions/3.1/06-add-email-permissions.js +0 -15
- package/core/server/data/migrations/versions/3.1/07-add-uuid-field-to-members.js +0 -8
- package/core/server/data/migrations/versions/3.1/08-add-uuid-values-to-members.js +0 -23
- package/core/server/data/migrations/versions/3.1/09-add-further-email-permissions.js +0 -25
- package/core/server/data/migrations/versions/3.1/10-add-email-error-data-column.js +0 -8
- package/core/server/data/migrations/versions/3.11/01-remove-broken-complimentary-plan-from-members-settings.js +0 -68
- package/core/server/data/migrations/versions/3.12/01-add-identity-permission.js +0 -7
- package/core/server/data/migrations/versions/3.12/02-remove-legacy-is-paid-flag-from-settings.js +0 -93
- package/core/server/data/migrations/versions/3.18/01-add-email-preview-permissions-to-roles.js +0 -39
- package/core/server/data/migrations/versions/3.18/02-add-members_stripe_connect-auth-permissions.js +0 -7
- package/core/server/data/migrations/versions/3.19/01-update-member-from-email-address.js +0 -91
- package/core/server/data/migrations/versions/3.2/01-add-cancel-at-period-end-to-subscriptions.js +0 -7
- package/core/server/data/migrations/versions/3.22/01-removed-legacy-values-from-settings-table.js +0 -65
- package/core/server/data/migrations/versions/3.22/02-settings-key-renames.js +0 -90
- package/core/server/data/migrations/versions/3.22/03-add-group-and-flags-to-settings.js +0 -15
- package/core/server/data/migrations/versions/3.22/04-populate-settings-groups-and-flags.js +0 -194
- package/core/server/data/migrations/versions/3.22/05-migrate-members-subscription-settings.js +0 -182
- package/core/server/data/migrations/versions/3.22/06-migrate-stripe-connect-settings.js +0 -132
- package/core/server/data/migrations/versions/3.22/07-update-type-for-settings.js +0 -137
- package/core/server/data/migrations/versions/3.23/01-migrate-bulk-email-settings.js +0 -65
- package/core/server/data/migrations/versions/3.23/02-remove-bulk-email-settings.js +0 -48
- package/core/server/data/migrations/versions/3.23/03-update-portal-button-setting.js +0 -24
- package/core/server/data/migrations/versions/3.23/04-add-meta-columns-to-tags-table.js +0 -54
- package/core/server/data/migrations/versions/3.24/01-populate-group-for-new-portal-settings.js +0 -38
- package/core/server/data/migrations/versions/3.25/01-add-members-stripe-webhook-settings.js +0 -22
- package/core/server/data/migrations/versions/3.26/01-add-amp-gtag-id-setting.js +0 -20
- package/core/server/data/migrations/versions/3.29/01-remove-duplicate-subscriptions.js +0 -53
- package/core/server/data/migrations/versions/3.29/02-remove-duplicate-customers.js +0 -53
- package/core/server/data/migrations/versions/3.29/03-remove-orphaned-customers.js +0 -35
- package/core/server/data/migrations/versions/3.29/04-remove-orphaned-subscriptions.js +0 -35
- package/core/server/data/migrations/versions/3.29/05-add-member-constraints.js +0 -177
- package/core/server/data/migrations/versions/3.30/01-add-member-signin-url-permission-roles.js +0 -8
- package/core/server/data/migrations/versions/3.32/01-add-member-support-address-setting.js +0 -27
- package/core/server/data/migrations/versions/3.32/02-add-member-reply-address-setting.js +0 -20
- package/core/server/data/migrations/versions/3.32/03-add-routes-hash-setting.js +0 -20
- package/core/server/data/migrations/versions/3.33/01-add-email-recipients-tables.js +0 -8
- package/core/server/data/migrations/versions/3.34/01-add-tokens-table.js +0 -2
- package/core/server/data/migrations/versions/3.35/01-add-address-columns-to-emails-table.js +0 -14
- package/core/server/data/migrations/versions/3.36/01-add-snippets-table.js +0 -2
- package/core/server/data/migrations/versions/3.36/02-add-snippets-permissions.js +0 -56
- package/core/server/data/migrations/versions/3.37/01-update-portal-button-setting.js +0 -30
- package/core/server/data/migrations/versions/3.38/01-add-email-recipient-filter-column.js +0 -8
- package/core/server/data/migrations/versions/3.38/02-populate-email-recipient-filter-column.js +0 -34
- package/core/server/data/migrations/versions/3.38/03-add-recipient-filter-column.js +0 -8
- package/core/server/data/migrations/versions/3.38/04-populate-recipient-filter-column.js +0 -49
- package/core/server/data/migrations/versions/3.38/05-add-emails-track-opens-column.js +0 -7
- package/core/server/data/migrations/versions/3.38/06-add-newsletter-settings.js +0 -16
- package/core/server/data/migrations/versions/3.38/07-migrate-newsletter-settings-from-config.js +0 -48
- package/core/server/data/migrations/versions/3.38/08-repopulate-send-email-when-published-down-migration.js +0 -25
- package/core/server/data/migrations/versions/3.38/09-remove-send-email-when-published-column.js +0 -7
- package/core/server/data/migrations/versions/3.39/01-add-members-signup-redirect-settings.js +0 -16
- package/core/server/data/migrations/versions/3.39/02-add-user-id-to-api-keys-table.js +0 -7
- package/core/server/data/migrations/versions/3.39/03-add-email-track-opens-setting.js +0 -16
- package/core/server/data/migrations/versions/3.39/04-add-cancellation-reason-column.js +0 -7
- package/core/server/data/migrations/versions/3.39/05-remove-unused-columns-on-emails.js +0 -14
- package/core/server/data/migrations/versions/3.39/06-add-email-recipient-index.js +0 -58
- package/core/server/data/migrations/versions/3.39/07-add-email-recipients-event-timestamps.js +0 -19
- package/core/server/data/migrations/versions/3.39/08-add-email-stats-columns.js +0 -22
- package/core/server/data/migrations/versions/3.40/01-add-members-email-open-rate-column.js +0 -8
- package/core/server/data/migrations/versions/3.40/02-add members-email-aggregation-columns.js +0 -16
- package/core/server/data/migrations/versions/3.40/03-populate-members-email-counts.js +0 -15
- package/core/server/data/migrations/versions/3.41/01-add-firstpromoter-settings.js +0 -16
- package/core/server/data/migrations/versions/3.6/1-add-labels-table.js +0 -2
- package/core/server/data/migrations/versions/3.6/2-add-members-labels-table.js +0 -2
- package/core/server/data/migrations/versions/3.6/3-add-labels-permissions.js +0 -47
- package/core/server/data/migrations/versions/3.7/01-fix-incorrect-member-labels-foreign-keys.js +0 -46
- package/core/server/data/migrations/versions/3.8/01-add-geolocation-to-members.js +0 -7
- package/core/server/data/migrations/versions/3.9/01-add-member-sigin-url-permissions.js +0 -7
- package/core/server/services/mail/utils.js +0 -34
- package/core/server/services/url/configs/canary.js +0 -143
- package/core/server/services/url/configs/v3.js +0 -141
- package/core/server/services/url/configs/v4.js +0 -143
- package/core/server/web/api/v2/admin/app.js +0 -43
- package/core/server/web/api/v2/admin/middleware.js +0 -85
- package/core/server/web/api/v2/admin/routes.js +0 -200
- package/core/server/web/api/v2/content/app.js +0 -38
- package/core/server/web/api/v2/content/middleware.js +0 -23
- package/core/server/web/api/v2/content/routes.js +0 -37
- package/core/server/web/api/v3/admin/app.js +0 -43
- package/core/server/web/api/v3/admin/middleware.js +0 -89
- package/core/server/web/api/v3/admin/routes.js +0 -267
- package/core/server/web/api/v3/content/app.js +0 -38
- package/core/server/web/api/v3/content/middleware.js +0 -23
- package/core/server/web/api/v3/content/routes.js +0 -37
- package/core/server/web/oauth/app.js +0 -153
- package/core/server/web/oauth/index.js +0 -1
|
@@ -11,7 +11,7 @@ const path = require('path');
|
|
|
11
11
|
* @prop {Object} Base
|
|
12
12
|
* @prop {(callback: function) => Promise} Base.transaction
|
|
13
13
|
* @prop {Object} Post
|
|
14
|
-
* @prop {(frameOptions: Object) => Promise} Post.
|
|
14
|
+
* @prop {(frameOptions: Object) => Promise} Post.reassignByAuthor
|
|
15
15
|
* @prop {Object} ApiKey
|
|
16
16
|
* @prop {(Object) => Promise} ApiKey.destroy
|
|
17
17
|
* @prop {Object} ApiKey.NotFoundError
|
|
@@ -76,7 +76,7 @@ class Users {
|
|
|
76
76
|
return this.models.Base.transaction(async (t) => {
|
|
77
77
|
frameOptions.transacting = t;
|
|
78
78
|
|
|
79
|
-
await this.models.Post.
|
|
79
|
+
await this.models.Post.reassignByAuthor(frameOptions);
|
|
80
80
|
|
|
81
81
|
try {
|
|
82
82
|
await this.models.ApiKey.destroy({
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
const _ = require('lodash');
|
|
2
2
|
const limitService = require('../../services/limits');
|
|
3
3
|
const logging = require('@tryghost/logging');
|
|
4
|
-
const
|
|
4
|
+
const WebhookTrigger = require('./trigger');
|
|
5
|
+
const models = require('../../models');
|
|
6
|
+
const payload = require('./payload');
|
|
5
7
|
|
|
6
8
|
// The webhook system is fundamentally built on top of our model event system
|
|
7
9
|
const events = require('../../lib/common/events');
|
|
@@ -55,6 +57,7 @@ const listen = async () => {
|
|
|
55
57
|
}
|
|
56
58
|
}
|
|
57
59
|
|
|
60
|
+
const webhookTrigger = new WebhookTrigger({models, payload});
|
|
58
61
|
_.each(WEBHOOKS, (event) => {
|
|
59
62
|
events.on(event, (model, options) => {
|
|
60
63
|
// CASE: avoid triggering webhooks when importing
|
|
@@ -62,7 +65,7 @@ const listen = async () => {
|
|
|
62
65
|
return;
|
|
63
66
|
}
|
|
64
67
|
|
|
65
|
-
trigger(event, model);
|
|
68
|
+
webhookTrigger.trigger(event, model);
|
|
66
69
|
});
|
|
67
70
|
});
|
|
68
71
|
};
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
module.exports = (event, model) => {
|
|
2
2
|
const _ = require('lodash');
|
|
3
3
|
const {sequence} = require('@tryghost/promise');
|
|
4
|
-
const api = require('../../api');
|
|
5
|
-
|
|
6
|
-
const apiVersion = model.get('api_version') || 'v4';
|
|
4
|
+
const api = require('../../api').endpoints;
|
|
5
|
+
const apiShared = require('../../api').shared;
|
|
7
6
|
|
|
8
7
|
const resourceName = event.match(/(\w+)\./)[1];
|
|
9
8
|
const docName = `${resourceName}s`;
|
|
@@ -19,10 +18,10 @@ module.exports = (event, model) => {
|
|
|
19
18
|
frame.options.withRelated = ['tags', 'authors'];
|
|
20
19
|
}
|
|
21
20
|
|
|
22
|
-
return
|
|
21
|
+
return apiShared
|
|
23
22
|
.serializers
|
|
24
23
|
.handle
|
|
25
|
-
.output(model, {docName: docName, method: 'read'}, api
|
|
24
|
+
.output(model, {docName: docName, method: 'read'}, api.serializers.output, frame)
|
|
26
25
|
.then(() => {
|
|
27
26
|
return frame.response[docName][0];
|
|
28
27
|
});
|
|
@@ -42,10 +41,10 @@ module.exports = (event, model) => {
|
|
|
42
41
|
frame.options.withRelated = ['tags', 'authors'];
|
|
43
42
|
}
|
|
44
43
|
|
|
45
|
-
return
|
|
44
|
+
return apiShared
|
|
46
45
|
.serializers
|
|
47
46
|
.handle
|
|
48
|
-
.output(model, {docName: docName, method: 'read'}, api
|
|
47
|
+
.output(model, {docName: docName, method: 'read'}, api.serializers.output, frame)
|
|
49
48
|
.then(() => {
|
|
50
49
|
return frame.response[docName][0];
|
|
51
50
|
});
|
|
@@ -1,19 +1,30 @@
|
|
|
1
|
-
const _ = require('lodash');
|
|
2
1
|
const debug = require('@tryghost/debug')('services:webhooks:trigger');
|
|
3
2
|
const logging = require('@tryghost/logging');
|
|
4
|
-
const
|
|
5
|
-
|
|
6
|
-
|
|
3
|
+
const ghostVersion = require('@tryghost/version');
|
|
4
|
+
|
|
5
|
+
class WebhookTrigger {
|
|
6
|
+
/**
|
|
7
|
+
*
|
|
8
|
+
* @param {Object} options
|
|
9
|
+
* @param {Object} options.models - Ghost models
|
|
10
|
+
* @param {Function} options.payload - Function to generate payload
|
|
11
|
+
* @param {Object} [options.request] - HTTP request handling library
|
|
12
|
+
*/
|
|
13
|
+
constructor({models, payload, request}){
|
|
14
|
+
this.models = models;
|
|
15
|
+
this.payload = payload;
|
|
16
|
+
|
|
17
|
+
this.request = request ?? require('@tryghost/request');
|
|
18
|
+
}
|
|
7
19
|
|
|
8
|
-
const webhooks = {
|
|
9
20
|
getAll(event) {
|
|
10
|
-
return models
|
|
21
|
+
return this.models
|
|
11
22
|
.Webhook
|
|
12
23
|
.findAllByEvent(event, {context: {internal: true}});
|
|
13
|
-
}
|
|
24
|
+
}
|
|
14
25
|
|
|
15
26
|
update(webhook, data) {
|
|
16
|
-
models
|
|
27
|
+
this.models
|
|
17
28
|
.Webhook
|
|
18
29
|
.edit({
|
|
19
30
|
last_triggered_at: Date.now(),
|
|
@@ -23,36 +34,34 @@ const webhooks = {
|
|
|
23
34
|
.catch(() => {
|
|
24
35
|
logging.warn(`Unable to update "last_triggered" for webhook: ${webhook.id}`);
|
|
25
36
|
});
|
|
26
|
-
}
|
|
37
|
+
}
|
|
27
38
|
|
|
28
39
|
destroy(webhook) {
|
|
29
|
-
return models
|
|
40
|
+
return this.models
|
|
30
41
|
.Webhook
|
|
31
42
|
.destroy({id: webhook.id}, {context: {internal: true}})
|
|
32
43
|
.catch(() => {
|
|
33
44
|
logging.warn(`Unable to destroy webhook ${webhook.id}.`);
|
|
34
45
|
});
|
|
35
46
|
}
|
|
36
|
-
};
|
|
37
47
|
|
|
38
|
-
const response = {
|
|
39
48
|
onSuccess(webhook) {
|
|
40
49
|
return (res) => {
|
|
41
|
-
|
|
50
|
+
this.update(webhook, {
|
|
42
51
|
statusCode: res.statusCode
|
|
43
52
|
});
|
|
44
53
|
};
|
|
45
|
-
}
|
|
54
|
+
}
|
|
46
55
|
|
|
47
56
|
onError(webhook) {
|
|
48
57
|
return (err) => {
|
|
49
58
|
if (err.statusCode === 410) {
|
|
50
59
|
logging.info(`Webhook destroyed (410 response) for "${webhook.get('event')}" with url "${webhook.get('target_url')}".`);
|
|
51
60
|
|
|
52
|
-
return
|
|
61
|
+
return this.destroy(webhook);
|
|
53
62
|
}
|
|
54
63
|
|
|
55
|
-
|
|
64
|
+
this.update(webhook, {
|
|
56
65
|
statusCode: err.statusCode,
|
|
57
66
|
error: `Request failed: ${err.code || 'unknown'}`
|
|
58
67
|
});
|
|
@@ -60,34 +69,40 @@ const response = {
|
|
|
60
69
|
logging.warn(`Request to ${webhook.get('target_url') || null} failed because of: ${err.code || ''}.`);
|
|
61
70
|
};
|
|
62
71
|
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
72
|
+
|
|
73
|
+
async trigger(event, model) {
|
|
74
|
+
const response = {
|
|
75
|
+
onSuccess: this.onSuccess.bind(this),
|
|
76
|
+
onError: this.onError.bind(this)
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
const hooks = await this.getAll(event);
|
|
80
|
+
|
|
81
|
+
debug(`${hooks.models.length} webhooks found for ${event}.`);
|
|
82
|
+
|
|
83
|
+
for (const webhook of hooks.models) {
|
|
84
|
+
const hookPayload = await this.payload(webhook.get('event'), model);
|
|
85
|
+
|
|
86
|
+
const reqPayload = JSON.stringify(hookPayload);
|
|
87
|
+
const url = webhook.get('target_url');
|
|
88
|
+
const opts = {
|
|
89
|
+
body: reqPayload,
|
|
90
|
+
headers: {
|
|
91
|
+
'Content-Length': Buffer.byteLength(reqPayload),
|
|
92
|
+
'Content-Type': 'application/json',
|
|
93
|
+
'Content-Version': `v${ghostVersion.safe}`
|
|
94
|
+
},
|
|
95
|
+
timeout: 2 * 1000,
|
|
96
|
+
retry: 5
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
logging.info(`Triggering webhook for "${webhook.get('event')}" with url "${url}"`);
|
|
100
|
+
|
|
101
|
+
await this.request(url, opts)
|
|
102
|
+
.then(response.onSuccess(webhook))
|
|
103
|
+
.catch(response.onError(webhook));
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
module.exports = WebhookTrigger;
|
|
@@ -17,7 +17,7 @@ module.exports = function setupAdminApp() {
|
|
|
17
17
|
// @TODO ensure this gets a local 404 error handler
|
|
18
18
|
const configMaxAge = config.get('caching:admin:maxAge');
|
|
19
19
|
adminApp.use('/assets', serveStatic(
|
|
20
|
-
config.get('paths').
|
|
20
|
+
config.get('paths').adminAssets,
|
|
21
21
|
{maxAge: (configMaxAge || configMaxAge === 0) ? configMaxAge : constants.ONE_YEAR_MS, fallthrough: false}
|
|
22
22
|
));
|
|
23
23
|
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
<title>Ghost Admin</title>
|
|
9
9
|
|
|
10
10
|
|
|
11
|
-
<meta name="ghost-admin/config/environment" content="%7B%22modulePrefix%22%3A%22ghost-admin%22%2C%22environment%22%3A%22production%22%2C%22rootURL%22%3A%22%2F%22%2C%22locationType%22%3A%22trailing-hash%22%2C%22EmberENV%22%3A%7B%22FEATURES%22%3A%7B%7D%2C%22EXTEND_PROTOTYPES%22%3A%7B%22Date%22%3Afalse%2C%22Array%22%3Atrue%2C%22String%22%3Atrue%2C%22Function%22%3Afalse%7D%2C%22_APPLICATION_TEMPLATE_WRAPPER%22%3Afalse%2C%22_JQUERY_INTEGRATION%22%3Atrue%2C%22_TEMPLATE_ONLY_GLIMMER_COMPONENTS%22%3Atrue%7D%2C%22APP%22%3A%7B%22version%22%3A%
|
|
11
|
+
<meta name="ghost-admin/config/environment" content="%7B%22modulePrefix%22%3A%22ghost-admin%22%2C%22environment%22%3A%22production%22%2C%22rootURL%22%3A%22%2F%22%2C%22locationType%22%3A%22trailing-hash%22%2C%22EmberENV%22%3A%7B%22FEATURES%22%3A%7B%7D%2C%22EXTEND_PROTOTYPES%22%3A%7B%22Date%22%3Afalse%2C%22Array%22%3Atrue%2C%22String%22%3Atrue%2C%22Function%22%3Afalse%7D%2C%22_APPLICATION_TEMPLATE_WRAPPER%22%3Afalse%2C%22_JQUERY_INTEGRATION%22%3Atrue%2C%22_TEMPLATE_ONLY_GLIMMER_COMPONENTS%22%3Atrue%7D%2C%22APP%22%3A%7B%22version%22%3A%225.0%22%2C%22name%22%3A%22ghost-admin%22%7D%2C%22ember-simple-auth%22%3A%7B%7D%2C%22moment%22%3A%7B%22includeTimezone%22%3A%22all%22%7D%2C%22%40sentry%2Fember%22%3A%7B%22disablePerformance%22%3Atrue%2C%22sentry%22%3A%7B%7D%7D%2C%22ember-cli-mirage%22%3A%7B%22usingProxy%22%3Afalse%2C%22useDefaultPassthroughs%22%3Atrue%7D%2C%22exportApplicationGlobal%22%3Afalse%2C%22ember-load%22%3A%7B%22loadingIndicatorClass%22%3A%22ember-load-indicator%22%7D%7D" />
|
|
12
12
|
|
|
13
13
|
<meta name="HandheldFriendly" content="True" />
|
|
14
14
|
<meta name="MobileOptimized" content="320" />
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
|
|
39
39
|
|
|
40
40
|
<link rel="stylesheet" href="assets/vendor.min-ba66b98f7c24fa40e061c7ffc94f4e23.css">
|
|
41
|
-
<link rel="stylesheet" href="assets/ghost.min-
|
|
41
|
+
<link rel="stylesheet" href="assets/ghost.min-a40c7b301c702bd84c2fae19366ab5d7.css" title="light">
|
|
42
42
|
|
|
43
43
|
|
|
44
44
|
|
|
@@ -56,8 +56,8 @@
|
|
|
56
56
|
<div id="ember-basic-dropdown-wormhole"></div>
|
|
57
57
|
|
|
58
58
|
|
|
59
|
-
<script src="assets/vendor.min-
|
|
60
|
-
<script src="assets/ghost.min-
|
|
59
|
+
<script src="assets/vendor.min-2bca41946dea27dc292428db605d466d.js"></script>
|
|
60
|
+
<script src="assets/ghost.min-2cc3688ea6600a54e0cd83107a8577e8.js"></script>
|
|
61
61
|
|
|
62
62
|
</body>
|
|
63
63
|
</html>
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
<title>Ghost Admin</title>
|
|
9
9
|
|
|
10
10
|
|
|
11
|
-
<meta name="ghost-admin/config/environment" content="%7B%22modulePrefix%22%3A%22ghost-admin%22%2C%22environment%22%3A%22production%22%2C%22rootURL%22%3A%22%2F%22%2C%22locationType%22%3A%22trailing-hash%22%2C%22EmberENV%22%3A%7B%22FEATURES%22%3A%7B%7D%2C%22EXTEND_PROTOTYPES%22%3A%7B%22Date%22%3Afalse%2C%22Array%22%3Atrue%2C%22String%22%3Atrue%2C%22Function%22%3Afalse%7D%2C%22_APPLICATION_TEMPLATE_WRAPPER%22%3Afalse%2C%22_JQUERY_INTEGRATION%22%3Atrue%2C%22_TEMPLATE_ONLY_GLIMMER_COMPONENTS%22%3Atrue%7D%2C%22APP%22%3A%7B%22version%22%3A%
|
|
11
|
+
<meta name="ghost-admin/config/environment" content="%7B%22modulePrefix%22%3A%22ghost-admin%22%2C%22environment%22%3A%22production%22%2C%22rootURL%22%3A%22%2F%22%2C%22locationType%22%3A%22trailing-hash%22%2C%22EmberENV%22%3A%7B%22FEATURES%22%3A%7B%7D%2C%22EXTEND_PROTOTYPES%22%3A%7B%22Date%22%3Afalse%2C%22Array%22%3Atrue%2C%22String%22%3Atrue%2C%22Function%22%3Afalse%7D%2C%22_APPLICATION_TEMPLATE_WRAPPER%22%3Afalse%2C%22_JQUERY_INTEGRATION%22%3Atrue%2C%22_TEMPLATE_ONLY_GLIMMER_COMPONENTS%22%3Atrue%7D%2C%22APP%22%3A%7B%22version%22%3A%225.0%22%2C%22name%22%3A%22ghost-admin%22%7D%2C%22ember-simple-auth%22%3A%7B%7D%2C%22moment%22%3A%7B%22includeTimezone%22%3A%22all%22%7D%2C%22%40sentry%2Fember%22%3A%7B%22disablePerformance%22%3Atrue%2C%22sentry%22%3A%7B%7D%7D%2C%22ember-cli-mirage%22%3A%7B%22usingProxy%22%3Afalse%2C%22useDefaultPassthroughs%22%3Atrue%7D%2C%22exportApplicationGlobal%22%3Afalse%2C%22ember-load%22%3A%7B%22loadingIndicatorClass%22%3A%22ember-load-indicator%22%7D%7D" />
|
|
12
12
|
|
|
13
13
|
<meta name="HandheldFriendly" content="True" />
|
|
14
14
|
<meta name="MobileOptimized" content="320" />
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
|
|
39
39
|
|
|
40
40
|
<link rel="stylesheet" href="assets/vendor.min-ba66b98f7c24fa40e061c7ffc94f4e23.css">
|
|
41
|
-
<link rel="stylesheet" href="assets/ghost.min-
|
|
41
|
+
<link rel="stylesheet" href="assets/ghost.min-a40c7b301c702bd84c2fae19366ab5d7.css" title="light">
|
|
42
42
|
|
|
43
43
|
|
|
44
44
|
|
|
@@ -56,8 +56,8 @@
|
|
|
56
56
|
<div id="ember-basic-dropdown-wormhole"></div>
|
|
57
57
|
|
|
58
58
|
|
|
59
|
-
<script src="assets/vendor.min-
|
|
60
|
-
<script src="assets/ghost.min-
|
|
59
|
+
<script src="assets/vendor.min-2bca41946dea27dc292428db605d466d.js"></script>
|
|
60
|
+
<script src="assets/ghost.min-2cc3688ea6600a54e0cd83107a8577e8.js"></script>
|
|
61
61
|
|
|
62
62
|
</body>
|
|
63
63
|
</html>
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
const debug = require('@tryghost/debug')('web:api:default:app');
|
|
2
2
|
const config = require('../../../shared/config');
|
|
3
3
|
const express = require('../../../shared/express');
|
|
4
|
-
const urlUtils = require('../../../shared/url-utils');
|
|
5
4
|
const sentry = require('../../../shared/sentry');
|
|
6
5
|
const errorHandler = require('@tryghost/mw-error-handler');
|
|
7
6
|
const APIVersionCompatibilityService = require('../../services/api-version-compatibility');
|
|
@@ -14,22 +13,11 @@ module.exports = function setupApiApp() {
|
|
|
14
13
|
apiApp.use(require('./testmode')());
|
|
15
14
|
}
|
|
16
15
|
|
|
16
|
+
apiApp.use(APIVersionCompatibilityService.versionRewrites);
|
|
17
17
|
apiApp.use(APIVersionCompatibilityService.contentVersion);
|
|
18
18
|
|
|
19
|
-
apiApp.lazyUse(
|
|
20
|
-
apiApp.lazyUse(
|
|
21
|
-
|
|
22
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'v3', type: 'content'}), require('./v3/content/app'));
|
|
23
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'v3', type: 'admin'}), require('./v3/admin/app'));
|
|
24
|
-
|
|
25
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'v4', type: 'content'}), require('./canary/content/app'));
|
|
26
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'v4', type: 'admin'}), require('./canary/admin/app'));
|
|
27
|
-
|
|
28
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'v5', type: 'content'}), require('./canary/content/app'));
|
|
29
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'v5', type: 'admin'}), require('./canary/admin/app'));
|
|
30
|
-
|
|
31
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'canary', type: 'content'}), require('./canary/content/app'));
|
|
32
|
-
apiApp.lazyUse(urlUtils.getVersionPath({version: 'canary', type: 'admin'}), require('./canary/admin/app'));
|
|
19
|
+
apiApp.lazyUse('/content/', require('./canary/content/app'));
|
|
20
|
+
apiApp.lazyUse('/admin/', require('./canary/admin/app'));
|
|
33
21
|
|
|
34
22
|
// Error handling for requests to non-existent API versions
|
|
35
23
|
apiApp.use(errorHandler.resourceNotFound);
|
|
@@ -35,7 +35,7 @@ module.exports = function setupApiApp() {
|
|
|
35
35
|
// API error handling
|
|
36
36
|
apiApp.use(errorHandler.resourceNotFound);
|
|
37
37
|
apiApp.use(APIVersionCompatibilityService.errorHandler);
|
|
38
|
-
apiApp.use(errorHandler.
|
|
38
|
+
apiApp.use(errorHandler.handleJSONResponse(sentry));
|
|
39
39
|
|
|
40
40
|
debug('Admin API canary setup end');
|
|
41
41
|
|
|
@@ -31,11 +31,13 @@ const notImplemented = function (req, res, next) {
|
|
|
31
31
|
members: ['GET', 'PUT', 'DELETE', 'POST'],
|
|
32
32
|
tiers: ['GET', 'PUT', 'POST'],
|
|
33
33
|
offers: ['GET', 'PUT', 'POST'],
|
|
34
|
+
newsletters: ['GET', 'PUT', 'POST'],
|
|
34
35
|
config: ['GET'],
|
|
35
36
|
schedules: ['PUT'],
|
|
36
37
|
files: ['POST'],
|
|
37
38
|
media: ['POST'],
|
|
38
|
-
db: ['POST']
|
|
39
|
+
db: ['POST'],
|
|
40
|
+
settings: ['GET']
|
|
39
41
|
};
|
|
40
42
|
|
|
41
43
|
const match = req.url.match(/^\/(\w+)\/?/);
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
const express = require('../../../../../shared/express');
|
|
2
|
-
const api = require('../../../../api').
|
|
2
|
+
const api = require('../../../../api').endpoints;
|
|
3
|
+
const http = require('../../../../api').shared.http;
|
|
3
4
|
const apiMw = require('../../middleware');
|
|
4
5
|
const mw = require('./middleware');
|
|
5
6
|
|
|
@@ -13,8 +14,6 @@ module.exports = function apiRoutes() {
|
|
|
13
14
|
|
|
14
15
|
router.use(apiMw.cors);
|
|
15
16
|
|
|
16
|
-
const http = api.http;
|
|
17
|
-
|
|
18
17
|
// ## Public
|
|
19
18
|
router.get('/site', mw.publicAdminApi, http(api.site.read));
|
|
20
19
|
|
|
@@ -59,7 +58,6 @@ module.exports = function apiRoutes() {
|
|
|
59
58
|
);
|
|
60
59
|
|
|
61
60
|
router.get('/settings', mw.authAdminApi, http(api.settings.browse));
|
|
62
|
-
router.get('/settings/:key', mw.authAdminApi, http(api.settings.read));
|
|
63
61
|
router.put('/settings', mw.authAdminApi, http(api.settings.edit));
|
|
64
62
|
router.get('/settings/members/email', http(api.settings.validateMembersEmailUpdate));
|
|
65
63
|
router.post('/settings/members/email', mw.authAdminApi, http(api.settings.updateMembersEmail));
|
|
@@ -87,13 +85,6 @@ module.exports = function apiRoutes() {
|
|
|
87
85
|
router.put('/tags/:id', mw.authAdminApi, http(api.tags.edit));
|
|
88
86
|
router.del('/tags/:id', mw.authAdminApi, http(api.tags.destroy));
|
|
89
87
|
|
|
90
|
-
// Products
|
|
91
|
-
// TODO Remove
|
|
92
|
-
router.get('/products', mw.authAdminApi, http(api.products.browse));
|
|
93
|
-
router.post('/products', mw.authAdminApi, http(api.products.add));
|
|
94
|
-
router.get('/products/:id', mw.authAdminApi, http(api.products.read));
|
|
95
|
-
router.put('/products/:id', mw.authAdminApi, http(api.products.edit));
|
|
96
|
-
|
|
97
88
|
// Tiers
|
|
98
89
|
router.get('/tiers', mw.authAdminApi, http(api.tiers.browse));
|
|
99
90
|
router.post('/tiers', mw.authAdminApi, http(api.tiers.add));
|
|
@@ -124,8 +115,6 @@ module.exports = function apiRoutes() {
|
|
|
124
115
|
http(api.members.importCSV)
|
|
125
116
|
);
|
|
126
117
|
|
|
127
|
-
router.get('/members/hasActiveStripeSubscriptions', mw.authAdminApi, http(api.members.hasActiveStripeSubscriptions));
|
|
128
|
-
|
|
129
118
|
router.get('/members/stripe_connect', mw.authAdminApi, http(api.membersStripeConnect.auth));
|
|
130
119
|
|
|
131
120
|
router.get('/members/:id', mw.authAdminApi, http(api.members.read));
|
|
@@ -202,10 +191,6 @@ module.exports = function apiRoutes() {
|
|
|
202
191
|
http(api.db.backupContent)
|
|
203
192
|
);
|
|
204
193
|
|
|
205
|
-
// ## Mail
|
|
206
|
-
router.post('/mail', mw.authAdminApi, http(api.mail.send));
|
|
207
|
-
router.post('/mail/test', mw.authAdminApi, http(api.mail.sendTest));
|
|
208
|
-
|
|
209
194
|
// ## Slack
|
|
210
195
|
router.post('/slack/test', mw.authAdminApi, http(api.slack.sendTest));
|
|
211
196
|
|
|
@@ -223,18 +208,18 @@ module.exports = function apiRoutes() {
|
|
|
223
208
|
router.get('/identities', mw.authAdminApi, http(api.identities.read));
|
|
224
209
|
|
|
225
210
|
// ## Authentication
|
|
226
|
-
router.post('/authentication/
|
|
211
|
+
router.post('/authentication/password_reset',
|
|
227
212
|
shared.middleware.brute.globalReset,
|
|
228
213
|
shared.middleware.brute.userReset,
|
|
229
214
|
http(api.authentication.generateResetToken)
|
|
230
215
|
);
|
|
231
|
-
router.put('/authentication/
|
|
216
|
+
router.put('/authentication/password_reset', shared.middleware.brute.globalBlock, http(api.authentication.resetPassword));
|
|
232
217
|
router.post('/authentication/invitation', http(api.authentication.acceptInvitation));
|
|
233
218
|
router.get('/authentication/invitation', http(api.authentication.isInvitation));
|
|
234
219
|
router.post('/authentication/setup', http(api.authentication.setup));
|
|
235
220
|
router.put('/authentication/setup', mw.authAdminApi, http(api.authentication.updateSetup));
|
|
236
221
|
router.get('/authentication/setup', http(api.authentication.isSetup));
|
|
237
|
-
router.post('/authentication/
|
|
222
|
+
router.post('/authentication/global_password_reset', mw.authAdminApi, http(api.authentication.resetAllPasswords));
|
|
238
223
|
|
|
239
224
|
// ## Images
|
|
240
225
|
router.post('/images/upload',
|
|
@@ -293,9 +278,8 @@ module.exports = function apiRoutes() {
|
|
|
293
278
|
router.get('/actions', mw.authAdminApi, http(api.actions.browse));
|
|
294
279
|
|
|
295
280
|
// ## Email Preview
|
|
296
|
-
|
|
297
|
-
router.
|
|
298
|
-
router.post('/email_preview/posts/:id', mw.authAdminApi, http(api.email_preview.sendTestEmail));
|
|
281
|
+
router.get('/email_previews/posts/:id', mw.authAdminApi, http(api.email_previews.read));
|
|
282
|
+
router.post('/email_previews/posts/:id', mw.authAdminApi, http(api.email_previews.sendTestEmail));
|
|
299
283
|
|
|
300
284
|
// ## Emails
|
|
301
285
|
router.get('/emails', mw.authAdminApi, http(api.emails.browse));
|
|
@@ -6,8 +6,7 @@ const sentry = require('../../../../../shared/sentry');
|
|
|
6
6
|
const shared = require('../../../shared');
|
|
7
7
|
const routes = require('./routes');
|
|
8
8
|
const errorHandler = require('@tryghost/mw-error-handler');
|
|
9
|
-
const
|
|
10
|
-
const {APIVersionCompatibilityServiceInstance} = require('../../../../services/api-version-compatibility');
|
|
9
|
+
const apiVersionCompatibility = require('../../../../services/api-version-compatibility');
|
|
11
10
|
|
|
12
11
|
module.exports = function setupApiApp() {
|
|
13
12
|
debug('Content API canary setup start');
|
|
@@ -29,7 +28,7 @@ module.exports = function setupApiApp() {
|
|
|
29
28
|
|
|
30
29
|
// API error handling
|
|
31
30
|
apiApp.use(errorHandler.resourceNotFound);
|
|
32
|
-
apiApp.use(
|
|
31
|
+
apiApp.use(apiVersionCompatibility.errorHandler);
|
|
33
32
|
apiApp.use(errorHandler.handleJSONResponse(sentry));
|
|
34
33
|
|
|
35
34
|
debug('Content API canary setup end');
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
const express = require('../../../../../shared/express');
|
|
2
2
|
const cors = require('cors');
|
|
3
|
-
const api = require('../../../../api').
|
|
3
|
+
const api = require('../../../../api').endpoints;
|
|
4
|
+
const http = require('../../../../api').shared.http;
|
|
4
5
|
const mw = require('./middleware');
|
|
5
6
|
|
|
6
7
|
module.exports = function apiRoutes() {
|
|
@@ -8,8 +9,6 @@ module.exports = function apiRoutes() {
|
|
|
8
9
|
|
|
9
10
|
router.use(cors());
|
|
10
11
|
|
|
11
|
-
const http = api.http;
|
|
12
|
-
|
|
13
12
|
// ## Posts
|
|
14
13
|
router.get('/posts', mw.authenticatePublic, http(api.postsPublic.browse));
|
|
15
14
|
router.get('/posts/:id', mw.authenticatePublic, http(api.postsPublic.read));
|
|
@@ -33,8 +32,10 @@ module.exports = function apiRoutes() {
|
|
|
33
32
|
// ## Settings
|
|
34
33
|
router.get('/settings', mw.authenticatePublic, http(api.publicSettings.browse));
|
|
35
34
|
|
|
36
|
-
|
|
35
|
+
// ## Members
|
|
36
|
+
router.get('/newsletters', mw.authenticatePublic, http(api.newslettersPublic.browse));
|
|
37
37
|
router.get('/tiers', mw.authenticatePublic, http(api.tiersPublic.browse));
|
|
38
|
+
router.get('/offers/:id', mw.authenticatePublic, http(api.offersPublic.read));
|
|
38
39
|
|
|
39
40
|
return router;
|
|
40
41
|
};
|
|
@@ -38,13 +38,14 @@ module.exports = function setupMembersApp() {
|
|
|
38
38
|
membersApp.get('/api/member/newsletters', middleware.getMemberNewsletters);
|
|
39
39
|
membersApp.put('/api/member/newsletters', bodyParser.json({limit: '1mb'}), middleware.updateMemberNewsletters);
|
|
40
40
|
|
|
41
|
+
// Get and update member data
|
|
41
42
|
membersApp.get('/api/member', middleware.getMemberData);
|
|
42
43
|
membersApp.put('/api/member', bodyParser.json({limit: '1mb'}), middleware.updateMemberData);
|
|
43
44
|
membersApp.post('/api/member/email', bodyParser.json({limit: '1mb'}), (req, res) => membersService.api.middleware.updateEmailAddress(req, res));
|
|
45
|
+
|
|
46
|
+
// Manage session
|
|
44
47
|
membersApp.get('/api/session', middleware.getIdentityToken);
|
|
45
|
-
membersApp.get('/api/offers/:id', middleware.getOfferData);
|
|
46
48
|
membersApp.delete('/api/session', middleware.deleteSession);
|
|
47
|
-
membersApp.get('/api/site', middleware.getMemberSiteData);
|
|
48
49
|
|
|
49
50
|
// NOTE: this is wrapped in a function to ensure we always go via the getter
|
|
50
51
|
membersApp.post('/api/send-magic-link', bodyParser.json(), shared.middleware.brute.membersAuth, (req, res, next) => membersService.api.middleware.sendMagicLink(req, res, next));
|
|
@@ -55,11 +56,11 @@ module.exports = function setupMembersApp() {
|
|
|
55
56
|
|
|
56
57
|
// API error handling
|
|
57
58
|
membersApp.use('/api', errorHandler.resourceNotFound);
|
|
58
|
-
membersApp.use('/api', errorHandler.
|
|
59
|
+
membersApp.use('/api', errorHandler.handleJSONResponse(sentry));
|
|
59
60
|
|
|
60
61
|
// Webhook error handling
|
|
61
62
|
membersApp.use('/webhooks', errorHandler.resourceNotFound);
|
|
62
|
-
membersApp.use('/webhooks', errorHandler.
|
|
63
|
+
membersApp.use('/webhooks', errorHandler.handleJSONResponse(sentry));
|
|
63
64
|
|
|
64
65
|
debug('Members App setup end');
|
|
65
66
|
|
|
@@ -13,7 +13,6 @@ module.exports = () => {
|
|
|
13
13
|
const backendApp = express('backend');
|
|
14
14
|
|
|
15
15
|
backendApp.lazyUse(BASE_API_PATH, require('../api'));
|
|
16
|
-
backendApp.lazyUse('/ghost/oauth', require('../oauth'));
|
|
17
16
|
backendApp.lazyUse('/ghost/.well-known', require('../well-known'));
|
|
18
17
|
|
|
19
18
|
backendApp.use('/ghost', require('../../services/auth/session').createSessionFromToken, require('../admin')());
|
|
@@ -1,25 +1,24 @@
|
|
|
1
1
|
const debug = require('@tryghost/debug')('frontend');
|
|
2
2
|
const express = require('../../../shared/express');
|
|
3
|
-
|
|
4
3
|
const shared = require('../shared');
|
|
5
4
|
|
|
6
5
|
/**
|
|
7
6
|
*
|
|
8
|
-
* @param {
|
|
7
|
+
* @param {import('../../../frontend/services/routing/router-manager').RouterConfig} routerConfig
|
|
9
8
|
* @returns {import('express').RequestHandler}
|
|
10
9
|
*/
|
|
11
|
-
module.exports = (
|
|
12
|
-
debug('FrontendApp setup start',
|
|
10
|
+
module.exports = (routerConfig) => {
|
|
11
|
+
debug('FrontendApp setup start', routerConfig);
|
|
13
12
|
|
|
14
13
|
// FRONTEND
|
|
15
14
|
const frontendApp = express('frontend');
|
|
16
15
|
|
|
17
16
|
// Force SSL if blog url is set to https. The redirects handling must happen before asset and page routing,
|
|
18
|
-
// otherwise we serve assets/pages with http. This can cause mixed content warnings in the admin
|
|
17
|
+
// otherwise we serve assets/pages with http. This can cause mixed content warnings in the admin app.
|
|
19
18
|
frontendApp.use(shared.middleware.urlRedirects.frontendSSLRedirect);
|
|
20
19
|
|
|
21
20
|
frontendApp.lazyUse('/members', require('../members'));
|
|
22
|
-
frontendApp.use('/', require('../../../frontend/web')(
|
|
21
|
+
frontendApp.use('/', require('../../../frontend/web')(routerConfig));
|
|
23
22
|
|
|
24
23
|
return frontendApp;
|
|
25
24
|
};
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
const ghostVersion = require('@tryghost/version');
|
|
2
|
-
const bridge = require('../../../../bridge');
|
|
3
2
|
|
|
4
3
|
// ### GhostLocals Middleware
|
|
5
4
|
// Expose the standard locals that every request will need to have available
|
|
@@ -12,8 +11,6 @@ module.exports = function ghostLocals(req, res, next) {
|
|
|
12
11
|
res.locals.safeVersion = ghostVersion.safe;
|
|
13
12
|
// relative path from the URL
|
|
14
13
|
res.locals.relativeUrl = req.path;
|
|
15
|
-
// make ghost api version available for the theme + routing
|
|
16
|
-
res.locals.apiVersion = bridge.getFrontendApiVersion();
|
|
17
14
|
|
|
18
15
|
next();
|
|
19
16
|
};
|
|
@@ -16,7 +16,20 @@ module.exports = function setupWellKnownApp() {
|
|
|
16
16
|
|
|
17
17
|
wellKnownApp.get('/jwks.json', async (req, res) => {
|
|
18
18
|
const jwks = await getSafePublicJWKS();
|
|
19
|
-
|
|
19
|
+
|
|
20
|
+
// there's only one key in the store atm
|
|
21
|
+
// based on this setting all of the keys to have
|
|
22
|
+
// "use": "sig" property
|
|
23
|
+
const keys = jwks.keys
|
|
24
|
+
.map(key => ({
|
|
25
|
+
e: key.e,
|
|
26
|
+
kid: key.kid,
|
|
27
|
+
kty: key.kty,
|
|
28
|
+
n: key.n,
|
|
29
|
+
use: 'sig'
|
|
30
|
+
}));
|
|
31
|
+
|
|
32
|
+
res.json({keys});
|
|
20
33
|
});
|
|
21
34
|
|
|
22
35
|
return wellKnownApp;
|