Files
gluetun/internal/env/env.go

41 lines
809 B
Go
Raw Normal View History

package env
import (
2020-04-19 18:13:48 +00:00
"context"
"github.com/qdm12/golibs/logging"
)
type Env interface {
FatalOnError(err error)
2020-04-19 18:13:48 +00:00
PrintVersion(ctx context.Context, program string, commandFn func(ctx context.Context) (string, error))
}
type env struct {
2020-05-02 13:05:09 +00:00
logger logging.Logger
cancelContext func()
}
2020-05-02 13:05:09 +00:00
func New(logger logging.Logger, cancelContext context.CancelFunc) Env {
return &env{
2020-05-02 13:05:09 +00:00
logger: logger,
cancelContext: cancelContext,
}
}
func (e *env) FatalOnError(err error) {
if err != nil {
e.logger.Error(err)
2020-05-02 13:05:09 +00:00
e.cancelContext()
}
}
2020-04-19 18:13:48 +00:00
func (e *env) PrintVersion(ctx context.Context, program string, commandFn func(ctx context.Context) (string, error)) {
version, err := commandFn(ctx)
if err != nil {
e.logger.Error(err)
} else {
e.logger.Info("%s version: %s", program, version)
}
}