mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Basic xss prevention
This commit is contained in:
		@@ -24,6 +24,7 @@ github.com/macaron-contrib/session =
 | 
			
		||||
github.com/macaron-contrib/toolbox = commit:57127bcc89
 | 
			
		||||
github.com/mattn/go-sqlite3 = commit:a80c27ba33
 | 
			
		||||
github.com/nfnt/resize = commit:581d15cb53
 | 
			
		||||
github.com/russross/blackfriday = 
 | 
			
		||||
github.com/saintfish/chardet = commit:3af4cd4741
 | 
			
		||||
 | 
			
		||||
[res]
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										2
									
								
								gogs.go
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								gogs.go
									
									
									
									
									
								
							@@ -17,7 +17,7 @@ import (
 | 
			
		||||
	"github.com/gogits/gogs/modules/setting"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const APP_VER = "0.5.4.1003 Beta"
 | 
			
		||||
const APP_VER = "0.5.4.1004 Beta"
 | 
			
		||||
 | 
			
		||||
func init() {
 | 
			
		||||
	runtime.GOMAXPROCS(runtime.NumCPU())
 | 
			
		||||
 
 | 
			
		||||
@@ -23,6 +23,7 @@ import (
 | 
			
		||||
	"github.com/Unknwon/cae/zip"
 | 
			
		||||
	"github.com/Unknwon/com"
 | 
			
		||||
 | 
			
		||||
	"github.com/gogits/gogs/modules/base"
 | 
			
		||||
	"github.com/gogits/gogs/modules/git"
 | 
			
		||||
	"github.com/gogits/gogs/modules/log"
 | 
			
		||||
	"github.com/gogits/gogs/modules/process"
 | 
			
		||||
@@ -48,7 +49,7 @@ var (
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	DescriptionPattern = regexp.MustCompile(`https?://\S+`)
 | 
			
		||||
	DescPattern = regexp.MustCompile(`https?://\S+`)
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func LoadRepoConfig() {
 | 
			
		||||
@@ -181,7 +182,7 @@ func (repo *Repository) DescriptionHtml() template.HTML {
 | 
			
		||||
		ss := html.EscapeString(s)
 | 
			
		||||
		return fmt.Sprintf(`<a href="%s" target="_blank">%s</a>`, ss, ss)
 | 
			
		||||
	}
 | 
			
		||||
	return template.HTML(DescriptionPattern.ReplaceAllStringFunc(repo.Description, sanitize))
 | 
			
		||||
	return template.HTML(DescPattern.ReplaceAllStringFunc(base.XSSString(repo.Description), sanitize))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// IsRepositoryExist returns true if the repository with given name under user has already existed.
 | 
			
		||||
 
 | 
			
		||||
@@ -13,7 +13,8 @@ import (
 | 
			
		||||
	"regexp"
 | 
			
		||||
	"strings"
 | 
			
		||||
 | 
			
		||||
	"github.com/gogits/gfm"
 | 
			
		||||
	"github.com/russross/blackfriday"
 | 
			
		||||
 | 
			
		||||
	"github.com/gogits/gogs/modules/setting"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
@@ -74,7 +75,7 @@ func IsReadmeFile(name string) bool {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type CustomRender struct {
 | 
			
		||||
	gfm.Renderer
 | 
			
		||||
	blackfriday.Renderer
 | 
			
		||||
	urlPrefix string
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -154,39 +155,40 @@ func RenderSpecialLink(rawBytes []byte, urlPrefix string) []byte {
 | 
			
		||||
 | 
			
		||||
func RenderRawMarkdown(body []byte, urlPrefix string) []byte {
 | 
			
		||||
	htmlFlags := 0
 | 
			
		||||
	// htmlFlags |= gfm.HTML_USE_XHTML
 | 
			
		||||
	// htmlFlags |= gfm.HTML_USE_SMARTYPANTS
 | 
			
		||||
	// htmlFlags |= gfm.HTML_SMARTYPANTS_FRACTIONS
 | 
			
		||||
	// htmlFlags |= gfm.HTML_SMARTYPANTS_LATEX_DASHES
 | 
			
		||||
	// htmlFlags |= gfm.HTML_SKIP_HTML
 | 
			
		||||
	htmlFlags |= gfm.HTML_SKIP_STYLE
 | 
			
		||||
	htmlFlags |= gfm.HTML_SKIP_SCRIPT
 | 
			
		||||
	htmlFlags |= gfm.HTML_GITHUB_BLOCKCODE
 | 
			
		||||
	htmlFlags |= gfm.HTML_OMIT_CONTENTS
 | 
			
		||||
	// htmlFlags |= gfm.HTML_COMPLETE_PAGE
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_USE_XHTML
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_USE_SMARTYPANTS
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_SMARTYPANTS_FRACTIONS
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_SMARTYPANTS_LATEX_DASHES
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_SKIP_HTML
 | 
			
		||||
	htmlFlags |= blackfriday.HTML_SKIP_STYLE
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_SKIP_SCRIPT
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_GITHUB_BLOCKCODE
 | 
			
		||||
	htmlFlags |= blackfriday.HTML_OMIT_CONTENTS
 | 
			
		||||
	// htmlFlags |= blackfriday.HTML_COMPLETE_PAGE
 | 
			
		||||
	renderer := &CustomRender{
 | 
			
		||||
		Renderer:  gfm.HtmlRenderer(htmlFlags, "", ""),
 | 
			
		||||
		Renderer:  blackfriday.HtmlRenderer(htmlFlags, "", ""),
 | 
			
		||||
		urlPrefix: urlPrefix,
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// set up the parser
 | 
			
		||||
	extensions := 0
 | 
			
		||||
	extensions |= gfm.EXTENSION_NO_INTRA_EMPHASIS
 | 
			
		||||
	extensions |= gfm.EXTENSION_TABLES
 | 
			
		||||
	extensions |= gfm.EXTENSION_FENCED_CODE
 | 
			
		||||
	extensions |= gfm.EXTENSION_AUTOLINK
 | 
			
		||||
	extensions |= gfm.EXTENSION_STRIKETHROUGH
 | 
			
		||||
	extensions |= gfm.EXTENSION_HARD_LINE_BREAK
 | 
			
		||||
	extensions |= gfm.EXTENSION_SPACE_HEADERS
 | 
			
		||||
	extensions |= gfm.EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_NO_INTRA_EMPHASIS
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_TABLES
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_FENCED_CODE
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_AUTOLINK
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_STRIKETHROUGH
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_HARD_LINE_BREAK
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_SPACE_HEADERS
 | 
			
		||||
	extensions |= blackfriday.EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK
 | 
			
		||||
 | 
			
		||||
	body = gfm.Markdown(body, renderer, extensions)
 | 
			
		||||
	body = blackfriday.Markdown(body, renderer, extensions)
 | 
			
		||||
	return body
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func RenderMarkdown(rawBytes []byte, urlPrefix string) []byte {
 | 
			
		||||
	body := RenderSpecialLink(rawBytes, urlPrefix)
 | 
			
		||||
	body = RenderRawMarkdown(body, urlPrefix)
 | 
			
		||||
	body = XSS(body)
 | 
			
		||||
	return body
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -14,6 +14,7 @@ import (
 | 
			
		||||
	"hash"
 | 
			
		||||
	"html/template"
 | 
			
		||||
	"math"
 | 
			
		||||
	"regexp"
 | 
			
		||||
	"strings"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
@@ -446,3 +447,29 @@ func DateFormat(t time.Time, format string) string {
 | 
			
		||||
	format = replacer.Replace(format)
 | 
			
		||||
	return t.Format(format)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type xssFilter struct {
 | 
			
		||||
	reg  *regexp.Regexp
 | 
			
		||||
	repl []byte
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	whiteSpace = []byte(" ")
 | 
			
		||||
	xssFilters = []xssFilter{
 | 
			
		||||
		{regexp.MustCompile(`\ [ONon]\w*=["]*`), whiteSpace},
 | 
			
		||||
		{regexp.MustCompile(`<[SCRIPTscript]{6}`), whiteSpace},
 | 
			
		||||
		{regexp.MustCompile(`=[` + "`" + `'"]*[JAVASCRIPTjavascript \t\0
]*:`), whiteSpace},
 | 
			
		||||
	}
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// XSS goes through all the XSS filters to make user input content as safe as possible.
 | 
			
		||||
func XSS(in []byte) []byte {
 | 
			
		||||
	for _, filter := range xssFilters {
 | 
			
		||||
		in = filter.reg.ReplaceAll(in, filter.repl)
 | 
			
		||||
	}
 | 
			
		||||
	return in
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func XSSString(in string) string {
 | 
			
		||||
	return string(XSS([]byte(in)))
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1 +1 @@
 | 
			
		||||
0.5.4.1003 Beta
 | 
			
		||||
0.5.4.1004 Beta
 | 
			
		||||
		Reference in New Issue
	
	Block a user