-
Notifications
You must be signed in to change notification settings - Fork 510
/
Copy pathcontrollers.go
81 lines (69 loc) · 2.48 KB
/
controllers.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
// Copyright 2016 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package jujuclient
import (
"os"
"github.com/juju/errors"
"github.com/juju/utils/v4"
"gopkg.in/yaml.v3"
"github.com/juju/juju/juju/osenv"
)
// JujuControllersPath is the location where controllers information is
// expected to be found.
func JujuControllersPath() string {
return osenv.JujuXDGDataHomePath("controllers.yaml")
}
// ReadControllersFile loads all controllers defined in a given file.
// If the file is not found, it is not an error.
func ReadControllersFile(file string) (*Controllers, error) {
data, err := os.ReadFile(file)
if err != nil {
if os.IsNotExist(err) {
return &Controllers{}, nil
}
if os.IsPermission(err) {
u, userErr := utils.LocalUsername()
if userErr != nil {
return nil, err
}
if ok, fileErr := utils.IsFileOwner(file, u); fileErr == nil && !ok {
err = errors.Annotatef(err, "ownership of the file is not the same as the current user")
}
}
return nil, err
}
controllers, err := ParseControllers(data)
if err != nil {
return nil, err
}
return controllers, nil
}
// WriteControllersFile marshals to YAML details of the given controllers
// and writes it to the controllers file.
func WriteControllersFile(controllers *Controllers) error {
data, err := yaml.Marshal(controllers)
if err != nil {
return errors.Annotate(err, "cannot marshal yaml controllers")
}
return utils.AtomicWriteFile(JujuControllersPath(), data, os.FileMode(0600))
}
// ParseControllers parses the given YAML bytes into controllers metadata.
func ParseControllers(data []byte) (*Controllers, error) {
var result Controllers
err := yaml.Unmarshal(data, &result)
if err != nil {
return nil, errors.Annotate(err, "cannot unmarshal yaml controllers metadata")
}
return &result, nil
}
// Controllers stores per-client controller information.
type Controllers struct {
// Controllers is the collection of controllers known to the client.
Controllers map[string]ControllerDetails `yaml:"controllers"`
// CurrentController is the name of the active controller.
CurrentController string `yaml:"current-controller,omitempty"`
// PreviousController is the name of the previous active controller.
PreviousController string `yaml:"previous-controller,omitempty"`
// HasControllerChangedOnPreviousSwitch represents whether the controller has changed during the previous switch.
HasControllerChangedOnPreviousSwitch bool `yaml:"has-controller-changed-on-previous-switch"`
}