2017-04-13 10:52:24 +08:00
|
|
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
|
|
|
// Copyright 2017 The Gogs Authors. All rights reserved.
|
2022-11-28 02:20:29 +08:00
|
|
|
// SPDX-License-Identifier: MIT
|
2017-04-13 10:52:24 +08:00
|
|
|
|
2017-09-17 01:17:57 +08:00
|
|
|
package markup
|
2017-04-13 10:52:24 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"regexp"
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/microcosm-cc/bluemonday"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Sanitizer is a protection wrapper of *bluemonday.Policy which does not allow
|
|
|
|
// any modification to the underlying policies once it's been created.
|
|
|
|
type Sanitizer struct {
|
2023-11-24 00:34:25 +08:00
|
|
|
defaultPolicy *bluemonday.Policy
|
|
|
|
descriptionPolicy *bluemonday.Policy
|
|
|
|
rendererPolicies map[string]*bluemonday.Policy
|
2024-05-31 21:54:14 +08:00
|
|
|
allowAllRegex *regexp.Regexp
|
2017-04-13 10:52:24 +08:00
|
|
|
}
|
|
|
|
|
2023-05-19 23:17:07 +08:00
|
|
|
var (
|
2024-05-31 21:54:14 +08:00
|
|
|
defaultSanitizer *Sanitizer
|
|
|
|
defaultSanitizerOnce sync.Once
|
2023-05-19 23:17:07 +08:00
|
|
|
)
|
2017-04-13 10:52:24 +08:00
|
|
|
|
2024-05-31 21:54:14 +08:00
|
|
|
func GetDefaultSanitizer() *Sanitizer {
|
|
|
|
defaultSanitizerOnce.Do(func() {
|
|
|
|
defaultSanitizer = &Sanitizer{
|
|
|
|
rendererPolicies: map[string]*bluemonday.Policy{},
|
|
|
|
allowAllRegex: regexp.MustCompile(".+"),
|
2023-07-18 23:18:37 +08:00
|
|
|
}
|
2024-05-31 21:54:14 +08:00
|
|
|
for name, renderer := range renderers {
|
|
|
|
sanitizerRules := renderer.SanitizerRules()
|
|
|
|
if len(sanitizerRules) > 0 {
|
|
|
|
policy := defaultSanitizer.createDefaultPolicy()
|
|
|
|
defaultSanitizer.addSanitizerRules(policy, sanitizerRules)
|
|
|
|
defaultSanitizer.rendererPolicies[name] = policy
|
2021-06-24 05:09:51 +08:00
|
|
|
}
|
2019-12-08 03:49:04 +08:00
|
|
|
}
|
2024-05-31 21:54:14 +08:00
|
|
|
defaultSanitizer.defaultPolicy = defaultSanitizer.createDefaultPolicy()
|
|
|
|
defaultSanitizer.descriptionPolicy = defaultSanitizer.createRepoDescriptionPolicy()
|
|
|
|
})
|
|
|
|
return defaultSanitizer
|
2017-04-13 10:52:24 +08:00
|
|
|
}
|
|
|
|
|
2024-05-31 21:54:14 +08:00
|
|
|
func ResetDefaultSanitizerForTesting() {
|
|
|
|
defaultSanitizer = nil
|
|
|
|
defaultSanitizerOnce = sync.Once{}
|
2019-12-31 09:53:28 +08:00
|
|
|
}
|