ghost 5.9.1 → 5.9.4

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 (65) hide show
  1. package/components/tryghost-adapter-manager-0.0.0.tgz +0 -0
  2. package/components/tryghost-api-framework-0.0.0.tgz +0 -0
  3. package/components/tryghost-api-version-compatibility-service-0.0.0.tgz +0 -0
  4. package/components/tryghost-bootstrap-socket-0.0.0.tgz +0 -0
  5. package/components/tryghost-constants-0.0.0.tgz +0 -0
  6. package/components/tryghost-custom-theme-settings-service-0.0.0.tgz +0 -0
  7. package/components/tryghost-domain-events-0.0.0.tgz +0 -0
  8. package/components/tryghost-email-analytics-provider-mailgun-0.0.0.tgz +0 -0
  9. package/components/tryghost-email-analytics-service-0.0.0.tgz +0 -0
  10. package/components/tryghost-email-content-generator-0.0.0.tgz +0 -0
  11. package/components/tryghost-express-dynamic-redirects-0.0.0.tgz +0 -0
  12. package/components/tryghost-extract-api-key-0.0.0.tgz +0 -0
  13. package/components/tryghost-html-to-plaintext-0.0.0.tgz +0 -0
  14. package/components/tryghost-job-manager-0.0.0.tgz +0 -0
  15. package/components/tryghost-magic-link-0.0.0.tgz +0 -0
  16. package/components/tryghost-mailgun-client-0.0.0.tgz +0 -0
  17. package/components/tryghost-member-analytics-service-0.0.0.tgz +0 -0
  18. package/components/tryghost-member-events-0.0.0.tgz +0 -0
  19. package/components/tryghost-members-analytics-ingress-0.0.0.tgz +0 -0
  20. package/components/tryghost-members-api-0.0.0.tgz +0 -0
  21. package/components/tryghost-members-csv-0.0.0.tgz +0 -0
  22. package/components/tryghost-members-events-service-0.0.0.tgz +0 -0
  23. package/components/tryghost-members-importer-0.0.0.tgz +0 -0
  24. package/components/tryghost-members-offers-0.0.0.tgz +0 -0
  25. package/components/tryghost-members-payments-0.0.0.tgz +0 -0
  26. package/components/tryghost-members-ssr-0.0.0.tgz +0 -0
  27. package/components/tryghost-members-stripe-service-0.0.0.tgz +0 -0
  28. package/components/tryghost-minifier-0.0.0.tgz +0 -0
  29. package/components/tryghost-mw-api-version-mismatch-0.0.0.tgz +0 -0
  30. package/components/tryghost-mw-cache-control-0.0.0.tgz +0 -0
  31. package/components/tryghost-mw-error-handler-0.0.0.tgz +0 -0
  32. package/components/tryghost-mw-session-from-token-0.0.0.tgz +0 -0
  33. package/components/tryghost-mw-update-user-last-seen-0.0.0.tgz +0 -0
  34. package/components/tryghost-mw-vhost-0.0.0.tgz +0 -0
  35. package/components/tryghost-oembed-service-0.0.0.tgz +0 -0
  36. package/components/tryghost-package-json-0.0.0.tgz +0 -0
  37. package/components/tryghost-security-0.0.0.tgz +0 -0
  38. package/components/tryghost-session-service-0.0.0.tgz +0 -0
  39. package/components/tryghost-settings-path-manager-0.0.0.tgz +0 -0
  40. package/components/tryghost-update-check-service-0.0.0.tgz +0 -0
  41. package/components/tryghost-verification-trigger-0.0.0.tgz +0 -0
  42. package/components/tryghost-version-notifications-data-service-0.0.0.tgz +0 -0
  43. package/core/built/admin/assets/{chunk.143.9b9ae7a21f4620dc58b9.js → chunk.143.1c158e8ef19f10e5439c.js} +5 -5
  44. package/core/built/admin/assets/{chunk.178.711d94cc8a84182a6c38.js → chunk.178.506264293194a4922091.js} +4 -4
  45. package/core/built/admin/assets/{ghost-eca1a709a74b1af277e48aad4e16c9db.js → ghost-b441c9cfa2e31453e86460e50ae7e378.js} +18 -17
  46. package/core/built/admin/assets/{ghost-dark-6814c399ff5b3d9c8efe2d92bc7ec779.css → ghost-dark-4080c8f100997d4b8947f5da0e7946a1.css} +1 -1
  47. package/core/built/admin/assets/{ghost-686c383caa6a3469cefb939ab10e21b6.css → ghost-facfdf4a7d9759c5b681340805f21fd8.css} +1 -1
  48. package/core/built/admin/index.html +3 -3
  49. package/core/frontend/helpers/ghost_head.js +1 -1
  50. package/core/frontend/services/routing/controllers/unsubscribe.js +3 -0
  51. package/core/server/api/endpoints/oembed.js +1 -1
  52. package/core/server/services/bulk-email/bulk-email-processor.js +1 -1
  53. package/core/server/services/comments/email-templates/new-comment-reply.hbs +6 -1
  54. package/core/server/services/comments/email-templates/new-comment-reply.txt.js +1 -1
  55. package/core/server/services/comments/email-templates/new-comment.hbs +5 -0
  56. package/core/server/services/comments/emails.js +2 -1
  57. package/core/server/services/mega/post-email-serializer.js +9 -4
  58. package/core/server/web/admin/app.js +1 -1
  59. package/core/server/web/parent/frontend.js +0 -1
  60. package/core/shared/config/defaults.json +2 -2
  61. package/core/shared/config/overrides.json +0 -1
  62. package/core/shared/labs.js +1 -0
  63. package/package.json +6 -14
  64. package/yarn.lock +71 -71
  65. package/core/server/services/oembed.js +0 -346
@@ -37,7 +37,7 @@
37
37
  </style>
38
38
 
39
39
  <link integrity="" rel="stylesheet" href="assets/vendor-bc9d2c9e5c8a33f0c92e81189d48e04c.css">
40
- <link integrity="" rel="stylesheet" href="assets/ghost-686c383caa6a3469cefb939ab10e21b6.css" title="light">
40
+ <link integrity="" rel="stylesheet" href="assets/ghost-facfdf4a7d9759c5b681340805f21fd8.css" title="light">
41
41
 
42
42
 
43
43
  </head>
@@ -55,7 +55,7 @@
55
55
 
56
56
  <script src="assets/vendor-516c9e43b4aeb92079dc1ab92c9ce492.js"></script>
57
57
  <script src="assets/chunk.351.73f27952f867334a8228.js"></script>
58
- <script src="assets/chunk.143.9b9ae7a21f4620dc58b9.js"></script>
59
- <script src="assets/ghost-eca1a709a74b1af277e48aad4e16c9db.js"></script>
58
+ <script src="assets/chunk.143.1c158e8ef19f10e5439c.js"></script>
59
+ <script src="assets/ghost-b441c9cfa2e31453e86460e50ae7e378.js"></script>
60
60
  </body>
61
61
  </html>
@@ -229,7 +229,7 @@ module.exports = async function ghost_head(options) { // eslint-disable-line cam
229
229
  head.push(`<link rel="stylesheet" type="text/css" href="${getAssetUrl('public/cards.min.css')}">`);
230
230
  }
231
231
 
232
- if (settingsCache.get('enable_comments') !== 'off') {
232
+ if (settingsCache.get('comments_enabled') !== 'off') {
233
233
  head.push(`<script defer src="${getAssetUrl('public/comment-counts.min.js')}" data-ghost-comments-counts-api="${urlUtils.getSiteUrl(true)}members/api/comments/counts/"></script>`);
234
234
  }
235
235
 
@@ -18,6 +18,9 @@ module.exports = async function unsubscribeController(req, res) {
18
18
  if (query.newsletter) {
19
19
  redirectUrl.searchParams.append('newsletter', query.newsletter);
20
20
  }
21
+ if (query.comments) {
22
+ redirectUrl.searchParams.append('comments', query.comments);
23
+ }
21
24
  redirectUrl.searchParams.append('action', 'unsubscribe');
22
25
 
23
26
  return res.redirect(302, redirectUrl.href);
@@ -1,7 +1,7 @@
1
1
  const config = require('../../../shared/config');
2
2
  const externalRequest = require('../../lib/request-external');
3
3
 
4
- const OEmbed = require('../../services/oembed');
4
+ const OEmbed = require('@tryghost/oembed-service');
5
5
  const oembed = new OEmbed({config, externalRequest});
6
6
 
7
7
  const NFT = require('../../services/nft-oembed');
@@ -234,7 +234,7 @@ module.exports = {
234
234
  // static data for every recipient
235
235
  const data = {
236
236
  unique_id: recipient.member_uuid,
237
- unsubscribe_url: postEmailSerializer.createUnsubscribeUrl(recipient.member_uuid, newsletterUuid)
237
+ unsubscribe_url: postEmailSerializer.createUnsubscribeUrl(recipient.member_uuid, {newsletterUuid})
238
238
  };
239
239
 
240
240
  // computed properties on recipients - TODO: better way of handling these
@@ -96,6 +96,11 @@
96
96
  a {
97
97
  color: #15212A;
98
98
  }
99
+ blockquote {
100
+ margin-left: 0;
101
+ padding-left: 20px;
102
+ border-left: 3px solid #DDE1E5;
103
+ }
99
104
  </style>
100
105
  </head>
101
106
  <body style="background-color: #ffffff; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; -webkit-font-smoothing: antialiased; font-size: 14px; line-height: 1.5em; margin: 0; padding: 0; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%;">
@@ -174,7 +179,7 @@
174
179
  </tr>
175
180
  <tr>
176
181
  <td style="font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; font-size: 14px; vertical-align: top; padding-top: 2px">
177
- <p class="small" style="font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; line-height: 18px; font-size: 11px; color: #738A94; font-weight: normal; margin: 0; margin-bottom: 2px;"><a class="small" href="{{profileUrl}}" style="text-decoration: underline; color: #738A94; font-size: 11px;">Manage your email preferences</a></p>
182
+ <p class="small" style="font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; line-height: 18px; font-size: 11px; color: #738A94; font-weight: normal; margin: 0; margin-bottom: 2px;"><a class="small" href="{{profileUrl}}" style="text-decoration: underline; color: #738A94; font-size: 11px;">Unsubscribe from comment reply notifications</a></p>
178
183
  </td>
179
184
  </tr>
180
185
 
@@ -9,5 +9,5 @@ ${data.postUrl}#ghost-comments
9
9
  ---
10
10
 
11
11
  Sent to ${data.toEmail} from ${data.siteDomain}.
12
- You can manage your notification preferences at ${data.profileUrl}.`;
12
+ You can unsubscribe from these notifications at ${data.profileUrl}.`;
13
13
  };
@@ -96,6 +96,11 @@
96
96
  a {
97
97
  color: #15212A;
98
98
  }
99
+ blockquote {
100
+ margin-left: 0;
101
+ padding-left: 20px;
102
+ border-left: 3px solid #DDE1E5;
103
+ }
99
104
  </style>
100
105
  </head>
101
106
  <body style="background-color: #ffffff; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; -webkit-font-smoothing: antialiased; font-size: 14px; line-height: 1.5em; margin: 0; padding: 0; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%;">
@@ -2,6 +2,7 @@ const {promises: fs} = require('fs');
2
2
  const path = require('path');
3
3
  const moment = require('moment');
4
4
  const htmlToPlaintext = require('@tryghost/html-to-plaintext');
5
+ const postEmailSerializer = require('../mega/post-email-serializer');
5
6
 
6
7
  class CommentsServiceEmails {
7
8
  constructor({config, logging, models, mailer, settingsCache, urlService, urlUtils}) {
@@ -93,7 +94,7 @@ class CommentsServiceEmails {
93
94
  accentColor: this.settingsCache.get('accent_color'),
94
95
  fromEmail: this.notificationFromAddress,
95
96
  toEmail: to,
96
- profileUrl: `${this.urlUtils.getSiteUrl()}#/portal/account/profile`
97
+ profileUrl: postEmailSerializer.createUnsubscribeUrl(member.get('uuid'), {comments: true})
97
98
  };
98
99
 
99
100
  const {html, text} = await this.renderEmailTemplate('new-comment-reply', templateData);
@@ -59,9 +59,11 @@ const getSite = () => {
59
59
  * In case of no member uuid, generates the preview unsubscribe url - `?preview=1`
60
60
  *
61
61
  * @param {string} uuid post uuid
62
- * @param {string} newsletterUuid newsletter uuid
62
+ * @param {Object} [options]
63
+ * @param {string} [options.newsletterUuid] newsletter uuid
64
+ * @param {boolean} [options.comments] Unsubscribe from comment emails
63
65
  */
64
- const createUnsubscribeUrl = (uuid, newsletterUuid) => {
66
+ const createUnsubscribeUrl = (uuid, options = {}) => {
65
67
  const siteUrl = urlUtils.getSiteUrl();
66
68
  const unsubscribeUrl = new URL(siteUrl);
67
69
  unsubscribeUrl.pathname = `${unsubscribeUrl.pathname}/unsubscribe/`.replace('//', '/');
@@ -70,8 +72,11 @@ const createUnsubscribeUrl = (uuid, newsletterUuid) => {
70
72
  } else {
71
73
  unsubscribeUrl.searchParams.set('preview', '1');
72
74
  }
73
- if (newsletterUuid) {
74
- unsubscribeUrl.searchParams.set('newsletter', newsletterUuid);
75
+ if (options.newsletterUuid) {
76
+ unsubscribeUrl.searchParams.set('newsletter', options.newsletterUuid);
77
+ }
78
+ if (options.comments) {
79
+ unsubscribeUrl.searchParams.set('comments', '1');
75
80
  }
76
81
 
77
82
  return unsubscribeUrl.href;
@@ -23,7 +23,7 @@ module.exports = function setupAdminApp() {
23
23
  ));
24
24
 
25
25
  adminApp.use('/auth-frame', serveStatic(
26
- config.get('paths').adminAuthAssets
26
+ path.join(config.getContentPath('public'), 'admin-auth')
27
27
  ));
28
28
 
29
29
  // Ember CLI's live-reload script
@@ -18,7 +18,6 @@ module.exports = (routerConfig) => {
18
18
  frontendApp.use(shared.middleware.urlRedirects.frontendSSLRedirect);
19
19
 
20
20
  frontendApp.lazyUse('/members', require('../members'));
21
- frontendApp.lazyUse('/comments', require('../comments'));
22
21
  frontendApp.use('/', require('../../../frontend/web')(routerConfig));
23
22
 
24
23
  return frontendApp;
@@ -137,7 +137,7 @@
137
137
  },
138
138
  "portal": {
139
139
  "url": "https://cdn.jsdelivr.net/npm/@tryghost/portal@~{version}/umd/portal.min.js",
140
- "version": "2.7"
140
+ "version": "2.8"
141
141
  },
142
142
  "sodoSearch": {
143
143
  "url": "https://cdn.jsdelivr.net/npm/@tryghost/sodo-search@~{version}/umd/sodo-search.min.js",
@@ -147,7 +147,7 @@
147
147
  "comments": {
148
148
  "url": "https://cdn.jsdelivr.net/npm/@tryghost/comments-ui@~{version}/umd/comments-ui.min.js",
149
149
  "styles": "https://cdn.jsdelivr.net/npm/@tryghost/comments-ui@~{version}/umd/main.css",
150
- "version": "0.8"
150
+ "version": "0.9"
151
151
  },
152
152
  "editor": {
153
153
  "url": "https://unpkg.com/@tryghost/koenig-react/dist/umd/koenig-react.min.js"
@@ -3,7 +3,6 @@
3
3
  "appRoot": ".",
4
4
  "corePath": "core/",
5
5
  "adminAssets": "core/built/admin",
6
- "adminAuthAssets": "content/public/admin-auth",
7
6
  "helperTemplates": "core/frontend/helpers/tpl/",
8
7
  "defaultViews": "core/server/views/",
9
8
  "defaultRouteSettings": "core/server/services/route-settings/",
@@ -25,6 +25,7 @@ const BETA_FEATURES = [
25
25
  ];
26
26
 
27
27
  const ALPHA_FEATURES = [
28
+ 'auditLog',
28
29
  'urlCache',
29
30
  'beforeAfterCard',
30
31
  'freeTrial'
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ghost",
3
- "version": "5.9.1",
3
+ "version": "5.9.4",
4
4
  "description": "The professional publishing platform",
5
5
  "author": "Ghost Foundation",
6
6
  "homepage": "https://ghost.org",
@@ -100,6 +100,7 @@
100
100
  "@tryghost/mw-vhost": "file:components/tryghost-mw-vhost-0.0.0.tgz",
101
101
  "@tryghost/nodemailer": "0.3.25",
102
102
  "@tryghost/nql": "0.9.2",
103
+ "@tryghost/oembed-service": "file:components/tryghost-oembed-service-0.0.0.tgz",
103
104
  "@tryghost/package-json": "file:components/tryghost-package-json-0.0.0.tgz",
104
105
  "@tryghost/pretty-cli": "1.2.30",
105
106
  "@tryghost/promise": "0.1.21",
@@ -159,15 +160,6 @@
159
160
  "knex-migrator": "5.0.3",
160
161
  "lodash": "4.17.21",
161
162
  "luxon": "3.0.1",
162
- "metascraper": "5.30.1",
163
- "metascraper-author": "5.29.15",
164
- "metascraper-description": "5.29.15",
165
- "metascraper-image": "5.29.15",
166
- "metascraper-logo": "5.29.15",
167
- "metascraper-logo-favicon": "5.30.1",
168
- "metascraper-publisher": "5.29.15",
169
- "metascraper-title": "5.29.15",
170
- "metascraper-url": "5.29.15",
171
163
  "moment": "2.24.0",
172
164
  "moment-timezone": "0.5.23",
173
165
  "multer": "1.4.4",
@@ -181,12 +173,11 @@
181
173
  "sanitize-html": "2.7.1",
182
174
  "semver": "7.3.7",
183
175
  "stoppable": "1.1.0",
184
- "tough-cookie": "4.0.0",
185
176
  "uuid": "8.3.2",
186
177
  "xml": "1.0.1"
187
178
  },
188
179
  "optionalDependencies": {
189
- "@tryghost/html-to-mobiledoc": "1.8.7",
180
+ "@tryghost/html-to-mobiledoc": "1.8.9",
190
181
  "sqlite3": "5.0.11"
191
182
  },
192
183
  "devDependencies": {
@@ -196,8 +187,8 @@
196
187
  "@types/common-tags": "1.8.1",
197
188
  "c8": "7.12.0",
198
189
  "cli-progress": "3.11.2",
199
- "cssnano": "5.1.12",
200
- "eslint": "8.21.0",
190
+ "cssnano": "5.1.13",
191
+ "eslint": "8.22.0",
201
192
  "grunt": "1.5.3",
202
193
  "grunt-contrib-symlink": "1.0.0",
203
194
  "grunt-shell": "4.0.0",
@@ -251,6 +242,7 @@
251
242
  "@tryghost/mw-session-from-token": "file:components/tryghost-mw-session-from-token-0.0.0.tgz",
252
243
  "@tryghost/mw-update-user-last-seen": "file:components/tryghost-mw-update-user-last-seen-0.0.0.tgz",
253
244
  "@tryghost/mw-vhost": "file:components/tryghost-mw-vhost-0.0.0.tgz",
245
+ "@tryghost/oembed-service": "file:components/tryghost-oembed-service-0.0.0.tgz",
254
246
  "@tryghost/members-offers": "file:components/tryghost-members-offers-0.0.0.tgz",
255
247
  "@tryghost/package-json": "file:components/tryghost-package-json-0.0.0.tgz",
256
248
  "@tryghost/members-payments": "file:components/tryghost-members-payments-0.0.0.tgz",
package/yarn.lock CHANGED
@@ -2725,10 +2725,10 @@
2725
2725
  semver "^7.3.5"
2726
2726
  tar "^6.1.11"
2727
2727
 
2728
- "@metascraper/helpers@^5.29.15":
2729
- version "5.29.15"
2730
- resolved "https://registry.yarnpkg.com/@metascraper/helpers/-/helpers-5.29.15.tgz#73aaf1997ba54ac8d97493adcdadb8fa5a950317"
2731
- integrity sha512-7I7X3cHlOnFP5jmbv9/LgATR23tbcp+nYBRzUfnWH6zHt5MfbHIkN+JA45MeflrCBZ+X26RHm8tMVHrYNwUxmA==
2728
+ "@metascraper/helpers@^5.30.2":
2729
+ version "5.30.2"
2730
+ resolved "https://registry.yarnpkg.com/@metascraper/helpers/-/helpers-5.30.2.tgz#43d0e1fb74e3dff0efdd217d31c0258919bbb385"
2731
+ integrity sha512-ZLKw3MRTnAhcUDGGOSuHDejP+cs56rDQMKNfrY+502xnUpBRPvL3MtJToNqND39Hok/4ubWU0HChJ/2R/BNOnw==
2732
2732
  dependencies:
2733
2733
  audio-extensions "0.0.0"
2734
2734
  chrono-node "2.3.9"
@@ -3296,12 +3296,12 @@
3296
3296
  dependencies:
3297
3297
  lodash-es "^4.17.11"
3298
3298
 
3299
- "@tryghost/html-to-mobiledoc@1.8.7":
3300
- version "1.8.7"
3301
- resolved "https://registry.yarnpkg.com/@tryghost/html-to-mobiledoc/-/html-to-mobiledoc-1.8.7.tgz#d1b79c3b1077671ea6fcb13ef245c9cbdb7bc8e9"
3302
- integrity sha512-KD117Skh4wrGqB38zRpHIfBgP2d3HDJx5bMvwz2TSnQfPJdgzeLrl/meFKKAIj2VJ3ZEfjfFrPxNfVV60WA5WA==
3299
+ "@tryghost/html-to-mobiledoc@1.8.9":
3300
+ version "1.8.9"
3301
+ resolved "https://registry.yarnpkg.com/@tryghost/html-to-mobiledoc/-/html-to-mobiledoc-1.8.9.tgz#aec99761dd53798c0f63276fbf9e771c1efcab49"
3302
+ integrity sha512-HLSj+2zL0qzcMOaDugk7t7pZw6PezaLYJEx/A5i7uEdPD8nXV4KEhVQdpUHyM5oUHXFm6Efud9z3fFI2RfhkPw==
3303
3303
  dependencies:
3304
- "@tryghost/kg-parser-plugins" "^2.11.7"
3304
+ "@tryghost/kg-parser-plugins" "^2.11.9"
3305
3305
  "@tryghost/mobiledoc-kit" "^0.12.4-ghost.1"
3306
3306
  jsdom "^18.0.0"
3307
3307
 
@@ -3339,10 +3339,10 @@
3339
3339
  resolved "https://registry.yarnpkg.com/@tryghost/kg-card-factory/-/kg-card-factory-3.1.4.tgz#7166206156911ca48a525c54be53c4bb8074e7b9"
3340
3340
  integrity sha512-k/1g7PcoInahrhBxXdL1+XWFI4DOfnIqU0cH7Io7dWvaFBqNcWurUsIpQ7NnH+UT8Ow6YVgRn/Hse/U0k5iYeg==
3341
3341
 
3342
- "@tryghost/kg-clean-basic-html@2.2.11", "@tryghost/kg-clean-basic-html@^2.2.11":
3343
- version "2.2.11"
3344
- resolved "https://registry.yarnpkg.com/@tryghost/kg-clean-basic-html/-/kg-clean-basic-html-2.2.11.tgz#d4d78a257a97e82e5f6ca73a1a608dc5e3baa326"
3345
- integrity sha512-0/B1JiQa29JqhCb4QtnW3Oy+FL1434itZHLu5/88J0AUZIuggOQlAM6E1dpIpKXndoSZflpABy48pQnthic0Xg==
3342
+ "@tryghost/kg-clean-basic-html@2.2.13", "@tryghost/kg-clean-basic-html@^2.2.13":
3343
+ version "2.2.13"
3344
+ resolved "https://registry.yarnpkg.com/@tryghost/kg-clean-basic-html/-/kg-clean-basic-html-2.2.13.tgz#b390b2e57eb26d05790da5df47a5f7e358f33deb"
3345
+ integrity sha512-92VYyXAUJsdMnFe+tYtI851ZGhVkUHKRtXCdk5ssootEffVVRAojB6iEL9w8d/WXGlaqb21t3XX957BdPdxvNA==
3346
3346
 
3347
3347
  "@tryghost/kg-default-atoms@3.1.3":
3348
3348
  version "3.1.3"
@@ -3383,12 +3383,12 @@
3383
3383
  mobiledoc-dom-renderer "^0.7.0"
3384
3384
  simple-dom "^1.4.0"
3385
3385
 
3386
- "@tryghost/kg-parser-plugins@2.11.7", "@tryghost/kg-parser-plugins@^2.11.7":
3387
- version "2.11.7"
3388
- resolved "https://registry.yarnpkg.com/@tryghost/kg-parser-plugins/-/kg-parser-plugins-2.11.7.tgz#504064ce34c13157f68a4ef0ed8eaaab5e7a3a15"
3389
- integrity sha512-goIuPfBIgMkl88PgR4y8it/SxdwVxjsnJx9pd1wva3DJHjNRujuOaeT3qeXRnz10eDGefiEfD7CbRCHywoc1Ug==
3386
+ "@tryghost/kg-parser-plugins@2.11.9", "@tryghost/kg-parser-plugins@^2.11.9":
3387
+ version "2.11.9"
3388
+ resolved "https://registry.yarnpkg.com/@tryghost/kg-parser-plugins/-/kg-parser-plugins-2.11.9.tgz#e6f9081fb5a8349ffc2e542867461eda136bc0c0"
3389
+ integrity sha512-2tN+H5vIIhfOswQaSK4ZZNUnouqHEpFjFMJsP+X60szUXJe/l9d/JBz4eu9/NLCf6CmGjgL1f6w624qR9fwb0g==
3390
3390
  dependencies:
3391
- "@tryghost/kg-clean-basic-html" "^2.2.11"
3391
+ "@tryghost/kg-clean-basic-html" "^2.2.13"
3392
3392
 
3393
3393
  "@tryghost/kg-utils@^1.0.3":
3394
3394
  version "1.0.3"
@@ -8468,10 +8468,10 @@ cssnano@4.1.10:
8468
8468
  is-resolvable "^1.0.0"
8469
8469
  postcss "^7.0.0"
8470
8470
 
8471
- cssnano@5.1.12:
8472
- version "5.1.12"
8473
- resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-5.1.12.tgz#bcd0b64d6be8692de79332c501daa7ece969816c"
8474
- integrity sha512-TgvArbEZu0lk/dvg2ja+B7kYoD7BBCmn3+k58xD0qjrGHsFzXY/wKTo9M5egcUCabPol05e/PVoIu79s2JN4WQ==
8471
+ cssnano@5.1.13:
8472
+ version "5.1.13"
8473
+ resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-5.1.13.tgz#83d0926e72955332dc4802a7070296e6258efc0a"
8474
+ integrity sha512-S2SL2ekdEz6w6a2epXn4CmMKU4K3KpcyXLKfAYc9UQQqJRkD/2eLUG0vJ3Db/9OvO5GuAdgXw3pFbR6abqghDQ==
8475
8475
  dependencies:
8476
8476
  cssnano-preset-default "^5.2.12"
8477
8477
  lilconfig "^2.0.3"
@@ -11062,10 +11062,10 @@ eslint-visitor-keys@^3.3.0:
11062
11062
  resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz#f6480fa6b1f30efe2d1968aa8ac745b862469826"
11063
11063
  integrity sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==
11064
11064
 
11065
- eslint@8.21.0:
11066
- version "8.21.0"
11067
- resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.21.0.tgz#1940a68d7e0573cef6f50037addee295ff9be9ef"
11068
- integrity sha512-/XJ1+Qurf1T9G2M5IHrsjp+xrGT73RZf23xA1z5wB1ZzzEAWSZKvRwhWxTFp1rvkvCfwcvAUNAP31bhKTTGfDA==
11065
+ eslint@8.22.0:
11066
+ version "8.22.0"
11067
+ resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.22.0.tgz#78fcb044196dfa7eef30a9d65944f6f980402c48"
11068
+ integrity sha512-ci4t0sz6vSRKdmkOGmprBo6fmI4PrphDFMy5JEq/fNS0gQkJM3rLmrqcp8ipMcdobH3KtUP40KniAE9W19S4wA==
11069
11069
  dependencies:
11070
11070
  "@eslint/eslintrc" "^1.3.0"
11071
11071
  "@humanwhocodes/config-array" "^0.10.4"
@@ -16115,73 +16115,73 @@ merge@^1.2.0:
16115
16115
  resolved "https://registry.yarnpkg.com/merge/-/merge-1.2.1.tgz#38bebf80c3220a8a487b6fcfb3941bb11720c145"
16116
16116
  integrity sha512-VjFo4P5Whtj4vsLzsYBu5ayHhoHJ0UqNm7ibvShmbmoz7tGi0vXaoJbGdB+GmDMLUdg8DpQXEIeVDAe8MaABvQ==
16117
16117
 
16118
- metascraper-author@5.29.15:
16119
- version "5.29.15"
16120
- resolved "https://registry.yarnpkg.com/metascraper-author/-/metascraper-author-5.29.15.tgz#cd3f77344f0dc6c2dc6046700bc48714777773d7"
16121
- integrity sha512-+ts7LAk+piqLTjz1mO3x0XNTSkvu1crCVx/nhKvzmkf8hVmESxI8FxfdLX8FrLGhatP0iUM3qox8CbunnJxS2g==
16118
+ metascraper-author@5.30.2:
16119
+ version "5.30.2"
16120
+ resolved "https://registry.yarnpkg.com/metascraper-author/-/metascraper-author-5.30.2.tgz#04d8f685b79affa45675979f1c4611859fd7ebb0"
16121
+ integrity sha512-0cxatAdHbqwYHIRL1gwyE32bwJadLH7ury3EZc/xEtBhmaAe41QDUWc4pv+pJDNeIbHATA3PuxRqKUkL+WGRUw==
16122
16122
  dependencies:
16123
- "@metascraper/helpers" "^5.29.15"
16123
+ "@metascraper/helpers" "^5.30.2"
16124
16124
 
16125
- metascraper-description@5.29.15:
16126
- version "5.29.15"
16127
- resolved "https://registry.yarnpkg.com/metascraper-description/-/metascraper-description-5.29.15.tgz#f73e8aa38b6527a6433be69d185ca3e81b7ec9a5"
16128
- integrity sha512-UJ9wds13BP3g7u9xr8+YVMZJtJgHIem7U+KiE+KybtLJsNDWUr3NzkhVWJ0PlX4U+VwKBzFNxhlBTWxEY2fGGw==
16125
+ metascraper-description@5.30.2:
16126
+ version "5.30.2"
16127
+ resolved "https://registry.yarnpkg.com/metascraper-description/-/metascraper-description-5.30.2.tgz#81326a29147b7f4613273cff285e167d400351ca"
16128
+ integrity sha512-XJ8O735UAuBG6m7i3JU1+qKlOyVDEQ2HGhlMS4PSLQ08N7mjqcvVwJX6NgCbmCRySzRteaA2INGSH4vYIK8JHg==
16129
16129
  dependencies:
16130
- "@metascraper/helpers" "^5.29.15"
16130
+ "@metascraper/helpers" "^5.30.2"
16131
16131
 
16132
- metascraper-image@5.29.15:
16133
- version "5.29.15"
16134
- resolved "https://registry.yarnpkg.com/metascraper-image/-/metascraper-image-5.29.15.tgz#42fba11fd94219a60e0ed4cdea526307fc198df3"
16135
- integrity sha512-Ng0gS8qNCHFVSQELHTgeB8W3Ygwz+LxoFscjGhil6cg8PMxB7IkZLbDn6jEY+YtiBDcEJHPJ1gzfhTInt2bJrw==
16132
+ metascraper-image@5.30.2:
16133
+ version "5.30.2"
16134
+ resolved "https://registry.yarnpkg.com/metascraper-image/-/metascraper-image-5.30.2.tgz#9f418ee504b729e62fefdb18091cec8bbf68da4a"
16135
+ integrity sha512-6H4GICubSaqVyJUXbNq1Wzy9VUne2DfJfnKjyQByGY35OC6eQUgTmtgRpX+KfgM9sp4GFsq3fNXQBPnpR3t3jg==
16136
16136
  dependencies:
16137
- "@metascraper/helpers" "^5.29.15"
16137
+ "@metascraper/helpers" "^5.30.2"
16138
16138
 
16139
- metascraper-logo-favicon@5.30.1:
16140
- version "5.30.1"
16141
- resolved "https://registry.yarnpkg.com/metascraper-logo-favicon/-/metascraper-logo-favicon-5.30.1.tgz#ef01c27ef25d2ebac040c4ca9f7f4e31f38a5706"
16142
- integrity sha512-xamWOhYlGib9Qfi7sKnmh6v5dBrAqWRZhXPM6PfWVZt8yCwb4Nk6EAkfr2DmzBD2hdXIww7fvaDIfDx2KfWLyg==
16139
+ metascraper-logo-favicon@5.30.2:
16140
+ version "5.30.2"
16141
+ resolved "https://registry.yarnpkg.com/metascraper-logo-favicon/-/metascraper-logo-favicon-5.30.2.tgz#b2c765094aa7dbfba47d8fb6ba8c13f65e6a0f62"
16142
+ integrity sha512-zRn4F6cJK7GsZBqpIH7TTK5XCiFBxrMBBP2m7zClIfTbeeK2cjELWlv/4WsordHGLMh8vah1FDGdV1g0+pwXsA==
16143
16143
  dependencies:
16144
16144
  "@keyvhq/memoize" "~1.6.14"
16145
- "@metascraper/helpers" "^5.29.15"
16145
+ "@metascraper/helpers" "^5.30.2"
16146
16146
  lodash "~4.17.21"
16147
16147
  reachable-url "~1.6.11"
16148
16148
  tldts "~5.7.87"
16149
16149
 
16150
- metascraper-logo@5.29.15:
16151
- version "5.29.15"
16152
- resolved "https://registry.yarnpkg.com/metascraper-logo/-/metascraper-logo-5.29.15.tgz#c3a74f72c6d488e8348281ed1afd18680828aa44"
16153
- integrity sha512-z2h71seA7JQ1yIpMGjjW4w7qM8mmorN2/8q+LlX8ImBoNyydxTImnDKKOvlhAFJT9ywSbChaHWxdKif62ORDkg==
16150
+ metascraper-logo@5.30.2:
16151
+ version "5.30.2"
16152
+ resolved "https://registry.yarnpkg.com/metascraper-logo/-/metascraper-logo-5.30.2.tgz#f2b2e221a4499bdabf0fe6640a74ed90861cde4e"
16153
+ integrity sha512-3sP9uUHfGZjp81nbEEbIk/w37jpdcpY2Gh8OPrMLLzYehDf5/A8wjTvwrN2dU1a8euYrNk6KAbkX9uLrI3810w==
16154
16154
  dependencies:
16155
- "@metascraper/helpers" "^5.29.15"
16155
+ "@metascraper/helpers" "^5.30.2"
16156
16156
  lodash "~4.17.21"
16157
16157
 
16158
- metascraper-publisher@5.29.15:
16159
- version "5.29.15"
16160
- resolved "https://registry.yarnpkg.com/metascraper-publisher/-/metascraper-publisher-5.29.15.tgz#1f45f81ebfcdf8f231f6fb7939c2c6e09b805d1e"
16161
- integrity sha512-fxvh8RW4lJ+N539amHnucIFkQGnhEI823Jh9gwrm2aVe7uzESAoTcJDt2wTbOuxusFYKK2G8z0Wx+Z3CjocEbw==
16158
+ metascraper-publisher@5.30.2:
16159
+ version "5.30.2"
16160
+ resolved "https://registry.yarnpkg.com/metascraper-publisher/-/metascraper-publisher-5.30.2.tgz#63baf65365155ad7fcc58ff1cbb9ab06cc0f625a"
16161
+ integrity sha512-6Xdc//GASlzJvz6uCDciDLQcfHr0pvHwv6FsEhsv+g+HQUZNXNKkmXU+kyHBlyS3ctI2AHUAq2Urx2If0HI5sw==
16162
16162
  dependencies:
16163
- "@metascraper/helpers" "^5.29.15"
16163
+ "@metascraper/helpers" "^5.30.2"
16164
16164
 
16165
- metascraper-title@5.29.15:
16166
- version "5.29.15"
16167
- resolved "https://registry.yarnpkg.com/metascraper-title/-/metascraper-title-5.29.15.tgz#9c8804829755c14efeb8a4478dabfb30a3e66421"
16168
- integrity sha512-k4XovXjH9Pmpihnq2as+jn+1ln9tYBOTW1CVMrThvjK2kCM5aKqxgZokvTx4RyUaUPu/rX3HTsigqsw20gcnzQ==
16165
+ metascraper-title@5.30.2:
16166
+ version "5.30.2"
16167
+ resolved "https://registry.yarnpkg.com/metascraper-title/-/metascraper-title-5.30.2.tgz#1820547372aada10243ef7113777771333c9425b"
16168
+ integrity sha512-b2rHz/PctXiy26GYO9oaVfkI0SiloVJD+TiqVKXH4nLkSU/1KQywvj5SXne3Iyl6U+SLeaSh104CKmdNkZQ88A==
16169
16169
  dependencies:
16170
- "@metascraper/helpers" "^5.29.15"
16170
+ "@metascraper/helpers" "^5.30.2"
16171
16171
 
16172
- metascraper-url@5.29.15:
16173
- version "5.29.15"
16174
- resolved "https://registry.yarnpkg.com/metascraper-url/-/metascraper-url-5.29.15.tgz#f8b4fbea1c82ad18f970bed9a1aaeae05d2c8783"
16175
- integrity sha512-TB+fdRR5NnvyUGfw9vJnO1m7S2d+ZccCoem1bUiMrdmC1JQTQ5RyKv0WOLCQpBHzGVdMipFMlclTQkXXC8s+XQ==
16172
+ metascraper-url@5.30.2:
16173
+ version "5.30.2"
16174
+ resolved "https://registry.yarnpkg.com/metascraper-url/-/metascraper-url-5.30.2.tgz#b7574aca54801adf3d9a9fcbb245d69b8eaed1e6"
16175
+ integrity sha512-ESXIyQ4H0nxj7xufVbRcfqgH5eNT4r05ZFs7AWkyBbeLtEJ1m4Or/aluTjyOL65bDQzo9TPXpByVDGR4Li2t7Q==
16176
16176
  dependencies:
16177
- "@metascraper/helpers" "^5.29.15"
16177
+ "@metascraper/helpers" "^5.30.2"
16178
16178
 
16179
- metascraper@5.30.1:
16180
- version "5.30.1"
16181
- resolved "https://registry.yarnpkg.com/metascraper/-/metascraper-5.30.1.tgz#fed866c79db979bcdb68e94999ef5685a2491adc"
16182
- integrity sha512-KDBbAMdNPYTO10EbIalz2au8nVgCH5oPZe65nw4Vpt407WQEW8nyqvuP5aNCVHKie0gPceSCGgi7IAiyt3Efjw==
16179
+ metascraper@5.30.2:
16180
+ version "5.30.2"
16181
+ resolved "https://registry.yarnpkg.com/metascraper/-/metascraper-5.30.2.tgz#fce7fd08f848e43a503df377939aa6e1351dc1e2"
16182
+ integrity sha512-rgxv639/etSuJj992KJ6eNjxugxbf5HfQq6Uht2P8F0879t0Jxo8ghk6Mh/i/zoQQLjBlcYHQOt0QEZumst9Zw==
16183
16183
  dependencies:
16184
- "@metascraper/helpers" "^5.29.15"
16184
+ "@metascraper/helpers" "^5.30.2"
16185
16185
  cheerio "~1.0.0-rc.12"
16186
16186
  lodash "~4.17.21"
16187
16187
  whoops "~4.1.2"