escaping csv column content
This commit is contained in:
parent
5304fa6bf4
commit
8da44d1844
|
|
@ -7,6 +7,7 @@ package markup
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/csv"
|
"encoding/csv"
|
||||||
|
"html"
|
||||||
"io"
|
"io"
|
||||||
|
|
||||||
"code.gitea.io/gitea/modules/markup"
|
"code.gitea.io/gitea/modules/markup"
|
||||||
|
|
@ -46,7 +47,7 @@ func (Parser) Render(rawBytes []byte, urlPrefix string, metas map[string]string,
|
||||||
tmpBlock.WriteString("<tr>")
|
tmpBlock.WriteString("<tr>")
|
||||||
for _, field := range fields {
|
for _, field := range fields {
|
||||||
tmpBlock.WriteString("<td>")
|
tmpBlock.WriteString("<td>")
|
||||||
tmpBlock.WriteString(field)
|
tmpBlock.WriteString(html.EscapeString(field))
|
||||||
tmpBlock.WriteString("</td>")
|
tmpBlock.WriteString("</td>")
|
||||||
}
|
}
|
||||||
tmpBlock.WriteString("<tr>")
|
tmpBlock.WriteString("<tr>")
|
||||||
|
|
|
||||||
25
modules/markup/csv/csv_test.go
Normal file
25
modules/markup/csv/csv_test.go
Normal file
|
|
@ -0,0 +1,25 @@
|
||||||
|
// Copyright 2018 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package markup
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestRenderCSV(t *testing.T) {
|
||||||
|
var parser Parser
|
||||||
|
var kases = map[string]string{
|
||||||
|
"a": "<table class=\"table\"><tr><td>a</td><tr></table>",
|
||||||
|
"1,2": "<table class=\"table\"><tr><td>1</td><td>2</td><tr></table>",
|
||||||
|
"<br/>": "<table class=\"table\"><tr><td><br/></td><tr></table>",
|
||||||
|
}
|
||||||
|
|
||||||
|
for k, v := range kases {
|
||||||
|
res := parser.Render([]byte(k), "", nil, false)
|
||||||
|
assert.EqualValues(t, v, string(res))
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue
Block a user