diff options
author | Joe Mooring <[email protected]> | 2024-04-24 12:15:57 -0700 |
---|---|---|
committer | Bjørn Erik Pedersen <[email protected]> | 2024-04-25 10:03:17 +0200 |
commit | fb51b698b3aad83c23328887b20e7ceb6ae75244 (patch) | |
tree | e39e20a88ff61aaca9e715c1b4d768e4b5e44a3e | |
parent | 6b867972ec6df0ce79ddf614bbca039f4daa6060 (diff) | |
download | hugo-fb51b698b3aad83c23328887b20e7ceb6ae75244.tar.gz hugo-fb51b698b3aad83c23328887b20e7ceb6ae75244.zip |
tpl/tplimpl: Fix double-escaping in opengraph template
Closes #12418
-rw-r--r-- | tpl/tplimpl/embedded/templates/opengraph.html | 8 | ||||
-rw-r--r-- | tpl/tplimpl/tplimpl_integration_test.go | 106 |
2 files changed, 111 insertions, 3 deletions
diff --git a/tpl/tplimpl/embedded/templates/opengraph.html b/tpl/tplimpl/embedded/templates/opengraph.html index c245e5bd1..a9b348e9e 100644 --- a/tpl/tplimpl/embedded/templates/opengraph.html +++ b/tpl/tplimpl/embedded/templates/opengraph.html @@ -4,11 +4,11 @@ <meta property="og:site_name" content="{{ . }}"> {{- end }} -{{- with or .Title site.Title site.Params.title | plainify}} +{{- with or .Title site.Title site.Params.title | plainify }} <meta property="og:title" content="{{ . }}"> {{- end }} -{{- with or .Description .Summary site.Params.description | plainify }} +{{- with or .Description .Summary site.Params.description | plainify | htmlUnescape | chomp }} <meta property="og:description" content="{{ . }}"> {{- end }} @@ -18,7 +18,9 @@ {{- if .IsPage }} <meta property="og:type" content="article"> - <meta property="article:section" content="{{ .Section }}"> + {{- with .Section }} + <meta property="article:section" content="{{ . }}"> + {{- end }} {{- $ISO8601 := "2006-01-02T15:04:05-07:00" }} {{- with .PublishDate }} <meta property="article:published_time" {{ .Format $ISO8601 | printf "content=%q" | safeHTMLAttr }}> diff --git a/tpl/tplimpl/tplimpl_integration_test.go b/tpl/tplimpl/tplimpl_integration_test.go index 28d442e0d..6b2664c4d 100644 --- a/tpl/tplimpl/tplimpl_integration_test.go +++ b/tpl/tplimpl/tplimpl_integration_test.go @@ -305,3 +305,109 @@ title: p2 "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"yes\"?>\n<urlset xmlns=\"http://www.sitemaps.org/schemas/sitemap/0.9\"\n xmlns:xhtml=\"http://www.w3.org/1999/xhtml\">\n <url>\n <loc>/p2/</loc>\n </url>\n</urlset>\n", ) } + +// Issue 12418 +func TestOpengraph(t *testing.T) { + t.Parallel() + + files := ` +-- hugo.toml -- +capitalizeListTitles = false +disableKinds = ['rss','sitemap'] +languageCode = 'en-US' +[markup.goldmark.renderer] +unsafe = true +[params] +description = "m <em>n</em> and **o** can't." +[params.social] +facebook_admin = 'foo' +[taxonomies] +series = 'series' +tag = 'tags' +-- layouts/_default/list.html -- +{{ template "_internal/opengraph.html" . }} +-- layouts/_default/single.html -- +{{ template "_internal/opengraph.html" . }} +-- content/s1/p1.md -- +--- +title: p1 +date: 2024-04-24T08:00:00-07:00 +lastmod: 2024-04-24T11:00:00-07:00 +images: [a.jpg,b.jpg] +audio: [c.mp3,d.mp3] +videos: [e.mp4,f.mp4] +series: [series-1] +tags: [t1,t2] +--- +a <em>b</em> and **c** can't. +-- content/s1/p2.md -- +--- +title: p2 +series: [series-1] +--- +d <em>e</em> and **f** can't. +<!--more--> +-- content/s1/p3.md -- +--- +title: p3 +series: [series-1] +summary: g <em>h</em> and **i** can't. +--- +-- content/s1/p4.md -- +--- +title: p4 +series: [series-1] +description: j <em>k</em> and **l** can't. +--- +-- content/s1/p5.md -- +--- +title: p5 +series: [series-1] +--- +` + + b := hugolib.Test(t, files) + + b.AssertFileContent("public/s1/p1/index.html", ` + <meta property="og:url" content="/s1/p1/"> + <meta property="og:title" content="p1"> + <meta property="og:description" content="a b and c can’t."> + <meta property="og:locale" content="en-US"> + <meta property="og:type" content="article"> + <meta property="article:section" content="s1"> + <meta property="article:published_time" content="2024-04-24T08:00:00-07:00"> + <meta property="article:modified_time" content="2024-04-24T11:00:00-07:00"> + <meta property="article:tag" content="t1"> + <meta property="article:tag" content="t2"> + <meta property="og:image" content="/a.jpg"> + <meta property="og:image" content="/b.jpg"> + <meta property="og:audio" content="/c.mp3"> + <meta property="og:audio" content="/d.mp3"> + <meta property="og:video" content="/e.mp4"> + <meta property="og:video" content="/f.mp4"> + <meta property="og:see_also" content="/s1/p2/"> + <meta property="og:see_also" content="/s1/p3/"> + <meta property="og:see_also" content="/s1/p4/"> + <meta property="og:see_also" content="/s1/p5/"> + <meta property="fb:admins" content="foo"> + `, + ) + + b.AssertFileContent("public/s1/p2/index.html", + `<meta property="og:description" content="d e and f can’t.">`, + ) + + b.AssertFileContent("public/s1/p3/index.html", + `<meta property="og:description" content="g h and i can’t.">`, + ) + + // The markdown is intentionally not rendered to HTML. + b.AssertFileContent("public/s1/p4/index.html", + `<meta property="og:description" content="j k and **l** can't.">`, + ) + + // The markdown is intentionally not rendered to HTML. + b.AssertFileContent("public/s1/p5/index.html", + `<meta property="og:description" content="m n and **o** can't.">`, + ) +} |