2017-04-12 20:52:24 -06:00
|
|
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
|
|
|
// Copyright 2017 The Gogs Authors. All rights reserved.
|
2022-11-27 11:20:29 -07:00
|
|
|
// SPDX-License-Identifier: MIT
|
2017-04-12 20:52:24 -06:00
|
|
|
|
2017-09-16 11:17:57 -06:00
|
|
|
package markup
|
2017-04-12 20:52:24 -06: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-23 09:34:25 -07:00
|
|
|
defaultPolicy *bluemonday.Policy
|
|
|
|
descriptionPolicy *bluemonday.Policy
|
|
|
|
rendererPolicies map[string]*bluemonday.Policy
|
2024-05-31 07:54:14 -06:00
|
|
|
allowAllRegex *regexp.Regexp
|
2017-04-12 20:52:24 -06:00
|
|
|
}
|
|
|
|
|
2023-05-19 09:17:07 -06:00
|
|
|
var (
|
2024-05-31 07:54:14 -06:00
|
|
|
defaultSanitizer *Sanitizer
|
|
|
|
defaultSanitizerOnce sync.Once
|
2023-05-19 09:17:07 -06:00
|
|
|
)
|
2017-04-12 20:52:24 -06:00
|
|
|
|
2024-05-31 07:54:14 -06:00
|
|
|
func GetDefaultSanitizer() *Sanitizer {
|
|
|
|
defaultSanitizerOnce.Do(func() {
|
|
|
|
defaultSanitizer = &Sanitizer{
|
|
|
|
rendererPolicies: map[string]*bluemonday.Policy{},
|
|
|
|
allowAllRegex: regexp.MustCompile(".+"),
|
2023-07-18 09:18:37 -06:00
|
|
|
}
|
2024-05-31 07:54:14 -06: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-23 15:09:51 -06:00
|
|
|
}
|
2019-12-07 12:49:04 -07:00
|
|
|
}
|
2024-05-31 07:54:14 -06:00
|
|
|
defaultSanitizer.defaultPolicy = defaultSanitizer.createDefaultPolicy()
|
|
|
|
defaultSanitizer.descriptionPolicy = defaultSanitizer.createRepoDescriptionPolicy()
|
|
|
|
})
|
|
|
|
return defaultSanitizer
|
2017-04-12 20:52:24 -06:00
|
|
|
}
|
|
|
|
|
2024-05-31 07:54:14 -06:00
|
|
|
func ResetDefaultSanitizerForTesting() {
|
|
|
|
defaultSanitizer = nil
|
|
|
|
defaultSanitizerOnce = sync.Once{}
|
2019-12-30 18:53:28 -07:00
|
|
|
}
|