mirror of
https://github.com/yusing/godoxy.git
synced 2026-02-24 19:34:53 +01:00
- Refactors the fmtMessage function to use strings.Builder - Simplifies multi-writer creation with a helper function - Updates the new console writer initialization pattern - Moves InitLogger function to the top - Fixed NewLoggerWithFixedLevel
50 lines
1.1 KiB
Go
50 lines
1.1 KiB
Go
package rulepresets
|
|
|
|
import (
|
|
"embed"
|
|
"reflect"
|
|
"sync"
|
|
|
|
"github.com/rs/zerolog/log"
|
|
"github.com/yusing/godoxy/internal/route/rules"
|
|
"github.com/yusing/godoxy/internal/serialization"
|
|
gperr "github.com/yusing/goutils/errs"
|
|
)
|
|
|
|
//go:embed *.yml
|
|
var fs embed.FS
|
|
|
|
var rulePresets = make(map[string]rules.Rules)
|
|
|
|
var once sync.Once
|
|
|
|
func GetRulePreset(name string) (rules.Rules, bool) {
|
|
once.Do(initPresets)
|
|
rules, ok := rulePresets[name]
|
|
return rules, ok
|
|
}
|
|
|
|
// init all rule presetsl lazily
|
|
func initPresets() {
|
|
files, err := fs.ReadDir(".")
|
|
if err != nil {
|
|
log.Error().Err(err).Msg("failed to read rule presets")
|
|
return
|
|
}
|
|
for _, file := range files {
|
|
var rules rules.Rules
|
|
content, err := fs.ReadFile(file.Name())
|
|
if err != nil {
|
|
gperr.LogError("failed to read rule preset", err)
|
|
continue
|
|
}
|
|
_, err = serialization.ConvertString(string(content), reflect.ValueOf(&rules))
|
|
if err != nil {
|
|
gperr.LogError("failed to unmarshal rule preset", err)
|
|
continue
|
|
}
|
|
rulePresets[file.Name()] = rules
|
|
log.Debug().Str("name", file.Name()).Msg("loaded rule preset")
|
|
}
|
|
}
|