-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor: separate rpm-ostree and bootc drivers w/ new format
- Loading branch information
1 parent
a28288e
commit 6ebb0ac
Showing
3 changed files
with
215 additions
and
137 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,121 @@ | ||
package drv | ||
|
||
// Temporary: WILL get removed at some point. | ||
// FIXME: Remove this on Spring 2025 when we all move to dnf5 and bootc ideally | ||
|
||
import ( | ||
"encoding/json" | ||
"os/exec" | ||
"strings" | ||
"time" | ||
) | ||
|
||
type rpmOstreeStatus struct { | ||
Deployments []struct { | ||
Timestamp int64 `json:"timestamp"` | ||
} `json:"deployments"` | ||
} | ||
|
||
type RpmOstreeUpdater struct { | ||
Config DriverConfiguration | ||
BinaryPath string | ||
} | ||
|
||
func (dr RpmOstreeUpdater) Outdated() (bool, error) { | ||
if dr.Config.DryRun { | ||
return false, nil | ||
} | ||
oneMonthAgo := time.Now().AddDate(0, -1, 0) | ||
var timestamp time.Time | ||
|
||
cmd := exec.Command(dr.BinaryPath, "status", "--json", "--booted") | ||
out, err := cmd.CombinedOutput() | ||
if err != nil { | ||
return false, err | ||
} | ||
var status rpmOstreeStatus | ||
err = json.Unmarshal(out, &status) | ||
if err != nil { | ||
return false, err | ||
} | ||
timestamp = time.Unix(status.Deployments[0].Timestamp, 0).UTC() | ||
|
||
return timestamp.Before(oneMonthAgo), nil | ||
} | ||
|
||
func (dr RpmOstreeUpdater) Update() (*[]CommandOutput, error) { | ||
var finalOutput = []CommandOutput{} | ||
var cmd *exec.Cmd = nil | ||
binaryPath := dr.BinaryPath | ||
cli := []string{binaryPath, "upgrade"} | ||
cmd = exec.Command(cli[0], cli[1:]...) | ||
out, err := cmd.CombinedOutput() | ||
tmpout := CommandOutput{}.New(out, err) | ||
tmpout.Cli = cli | ||
Check failure on line 54 in drv/rpm-ostree.go GitHub Actions / lint
|
||
tmpout.Failure = err != nil | ||
tmpout.Context = "System Update" | ||
finalOutput = append(finalOutput, *tmpout) | ||
return &finalOutput, err | ||
} | ||
|
||
func (dr RpmOstreeUpdater) UpdateAvailable() (bool, error) { | ||
// This function may or may not be accurate, rpm-ostree updgrade --check has issues... https://github.com/coreos/rpm-ostree/issues/1579 | ||
// Not worried because we will end up removing rpm-ostree from the equation soon | ||
cmd := exec.Command(dr.BinaryPath, "upgrade", "--check") | ||
out, err := cmd.CombinedOutput() | ||
if err != nil { | ||
return true, err | ||
} | ||
return strings.Contains(string(out), "AvailableUpdate"), nil | ||
} | ||
|
||
func (up RpmOstreeUpdater) Steps() int { | ||
if up.Config.Enabled { | ||
return 1 | ||
} | ||
return 0 | ||
} | ||
|
||
func BootcCompatible(binaryPath string) (bool, error) { | ||
cmd := exec.Command(binaryPath, "status", "--format=json") | ||
out, err := cmd.CombinedOutput() | ||
if err != nil { | ||
return false, nil | ||
} | ||
var status bootcStatus | ||
err = json.Unmarshal(out, &status) | ||
if err != nil { | ||
return false, nil | ||
} | ||
return !(status.Status.Booted.Incompatible || status.Status.Staged.Incompatible), nil | ||
} | ||
|
||
func (up RpmOstreeUpdater) New(config UpdaterInitConfiguration) (RpmOstreeUpdater, error) { | ||
up.Config = DriverConfiguration{ | ||
Title: "System", | ||
Description: "System Updates", | ||
Enabled: !config.Ci, | ||
DryRun: config.DryRun, | ||
} | ||
|
||
if up.Config.DryRun { | ||
return up, nil | ||
} | ||
|
||
binaryPath, exists := config.Environment["UUPD_RPMOSTREE_BINARY"] | ||
if !exists || binaryPath == "" { | ||
up.BinaryPath = "/usr/bin/rpm-ostree" | ||
} else { | ||
up.BinaryPath = binaryPath | ||
} | ||
|
||
return up, nil | ||
} | ||
|
||
func (up RpmOstreeUpdater) Check() (bool, error) { | ||
if up.Config.DryRun { | ||
return true, nil | ||
} | ||
|
||
return up.UpdateAvailable() | ||
} |
Oops, something went wrong.