mirror of
https://github.com/russross/blackfriday.git
synced 2024-03-22 13:40:34 +08:00
Merge pull request #44 from FreakyDazio/safe-relatives
Relative URIs are considered safe
This commit is contained in:
commit
5405274d99
|
@ -718,7 +718,7 @@ func autoLink(p *parser, out *bytes.Buffer, data []byte, offset int) int {
|
|||
return linkEnd - rewind
|
||||
}
|
||||
|
||||
var validUris = [][]byte{[]byte("http://"), []byte("https://"), []byte("ftp://"), []byte("mailto://")}
|
||||
var validUris = [][]byte{[]byte("http://"), []byte("https://"), []byte("ftp://"), []byte("mailto://"), []byte("/")}
|
||||
|
||||
func isSafeLink(link []byte) bool {
|
||||
for _, prefix := range validUris {
|
||||
|
|
|
@ -32,6 +32,10 @@ func doTestsInline(t *testing.T, tests []string) {
|
|||
doTestsInlineParam(t, tests, 0, 0)
|
||||
}
|
||||
|
||||
func doSafeTestsInline(t *testing.T, tests []string) {
|
||||
doTestsInlineParam(t, tests, 0, HTML_SAFELINK)
|
||||
}
|
||||
|
||||
func doTestsInlineParam(t *testing.T, tests []string, extensions, htmlFlags int) {
|
||||
// catch and report panics
|
||||
var candidate string
|
||||
|
@ -417,6 +421,30 @@ func TestInlineLink(t *testing.T) {
|
|||
doTestsInline(t, tests)
|
||||
}
|
||||
|
||||
func TestSafeInlineLink(t *testing.T) {
|
||||
var tests = []string{
|
||||
"[foo](/bar/)\n",
|
||||
"<p><a href=\"/bar/\">foo</a></p>\n",
|
||||
|
||||
"[foo](http://bar/)\n",
|
||||
"<p><a href=\"http://bar/\">foo</a></p>\n",
|
||||
|
||||
"[foo](https://bar/)\n",
|
||||
"<p><a href=\"https://bar/\">foo</a></p>\n",
|
||||
|
||||
"[foo](ftp://bar/)\n",
|
||||
"<p><a href=\"ftp://bar/\">foo</a></p>\n",
|
||||
|
||||
"[foo](mailto://bar/)\n",
|
||||
"<p><a href=\"mailto://bar/\">foo</a></p>\n",
|
||||
|
||||
// Not considered safe
|
||||
"[foo](baz://bar/)\n",
|
||||
"<p><tt>foo</tt></p>\n",
|
||||
}
|
||||
doSafeTestsInline(t, tests)
|
||||
}
|
||||
|
||||
func TestReferenceLink(t *testing.T) {
|
||||
var tests = []string{
|
||||
"[link][ref]\n",
|
||||
|
|
Loading…
Reference in New Issue
Block a user