2022-05-13 15:38:19 +02:00
|
|
|
package check
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
"sync"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
ErrModuleNameConflict = errors.New("module name conflict")
|
|
|
|
ErrNoSuchModule = errors.New("no module of given name known")
|
|
|
|
)
|
|
|
|
|
|
|
|
func NewRegistry() *Registry {
|
|
|
|
return &Registry{
|
|
|
|
mods: make(map[string]*Module),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type (
|
|
|
|
Registry struct {
|
|
|
|
lock sync.RWMutex
|
|
|
|
mods map[string]*Module
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
2023-12-04 11:22:49 +01:00
|
|
|
func (r *Registry) Register(modules ...*Module) error {
|
2022-05-13 15:38:19 +02:00
|
|
|
r.lock.Lock()
|
|
|
|
defer r.lock.Unlock()
|
|
|
|
|
2023-12-04 11:22:49 +01:00
|
|
|
for _, mod := range modules {
|
|
|
|
modName := strings.ToLower(mod.Name())
|
2022-05-13 15:38:19 +02:00
|
|
|
|
2023-12-04 11:22:49 +01:00
|
|
|
if _, ok := r.mods[modName]; ok {
|
|
|
|
return fmt.Errorf("%w: %s", ErrModuleNameConflict, modName)
|
|
|
|
}
|
|
|
|
|
|
|
|
r.mods[modName] = mod
|
2022-05-13 15:38:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-06-09 22:40:32 +02:00
|
|
|
//nolint:ireturn // required to implement interface
|
2022-05-13 15:38:19 +02:00
|
|
|
func (r *Registry) Lookup(modName string) (CheckerLookup, error) {
|
|
|
|
r.lock.RLock()
|
|
|
|
defer r.lock.RUnlock()
|
|
|
|
|
|
|
|
modName = strings.ToLower(modName)
|
|
|
|
|
|
|
|
if mod, ok := r.mods[modName]; !ok {
|
|
|
|
return nil, fmt.Errorf("%w: %s", ErrNoSuchModule, modName)
|
|
|
|
} else {
|
|
|
|
return mod, nil
|
|
|
|
}
|
|
|
|
}
|