2022-10-09 17:16:49 +02:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
"sync/atomic"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/photoprism/photoprism/pkg/clean"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
extInit sync.Once
|
|
|
|
extMutex sync.Mutex
|
|
|
|
extensions atomic.Value
|
|
|
|
)
|
|
|
|
|
|
|
|
// Register registers a new package extension.
|
2024-01-20 15:01:40 +01:00
|
|
|
func Register(name string, initConfig func(c *Config) error, clientConfig func(c *Config, t ClientType) Map) {
|
2022-10-09 17:16:49 +02:00
|
|
|
extMutex.Lock()
|
|
|
|
n, _ := extensions.Load().(Extensions)
|
|
|
|
extensions.Store(append(n, Extension{name: name, init: initConfig, clientValues: clientConfig}))
|
|
|
|
extMutex.Unlock()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ext returns all registered package extensions.
|
|
|
|
func Ext() (ext Extensions) {
|
|
|
|
extMutex.Lock()
|
|
|
|
ext, _ = extensions.Load().(Extensions)
|
|
|
|
extMutex.Unlock()
|
|
|
|
return ext
|
|
|
|
}
|
|
|
|
|
|
|
|
// Extensions represents a list of package extensions.
|
|
|
|
type Extensions []Extension
|
|
|
|
|
|
|
|
// Extension represents a named package extension with callbacks.
|
|
|
|
type Extension struct {
|
|
|
|
name string
|
|
|
|
init func(c *Config) error
|
2024-01-20 15:01:40 +01:00
|
|
|
clientValues func(c *Config, t ClientType) Map
|
2022-10-09 17:16:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Init initializes the registered extensions.
|
|
|
|
func (ext Extensions) Init(c *Config) {
|
|
|
|
extInit.Do(func() {
|
|
|
|
for _, e := range ext {
|
|
|
|
start := time.Now()
|
|
|
|
|
|
|
|
if err := e.init(c); err != nil {
|
2024-01-21 14:22:16 +01:00
|
|
|
log.Warnf("config: %s when loading %s extension", err, clean.Log(e.name))
|
2022-10-09 17:16:49 +02:00
|
|
|
} else {
|
2023-05-05 09:55:00 +02:00
|
|
|
log.Tracef("config: %s extension loaded [%s]", clean.Log(e.name), time.Since(start))
|
2022-10-09 17:16:49 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|