* FIX: Allow for -beta OR -current detection and use the correct system upgrade command for the OpenBSD step * FIX: Run fmt, clippy, and test
67 lines
1.8 KiB
Rust
67 lines
1.8 KiB
Rust
use crate::command::CommandExt;
|
|
use crate::execution_context::ExecutionContext;
|
|
use crate::terminal::print_separator;
|
|
use crate::utils::{get_require_sudo_string, require_option};
|
|
use color_eyre::eyre::Result;
|
|
use rust_i18n::t;
|
|
use std::fs;
|
|
|
|
fn is_openbsd_current(ctx: &ExecutionContext) -> Result<bool> {
|
|
let motd_content = fs::read_to_string("/etc/motd")?;
|
|
let is_current = ["-current", "-beta"].iter().any(|&s| motd_content.contains(s));
|
|
if ctx.config().dry_run() {
|
|
println!("{}", t!("Would check if OpenBSD is -current"));
|
|
Ok(is_current)
|
|
} else {
|
|
Ok(is_current)
|
|
}
|
|
}
|
|
|
|
pub fn upgrade_openbsd(ctx: &ExecutionContext) -> Result<()> {
|
|
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
|
|
print_separator(t!("OpenBSD Update"));
|
|
|
|
let is_current = is_openbsd_current(ctx)?;
|
|
|
|
if ctx.config().dry_run() {
|
|
println!("{}", t!("Would upgrade the OpenBSD system"));
|
|
return Ok(());
|
|
}
|
|
|
|
let args = if is_current {
|
|
vec!["/usr/sbin/sysupgrade", "-sn"]
|
|
} else {
|
|
vec!["/usr/sbin/syspatch"]
|
|
};
|
|
|
|
ctx.run_type().execute(sudo).args(&args).status_checked()
|
|
}
|
|
|
|
pub fn upgrade_packages(ctx: &ExecutionContext) -> Result<()> {
|
|
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
|
|
print_separator(t!("OpenBSD Packages"));
|
|
|
|
let is_current = is_openbsd_current(ctx)?;
|
|
|
|
if ctx.config().dry_run() {
|
|
println!("{}", t!("Would upgrade OpenBSD packages"));
|
|
return Ok(());
|
|
}
|
|
|
|
if ctx.config().cleanup() {
|
|
ctx.run_type()
|
|
.execute(sudo)
|
|
.args(["/usr/sbin/pkg_delete", "-ac"])
|
|
.status_checked()?;
|
|
}
|
|
|
|
let mut args = vec!["/usr/sbin/pkg_add", "-u"];
|
|
if is_current {
|
|
args.push("-Dsnap");
|
|
}
|
|
|
|
ctx.run_type().execute(sudo).args(&args).status_checked()?;
|
|
|
|
Ok(())
|
|
}
|