ghost 4.48.0 → 5.0.2

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.
Files changed (663) hide show
  1. package/Gruntfile.js +24 -24
  2. package/README.md +3 -2
  3. package/content/themes/casper/assets/built/global.css +1 -1
  4. package/content/themes/casper/assets/built/global.css.map +1 -1
  5. package/content/themes/casper/assets/built/screen.css +1 -1
  6. package/content/themes/casper/assets/built/screen.css.map +1 -1
  7. package/content/themes/casper/assets/css/global.css +2 -2
  8. package/content/themes/casper/assets/css/screen.css +412 -664
  9. package/content/themes/casper/author.hbs +48 -35
  10. package/content/themes/casper/default.hbs +5 -23
  11. package/content/themes/casper/error-404.hbs +1 -1
  12. package/content/themes/casper/index.hbs +29 -22
  13. package/content/themes/casper/package.json +25 -37
  14. package/content/themes/casper/page.hbs +12 -12
  15. package/content/themes/casper/partials/icons/facebook.hbs +1 -1
  16. package/content/themes/casper/partials/icons/twitter.hbs +1 -1
  17. package/content/themes/casper/partials/post-card.hbs +26 -40
  18. package/content/themes/casper/post.hbs +54 -50
  19. package/content/themes/casper/tag.hbs +42 -47
  20. package/core/boot.js +18 -15
  21. package/core/bridge.js +24 -25
  22. package/core/built/assets/ghost-dark-b6e3268bcae976a8675b0d9ae54540f2.css +1 -0
  23. package/core/built/assets/ghost.min-a40c7b301c702bd84c2fae19366ab5d7.css +1 -0
  24. package/core/built/assets/{ghost.min-10ba0de3ecb93d63d62bb43ac11c740f.js → ghost.min-b37a2752b0abda202c14c948b8bc3587.js} +1138 -1212
  25. package/core/built/assets/icons/analytics.svg +14 -0
  26. package/core/built/assets/icons/calendar.svg +4 -1
  27. package/core/built/assets/icons/email-at.svg +1 -1
  28. package/core/built/assets/icons/email-name.svg +1 -1
  29. package/core/built/assets/icons/info.svg +1 -1
  30. package/core/built/assets/icons/twitter-logo.svg +3 -0
  31. package/core/built/assets/{vendor.min-97fd438f4772c5ec6bb30ad779b8530e.js → vendor.min-2bca41946dea27dc292428db605d466d.js} +99 -93
  32. package/core/cli/README.md +88 -0
  33. package/core/cli/command.js +129 -0
  34. package/core/cli/repl.js +32 -0
  35. package/core/cli/timetravel.js +87 -0
  36. package/core/frontend/apps/amp/lib/helpers/amp_content.js +10 -12
  37. package/core/frontend/apps/amp/lib/router.js +2 -3
  38. package/core/frontend/helpers/body_class.js +2 -2
  39. package/core/frontend/helpers/excerpt.js +0 -2
  40. package/core/frontend/helpers/get.js +23 -24
  41. package/core/frontend/helpers/ghost_head.js +104 -108
  42. package/core/frontend/helpers/navigation.js +0 -2
  43. package/core/frontend/helpers/prev_post.js +20 -26
  44. package/core/frontend/helpers/price.js +2 -2
  45. package/core/frontend/meta/author-url.js +2 -2
  46. package/core/frontend/meta/description.js +3 -3
  47. package/core/frontend/meta/excerpt.js +1 -2
  48. package/core/frontend/meta/generate-excerpt.js +2 -11
  49. package/core/frontend/meta/paginated-url.js +1 -1
  50. package/core/frontend/meta/rss-url.js +0 -1
  51. package/core/frontend/meta/url.js +4 -4
  52. package/core/frontend/services/data/entry-lookup.js +1 -1
  53. package/core/frontend/services/data/fetch-data.js +1 -1
  54. package/core/frontend/services/helpers/handlebars.js +11 -12
  55. package/core/frontend/services/proxy.js +11 -1
  56. package/core/frontend/services/rendering/context.js +1 -5
  57. package/core/frontend/services/rendering/format-response.js +9 -2
  58. package/core/frontend/services/rendering/index.js +0 -4
  59. package/core/frontend/services/rendering/render-entry.js +1 -1
  60. package/core/frontend/services/rendering/templates.js +15 -5
  61. package/core/frontend/services/routing/CollectionRouter.js +2 -2
  62. package/core/frontend/services/routing/EmailRouter.js +2 -2
  63. package/core/frontend/services/routing/ParentRouter.js +1 -1
  64. package/core/frontend/services/routing/PreviewRouter.js +3 -3
  65. package/core/frontend/services/routing/{config/v4.js → config.js} +3 -5
  66. package/core/frontend/services/routing/controllers/channel.js +0 -10
  67. package/core/frontend/services/routing/controllers/collection.js +0 -9
  68. package/core/frontend/services/routing/controllers/email-post.js +2 -7
  69. package/core/frontend/services/routing/controllers/entry.js +1 -3
  70. package/core/frontend/services/routing/controllers/index.js +2 -2
  71. package/core/frontend/services/routing/controllers/{preview.js → previews.js} +3 -8
  72. package/core/frontend/services/routing/controllers/static.js +1 -6
  73. package/core/frontend/services/routing/router-manager.js +38 -20
  74. package/core/frontend/services/rss/generate-feed.js +7 -9
  75. package/core/frontend/services/theme-engine/active.js +0 -8
  76. package/core/frontend/services/theme-engine/config/defaults.json +1 -3
  77. package/core/frontend/services/theme-engine/middleware/index.js +0 -1
  78. package/core/frontend/services/theme-engine/middleware/update-global-template-options.js +0 -69
  79. package/core/frontend/services/theme-engine/middleware/update-local-template-options.js +3 -6
  80. package/core/frontend/web/middleware/static-theme.js +14 -6
  81. package/core/frontend/web/routes.js +9 -9
  82. package/core/frontend/web/site.js +15 -18
  83. package/core/server/adapters/scheduling/post-scheduling/index.js +1 -1
  84. package/core/server/api/README.md +2 -6
  85. package/core/server/api/canary/authentication.js +4 -3
  86. package/core/server/api/canary/{email-preview.js → email-previews.js} +9 -8
  87. package/core/server/api/canary/index.js +14 -18
  88. package/core/server/api/canary/members.js +1 -13
  89. package/core/server/api/{v3/actions.js → canary/newsletters-public.js} +6 -6
  90. package/core/server/api/canary/newsletters.js +1 -13
  91. package/core/server/api/canary/notifications.js +17 -22
  92. package/core/server/api/canary/offers-public.js +28 -0
  93. package/core/server/api/canary/pages.js +1 -1
  94. package/core/server/api/canary/posts.js +4 -8
  95. package/core/server/api/canary/{preview.js → previews.js} +1 -1
  96. package/core/server/api/canary/schedules.js +1 -1
  97. package/core/server/api/canary/session.js +1 -1
  98. package/core/server/api/canary/settings-public.js +3 -1
  99. package/core/server/api/canary/settings.js +30 -16
  100. package/core/server/api/canary/utils/index.js +2 -4
  101. package/core/server/api/canary/utils/serializers/input/index.js +0 -4
  102. package/core/server/api/canary/utils/serializers/input/members.js +46 -17
  103. package/core/server/api/canary/utils/serializers/input/pages.js +0 -17
  104. package/core/server/api/canary/utils/serializers/input/posts.js +1 -28
  105. package/core/server/api/canary/utils/serializers/input/settings.js +61 -142
  106. package/core/server/api/canary/utils/serializers/input/tiers.js +56 -12
  107. package/core/server/api/canary/utils/serializers/output/authentication.js +2 -6
  108. package/core/server/api/canary/utils/serializers/output/index.js +2 -10
  109. package/core/server/api/canary/utils/serializers/output/mappers/index.js +1 -0
  110. package/core/server/api/canary/utils/serializers/output/mappers/newsletters.js +24 -0
  111. package/core/server/api/canary/utils/serializers/output/mappers/pages.js +1 -1
  112. package/core/server/api/canary/utils/serializers/output/mappers/posts.js +9 -7
  113. package/core/server/api/canary/utils/serializers/output/mappers/settings.js +5 -31
  114. package/core/server/api/canary/utils/serializers/output/members.js +18 -3
  115. package/core/server/api/canary/utils/serializers/output/offers.js +9 -1
  116. package/core/server/api/canary/utils/serializers/output/{preview.js → previews.js} +2 -2
  117. package/core/server/api/canary/utils/serializers/output/settings.js +6 -14
  118. package/core/server/api/canary/utils/serializers/output/site.js +0 -1
  119. package/core/server/api/canary/utils/serializers/output/tiers.js +35 -75
  120. package/core/server/api/canary/utils/serializers/output/utils/clean.js +5 -10
  121. package/core/server/api/canary/utils/serializers/output/utils/extra-attrs.js +0 -126
  122. package/core/server/api/canary/utils/serializers/output/utils/post-gating.js +1 -1
  123. package/core/server/api/canary/utils/serializers/output/utils/url.js +0 -5
  124. package/core/server/api/canary/utils/validators/input/index.js +2 -2
  125. package/core/server/api/canary/utils/validators/input/{passwordreset.js → password_reset.js} +2 -2
  126. package/core/server/api/canary/utils/validators/input/settings.js +2 -23
  127. package/core/server/api/canary/utils/validators/utils/json-schema.js +1 -2
  128. package/core/server/api/index.js +1 -7
  129. package/core/server/api/shared/serializers/input/utils/settings-key-group-mapper.js +2 -2
  130. package/core/server/api/shared/serializers/input/utils/settings-key-type-mapper.js +2 -4
  131. package/core/server/data/db/connection.js +0 -13
  132. package/core/server/data/exporter/table-lists.js +0 -3
  133. package/core/server/data/importer/importers/data/base.js +16 -7
  134. package/core/server/data/importer/importers/data/data-importer.js +38 -1
  135. package/core/server/data/importer/importers/data/newsletters.js +45 -0
  136. package/core/server/data/importer/importers/data/posts.js +40 -12
  137. package/core/server/data/importer/importers/data/products.js +68 -0
  138. package/core/server/data/importer/importers/data/settings.js +10 -10
  139. package/core/server/data/importer/importers/data/stripe-prices.js +59 -0
  140. package/core/server/data/importer/importers/data/stripe-products.js +61 -0
  141. package/core/server/data/migrations/utils/constants.js +3 -0
  142. package/core/server/data/migrations/utils/index.js +10 -0
  143. package/core/server/data/migrations/utils/migrations.js +156 -0
  144. package/core/server/data/migrations/utils/permissions.js +291 -0
  145. package/core/server/data/migrations/utils/schema.js +158 -0
  146. package/core/server/data/migrations/utils/settings.js +59 -0
  147. package/core/server/data/migrations/utils/tables.js +94 -0
  148. package/core/server/data/migrations/versions/1.25/01-final-v1.js +2 -0
  149. package/core/server/data/migrations/versions/1.25/02-noop.js +6 -0
  150. package/core/server/data/migrations/versions/2.37/01-final-v2.js +2 -0
  151. package/core/server/data/migrations/versions/3.41/01-final-v3.js +2 -0
  152. package/core/server/data/migrations/versions/4.0/22-solve-orphaned-webhooks.js +3 -9
  153. package/core/server/data/migrations/versions/4.0/23-regenerate-posts-html.js +2 -11
  154. package/core/server/data/migrations/versions/4.11/02-add-email-verification-required-setting.js +1 -1
  155. package/core/server/data/migrations/versions/4.12/02-fix-member-statuses.js +1 -1
  156. package/core/server/data/migrations/versions/4.14/02-fix-free-members-status-events.js +1 -1
  157. package/core/server/data/migrations/versions/4.22/01-add-is-launch-complete-setting.js +1 -1
  158. package/core/server/data/migrations/versions/4.22/02-update-launch-complete-setting-from-user-data.js +1 -1
  159. package/core/server/data/migrations/versions/4.35/2022-02-02-10-38-add-default-content-visibility-tiers-setting.js +1 -1
  160. package/core/server/data/migrations/versions/4.45/2022-04-21-02-55-add-notifications-key-entry-to-settings-table.js +1 -1
  161. package/core/server/data/migrations/versions/4.6/01-remove-comped-status.js +1 -1
  162. package/core/server/data/migrations/versions/4.7/03-add-labs-setting.js +1 -1
  163. package/core/server/data/migrations/versions/4.9/05-fix-missed-mobiledoc-url-transforms.js +1 -1
  164. package/core/server/data/migrations/versions/4.9/06-add-comped-status.js +1 -1
  165. package/core/server/data/migrations/versions/4.9/07-update-comped-members-status-events.js +1 -1
  166. package/core/server/data/migrations/versions/5.0/2022-03-14-12-33-delete-duplicate-offer-redemptions.js +36 -0
  167. package/core/server/data/migrations/versions/5.0/2022-03-28-15-25-backfill-mrr-adjustments-for-offers.js +108 -0
  168. package/core/server/data/migrations/versions/5.0/2022-04-25-10-32-backfill-mrr-for-discounted-subscriptions.js +44 -0
  169. package/core/server/data/migrations/versions/5.0/2022-04-26-15-44-backfill-mrr-events-for-canceled-subscriptions.js +73 -0
  170. package/core/server/data/migrations/versions/5.0/2022-04-27-11-26-backfill-mrr-for-canceled-subscriptions.js +31 -0
  171. package/core/server/data/migrations/versions/5.0/2022-04-28-03-26-remove-author-id-column-from-posts-table.js +7 -0
  172. package/core/server/data/migrations/versions/5.0/2022-05-03-09-39-drop-nullable-subscribe-event-newsletter-id.js +4 -0
  173. package/core/server/data/migrations/versions/5.0/2022-05-04-15-24-map-existing-emails-to-default-newsletter.js +44 -0
  174. package/core/server/data/migrations/versions/5.0/2022-05-05-13-13-migrate-legacy-recipient-filters.js +30 -0
  175. package/core/server/data/migrations/versions/5.0/2022-05-05-13-29-add-newsletters-admin-integration-permission-roles.js +20 -0
  176. package/core/server/data/migrations/versions/5.0/2022-05-05-15-17-drop-oauth-table.js +3 -0
  177. package/core/server/data/migrations/versions/5.0/2022-05-06-08-16-cleanup-client-subscriber-permissions.js +68 -0
  178. package/core/server/data/migrations/versions/5.0/2022-05-06-13-22-add-frontend-integration.js +68 -0
  179. package/core/server/data/migrations/versions/5.0/2022-05-09-10-00-drop-members-subscribed-column.js +18 -0
  180. package/core/server/data/migrations/versions/5.0/2022-05-09-14-17-cleanup-invalid-users-status.js +17 -0
  181. package/core/server/data/migrations/versions/5.0/2022-05-10-08-33-drop-members-analytics-table.js +3 -0
  182. package/core/server/data/migrations/versions/5.0/2022-05-10-14-57-cleanup-invalid-posts-status.js +17 -0
  183. package/core/server/data/migrations/versions/5.0/2022-05-11-12-08-drop-webhooks-status-column.js +18 -0
  184. package/core/server/data/migrations/versions/5.0/2022-05-11-13-12-rename-settings.js +51 -0
  185. package/core/server/data/migrations/versions/5.0/2022-05-11-16-36-remove-unused-settings.js +54 -0
  186. package/core/server/data/migrations/versions/5.0/2022-05-12-10-29-add-newsletter-permissions-for-editors-and-authors.js +20 -0
  187. package/core/server/data/migrations/versions/5.0/2022-05-12-13-51-add-label-permissions-for-authors.js +12 -0
  188. package/core/server/data/migrations/versions/5.0/2022-05-13-11-38-drop-none-email-recipient-filter.js +28 -0
  189. package/core/server/data/migrations/versions/5.0/2022-05-21-00-00-regenerate-posts-html.js +70 -0
  190. package/core/server/data/schema/commands.js +35 -3
  191. package/core/server/data/schema/default-settings/default-settings.json +2 -159
  192. package/core/server/data/schema/fixtures/fixture-manager.js +11 -2
  193. package/core/server/data/schema/fixtures/fixtures.json +16 -7
  194. package/core/server/data/schema/schema.js +26 -38
  195. package/core/server/data/schema/validator.js +2 -0
  196. package/core/server/ghost-server.js +34 -64
  197. package/core/server/lib/image/gravatar.js +25 -9
  198. package/core/server/models/api-key.js +3 -26
  199. package/core/server/models/base/plugins/bulk-operations.js +14 -6
  200. package/core/server/models/integration.js +17 -0
  201. package/core/server/models/member.js +8 -4
  202. package/core/server/models/newsletter.js +27 -0
  203. package/core/server/models/post.js +30 -32
  204. package/core/server/models/relations/authors.js +74 -100
  205. package/core/server/models/settings.js +6 -2
  206. package/core/server/models/webhook.js +2 -1
  207. package/core/server/run-update-check.js +1 -1
  208. package/core/server/services/api-version-compatibility/index.js +24 -18
  209. package/core/server/services/api-version-compatibility/legacy-api-path-match.js +23 -0
  210. package/core/server/services/api-version-compatibility/mw-version-rewrites.js +36 -0
  211. package/core/server/services/auth/api-key/admin.js +8 -7
  212. package/core/server/services/auth/passwordreset.js +3 -3
  213. package/core/server/services/auth/session/express-session.js +1 -1
  214. package/core/server/services/auth/session/index.js +1 -1
  215. package/core/server/services/auth/setup.js +8 -8
  216. package/core/server/services/bulk-email/bulk-email-processor.js +5 -1
  217. package/core/server/services/email-analytics/lib/event-processor.js +25 -14
  218. package/core/server/services/frontend-data-service/frontend-data-service.js +27 -0
  219. package/core/server/services/frontend-data-service/index.js +6 -0
  220. package/core/server/services/mail/index.js +14 -1
  221. package/core/server/services/mega/email-preview.js +14 -15
  222. package/core/server/services/mega/mega.js +37 -52
  223. package/core/server/services/mega/post-email-serializer.js +18 -28
  224. package/core/server/services/members/api.js +0 -3
  225. package/core/server/services/members/config.js +0 -49
  226. package/core/server/services/members/exporter/query.js +7 -7
  227. package/core/server/services/members/middleware.js +3 -135
  228. package/core/server/services/members/service.js +0 -27
  229. package/core/server/services/members/settings.js +3 -9
  230. package/core/server/services/newsletters/service.js +78 -10
  231. package/core/server/services/posts/post-scheduling-service.js +5 -17
  232. package/core/server/services/posts/posts-service.js +15 -62
  233. package/core/server/services/public-config/site.js +0 -6
  234. package/core/server/services/route-settings/index.js +0 -3
  235. package/core/server/services/route-settings/settings-loader.js +10 -34
  236. package/core/server/services/route-settings/validate.js +1 -7
  237. package/core/server/services/settings/index.js +1 -77
  238. package/core/server/services/settings/settings-service.js +184 -0
  239. package/core/server/services/themes/validate.js +1 -1
  240. package/core/server/services/url/Resources.js +1 -3
  241. package/core/server/services/url/UrlGenerator.js +1 -1
  242. package/core/server/services/url/UrlService.js +6 -20
  243. package/core/server/services/url/{configs/v2.js → config.js} +0 -0
  244. package/core/server/services/users.js +2 -2
  245. package/core/server/services/webhooks/listen.js +5 -2
  246. package/core/server/services/webhooks/serialize.js +6 -7
  247. package/core/server/services/webhooks/trigger.js +62 -47
  248. package/core/server/update-check.js +1 -1
  249. package/core/server/web/admin/app.js +1 -1
  250. package/core/server/web/admin/views/default-prod.html +4 -4
  251. package/core/server/web/admin/views/default.html +4 -4
  252. package/core/server/web/api/app.js +3 -15
  253. package/core/server/web/api/canary/admin/app.js +1 -1
  254. package/core/server/web/api/canary/admin/middleware.js +3 -1
  255. package/core/server/web/api/canary/admin/routes.js +7 -23
  256. package/core/server/web/api/canary/content/app.js +2 -3
  257. package/core/server/web/api/canary/content/routes.js +5 -4
  258. package/core/server/web/members/app.js +5 -4
  259. package/core/server/web/parent/backend.js +0 -1
  260. package/core/server/web/parent/frontend.js +5 -6
  261. package/core/server/web/parent/middleware/ghost-locals.js +0 -3
  262. package/core/server/web/well-known.js +14 -1
  263. package/core/shared/config/defaults.json +5 -2
  264. package/core/shared/config/overrides.json +1 -27
  265. package/core/shared/html-to-plaintext.js +78 -10
  266. package/core/shared/labs.js +4 -8
  267. package/core/shared/settings-cache/cache.js +38 -4
  268. package/core/shared/settings-cache/public.js +13 -7
  269. package/core/shared/url-utils.js +0 -2
  270. package/ghost.js +6 -0
  271. package/package.json +66 -64
  272. package/yarn.lock +765 -1300
  273. package/core/built/assets/ghost-dark-c94ae212747200ca4bafc37cfb0714d8.css +0 -1
  274. package/core/built/assets/ghost.min-4084931bc22e794fe3722139050a80b3.css +0 -1
  275. package/core/frontend/helpers/author.js +0 -41
  276. package/core/frontend/helpers/products.js +0 -65
  277. package/core/frontend/services/rendering/secure.js +0 -19
  278. package/core/frontend/services/routing/config/canary.js +0 -61
  279. package/core/frontend/services/routing/config/v2.js +0 -54
  280. package/core/frontend/services/routing/config/v3.js +0 -54
  281. package/core/frontend/services/theme-engine/engines/create.js +0 -45
  282. package/core/frontend/services/theme-engine/engines/index.js +0 -5
  283. package/core/frontend/services/theme-engine/middleware/update-local-template-data.js +0 -9
  284. package/core/server/api/canary/products-public.js +0 -34
  285. package/core/server/api/canary/products.js +0 -116
  286. package/core/server/api/canary/utils/serializers/input/products.js +0 -28
  287. package/core/server/api/canary/utils/serializers/output/email-previews.js +0 -7
  288. package/core/server/api/canary/utils/serializers/output/products.js +0 -213
  289. package/core/server/api/v2/actions.js +0 -38
  290. package/core/server/api/v2/authentication.js +0 -191
  291. package/core/server/api/v2/authors-public.js +0 -69
  292. package/core/server/api/v2/config.js +0 -12
  293. package/core/server/api/v2/db.js +0 -120
  294. package/core/server/api/v2/images.js +0 -20
  295. package/core/server/api/v2/index.js +0 -147
  296. package/core/server/api/v2/integrations.js +0 -144
  297. package/core/server/api/v2/invites.js +0 -126
  298. package/core/server/api/v2/mail.js +0 -66
  299. package/core/server/api/v2/notifications.js +0 -96
  300. package/core/server/api/v2/oembed.js +0 -186
  301. package/core/server/api/v2/pages-public.js +0 -78
  302. package/core/server/api/v2/pages.js +0 -197
  303. package/core/server/api/v2/posts-public.js +0 -78
  304. package/core/server/api/v2/posts.js +0 -192
  305. package/core/server/api/v2/preview.js +0 -46
  306. package/core/server/api/v2/redirects.js +0 -28
  307. package/core/server/api/v2/roles.js +0 -19
  308. package/core/server/api/v2/schedules.js +0 -77
  309. package/core/server/api/v2/session.js +0 -70
  310. package/core/server/api/v2/settings-public.js +0 -17
  311. package/core/server/api/v2/settings.js +0 -195
  312. package/core/server/api/v2/site.js +0 -14
  313. package/core/server/api/v2/slack.js +0 -12
  314. package/core/server/api/v2/slugs.js +0 -51
  315. package/core/server/api/v2/tags-public.js +0 -71
  316. package/core/server/api/v2/tags.js +0 -159
  317. package/core/server/api/v2/themes.js +0 -133
  318. package/core/server/api/v2/users.js +0 -179
  319. package/core/server/api/v2/utils/index.js +0 -34
  320. package/core/server/api/v2/utils/permissions.js +0 -112
  321. package/core/server/api/v2/utils/serializers/index.js +0 -9
  322. package/core/server/api/v2/utils/serializers/input/db.js +0 -20
  323. package/core/server/api/v2/utils/serializers/input/index.js +0 -33
  324. package/core/server/api/v2/utils/serializers/input/integrations.js +0 -33
  325. package/core/server/api/v2/utils/serializers/input/pages.js +0 -203
  326. package/core/server/api/v2/utils/serializers/input/posts.js +0 -218
  327. package/core/server/api/v2/utils/serializers/input/settings.js +0 -152
  328. package/core/server/api/v2/utils/serializers/input/tags.js +0 -35
  329. package/core/server/api/v2/utils/serializers/input/users.js +0 -26
  330. package/core/server/api/v2/utils/serializers/input/utils/url.js +0 -71
  331. package/core/server/api/v2/utils/serializers/input/webhooks.js +0 -12
  332. package/core/server/api/v2/utils/serializers/output/actions.js +0 -13
  333. package/core/server/api/v2/utils/serializers/output/all.js +0 -25
  334. package/core/server/api/v2/utils/serializers/output/authentication.js +0 -68
  335. package/core/server/api/v2/utils/serializers/output/authors.js +0 -21
  336. package/core/server/api/v2/utils/serializers/output/config.js +0 -21
  337. package/core/server/api/v2/utils/serializers/output/db.js +0 -40
  338. package/core/server/api/v2/utils/serializers/output/images.js +0 -19
  339. package/core/server/api/v2/utils/serializers/output/index.js +0 -107
  340. package/core/server/api/v2/utils/serializers/output/integrations.js +0 -35
  341. package/core/server/api/v2/utils/serializers/output/invites.js +0 -24
  342. package/core/server/api/v2/utils/serializers/output/mail.js +0 -19
  343. package/core/server/api/v2/utils/serializers/output/notifications.js +0 -29
  344. package/core/server/api/v2/utils/serializers/output/oembed.js +0 -8
  345. package/core/server/api/v2/utils/serializers/output/pages.js +0 -26
  346. package/core/server/api/v2/utils/serializers/output/posts.js +0 -26
  347. package/core/server/api/v2/utils/serializers/output/preview.js +0 -9
  348. package/core/server/api/v2/utils/serializers/output/redirects.js +0 -5
  349. package/core/server/api/v2/utils/serializers/output/roles.js +0 -29
  350. package/core/server/api/v2/utils/serializers/output/schedules.js +0 -5
  351. package/core/server/api/v2/utils/serializers/output/settings.js +0 -61
  352. package/core/server/api/v2/utils/serializers/output/site.js +0 -16
  353. package/core/server/api/v2/utils/serializers/output/slugs.js +0 -11
  354. package/core/server/api/v2/utils/serializers/output/tags.js +0 -25
  355. package/core/server/api/v2/utils/serializers/output/themes.js +0 -25
  356. package/core/server/api/v2/utils/serializers/output/users.js +0 -45
  357. package/core/server/api/v2/utils/serializers/output/utils/clean.js +0 -174
  358. package/core/server/api/v2/utils/serializers/output/utils/date.js +0 -21
  359. package/core/server/api/v2/utils/serializers/output/utils/extra-attrs.js +0 -161
  360. package/core/server/api/v2/utils/serializers/output/utils/mapper.js +0 -136
  361. package/core/server/api/v2/utils/serializers/output/utils/post-gating.js +0 -29
  362. package/core/server/api/v2/utils/serializers/output/utils/settings-type-group-mapper.js +0 -24
  363. package/core/server/api/v2/utils/serializers/output/utils/url.js +0 -67
  364. package/core/server/api/v2/utils/serializers/output/webhooks.js +0 -15
  365. package/core/server/api/v2/utils/validators/index.js +0 -9
  366. package/core/server/api/v2/utils/validators/input/images.js +0 -85
  367. package/core/server/api/v2/utils/validators/input/index.js +0 -45
  368. package/core/server/api/v2/utils/validators/input/invitations.js +0 -49
  369. package/core/server/api/v2/utils/validators/input/invites.js +0 -21
  370. package/core/server/api/v2/utils/validators/input/oembed.js +0 -17
  371. package/core/server/api/v2/utils/validators/input/pages.js +0 -46
  372. package/core/server/api/v2/utils/validators/input/passwordreset.js +0 -36
  373. package/core/server/api/v2/utils/validators/input/posts.js +0 -46
  374. package/core/server/api/v2/utils/validators/input/settings.js +0 -79
  375. package/core/server/api/v2/utils/validators/input/setup.js +0 -17
  376. package/core/server/api/v2/utils/validators/input/tags.js +0 -6
  377. package/core/server/api/v2/utils/validators/input/users.js +0 -21
  378. package/core/server/api/v2/utils/validators/output/index.js +0 -1
  379. package/core/server/api/v2/utils/validators/utils/json-schema.js +0 -17
  380. package/core/server/api/v2/webhooks.js +0 -163
  381. package/core/server/api/v3/authentication.js +0 -192
  382. package/core/server/api/v3/authors-public.js +0 -69
  383. package/core/server/api/v3/config.js +0 -12
  384. package/core/server/api/v3/db.js +0 -131
  385. package/core/server/api/v3/email-preview.js +0 -74
  386. package/core/server/api/v3/email.js +0 -65
  387. package/core/server/api/v3/identities.js +0 -36
  388. package/core/server/api/v3/images.js +0 -20
  389. package/core/server/api/v3/index.js +0 -179
  390. package/core/server/api/v3/integrations.js +0 -150
  391. package/core/server/api/v3/invites.js +0 -125
  392. package/core/server/api/v3/labels.js +0 -162
  393. package/core/server/api/v3/mail.js +0 -66
  394. package/core/server/api/v3/memberSigninUrls.js +0 -33
  395. package/core/server/api/v3/members.js +0 -412
  396. package/core/server/api/v3/membersStripeConnect.js +0 -29
  397. package/core/server/api/v3/notifications.js +0 -96
  398. package/core/server/api/v3/oembed.js +0 -23
  399. package/core/server/api/v3/pages-public.js +0 -77
  400. package/core/server/api/v3/pages.js +0 -199
  401. package/core/server/api/v3/posts-public.js +0 -76
  402. package/core/server/api/v3/posts.js +0 -200
  403. package/core/server/api/v3/preview.js +0 -44
  404. package/core/server/api/v3/redirects.js +0 -47
  405. package/core/server/api/v3/roles.js +0 -19
  406. package/core/server/api/v3/schedules.js +0 -77
  407. package/core/server/api/v3/session.js +0 -70
  408. package/core/server/api/v3/settings-public.js +0 -17
  409. package/core/server/api/v3/settings.js +0 -224
  410. package/core/server/api/v3/site.js +0 -14
  411. package/core/server/api/v3/slack.js +0 -12
  412. package/core/server/api/v3/slugs.js +0 -48
  413. package/core/server/api/v3/snippets.js +0 -115
  414. package/core/server/api/v3/tags-public.js +0 -71
  415. package/core/server/api/v3/tags.js +0 -159
  416. package/core/server/api/v3/themes.js +0 -131
  417. package/core/server/api/v3/users.js +0 -242
  418. package/core/server/api/v3/utils/index.js +0 -34
  419. package/core/server/api/v3/utils/permissions.js +0 -116
  420. package/core/server/api/v3/utils/serializers/index.js +0 -9
  421. package/core/server/api/v3/utils/serializers/input/authors.js +0 -31
  422. package/core/server/api/v3/utils/serializers/input/db.js +0 -20
  423. package/core/server/api/v3/utils/serializers/input/index.js +0 -41
  424. package/core/server/api/v3/utils/serializers/input/integrations.js +0 -33
  425. package/core/server/api/v3/utils/serializers/input/members.js +0 -62
  426. package/core/server/api/v3/utils/serializers/input/pages.js +0 -208
  427. package/core/server/api/v3/utils/serializers/input/posts.js +0 -242
  428. package/core/server/api/v3/utils/serializers/input/settings.js +0 -168
  429. package/core/server/api/v3/utils/serializers/input/tags.js +0 -42
  430. package/core/server/api/v3/utils/serializers/input/users.js +0 -26
  431. package/core/server/api/v3/utils/serializers/input/utils/slug-filter-order.js +0 -18
  432. package/core/server/api/v3/utils/serializers/input/utils/url.js +0 -71
  433. package/core/server/api/v3/utils/serializers/input/webhooks.js +0 -12
  434. package/core/server/api/v3/utils/serializers/output/actions.js +0 -13
  435. package/core/server/api/v3/utils/serializers/output/all.js +0 -25
  436. package/core/server/api/v3/utils/serializers/output/authentication.js +0 -69
  437. package/core/server/api/v3/utils/serializers/output/authors.js +0 -21
  438. package/core/server/api/v3/utils/serializers/output/config.js +0 -25
  439. package/core/server/api/v3/utils/serializers/output/db.js +0 -40
  440. package/core/server/api/v3/utils/serializers/output/email-preview.js +0 -7
  441. package/core/server/api/v3/utils/serializers/output/emails.js +0 -13
  442. package/core/server/api/v3/utils/serializers/output/identities.js +0 -7
  443. package/core/server/api/v3/utils/serializers/output/images.js +0 -19
  444. package/core/server/api/v3/utils/serializers/output/index.js +0 -135
  445. package/core/server/api/v3/utils/serializers/output/integrations.js +0 -35
  446. package/core/server/api/v3/utils/serializers/output/invites.js +0 -24
  447. package/core/server/api/v3/utils/serializers/output/labels.js +0 -25
  448. package/core/server/api/v3/utils/serializers/output/mail.js +0 -19
  449. package/core/server/api/v3/utils/serializers/output/member-signin_urls.js +0 -7
  450. package/core/server/api/v3/utils/serializers/output/members.js +0 -228
  451. package/core/server/api/v3/utils/serializers/output/notifications.js +0 -29
  452. package/core/server/api/v3/utils/serializers/output/oembed.js +0 -8
  453. package/core/server/api/v3/utils/serializers/output/pages.js +0 -26
  454. package/core/server/api/v3/utils/serializers/output/posts.js +0 -26
  455. package/core/server/api/v3/utils/serializers/output/preview.js +0 -10
  456. package/core/server/api/v3/utils/serializers/output/redirects.js +0 -5
  457. package/core/server/api/v3/utils/serializers/output/roles.js +0 -29
  458. package/core/server/api/v3/utils/serializers/output/schedules.js +0 -5
  459. package/core/server/api/v3/utils/serializers/output/settings.js +0 -65
  460. package/core/server/api/v3/utils/serializers/output/site.js +0 -19
  461. package/core/server/api/v3/utils/serializers/output/slugs.js +0 -11
  462. package/core/server/api/v3/utils/serializers/output/snippets.js +0 -97
  463. package/core/server/api/v3/utils/serializers/output/tags.js +0 -25
  464. package/core/server/api/v3/utils/serializers/output/themes.js +0 -25
  465. package/core/server/api/v3/utils/serializers/output/users.js +0 -74
  466. package/core/server/api/v3/utils/serializers/output/utils/clean.js +0 -166
  467. package/core/server/api/v3/utils/serializers/output/utils/date.js +0 -21
  468. package/core/server/api/v3/utils/serializers/output/utils/extra-attrs.js +0 -174
  469. package/core/server/api/v3/utils/serializers/output/utils/mapper.js +0 -197
  470. package/core/server/api/v3/utils/serializers/output/utils/post-gating.js +0 -39
  471. package/core/server/api/v3/utils/serializers/output/utils/settings-type-group-mapper.js +0 -24
  472. package/core/server/api/v3/utils/serializers/output/utils/url.js +0 -67
  473. package/core/server/api/v3/utils/serializers/output/webhooks.js +0 -15
  474. package/core/server/api/v3/utils/validators/index.js +0 -9
  475. package/core/server/api/v3/utils/validators/input/images.js +0 -85
  476. package/core/server/api/v3/utils/validators/input/index.js +0 -61
  477. package/core/server/api/v3/utils/validators/input/invitations.js +0 -49
  478. package/core/server/api/v3/utils/validators/input/invites.js +0 -21
  479. package/core/server/api/v3/utils/validators/input/labels.js +0 -6
  480. package/core/server/api/v3/utils/validators/input/members.js +0 -6
  481. package/core/server/api/v3/utils/validators/input/oembed.js +0 -17
  482. package/core/server/api/v3/utils/validators/input/pages.js +0 -46
  483. package/core/server/api/v3/utils/validators/input/passwordreset.js +0 -36
  484. package/core/server/api/v3/utils/validators/input/posts.js +0 -46
  485. package/core/server/api/v3/utils/validators/input/settings.js +0 -89
  486. package/core/server/api/v3/utils/validators/input/setup.js +0 -17
  487. package/core/server/api/v3/utils/validators/input/snippets.js +0 -6
  488. package/core/server/api/v3/utils/validators/input/tags.js +0 -6
  489. package/core/server/api/v3/utils/validators/input/users.js +0 -22
  490. package/core/server/api/v3/utils/validators/input/webhooks.js +0 -27
  491. package/core/server/api/v3/utils/validators/output/index.js +0 -1
  492. package/core/server/api/v3/utils/validators/utils/json-schema.js +0 -17
  493. package/core/server/api/v3/webhooks.js +0 -130
  494. package/core/server/data/migrations/utils.js +0 -571
  495. package/core/server/data/migrations/versions/1.13/1-custom-template-post.js +0 -7
  496. package/core/server/data/migrations/versions/1.13/2-theme-permissions.js +0 -58
  497. package/core/server/data/migrations/versions/1.18/1-add-webhooks-table.js +0 -2
  498. package/core/server/data/migrations/versions/1.19/1-webhook-permissions.js +0 -31
  499. package/core/server/data/migrations/versions/1.20/1-remove-settings-keys.js +0 -65
  500. package/core/server/data/migrations/versions/1.21/1-add-contributor-role.js +0 -58
  501. package/core/server/data/migrations/versions/1.22/1-multiple-authors-DDL.js +0 -2
  502. package/core/server/data/migrations/versions/1.22/1-multiple-authors-DML.js +0 -63
  503. package/core/server/data/migrations/versions/1.25/1-update-koenig-beta-html.js +0 -70
  504. package/core/server/data/migrations/versions/1.25/2-demo-post.js +0 -55
  505. package/core/server/data/migrations/versions/1.3/1-post-excerpt.js +0 -7
  506. package/core/server/data/migrations/versions/1.4/1-codeinjection-post.js +0 -14
  507. package/core/server/data/migrations/versions/1.5/1-og-twitter-post.js +0 -34
  508. package/core/server/data/migrations/versions/1.7/1-add-backup-client.js +0 -10
  509. package/core/server/data/migrations/versions/1.9/1-add-permissions-redirect.js +0 -23
  510. package/core/server/data/migrations/versions/2.0/1-rename-amp-column.js +0 -44
  511. package/core/server/data/migrations/versions/2.0/2-update-posts.js +0 -7
  512. package/core/server/data/migrations/versions/2.0/3-remove-koenig-labs.js +0 -42
  513. package/core/server/data/migrations/versions/2.0/4-permalink-setting.js +0 -85
  514. package/core/server/data/migrations/versions/2.0/5-remove-demo-post.js +0 -85
  515. package/core/server/data/migrations/versions/2.0/6-replace-fixture-posts.js +0 -10
  516. package/core/server/data/migrations/versions/2.13/1-remove-empty-strings.js +0 -5
  517. package/core/server/data/migrations/versions/2.14/1-add-actions-table.js +0 -2
  518. package/core/server/data/migrations/versions/2.14/2-add-actions-permissions.js +0 -12
  519. package/core/server/data/migrations/versions/2.15/1-add-type-column-to-integrations.js +0 -8
  520. package/core/server/data/migrations/versions/2.15/2-insert-zapier-integration.js +0 -69
  521. package/core/server/data/migrations/versions/2.16/1-add-members-perrmissions.js +0 -1
  522. package/core/server/data/migrations/versions/2.17/1-normalize-settings.js +0 -74
  523. package/core/server/data/migrations/versions/2.17/2-posts-add-canonical-url.js +0 -7
  524. package/core/server/data/migrations/versions/2.18/1-restore-settings-from-backup.js +0 -134
  525. package/core/server/data/migrations/versions/2.2/1-add-sessions-table.js +0 -2
  526. package/core/server/data/migrations/versions/2.2/2-add-integrations-and-api-key-tables.js +0 -6
  527. package/core/server/data/migrations/versions/2.2/3-insert-admin-integration-role.js +0 -83
  528. package/core/server/data/migrations/versions/2.2/4-insert-integration-and-api-key-permissions.js +0 -77
  529. package/core/server/data/migrations/versions/2.2/5-add-mobiledoc-revisions-table.js +0 -2
  530. package/core/server/data/migrations/versions/2.21/1-update-editor-permissions.js +0 -28
  531. package/core/server/data/migrations/versions/2.22/1-add-member-permissions-to-roles.js +0 -47
  532. package/core/server/data/migrations/versions/2.27/1-insert-ghost-db-backup-role.js +0 -83
  533. package/core/server/data/migrations/versions/2.27/2-insert-db-backup-integration.js +0 -69
  534. package/core/server/data/migrations/versions/2.27/3-add-subdirectory-to-relative-canonical-urls.js +0 -100
  535. package/core/server/data/migrations/versions/2.28/1-add-db-backup-content-permission.js +0 -9
  536. package/core/server/data/migrations/versions/2.28/2-add-db-backup-content-permission-to-roles.js +0 -15
  537. package/core/server/data/migrations/versions/2.28/3-insert-ghost-scheduler-role.js +0 -84
  538. package/core/server/data/migrations/versions/2.28/4-insert-scheduler-integration.js +0 -69
  539. package/core/server/data/migrations/versions/2.28/5-add-scheduler-permission-to-roles.js +0 -23
  540. package/core/server/data/migrations/versions/2.28/6-add-type-column.js +0 -6
  541. package/core/server/data/migrations/versions/2.28/7-populate-type-column.js +0 -6
  542. package/core/server/data/migrations/versions/2.28/8-remove-page-column.js +0 -6
  543. package/core/server/data/migrations/versions/2.29/1-add-post-page-column.js +0 -20
  544. package/core/server/data/migrations/versions/2.29/2-populate-post-page-column.js +0 -98
  545. package/core/server/data/migrations/versions/2.29/3-remove-page-type-column.js +0 -15
  546. package/core/server/data/migrations/versions/2.3/1-add-webhook-columns.js +0 -45
  547. package/core/server/data/migrations/versions/2.3/2-add-webhook-edit-permission.js +0 -9
  548. package/core/server/data/migrations/versions/2.31/1-remove-name-and-password-from-members-table.js +0 -15
  549. package/core/server/data/migrations/versions/2.32/01-add-members-stripe-customers-table.js +0 -4
  550. package/core/server/data/migrations/versions/2.32/02-add-name-to-members-table.js +0 -7
  551. package/core/server/data/migrations/versions/2.33/01-correct-members-stripe-customers-table.js +0 -37
  552. package/core/server/data/migrations/versions/2.34/01-add-stripe-customers-subscriptions-table.js +0 -2
  553. package/core/server/data/migrations/versions/2.34/02-add-email-to-members-stripe-customers-table.js +0 -7
  554. package/core/server/data/migrations/versions/2.34/03-add-name-to-members-stripe-customers-table.js +0 -7
  555. package/core/server/data/migrations/versions/2.35/01-add-note-to-members-table.js +0 -7
  556. package/core/server/data/migrations/versions/2.37/01-add-self-signup-and-from address-to-members-settings.js +0 -67
  557. package/core/server/data/migrations/versions/2.6/1-add-webhook-permission-roles.js +0 -31
  558. package/core/server/data/migrations/versions/2.8/1-add-members-table.js +0 -2
  559. package/core/server/data/migrations/versions/3.0/01-remove-user-ghost-auth-columns.js +0 -14
  560. package/core/server/data/migrations/versions/3.0/02-drop-token-auth-tables.js +0 -31
  561. package/core/server/data/migrations/versions/3.0/03-drop-client-auth-tables.js +0 -35
  562. package/core/server/data/migrations/versions/3.0/04-add-posts-meta-table.js +0 -2
  563. package/core/server/data/migrations/versions/3.0/05-populate-posts-meta-table.js +0 -83
  564. package/core/server/data/migrations/versions/3.0/06-remove-posts-meta-columns.js +0 -44
  565. package/core/server/data/migrations/versions/3.0/07-add-posts-type-column.js +0 -8
  566. package/core/server/data/migrations/versions/3.0/08-populate-posts-type-column.js +0 -94
  567. package/core/server/data/migrations/versions/3.0/09-remove-posts-page-column.js +0 -7
  568. package/core/server/data/migrations/versions/3.0/10-remove-empty-strings.js +0 -81
  569. package/core/server/data/migrations/versions/3.0/11-update-posts-html.js +0 -7
  570. package/core/server/data/migrations/versions/3.0/12-populate-members-table-from-subscribers.js +0 -54
  571. package/core/server/data/migrations/versions/3.0/13-drop-subscribers-table.js +0 -34
  572. package/core/server/data/migrations/versions/3.0/14-remove-subscribers-flag.js +0 -24
  573. package/core/server/data/migrations/versions/3.1/01-add-send-email-when-published-to-posts.js +0 -7
  574. package/core/server/data/migrations/versions/3.1/02-add-email-subject-to-posts-meta.js +0 -7
  575. package/core/server/data/migrations/versions/3.1/03-add-email-preview-permissions.js +0 -18
  576. package/core/server/data/migrations/versions/3.1/04-add-subscribed-flag-to-members.js +0 -7
  577. package/core/server/data/migrations/versions/3.1/05-add-emails-table.js +0 -2
  578. package/core/server/data/migrations/versions/3.1/06-add-email-permissions.js +0 -15
  579. package/core/server/data/migrations/versions/3.1/07-add-uuid-field-to-members.js +0 -8
  580. package/core/server/data/migrations/versions/3.1/08-add-uuid-values-to-members.js +0 -23
  581. package/core/server/data/migrations/versions/3.1/09-add-further-email-permissions.js +0 -25
  582. package/core/server/data/migrations/versions/3.1/10-add-email-error-data-column.js +0 -8
  583. package/core/server/data/migrations/versions/3.11/01-remove-broken-complimentary-plan-from-members-settings.js +0 -68
  584. package/core/server/data/migrations/versions/3.12/01-add-identity-permission.js +0 -7
  585. package/core/server/data/migrations/versions/3.12/02-remove-legacy-is-paid-flag-from-settings.js +0 -93
  586. package/core/server/data/migrations/versions/3.18/01-add-email-preview-permissions-to-roles.js +0 -39
  587. package/core/server/data/migrations/versions/3.18/02-add-members_stripe_connect-auth-permissions.js +0 -7
  588. package/core/server/data/migrations/versions/3.19/01-update-member-from-email-address.js +0 -91
  589. package/core/server/data/migrations/versions/3.2/01-add-cancel-at-period-end-to-subscriptions.js +0 -7
  590. package/core/server/data/migrations/versions/3.22/01-removed-legacy-values-from-settings-table.js +0 -65
  591. package/core/server/data/migrations/versions/3.22/02-settings-key-renames.js +0 -90
  592. package/core/server/data/migrations/versions/3.22/03-add-group-and-flags-to-settings.js +0 -15
  593. package/core/server/data/migrations/versions/3.22/04-populate-settings-groups-and-flags.js +0 -194
  594. package/core/server/data/migrations/versions/3.22/05-migrate-members-subscription-settings.js +0 -182
  595. package/core/server/data/migrations/versions/3.22/06-migrate-stripe-connect-settings.js +0 -132
  596. package/core/server/data/migrations/versions/3.22/07-update-type-for-settings.js +0 -137
  597. package/core/server/data/migrations/versions/3.23/01-migrate-bulk-email-settings.js +0 -65
  598. package/core/server/data/migrations/versions/3.23/02-remove-bulk-email-settings.js +0 -48
  599. package/core/server/data/migrations/versions/3.23/03-update-portal-button-setting.js +0 -24
  600. package/core/server/data/migrations/versions/3.23/04-add-meta-columns-to-tags-table.js +0 -54
  601. package/core/server/data/migrations/versions/3.24/01-populate-group-for-new-portal-settings.js +0 -38
  602. package/core/server/data/migrations/versions/3.25/01-add-members-stripe-webhook-settings.js +0 -22
  603. package/core/server/data/migrations/versions/3.26/01-add-amp-gtag-id-setting.js +0 -20
  604. package/core/server/data/migrations/versions/3.29/01-remove-duplicate-subscriptions.js +0 -53
  605. package/core/server/data/migrations/versions/3.29/02-remove-duplicate-customers.js +0 -53
  606. package/core/server/data/migrations/versions/3.29/03-remove-orphaned-customers.js +0 -35
  607. package/core/server/data/migrations/versions/3.29/04-remove-orphaned-subscriptions.js +0 -35
  608. package/core/server/data/migrations/versions/3.29/05-add-member-constraints.js +0 -177
  609. package/core/server/data/migrations/versions/3.30/01-add-member-signin-url-permission-roles.js +0 -8
  610. package/core/server/data/migrations/versions/3.32/01-add-member-support-address-setting.js +0 -27
  611. package/core/server/data/migrations/versions/3.32/02-add-member-reply-address-setting.js +0 -20
  612. package/core/server/data/migrations/versions/3.32/03-add-routes-hash-setting.js +0 -20
  613. package/core/server/data/migrations/versions/3.33/01-add-email-recipients-tables.js +0 -8
  614. package/core/server/data/migrations/versions/3.34/01-add-tokens-table.js +0 -2
  615. package/core/server/data/migrations/versions/3.35/01-add-address-columns-to-emails-table.js +0 -14
  616. package/core/server/data/migrations/versions/3.36/01-add-snippets-table.js +0 -2
  617. package/core/server/data/migrations/versions/3.36/02-add-snippets-permissions.js +0 -56
  618. package/core/server/data/migrations/versions/3.37/01-update-portal-button-setting.js +0 -30
  619. package/core/server/data/migrations/versions/3.38/01-add-email-recipient-filter-column.js +0 -8
  620. package/core/server/data/migrations/versions/3.38/02-populate-email-recipient-filter-column.js +0 -34
  621. package/core/server/data/migrations/versions/3.38/03-add-recipient-filter-column.js +0 -8
  622. package/core/server/data/migrations/versions/3.38/04-populate-recipient-filter-column.js +0 -49
  623. package/core/server/data/migrations/versions/3.38/05-add-emails-track-opens-column.js +0 -7
  624. package/core/server/data/migrations/versions/3.38/06-add-newsletter-settings.js +0 -16
  625. package/core/server/data/migrations/versions/3.38/07-migrate-newsletter-settings-from-config.js +0 -48
  626. package/core/server/data/migrations/versions/3.38/08-repopulate-send-email-when-published-down-migration.js +0 -25
  627. package/core/server/data/migrations/versions/3.38/09-remove-send-email-when-published-column.js +0 -7
  628. package/core/server/data/migrations/versions/3.39/01-add-members-signup-redirect-settings.js +0 -16
  629. package/core/server/data/migrations/versions/3.39/02-add-user-id-to-api-keys-table.js +0 -7
  630. package/core/server/data/migrations/versions/3.39/03-add-email-track-opens-setting.js +0 -16
  631. package/core/server/data/migrations/versions/3.39/04-add-cancellation-reason-column.js +0 -7
  632. package/core/server/data/migrations/versions/3.39/05-remove-unused-columns-on-emails.js +0 -14
  633. package/core/server/data/migrations/versions/3.39/06-add-email-recipient-index.js +0 -58
  634. package/core/server/data/migrations/versions/3.39/07-add-email-recipients-event-timestamps.js +0 -19
  635. package/core/server/data/migrations/versions/3.39/08-add-email-stats-columns.js +0 -22
  636. package/core/server/data/migrations/versions/3.40/01-add-members-email-open-rate-column.js +0 -8
  637. package/core/server/data/migrations/versions/3.40/02-add members-email-aggregation-columns.js +0 -16
  638. package/core/server/data/migrations/versions/3.40/03-populate-members-email-counts.js +0 -15
  639. package/core/server/data/migrations/versions/3.41/01-add-firstpromoter-settings.js +0 -16
  640. package/core/server/data/migrations/versions/3.6/1-add-labels-table.js +0 -2
  641. package/core/server/data/migrations/versions/3.6/2-add-members-labels-table.js +0 -2
  642. package/core/server/data/migrations/versions/3.6/3-add-labels-permissions.js +0 -47
  643. package/core/server/data/migrations/versions/3.7/01-fix-incorrect-member-labels-foreign-keys.js +0 -46
  644. package/core/server/data/migrations/versions/3.8/01-add-geolocation-to-members.js +0 -7
  645. package/core/server/data/migrations/versions/3.9/01-add-member-sigin-url-permissions.js +0 -7
  646. package/core/server/services/mail/utils.js +0 -34
  647. package/core/server/services/url/configs/canary.js +0 -143
  648. package/core/server/services/url/configs/v3.js +0 -141
  649. package/core/server/services/url/configs/v4.js +0 -143
  650. package/core/server/web/api/v2/admin/app.js +0 -43
  651. package/core/server/web/api/v2/admin/middleware.js +0 -85
  652. package/core/server/web/api/v2/admin/routes.js +0 -200
  653. package/core/server/web/api/v2/content/app.js +0 -38
  654. package/core/server/web/api/v2/content/middleware.js +0 -23
  655. package/core/server/web/api/v2/content/routes.js +0 -37
  656. package/core/server/web/api/v3/admin/app.js +0 -43
  657. package/core/server/web/api/v3/admin/middleware.js +0 -89
  658. package/core/server/web/api/v3/admin/routes.js +0 -267
  659. package/core/server/web/api/v3/content/app.js +0 -38
  660. package/core/server/web/api/v3/content/middleware.js +0 -23
  661. package/core/server/web/api/v3/content/routes.js +0 -37
  662. package/core/server/web/oauth/app.js +0 -153
  663. package/core/server/web/oauth/index.js +0 -1
@@ -0,0 +1,94 @@
1
+ const logging = require('@tryghost/logging');
2
+ const {commands} = require('../../schema');
3
+ const {createIrreversibleMigration, createNonTransactionalMigration} = require('./migrations');
4
+
5
+ /**
6
+ * Creates a migrations which will add a new table from schema.js to the database
7
+ * @param {string} name - table name
8
+ * @param {Object} tableSpec - copy of table schema definition as defined in schema.js at the moment of writing the migration,
9
+ * this parameter MUST be present, otherwise @daniellockyer will hunt you down
10
+ *
11
+ * @returns {Object} migration object returning config/up/down properties
12
+ */
13
+ function addTable(name, tableSpec) {
14
+ return createNonTransactionalMigration(
15
+ async function up(connection) {
16
+ const tableExists = await connection.schema.hasTable(name);
17
+ if (tableExists) {
18
+ logging.warn(`Skipping adding table: ${name} - table already exists`);
19
+ return;
20
+ }
21
+
22
+ logging.info(`Adding table: ${name}`);
23
+ return commands.createTable(name, connection, tableSpec);
24
+ },
25
+ async function down(connection) {
26
+ const tableExists = await connection.schema.hasTable(name);
27
+ if (!tableExists) {
28
+ logging.warn(`Skipping dropping table: ${name} - table does not exist`);
29
+ return;
30
+ }
31
+
32
+ logging.info(`Dropping table: ${name}`);
33
+ return commands.deleteTable(name, connection);
34
+ }
35
+ );
36
+ }
37
+
38
+ /**
39
+ * Creates migration which will drop a table
40
+ *
41
+ * @param {[string]} names - names of the tables to drop
42
+ */
43
+ function dropTables(names) {
44
+ return createIrreversibleMigration(
45
+ async function up(connection) {
46
+ for (const name of names) {
47
+ const exists = await connection.schema.hasTable(name);
48
+
49
+ if (!exists) {
50
+ logging.warn(`Skipping dropping table: ${name} - table does not exist`);
51
+ } else {
52
+ logging.info(`Dropping table: ${name}`);
53
+ await commands.deleteTable(name, connection);
54
+ }
55
+ }
56
+ }
57
+ );
58
+ }
59
+
60
+ /**
61
+ * Creates a migration which will drop an existing table and then re-add a new table based on provided spec
62
+ * @param {string} name - table name
63
+ * @param {Object} tableSpec - copy of table schema definition as defined in schema.js at the moment of writing the migration,
64
+ * this parameter MUST be present, otherwise @daniellockyer will hunt you down
65
+ *
66
+ * @returns {Object} migration object returning config/up/down properties
67
+ */
68
+ function recreateTable(name, tableSpec) {
69
+ return createNonTransactionalMigration(
70
+ async function up(connection) {
71
+ const exists = await connection.schema.hasTable(name);
72
+
73
+ if (!exists) {
74
+ logging.warn(`Skipping dropping table: ${name} - table does not exist`);
75
+ } else {
76
+ logging.info(`Dropping table: ${name}`);
77
+ await commands.deleteTable(name, connection);
78
+ logging.info(`Re-adding table: ${name}`);
79
+ await commands.createTable(name, connection, tableSpec);
80
+ }
81
+ },
82
+ async function down() {
83
+ // noop: we cannot go back to old table schema
84
+ logging.warn(`Ignoring rollback for table recreate: ${name}`);
85
+ return Promise.resolve();
86
+ }
87
+ );
88
+ }
89
+
90
+ module.exports = {
91
+ addTable,
92
+ dropTables,
93
+ recreateTable
94
+ };
@@ -0,0 +1,2 @@
1
+ const {createFinalMigration} = require('../../utils');
2
+ module.exports = createFinalMigration(1);
@@ -0,0 +1,6 @@
1
+ const {createTransactionalMigration} = require('../../utils');
2
+
3
+ module.exports = createTransactionalMigration(
4
+ async function up() {},
5
+ async function down() {}
6
+ );
@@ -0,0 +1,2 @@
1
+ const {createFinalMigration} = require('../../utils');
2
+ module.exports = createFinalMigration(2);
@@ -0,0 +1,2 @@
1
+ const {createFinalMigration} = require('../../utils');
2
+ module.exports = createFinalMigration(3);
@@ -1,13 +1,7 @@
1
1
  const {createIrreversibleMigration} = require('../../utils');
2
2
  const logging = require('@tryghost/logging');
3
3
  const ObjectID = require('bson-objectid');
4
- const crypto = require('crypto');
5
-
6
- // createSecret is copied from core/server/models/api-key.js
7
- const createSecret = (type) => {
8
- const bytes = type === 'content' ? 13 : 32;
9
- return crypto.randomBytes(bytes).toString('hex');
10
- };
4
+ const security = require('@tryghost/security');
11
5
 
12
6
  module.exports = createIrreversibleMigration(
13
7
  async function up(knex) {
@@ -54,7 +48,7 @@ module.exports = createIrreversibleMigration(
54
48
  const contentKey = {
55
49
  id: ObjectID().toHexString(),
56
50
  type: 'content',
57
- secret: createSecret('content'),
51
+ secret: security.secret.create('content'),
58
52
  role_id: null,
59
53
  integration_id: integration.id,
60
54
  created_at: now,
@@ -67,7 +61,7 @@ module.exports = createIrreversibleMigration(
67
61
  const adminKey = {
68
62
  id: ObjectID().toHexString(),
69
63
  type: 'admin',
70
- secret: createSecret('admin'),
64
+ secret: security.secret.create('admin'),
71
65
  role_id: role.id,
72
66
  integration_id: integration.id,
73
67
  created_at: now,
@@ -1,7 +1,7 @@
1
1
  const logging = require('@tryghost/logging');
2
2
  const {createIrreversibleMigration} = require('../../utils');
3
3
  const mobiledocLib = require('../../../../lib/mobiledoc');
4
- const htmlToText = require('html-to-text');
4
+ const htmlToPlaintext = require('../../../../../shared/html-to-plaintext');
5
5
 
6
6
  module.exports = createIrreversibleMigration(async (knex) => {
7
7
  logging.info('Starting re-generation of posts html.');
@@ -45,17 +45,8 @@ module.exports = createIrreversibleMigration(async (knex) => {
45
45
  html: html
46
46
  };
47
47
 
48
- // NOTE: block comes straight from the Post model
49
- // https://github.com/TryGhost/Ghost/blob/4.0.0-alpha.2/core/server/models/post.js#L484
50
48
  if (html !== post.html || !post.plaintext) {
51
- const plaintext = htmlToText.fromString(html, {
52
- wordwrap: 80,
53
- ignoreImage: true,
54
- hideLinkHrefIfSameAsText: true,
55
- preserveNewlines: true,
56
- returnDomByDefault: true,
57
- uppercaseHeadings: false
58
- });
49
+ const plaintext = htmlToPlaintext.excerpt(html);
59
50
 
60
51
  if (plaintext !== post.plaintext) {
61
52
  updatedAttrs.plaintext = plaintext;
@@ -1,6 +1,6 @@
1
1
  const ObjectID = require('bson-objectid');
2
2
  const logging = require('@tryghost/logging');
3
- const {createTransactionalMigration} = require('../../utils.js');
3
+ const {createTransactionalMigration} = require('../../utils');
4
4
 
5
5
  const MIGRATION_USER = 1;
6
6
 
@@ -1,6 +1,6 @@
1
1
  const logging = require('@tryghost/logging');
2
2
  const {chunk: chunkArray} = require('lodash');
3
- const {createTransactionalMigration} = require('../../utils.js');
3
+ const {createTransactionalMigration} = require('../../utils');
4
4
 
5
5
  module.exports = createTransactionalMigration(
6
6
  async function up(knex) {
@@ -1,6 +1,6 @@
1
1
  const _ = require('lodash');
2
2
  const logging = require('@tryghost/logging');
3
- const {createTransactionalMigration} = require('../../utils.js');
3
+ const {createTransactionalMigration} = require('../../utils');
4
4
 
5
5
  module.exports = createTransactionalMigration(
6
6
  async function up(knex) {
@@ -1,4 +1,4 @@
1
- const {addSetting} = require('../../utils.js');
1
+ const {addSetting} = require('../../utils');
2
2
 
3
3
  module.exports = addSetting({
4
4
  key: 'editor_is_launch_complete',
@@ -1,5 +1,5 @@
1
1
  const logging = require('@tryghost/logging');
2
- const {createTransactionalMigration} = require('../../utils.js');
2
+ const {createTransactionalMigration} = require('../../utils');
3
3
 
4
4
  module.exports = createTransactionalMigration(
5
5
  async function up(knex) {
@@ -1,4 +1,4 @@
1
- const {addSetting} = require('../../utils.js');
1
+ const {addSetting} = require('../../utils');
2
2
 
3
3
  module.exports = addSetting({
4
4
  key: 'default_content_visibility_tiers',
@@ -1,4 +1,4 @@
1
- const {addSetting} = require('../../utils.js');
1
+ const {addSetting} = require('../../utils');
2
2
 
3
3
  module.exports = addSetting({
4
4
  key: 'version_notifications',
@@ -1,5 +1,5 @@
1
1
  const logging = require('@tryghost/logging');
2
- const {createTransactionalMigration} = require('../../utils.js');
2
+ const {createTransactionalMigration} = require('../../utils');
3
3
 
4
4
  module.exports = createTransactionalMigration(
5
5
  async function up(knex) {
@@ -1,6 +1,6 @@
1
1
  const ObjectID = require('bson-objectid');
2
2
  const logging = require('@tryghost/logging');
3
- const {createTransactionalMigration} = require('../../utils.js');
3
+ const {createTransactionalMigration} = require('../../utils');
4
4
 
5
5
  const MIGRATION_USER = 1;
6
6
 
@@ -65,7 +65,7 @@ module.exports = createTransactionalMigration(
65
65
  continue;
66
66
  }
67
67
 
68
- const plaintext = htmlToPlaintext(html);
68
+ const plaintext = htmlToPlaintext.excerpt(html);
69
69
 
70
70
  await knex('posts')
71
71
  .transacting(trx)
@@ -1,5 +1,5 @@
1
1
  const logging = require('@tryghost/logging');
2
- const {createTransactionalMigration} = require('../../utils.js');
2
+ const {createTransactionalMigration} = require('../../utils');
3
3
 
4
4
  module.exports = createTransactionalMigration(
5
5
  async function up(knex) {
@@ -1,5 +1,5 @@
1
1
  const logging = require('@tryghost/logging');
2
- const {createTransactionalMigration} = require('../../utils.js');
2
+ const {createTransactionalMigration} = require('../../utils');
3
3
 
4
4
  module.exports = createTransactionalMigration(
5
5
  async function up(knex) {
@@ -0,0 +1,36 @@
1
+ const DatabaseInfo = require('@tryghost/database-info/lib/database-info');
2
+ const logging = require('@tryghost/logging');
3
+
4
+ const {createTransactionalMigration} = require('../../utils');
5
+
6
+ module.exports = createTransactionalMigration(
7
+ async function up(knex) {
8
+ if (DatabaseInfo.isSQLite(knex)) {
9
+ const duplicates = await knex('offer_redemptions')
10
+ .select('subscription_id')
11
+ .count('subscription_id as count')
12
+ .groupBy('subscription_id')
13
+ .having('count', '>', 1);
14
+
15
+ logging.info(`Deleting all offer redemptions which have duplicates`);
16
+ await knex('offer_redemptions')
17
+ .whereIn('subscription_id', duplicates.map(row => row.subscription_id))
18
+ .del();
19
+ return;
20
+ }
21
+ const result = await knex.raw(`
22
+ DELETE
23
+ duplicate_redemptions
24
+ FROM
25
+ offer_redemptions AS duplicate_redemptions,
26
+ offer_redemptions
27
+ WHERE
28
+ duplicate_redemptions.subscription_id = offer_redemptions.subscription_id
29
+ AND
30
+ duplicate_redemptions.created_at < offer_redemptions.created_at
31
+ `);
32
+
33
+ logging.info(`Deleted ${result[0].affectedRows} duplicate offer redemptions`);
34
+ },
35
+ async function down() {}
36
+ );
@@ -0,0 +1,108 @@
1
+ const logging = require('@tryghost/logging');
2
+ const {uniq} = require('lodash');
3
+
4
+ const {createTransactionalMigration} = require('../../utils');
5
+
6
+ module.exports = createTransactionalMigration(
7
+ async function up(knex) {
8
+ logging.info('Adjusting MRR based on Offer Redemptions');
9
+ const offerRedemptions = await knex
10
+ .select('or.*', 'o.discount_type', 'o.discount_amount', 'o.interval AS discount_interval', 's.mrr AS mrr', 's.id AS subscription_id', 'p.amount AS amount', 'p.interval AS interval')
11
+ .from('offer_redemptions AS or')
12
+ .join('offers AS o', 'or.offer_id', '=', 'o.id')
13
+ .join('members_stripe_customers_subscriptions AS s', 'or.subscription_id', '=', 's.id')
14
+ .join('stripe_prices AS p', 'p.stripe_price_id', '=', 's.stripe_price_id')
15
+ .where('o.duration', '=', 'forever')
16
+ .whereNotNull('s.offer_id')
17
+ .where('s.mrr', '!=', 0)
18
+ .orderBy('or.created_at', 'asc');
19
+
20
+ if (offerRedemptions.length === 0) {
21
+ logging.info('No Offers redeemed, skipping migration');
22
+ return;
23
+ } else {
24
+ logging.info(`Adjusting MRR for ${offerRedemptions.length} Offer Redemptions`);
25
+ }
26
+
27
+ const memberIds = uniq(offerRedemptions.map(redemption => redemption.member_id));
28
+
29
+ const mrrCreatedEvents = await knex
30
+ .select('*')
31
+ .from('members_paid_subscription_events')
32
+ .where('type', 'created')
33
+ .whereIn('member_id', memberIds);
34
+
35
+ function storeEventOnMemberId(storage, event) {
36
+ return {
37
+ ...storage,
38
+ [event.member_id]: storage[event.member_id] ? storage[event.member_id].concat(event) : [event]
39
+ };
40
+ }
41
+
42
+ const mrrCreatedEventsByMemberId = mrrCreatedEvents.reduce(storeEventOnMemberId, {});
43
+
44
+ const updatedEvents = [];
45
+
46
+ function calculateMRR(subscription, redemption) {
47
+ if (redemption && subscription.interval !== redemption.discount_interval) {
48
+ logging.error('Found invalid price & redemption pair');
49
+ return calculateMRR(subscription);
50
+ }
51
+
52
+ if (!redemption) {
53
+ return subscription.interval === 'year' ? subscription.amount / 12 : subscription.amount;
54
+ }
55
+
56
+ if (redemption.discount_type === 'percent') {
57
+ return calculateMRR({
58
+ interval: subscription.interval,
59
+ amount: subscription.amount * (100 - redemption.discount_amount) / 100
60
+ });
61
+ }
62
+
63
+ return calculateMRR({
64
+ interval: subscription.interval,
65
+ amount: subscription.amount - redemption.discount_amount
66
+ });
67
+ }
68
+
69
+ // eslint-disable-next-line no-restricted-syntax
70
+ offerRedemptions.forEach((redemption) => {
71
+ const memberEvents = mrrCreatedEventsByMemberId[redemption.member_id];
72
+
73
+ // If a member has had multiple subscriptions we ignore because we cannot easily work out which event is correct.
74
+ if (memberEvents.length !== 1) {
75
+ return;
76
+ }
77
+
78
+ const firstEvent = memberEvents[0];
79
+
80
+ const mrr = calculateMRR({
81
+ interval: redemption.interval,
82
+ amount: redemption.amount
83
+ }, redemption);
84
+ updatedEvents.push({
85
+ id: firstEvent.id,
86
+ type: 'created',
87
+ subscription_id: redemption.subscription_id,
88
+ member_id: firstEvent.member_id,
89
+ from_plan: firstEvent.from_plan,
90
+ to_plan: firstEvent.to_plan,
91
+ currency: firstEvent.currency,
92
+ source: firstEvent.source,
93
+ created_at: firstEvent.created_at,
94
+ mrr_delta: mrr
95
+ });
96
+ });
97
+
98
+ if (updatedEvents.length === 0) {
99
+ return;
100
+ }
101
+
102
+ const idsToDelete = updatedEvents.map(event => event.id);
103
+
104
+ await knex('members_paid_subscription_events').whereIn('id', idsToDelete).del();
105
+ await knex.batchInsert('members_paid_subscription_events', updatedEvents);
106
+ },
107
+ async function down() {}
108
+ );
@@ -0,0 +1,44 @@
1
+ const logging = require('@tryghost/logging');
2
+
3
+ const {createTransactionalMigration} = require('../../utils');
4
+
5
+ module.exports = createTransactionalMigration(
6
+ async function up(knex) {
7
+ const subscriptionsToUpdate = await knex('members_stripe_customers_subscriptions AS s')
8
+ .join('offers AS o', 's.offer_id', '=', 'o.id')
9
+ .where('o.duration', '=', 'forever')
10
+ .andWhere('s.mrr', '!=', 0)
11
+ .select('s.*', 'o.discount_type AS offer_type', 'o.discount_amount AS offer_amount');
12
+
13
+ if (!subscriptionsToUpdate.length) {
14
+ logging.info('No subscriptions found needing updating');
15
+ return;
16
+ }
17
+
18
+ const toInsert = subscriptionsToUpdate.map((subscription) => {
19
+ let discountedAmount;
20
+ if (subscription.offer_type === 'percent') {
21
+ discountedAmount = subscription.plan_amount * (100 - subscription.offer_amount) / 100;
22
+ } else {
23
+ discountedAmount = subscription.plan_amount - subscription.offer_amount;
24
+ }
25
+
26
+ const newSubscription = {
27
+ ...subscription,
28
+ mrr: subscription.plan_interval === 'year' ? discountedAmount / 12 : discountedAmount
29
+ };
30
+
31
+ delete newSubscription.offer_type;
32
+ delete newSubscription.offer_amount;
33
+
34
+ return newSubscription;
35
+ });
36
+
37
+ const toDelete = toInsert.map(sub => sub.id);
38
+
39
+ logging.info(`Replacing ${toDelete.length} subscriptions with updated MRR based on Offers`);
40
+ await knex('members_stripe_customers_subscriptions').whereIn('id', toDelete).del();
41
+ await knex.batchInsert('members_stripe_customers_subscriptions', toInsert);
42
+ },
43
+ async function down() {}
44
+ );
@@ -0,0 +1,73 @@
1
+ const ObjectID = require('bson-objectid').default;
2
+ const logging = require('@tryghost/logging');
3
+
4
+ const {createTransactionalMigration} = require('../../utils');
5
+
6
+ module.exports = createTransactionalMigration(
7
+ async function up(knex) {
8
+ // eslint-disable-next-line no-restricted-syntax
9
+ const canceledSubscriptions = await knex('members_stripe_customers_subscriptions')
10
+ .select(
11
+ 'members_stripe_customers_subscriptions.id',
12
+ 'members_stripe_customers_subscriptions.updated_at',
13
+ 'members_stripe_customers_subscriptions.mrr',
14
+ 'members_stripe_customers_subscriptions.stripe_price_id',
15
+ 'members_stripe_customers_subscriptions.plan_currency',
16
+ 'members_stripe_customers.member_id'
17
+ )
18
+ .join('members_stripe_customers', 'members_stripe_customers_subscriptions.customer_id', '=', 'members_stripe_customers.customer_id')
19
+ .join('members', 'members_stripe_customers.member_id', '=', 'members.id')
20
+ .where('cancel_at_period_end', '=', true)
21
+ .where('mrr', '!=', 0);
22
+
23
+ if (canceledSubscriptions.length === 0) {
24
+ logging.info('No canceled subscriptions found, skipping migration.');
25
+ return;
26
+ } else {
27
+ logging.info(`Found ${canceledSubscriptions.length} canceled subscriptions, updating MRR events`);
28
+ }
29
+
30
+ const canceledEvents = await knex('members_paid_subscription_events')
31
+ .select('*')
32
+ .where('type', '=', 'canceled')
33
+ .whereIn('subscription_id', canceledSubscriptions.map(x => x.id))
34
+ .orderBy('created_at', 'desc');
35
+
36
+ const toUpdate = [];
37
+ const toInsert = [];
38
+
39
+ // eslint-disable-next-line no-restricted-syntax
40
+ for (const subscription of canceledSubscriptions) {
41
+ const event = canceledEvents.find(e => e.subscription_id === subscription.id);
42
+ if (event) {
43
+ // if an event exists, update it
44
+ // we always update the latest event for a subscription due to the orderBy DESC
45
+ toUpdate.push({
46
+ ...event,
47
+ mrr_delta: -subscription.mrr
48
+ });
49
+ } else {
50
+ toInsert.push({
51
+ id: ObjectID().toHexString(),
52
+ type: 'canceled',
53
+ source: 'migration',
54
+ created_at: subscription.updated_at,
55
+ from_plan: subscription.stripe_price_id,
56
+ to_plan: subscription.stripe_price_id,
57
+ subscription_id: subscription.id,
58
+ member_id: subscription.member_id,
59
+ currency: subscription.plan_currency,
60
+ mrr_delta: -subscription.mrr
61
+ });
62
+ }
63
+ }
64
+
65
+ logging.info(`Inserting ${toInsert.length} MRR events for canceled subscriptions`);
66
+ await knex.batchInsert('members_paid_subscription_events', toInsert);
67
+
68
+ logging.info(`Updating ${toUpdate.length} MRR events for canceled subscriptions`);
69
+ await knex('members_paid_subscription_events').whereIn('id', toUpdate.map(row => row.id)).del();
70
+ await knex.batchInsert('members_paid_subscription_events', toUpdate);
71
+ },
72
+ async function down() {}
73
+ );
@@ -0,0 +1,31 @@
1
+ const logging = require('@tryghost/logging');
2
+
3
+ const {createTransactionalMigration} = require('../../utils');
4
+
5
+ module.exports = createTransactionalMigration(
6
+ async function up(knex) {
7
+ logging.info('Setting "mrr" to 0 for all canceled subscriptions in "members_stripe_customers_subscriptions"');
8
+
9
+ await knex('members_stripe_customers_subscriptions')
10
+ .update('mrr', 0)
11
+ .where('cancel_at_period_end', true);
12
+ },
13
+ async function down(knex) {
14
+ logging.info('Setting "mrr" for all canceled and not yet expired subscriptions in "members_stripe_customers_subscriptions"');
15
+
16
+ await knex('members_stripe_customers_subscriptions')
17
+ .update('mrr', knex.raw(`
18
+ CASE WHEN plan_interval = 'year' THEN
19
+ FLOOR(plan_amount / 12)
20
+ WHEN plan_interval = 'week' THEN
21
+ plan_amount * 4
22
+ WHEN plan_interval = 'day' THEN
23
+ plan_amount * 30
24
+ ELSE
25
+ plan_amount
26
+ END
27
+ `))
28
+ .where('cancel_at_period_end', true)
29
+ .whereNotIn('status', ['trialing', 'incomplete', 'incomplete_expired', 'canceled']);
30
+ }
31
+ );
@@ -0,0 +1,7 @@
1
+ const {createDropColumnMigration} = require('../../utils');
2
+
3
+ module.exports = createDropColumnMigration('posts', 'author_id', {});
4
+
5
+ module.exports.down = async () => {
6
+ // noop - major version migrations are not backwards compatible
7
+ };
@@ -0,0 +1,4 @@
1
+ const {createDropNullableMigration} = require('../../utils');
2
+
3
+ // We need to disable foreign key checks because if MySQL is missing the STRICT_TRANS_TABLES mode, we cannot drop nullable from a foreign key
4
+ module.exports = createDropNullableMigration('members_subscribe_events', 'newsletter_id', {disableForeignKeyChecks: true});
@@ -0,0 +1,44 @@
1
+ const logging = require('@tryghost/logging');
2
+ const {createTransactionalMigration} = require('../../utils');
3
+
4
+ module.exports = createTransactionalMigration(
5
+ async function up(knex) {
6
+ logging.info('Linking existing emails and related posts to the default newsletter');
7
+
8
+ // Get the default newsletter
9
+ // Note we intentionally use the default newsletter slug instead of the usual orderBy logic
10
+ let newsletter = await knex('newsletters')
11
+ .where('slug', 'default-newsletter')
12
+ .first('id', 'slug');
13
+
14
+ if (!newsletter) {
15
+ // Fall back to orderBy - just in case
16
+ logging.warn(`Original default newsletter not found - using first in sort order`);
17
+ newsletter = await knex('newsletters')
18
+ .where('status', 'active')
19
+ .orderBy('sort_order', 'asc')
20
+ .orderBy('created_at', 'asc')
21
+ .orderBy('id', 'asc')
22
+ .first('id', 'slug');
23
+ }
24
+
25
+ if (!newsletter) {
26
+ logging.error(`Newsletter not found - skipping`);
27
+ return;
28
+ }
29
+
30
+ logging.info(`Assigning existing emails to newsletter ID ${newsletter.id} (${newsletter.slug})`);
31
+
32
+ // Set newsletter ID only on posts with related email records without a newsletter assigned
33
+ await knex('posts')
34
+ .update('newsletter_id', newsletter.id)
35
+ .whereIn('id', knex.raw('SELECT post_id FROM emails WHERE emails.newsletter_id IS NULL'));
36
+
37
+ await knex('emails')
38
+ .update('newsletter_id', newsletter.id)
39
+ .whereNull('newsletter_id');
40
+ },
41
+ async function down() {
42
+ // Not required
43
+ }
44
+ );