tpl: Make the safeHTML and cousins accept more than strings
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Thu, 3 Mar 2016 19:30:18 +0000 (20:30 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 14 Mar 2016 21:27:40 +0000 (22:27 +0100)
tpl/template_funcs.go
tpl/template_funcs_test.go

index eb2e2d4eb3e4d443d5dbabebeb512d3c072926a2..b262586929d199890a0a3790a25ac05a044d8f25 100644 (file)
@@ -1459,25 +1459,25 @@ func index(item interface{}, indices ...interface{}) (interface{}, error) {
 //
 // safeHTMLAttr is currently disabled, pending further discussion
 // on its use case.  2015-01-19
-func safeHTMLAttr(text string) template.HTMLAttr {
-       return template.HTMLAttr(text)
+func safeHTMLAttr(a interface{}) template.HTMLAttr {
+       return template.HTMLAttr(cast.ToString(a))
 }
 
 // safeCSS returns a given string as html/template CSS content.
-func safeCSS(text string) template.CSS {
-       return template.CSS(text)
+func safeCSS(a interface{}) template.CSS {
+       return template.CSS(cast.ToString(a))
 }
 
 // safeURL returns a given string as html/template URL content.
-func safeURL(text string) template.URL {
-       return template.URL(text)
+func safeURL(a interface{}) template.URL {
+       return template.URL(cast.ToString(a))
 }
 
 // safeHTML returns a given string as html/template HTML content.
-func safeHTML(a string) template.HTML { return template.HTML(a) }
+func safeHTML(a interface{}) template.HTML { return template.HTML(cast.ToString(a)) }
 
 // safeJS returns the given string as a html/template JS content.
-func safeJS(a string) template.JS { return template.JS(a) }
+func safeJS(a interface{}) template.JS { return template.JS(cast.ToString(a)) }
 
 func doArithmetic(a, b interface{}, op rune) (interface{}, error) {
        av := reflect.ValueOf(a)
index a483a1ca773a3de8f3f45f62cbe8b5f51506555d..ccdf7207098e088cd91ef4bb55eb2c3994cc4c74 100644 (file)
@@ -103,6 +103,11 @@ jsonify: {{ (slice "A" "B" "C") | jsonify }}
 md5: {{ md5 "Hello world, gophers!" }}
 sha1: {{ sha1 "Hello world, gophers!" }}
 emojify: {{ "I :heart: Hugo" | emojify }}
+safeHTML: {{ "Bat&Man" | safeHTML }}
+safeHTML: {{ "Bat&Man" | safeHTML | safeHTML }}
+safeCSS: {{ "Bat&Man" | safeCSS | safeCSS }}
+safeURL: {{ "http://gohugo.io" | safeURL | safeURL }}
+safeJS: {{ "(1*2)" | safeJS | safeJS }}
 `
        expected := `chomp: <p>Blockhead</p>
 dateFormat: Wednesday, Jan 21, 2015
@@ -141,6 +146,11 @@ jsonify: ["A","B","C"]
 md5: b3029f756f98f79e7f1b7f1d1f0dd53b
 sha1: c8b5b0e33d408246e30f53e32b8f7627a7a649d4
 emojify: I ❤️  Hugo
+safeHTML: Bat&Man
+safeHTML: Bat&Man
+safeCSS: Bat&amp;Man
+safeURL: http://gohugo.io
+safeJS: (1*2)
 `
 
        var b bytes.Buffer
@@ -166,7 +176,7 @@ emojify: I ❤️  Hugo
        }
 
        if b.String() != expected {
-               t.Errorf("Got\n%q\nExpected\n>%q<", b.String(), expected)
+               t.Errorf("Got\n%q\nExpected\n%q", b.String(), expected)
        }
 }