-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.go
78 lines (67 loc) · 1.95 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
// Copyright 2015 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package storage
import (
"github.com/juju/errors"
"github.com/juju/schema"
)
const (
// ConfigStorageDir is the path to the directory which a
// machine-scoped storage source may use to contain storage
// artifacts. This should not be used for environment-wide
// storage sources, as the contents are bound to the
// lifetime of the machine.
//
// ConfigStorageDir is set by the storage provisioner, so
// should not be relied upon until a storage source is
// constructed.
ConfigStorageDir = "storage-dir"
)
// Config defines the configuration for a storage source.
type Config struct {
name string
provider ProviderType
attrs map[string]interface{}
}
var fields = schema.Fields{}
var configChecker = schema.FieldMap(
fields,
schema.Defaults{},
)
// NewConfig creates a new Config for instantiating a storage source.
func NewConfig(name string, provider ProviderType, attrs map[string]interface{}) (*Config, error) {
_, err := configChecker.Coerce(attrs, nil)
if err != nil {
return nil, errors.Annotate(err, "validating common storage config")
}
return &Config{
name: name,
provider: provider,
attrs: attrs,
}, nil
}
// Name returns the name of a storage source. This is not necessarily unique,
// and should only be used for informational purposes.
func (c *Config) Name() string {
return c.name
}
// Provider returns the name of a storage provider.
func (c *Config) Provider() ProviderType {
return c.provider
}
// Attrs returns the configuration attributes for a storage source.
func (c *Config) Attrs() map[string]interface{} {
if c.attrs == nil {
return nil
}
attrs := make(map[string]interface{})
for k, v := range c.attrs {
attrs[k] = v
}
return attrs
}
// ValueString returns the named config attribute as a string.
func (c *Config) ValueString(name string) (string, bool) {
v, ok := c.attrs[name].(string)
return v, ok
}