/
backups_restore.go
112 lines (91 loc) · 3.08 KB
/
backups_restore.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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package cmd
import (
"errors"
"fmt"
resty "github.com/go-resty/resty/v2"
helper "github.com/home-assistant/cli/client"
log "github.com/sirupsen/logrus"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
var backupsRestoreCmd = &cobra.Command{
Use: "restore [slug]",
Short: "Restores a Home Assistant backup",
Long: `
When something goes wrong, this command allows you to restore a previously
take Home Assistant backup on your system.`,
Example: `
ha backups restore c1a07617
ha backups restore c1a07617 --addons core_ssh --addon core_mosquitto
ha backups restore c1a07617 --folders config`,
Args: cobra.ExactArgs(1),
Run: func(cmd *cobra.Command, args []string) {
log.WithField("args", args).Debug("backups restore")
section := "backups/{slug}"
command := "restore/full"
base := viper.GetString("endpoint")
request := helper.GetJSONRequestTimeout(helper.BackupTimeout)
options := make(map[string]interface{})
slug := args[0]
request.SetPathParams(map[string]string{
"slug": slug,
})
password, err := cmd.Flags().GetString("password")
if password != "" && err == nil && cmd.Flags().Changed("password") {
options["password"] = password
}
homeassistant, err := cmd.Flags().GetBool("homeassistant")
if err == nil && cmd.Flags().Changed("homeassistant") {
options["homeassistant"] = homeassistant
command = "restore/partial"
}
addons, err := cmd.Flags().GetStringArray("addons")
log.WithField("addons", addons).Debug("addons")
if len(addons) > 0 && err == nil {
options["addons"] = addons
command = "restore/partial"
}
folders, err := cmd.Flags().GetStringArray("folders")
log.WithField("folders", folders).Debug("folders")
if len(folders) > 0 && err == nil {
options["folders"] = folders
command = "restore/partial"
}
url, err := helper.URLHelper(base, section, command)
if err != nil {
fmt.Println(err)
ExitWithError = true
return
}
if len(options) > 0 {
log.WithField("options", options).Debug("Request body")
request.SetBody(options)
}
ProgressSpinner.Start()
resp, err := request.Post(url)
ProgressSpinner.Stop()
// returns 200 OK or 400, everything else is wrong
if err == nil {
if resp.StatusCode() != 200 && resp.StatusCode() != 400 {
err = errors.New("Unexpected server response")
log.Error(err)
} else if !resty.IsJSONType(resp.Header().Get("Content-Type")) {
err = errors.New("API did not return a JSON response")
log.Error(err)
}
}
if err != nil {
fmt.Println(err)
ExitWithError = true
} else {
ExitWithError = !helper.ShowJSONResponse(resp)
}
},
}
func init() {
backupsRestoreCmd.Flags().StringP("password", "", "", "Password")
backupsRestoreCmd.Flags().BoolP("homeassistant", "", true, "Restore homeassistant (default true), triggers a partial backup when se to false")
backupsRestoreCmd.Flags().StringArrayP("addons", "a", []string{}, "addons to restore, triggers a partial backup")
backupsRestoreCmd.Flags().StringArrayP("folders", "f", []string{}, "folders to restore, triggers a partial backup")
backupsCmd.AddCommand(backupsRestoreCmd)
}