summaryrefslogtreecommitdiffstats
path: root/modules/base
diff options
context:
space:
mode:
authorKim "BKC" Carlbäcker <kim.carlbacker@gmail.com>2016-01-14 07:20:03 +0100
committerKim "BKC" Carlbäcker <kim.carlbacker@gmail.com>2016-01-27 02:02:03 +0100
commit3a9fd81f5946cbd70390b9c061bdcd1842f29735 (patch)
tree84379248c2c02d766d83f79cd260a10a9393101f /modules/base
parentab0ba4bbae121c9ba3cf0d49efc1c90ef7bb3ddc (diff)
downloadgitea-3a9fd81f5946cbd70390b9c061bdcd1842f29735.tar.gz
gitea-3a9fd81f5946cbd70390b9c061bdcd1842f29735.zip
Custom URL-Schemas for Markdown
Diffstat (limited to 'modules/base')
-rw-r--r--modules/base/markdown.go12
-rw-r--r--modules/base/tool.go1
2 files changed, 4 insertions, 9 deletions
diff --git a/modules/base/markdown.go b/modules/base/markdown.go
index 0ef379b8ed..62db945a53 100644
--- a/modules/base/markdown.go
+++ b/modules/base/markdown.go
@@ -29,16 +29,10 @@ func isalnum(c byte) bool {
return (c >= '0' && c <= '9') || isletter(c)
}
-var validLinks = [][]byte{[]byte("http://"), []byte("https://"), []byte("ftp://"), []byte("mailto://")}
+var validLinksPattern = regexp.MustCompile(`^[a-z][\w-]+://`)
func isLink(link []byte) bool {
- for _, prefix := range validLinks {
- if len(link) > len(prefix) && bytes.Equal(bytes.ToLower(link[:len(prefix)]), prefix) && isalnum(link[len(prefix)]) {
- return true
- }
- }
-
- return false
+ return validLinksPattern.Match(link)
}
func IsMarkdownFile(name string) bool {
@@ -346,7 +340,7 @@ OUTER_LOOP:
func RenderMarkdown(rawBytes []byte, urlPrefix string, metas map[string]string) []byte {
result := RenderRawMarkdown(rawBytes, urlPrefix)
result = PostProcessMarkdown(result, urlPrefix, metas)
- result = Sanitizer.SanitizeBytes(result)
+ result = BuildSanitizer().SanitizeBytes(result)
return result
}
diff --git a/modules/base/tool.go b/modules/base/tool.go
index f98ae28b93..5280fef203 100644
--- a/modules/base/tool.go
+++ b/modules/base/tool.go
@@ -37,6 +37,7 @@ func BuildSanitizer() (p *bluemonday.Policy) {
p.AllowAttrs("type").Matching(regexp.MustCompile(`^checkbox$`)).OnElements("input")
p.AllowAttrs("checked", "disabled").OnElements("input")
+ p.AllowURLSchemes(setting.Markdown.CustomURLSchemes...)
return p
}