mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2026-01-06 12:19:37 -06:00
207 lines
6.8 KiB
Go
207 lines
6.8 KiB
Go
package config
|
|
|
|
import (
|
|
"fmt"
|
|
"reflect"
|
|
|
|
gofig "github.com/gookit/config/v2"
|
|
accounts "github.com/owncloud/ocis/accounts/pkg/config"
|
|
glauth "github.com/owncloud/ocis/glauth/pkg/config"
|
|
graphExplorer "github.com/owncloud/ocis/graph-explorer/pkg/config"
|
|
graph "github.com/owncloud/ocis/graph/pkg/config"
|
|
idp "github.com/owncloud/ocis/idp/pkg/config"
|
|
ocs "github.com/owncloud/ocis/ocs/pkg/config"
|
|
proxy "github.com/owncloud/ocis/proxy/pkg/config"
|
|
settings "github.com/owncloud/ocis/settings/pkg/config"
|
|
storage "github.com/owncloud/ocis/storage/pkg/config"
|
|
store "github.com/owncloud/ocis/store/pkg/config"
|
|
thumbnails "github.com/owncloud/ocis/thumbnails/pkg/config"
|
|
web "github.com/owncloud/ocis/web/pkg/config"
|
|
webdav "github.com/owncloud/ocis/webdav/pkg/config"
|
|
)
|
|
|
|
// Log defines the available logging configuration.
|
|
type Log struct {
|
|
Level string `mapstructure:"level"`
|
|
Pretty bool `mapstructure:"pretty"`
|
|
Color bool `mapstructure:"color"`
|
|
File string `mapstructure:"file"`
|
|
}
|
|
|
|
// Debug defines the available debug configuration.
|
|
type Debug struct {
|
|
Addr string `mapstructure:"addr"`
|
|
Token string `mapstructure:"token"`
|
|
Pprof bool `mapstructure:"pprof"`
|
|
Zpages bool `mapstructure:"zpages"`
|
|
}
|
|
|
|
// HTTP defines the available http configuration.
|
|
type HTTP struct {
|
|
Addr string `mapstructure:"addr"`
|
|
Root string `mapstructure:"root"`
|
|
}
|
|
|
|
// GRPC defines the available grpc configuration.
|
|
type GRPC struct {
|
|
Addr string `mapstructure:"addr"`
|
|
}
|
|
|
|
// Tracing defines the available tracing configuration.
|
|
type Tracing struct {
|
|
Enabled bool `mapstructure:"enabled"`
|
|
Type string `mapstructure:"type"`
|
|
Endpoint string `mapstructure:"endpoint"`
|
|
Collector string `mapstructure:"collector"`
|
|
Service string `mapstructure:"service"`
|
|
}
|
|
|
|
// TokenManager is the config for using the reva token manager
|
|
type TokenManager struct {
|
|
JWTSecret string `mapstructure:"jwt_secret"`
|
|
}
|
|
|
|
const (
|
|
// SUPERVISED sets the runtime mode as supervised threads.
|
|
SUPERVISED = iota
|
|
|
|
// UNSUPERVISED sets the runtime mode as a single thread.
|
|
UNSUPERVISED
|
|
)
|
|
|
|
type Mode int
|
|
|
|
// Runtime configures the oCIS runtime when running in supervised mode.
|
|
type Runtime struct {
|
|
Port string `mapstructure:"port"`
|
|
Host string `mapstructure:"host"`
|
|
Extensions string `mapstructure:"extensions"`
|
|
}
|
|
|
|
// Config combines all available configuration parts.
|
|
type Config struct {
|
|
// Mode is mostly used whenever we need to run an extension. The technical debt this introduces is in regard of
|
|
// what it does. Supervised (0) loads configuration from a unified config file because of known limitations of Viper; whereas
|
|
// Unsupervised (1) MUST parse config from all known sources.
|
|
Mode Mode
|
|
File string
|
|
OcisURL string `mapstructure:"ocis_url"`
|
|
|
|
Registry string `mapstructure:"registry"`
|
|
Log Log `mapstructure:"log"`
|
|
Debug Debug `mapstructure:"debug"`
|
|
HTTP HTTP `mapstructure:"http"`
|
|
GRPC GRPC `mapstructure:"grpc"`
|
|
Tracing Tracing `mapstructure:"tracing"`
|
|
TokenManager TokenManager `mapstructure:"token_manager"`
|
|
Runtime Runtime `mapstructure:"runtime"`
|
|
|
|
Accounts *accounts.Config `mapstructure:"accounts"`
|
|
GLAuth *glauth.Config `mapstructure:"glauth"`
|
|
Graph *graph.Config `mapstructure:"graph"`
|
|
GraphExplorer *graphExplorer.Config `mapstructure:"graph_explorer"`
|
|
IDP *idp.Config `mapstructure:"idp"`
|
|
OCS *ocs.Config `mapstructure:"ocs"`
|
|
Web *web.Config `mapstructure:"web"`
|
|
Proxy *proxy.Config `mapstructure:"proxy"`
|
|
Settings *settings.Config `mapstructure:"settings"`
|
|
Storage *storage.Config `mapstructure:"storage"`
|
|
Store *store.Config `mapstructure:"store"`
|
|
Thumbnails *thumbnails.Config `mapstructure:"thumbnails"`
|
|
WebDAV *webdav.Config `mapstructure:"webdav"`
|
|
}
|
|
|
|
// New initializes a new configuration with or without defaults.
|
|
func New() *Config {
|
|
return &Config{
|
|
Accounts: accounts.DefaultConfig(),
|
|
GLAuth: glauth.DefaultConfig(),
|
|
Graph: graph.DefaultConfig(),
|
|
IDP: idp.DefaultConfig(),
|
|
Proxy: proxy.DefaultConfig(),
|
|
GraphExplorer: graphExplorer.DefaultConfig(),
|
|
OCS: ocs.DefaultConfig(),
|
|
Settings: settings.DefaultConfig(),
|
|
Web: web.New(),
|
|
Storage: storage.New(),
|
|
Store: store.New(),
|
|
Thumbnails: thumbnails.DefaultConfig(),
|
|
WebDAV: webdav.New(),
|
|
}
|
|
}
|
|
|
|
// TODO(refs) refactoir refactor this outside
|
|
type mapping struct {
|
|
EnvVars []string // name of the EnvVars var.
|
|
Destination interface{} // memory address of the original config value to modify.
|
|
}
|
|
|
|
// GetEnv fetches a list of known env variables for this extension. It is to be used by gookit, as it provides a list
|
|
// with all the environment variables an extension supports.
|
|
func GetEnv() []string {
|
|
var r = make([]string, len(structMappings(&Config{})))
|
|
for i := range structMappings(&Config{}) {
|
|
r = append(r, structMappings(&Config{})[i].EnvVars...)
|
|
}
|
|
|
|
return r
|
|
}
|
|
|
|
// UnmapEnv loads values from the gooconf.Config argument and sets them in the expected destination.
|
|
// TODO(refs) can we avoid repetition here?
|
|
func (c *Config) UnmapEnv(gooconf *gofig.Config) error {
|
|
vals := structMappings(c)
|
|
for i := range vals {
|
|
for j := range vals[i].EnvVars {
|
|
// we need to guard against v != "" because this is the condition that checks that the value is set from the environment.
|
|
// the `ok` guard is not enough, apparently.
|
|
if v, ok := gooconf.GetValue(vals[i].EnvVars[j]); ok && v != "" {
|
|
|
|
// get the destination type from destination
|
|
switch reflect.ValueOf(vals[i].Destination).Type().String() {
|
|
case "*bool":
|
|
r := gooconf.Bool(vals[i].EnvVars[j])
|
|
*vals[i].Destination.(*bool) = r
|
|
case "*string":
|
|
r := gooconf.String(vals[i].EnvVars[j])
|
|
*vals[i].Destination.(*string) = r
|
|
case "*int":
|
|
r := gooconf.Int(vals[i].EnvVars[j])
|
|
*vals[i].Destination.(*int) = r
|
|
case "*float64":
|
|
// defaults to float64
|
|
r := gooconf.Float(vals[i].EnvVars[j])
|
|
*vals[i].Destination.(*float64) = r
|
|
default:
|
|
// it is unlikely we will ever get here. Let this serve more as a runtime check for when debugging.
|
|
return fmt.Errorf("invalid type for env var: `%v`", vals[i].EnvVars[j])
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// structMappings binds a set of environment variables to a destination on cfg.
|
|
func structMappings(cfg *Config) []mapping {
|
|
return []mapping{
|
|
{
|
|
EnvVars: []string{"OCIS_LOG_FILE"},
|
|
Destination: &cfg.Log.Level,
|
|
},
|
|
{
|
|
EnvVars: []string{"OCIS_LOG_LEVEL"},
|
|
Destination: &cfg.Log.Level,
|
|
},
|
|
{
|
|
EnvVars: []string{"OCIS_LOG_COLOR"},
|
|
Destination: &cfg.Log.Color,
|
|
},
|
|
{
|
|
EnvVars: []string{"OCIS_LOG_PRETTY"},
|
|
Destination: &cfg.Log.Pretty,
|
|
},
|
|
}
|
|
}
|