mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 01:48:31 +00:00 
			
		
		
		
	Fix data URI scramble (#16098)
* Removed unused method. * No prefix for data uris. * Added test to prevent regressions.
This commit is contained in:
		| @@ -364,24 +364,19 @@ func visitNode(ctx *RenderContext, procs []processor, node *html.Node, visitText | |||||||
| 		} | 		} | ||||||
| 	case html.ElementNode: | 	case html.ElementNode: | ||||||
| 		if node.Data == "img" { | 		if node.Data == "img" { | ||||||
| 			attrs := node.Attr | 			for _, attr := range node.Attr { | ||||||
| 			for idx, attr := range attrs { |  | ||||||
| 				if attr.Key != "src" { | 				if attr.Key != "src" { | ||||||
| 					continue | 					continue | ||||||
| 				} | 				} | ||||||
| 				link := []byte(attr.Val) | 				if len(attr.Val) > 0 && !isLinkStr(attr.Val) && !strings.HasPrefix(attr.Val, ""/>` | ||||||
|  |  | ||||||
|  | 	var res strings.Builder | ||||||
|  | 	err := PostProcess(&RenderContext{ | ||||||
|  | 		URLPrefix: "https://example.com", | ||||||
|  | 		Metas:     localMetas, | ||||||
|  | 	}, strings.NewReader(data), &res) | ||||||
|  | 	assert.NoError(t, err) | ||||||
|  | 	assert.Equal(t, data, res.String()) | ||||||
|  | } | ||||||
|   | |||||||
| @@ -131,13 +131,3 @@ func SanitizeReader(r io.Reader) *bytes.Buffer { | |||||||
| 	NewSanitizer() | 	NewSanitizer() | ||||||
| 	return sanitizer.policy.SanitizeReader(r) | 	return sanitizer.policy.SanitizeReader(r) | ||||||
| } | } | ||||||
|  |  | ||||||
| // SanitizeBytes takes a []byte slice that contains a HTML fragment or document and applies policy whitelist. |  | ||||||
| func SanitizeBytes(b []byte) []byte { |  | ||||||
| 	if len(b) == 0 { |  | ||||||
| 		// nothing to sanitize |  | ||||||
| 		return b |  | ||||||
| 	} |  | ||||||
| 	NewSanitizer() |  | ||||||
| 	return sanitizer.policy.SanitizeBytes(b) |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -49,7 +49,6 @@ func Test_Sanitizer(t *testing.T) { | |||||||
|  |  | ||||||
| 	for i := 0; i < len(testCases); i += 2 { | 	for i := 0; i < len(testCases); i += 2 { | ||||||
| 		assert.Equal(t, testCases[i+1], Sanitize(testCases[i])) | 		assert.Equal(t, testCases[i+1], Sanitize(testCases[i])) | ||||||
| 		assert.Equal(t, testCases[i+1], string(SanitizeBytes([]byte(testCases[i])))) |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user