1
0
mirror of https://github.com/imgproxy/imgproxy.git synced 2026-06-13 22:32:40 +02:00
Files
2026-05-13 18:48:55 +03:00

62 lines
1.8 KiB
Go

package cloudwatch
import (
"errors"
"time"
"github.com/imgproxy/imgproxy/v4/ensure"
"github.com/imgproxy/imgproxy/v4/env"
)
var (
IMGPROXY_CLOUD_WATCH_SERVICE_NAME = env.String("IMGPROXY_CLOUD_WATCH_SERVICE_NAME")
IMGPROXY_CLOUD_WATCH_NAMESPACE = env.String("IMGPROXY_CLOUD_WATCH_NAMESPACE")
IMGPROXY_CLOUD_WATCH_REGION = env.String("IMGPROXY_CLOUD_WATCH_REGION")
)
// Config holds the configuration for CloudWatch monitoring
type Config struct {
ServiceName string // CloudWatch service name (also used to enable/disable CloudWatch)
Namespace string // CloudWatch metrics namespace
Region string // AWS region for CloudWatch
MetricsInterval time.Duration // Interval between metrics collections
}
// NewDefaultConfig returns a new default configuration for CloudWatch monitoring
func NewDefaultConfig() Config {
return Config{
ServiceName: "", // CloudWatch service name, enabled if not empty
Namespace: "imgproxy", // CloudWatch metrics namespace
Region: "",
MetricsInterval: 10 * time.Second, // Metrics collection interval
}
}
// LoadConfigFromEnv loads configuration from environment variables
func LoadConfigFromEnv(c *Config) (*Config, error) {
c = ensure.Ensure(c, NewDefaultConfig)
err := errors.Join(
IMGPROXY_CLOUD_WATCH_SERVICE_NAME.Parse(&c.ServiceName),
IMGPROXY_CLOUD_WATCH_NAMESPACE.Parse(&c.Namespace),
IMGPROXY_CLOUD_WATCH_REGION.Parse(&c.Region),
)
return c, err
}
// Enabled returns true if CloudWatch is enabled
func (c *Config) Enabled() bool {
return len(c.ServiceName) > 0
}
// Validate checks the configuration for errors
func (c *Config) Validate() error {
// If service name is not set, CloudWatch is disabled, so no need to validate other fields
if !c.Enabled() {
return nil
}
return nil
}