1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- // init_once.go contains global initialization/teardown functions that should be called exactly once
- // per process.
- package imgproxy
- import (
- "github.com/DataDog/datadog-agent/pkg/trace/log"
- "github.com/imgproxy/imgproxy/v3/config"
- "github.com/imgproxy/imgproxy/v3/config/loadenv"
- "github.com/imgproxy/imgproxy/v3/errorreport"
- "github.com/imgproxy/imgproxy/v3/gliblog"
- "github.com/imgproxy/imgproxy/v3/logger"
- "github.com/imgproxy/imgproxy/v3/monitoring"
- "github.com/imgproxy/imgproxy/v3/options"
- "github.com/imgproxy/imgproxy/v3/processing"
- "github.com/imgproxy/imgproxy/v3/vips"
- "go.uber.org/automaxprocs/maxprocs"
- )
- // Init performs the global resources initialization. This should be done once per process.
- func Init() error {
- if err := loadenv.Load(); err != nil {
- return err
- }
- if err := logger.Init(); err != nil {
- return err
- }
- // NOTE: This is temporary workaround. We have to load env vars in config.go before
- // actually configuring ImgProxy instance because for now we use it as a source of truth.
- // Will be removed once we move env var loading to imgproxy.go
- if err := config.Configure(); err != nil {
- return err
- }
- // NOTE: End of temporary workaround.
- gliblog.Init()
- maxprocs.Set(maxprocs.Logger(log.Debugf))
- if err := monitoring.Init(); err != nil {
- return err
- }
- if err := vips.Init(); err != nil {
- return err
- }
- errorreport.Init()
- if err := processing.ValidatePreferredFormats(); err != nil {
- vips.Shutdown()
- return err
- }
- if err := options.ParsePresets(config.Presets); err != nil {
- vips.Shutdown()
- return err
- }
- if err := options.ValidatePresets(); err != nil {
- vips.Shutdown()
- return err
- }
- return nil
- }
- // Shutdown performs global cleanup
- func Shutdown() {
- monitoring.Stop()
- errorreport.Close()
- vips.Shutdown()
- }
|