|
1 | 1 | package serv |
2 | 2 |
|
3 | 3 | import ( |
4 | | - "fmt" |
5 | | - "os" |
6 | | - "path/filepath" |
7 | | - "runtime" |
8 | | - |
9 | 4 | "github.com/utmstack/UTMStack/agent/config" |
10 | 5 | "github.com/utmstack/UTMStack/agent/utils" |
11 | 6 | ) |
12 | 7 |
|
13 | 8 | func CleanOldServices(cnf *config.Config) { |
14 | | - oldVersion := false |
15 | | - |
16 | | - isUpdaterINstalled, err := utils.CheckIfServiceIsInstalled("UTMStackUpdater") |
17 | | - if err != nil { |
18 | | - utils.Logger.LogF(100, "error checking if service is installed: %v", err) |
19 | | - } |
20 | | - |
21 | | - if isUpdaterINstalled { |
22 | | - oldVersion = true |
23 | | - err = utils.StopService("UTMStackUpdater") |
24 | | - if err != nil { |
25 | | - utils.Logger.LogF(100, "error stopping service: %v", err) |
26 | | - } |
27 | | - |
28 | | - err = utils.UninstallService("UTMStackUpdater") |
29 | | - if err != nil { |
30 | | - utils.Logger.LogF(100, "error uninstalling service: %v", err) |
31 | | - } |
32 | | - } |
33 | | - |
34 | 9 | isRedlineInstalled, err := utils.CheckIfServiceIsInstalled("UTMStackRedline") |
35 | 10 | if err != nil { |
36 | | - utils.Logger.LogF(100, "error checking if service is installed: %v", err) |
| 11 | + utils.Logger.LogF(100, "error checking if UTMStackRedline service is installed: %v", err) |
| 12 | + return |
37 | 13 | } |
38 | 14 |
|
39 | 15 | if isRedlineInstalled { |
40 | | - oldVersion = true |
| 16 | + utils.Logger.Info("old UTMStackRedline service found, removing...") |
| 17 | + |
41 | 18 | err = utils.StopService("UTMStackRedline") |
42 | 19 | if err != nil { |
43 | | - utils.Logger.LogF(100, "error stopping service: %v", err) |
| 20 | + utils.Logger.LogF(100, "error stopping UTMStackRedline service: %v", err) |
44 | 21 | } |
45 | 22 |
|
46 | 23 | err = utils.UninstallService("UTMStackRedline") |
47 | 24 | if err != nil { |
48 | | - utils.Logger.LogF(100, "error uninstalling service: %v", err) |
49 | | - } |
50 | | - } |
51 | | - |
52 | | - if oldVersion { |
53 | | - utils.Logger.Info("old version of agent found, downloading new version") |
54 | | - if runtime.GOOS != "darwin" { |
55 | | - if err := utils.DownloadFile(fmt.Sprintf(config.DependUrl, cnf.Server, config.DependenciesPort, fmt.Sprintf(config.UpdaterSelf, "")), map[string]string{}, fmt.Sprintf(config.UpdaterSelf, "_new"), utils.GetMyPath(), cnf.SkipCertValidation); err != nil { |
56 | | - utils.Logger.LogF(100, "error downloading updater: %v", err) |
57 | | - return |
58 | | - } |
59 | | - } |
60 | | - |
61 | | - oldFilePath := filepath.Join(utils.GetMyPath(), fmt.Sprintf(config.UpdaterSelf, "")) |
62 | | - newFilePath := filepath.Join(utils.GetMyPath(), fmt.Sprintf(config.UpdaterSelf, "_new")) |
63 | | - |
64 | | - utils.Logger.LogF(100, "renaming %s to %s", newFilePath, oldFilePath) |
65 | | - err := os.Remove(oldFilePath) |
66 | | - if err != nil { |
67 | | - utils.Logger.LogF(100, "error removing old updater: %v", err) |
68 | | - } |
69 | | - err = os.Rename(newFilePath, oldFilePath) |
70 | | - if err != nil { |
71 | | - utils.Logger.LogF(100, "error renaming updater: %v", err) |
| 25 | + utils.Logger.LogF(100, "error uninstalling UTMStackRedline service: %v", err) |
| 26 | + } else { |
| 27 | + utils.Logger.Info("UTMStackRedline service removed successfully") |
72 | 28 | } |
73 | | - } else { |
74 | | - utils.Logger.LogF(100, "no old version of agent found") |
75 | 29 | } |
76 | 30 | } |
0 commit comments