-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathconfig.go
95 lines (82 loc) · 2.99 KB
/
config.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
package caretakerd
import (
"github.com/echocat/caretakerd/control"
"github.com/echocat/caretakerd/keyStore"
"github.com/echocat/caretakerd/logger"
"github.com/echocat/caretakerd/rpc"
"github.com/echocat/caretakerd/service"
"github.com/echocat/caretakerd/values"
"runtime"
)
// Root configuration of caretakerd.
type Config struct {
// Defines how the encryption of caretakerd works.
// This is especially important if {@ref #RPC RPC} is used.
//
// For details see {@ref github.com/echocat/caretakerd/keyStore.Config}.
KeyStore keyStore.Config `json:"keyStore" yaml:"keyStore,omitempty"`
// Defines how caretaker can controlled remotely.
//
// For details see {@ref github.com/echocat/caretakerd/rpc.Config}.
RPC rpc.Config `json:"rpc" yaml:"rpc,omitempty"`
// Defines the access rights of caretakerctl to caretakerd.
// This requires {@ref #RPC RPC} enabled.
//
// For details see {@ref github.com/echocat/caretakerd/control.Config}.
Control control.Config `json:"control" yaml:"control,omitempty"`
// Configures the logger for caretakerd itself.
// This does not include output of services.
//
// For details see {@ref github.com/echocat/caretakerd/logger.Config}.
Logger logger.Config `json:"logger" yaml:"logger,omitempty"`
// Services configuration to run with caretakerd.
//
// > **Important**: This is a map and requires exact one service
// > configured as {@ref github.com/echocat/caretakerd/service.Config#Type type} = {@ref github.com/echocat/caretakerd/service.Type#Master master}.
//
// For details see {@ref github.com/echocat/caretakerd/service.Config}.
Services service.Configs `json:"services" yaml:"services,omitempty"`
// Contains the source where this config comes from.
Source values.String `json:"-" yaml:"-"`
}
// NewConfigFor create a new config instance.
func NewConfigFor(platform string) Config {
result := Config{}
result.init(platform)
return result
}
// Validate do validate action on this object and return an error object if any.
func (instance Config) Validate() error {
err := instance.KeyStore.Validate()
if err == nil {
err = instance.RPC.Validate()
}
if err == nil {
err = instance.Control.Validate()
}
if err == nil {
err = instance.Logger.Validate()
}
if err == nil {
err = instance.Services.Validate()
}
return err
}
// ValidateMaster return an error instance on every validation problem of the
// master service config instance.
func (instance Config) ValidateMaster() error {
return instance.Services.ValidateMaster()
}
func (instance *Config) init(platform string) {
(*instance).KeyStore = keyStore.NewConfig()
(*instance).RPC = rpc.NewConfigFor(platform)
(*instance).Control = control.NewConfigFor(platform)
(*instance).Logger = logger.NewConfig()
(*instance).Services = service.NewConfigs()
}
// UnmarshalYAML is used by yaml unmarshalling. Do not call direct.
func (instance *Config) UnmarshalYAML(unmarshal func(interface{}) error) error {
instance.init(runtime.GOOS)
type noMethods Config
return unmarshal((*noMethods)(instance))
}