summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoe Mooring <joe.mooring@veriphor.com>2024-04-24 12:15:57 -0700
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2024-04-25 10:03:17 +0200
commitfb51b698b3aad83c23328887b20e7ceb6ae75244 (patch)
treee39e20a88ff61aaca9e715c1b4d768e4b5e44a3e
parent6b867972ec6df0ce79ddf614bbca039f4daa6060 (diff)
tpl/tplimpl: Fix double-escaping in opengraph template
Closes #12418
-rw-r--r--tpl/tplimpl/embedded/templates/opengraph.html8
-rw-r--r--tpl/tplimpl/tplimpl_integration_test.go106
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&#39;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&#39;t.">`,
+ )
+}