fix(openGraph): URL api error handling

This commit is contained in:
curben 2019-09-04 02:31:06 +01:00
parent 1d5966e191
commit 07ab8c08d7
No known key found for this signature in database
GPG Key ID: 5D9DB57A25D34EE3
1 changed files with 11 additions and 14 deletions

View File

@ -4,9 +4,9 @@
/*
* Modified from the hexo version,
* https://github.com/hexojs/hexo/blob/master/lib/plugins/helper/open_graph.js
* for compatibility with cloudinary.js
* the <meta name="og:image"> now use
* <a> where href value links to an image
* to include https://github.com/hexojs/hexo/pull/3674
* and use WHATWG URL API
* https://nodejs.org/api/url.html#url_the_whatwg_url_api
*/
'use strict'
@ -67,18 +67,14 @@ function openGraphHelper (options = {}) {
}
if (!images.length && content && content.includes('<img')) {
images = images.slice()
images = images.slice();
// https://github.com/hexojs/hexo/pull/3680
let img
const imgPattern = /<a [^>]*href=['"]([^'"]+)([^>]*>)/gi
const imgPattern = /<img [^>]*src=['"]([^'"]+)([^>]*>)/gi
while ((img = imgPattern.exec(content)) !== null) {
const imgExt = ['*.jpg', '*.png', '*.webp']
if (micromatch.isMatch(img[1], imgExt, { basename: true })) {
images.push(img[1])
}
}
}
if (description) {
result += meta('description', description, false)
@ -107,10 +103,11 @@ function openGraphHelper (options = {}) {
}
images = images.map(path => {
if (!new URL(path).host) {
// resolve `path`'s absolute path relative to current page's url
// `path` can be both absolute (starts with `/`) or relative.
return new URL(path, url || config.url)
// parse relative url to full url
try {
new URL(path)
} catch {
return new URL(path, config.url).href
}
return path