2022-11-23 10:06:23 -03:00
|
|
|
use crate::command::CommandExt;
|
2023-05-25 15:09:23 +08:00
|
|
|
use crate::execution_context::ExecutionContext;
|
2019-06-25 22:47:36 -07:00
|
|
|
use crate::terminal::print_separator;
|
2024-10-03 12:47:35 +02:00
|
|
|
use crate::utils::{get_require_sudo_string, require_option};
|
2023-10-07 17:13:26 -07:00
|
|
|
use crate::Step;
|
2022-11-11 09:39:29 -05:00
|
|
|
use color_eyre::eyre::Result;
|
2019-06-25 22:47:36 -07:00
|
|
|
use std::process::Command;
|
|
|
|
|
|
2023-05-25 15:09:23 +08:00
|
|
|
pub fn upgrade_packages(ctx: &ExecutionContext) -> Result<()> {
|
2024-10-03 12:47:35 +02:00
|
|
|
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
|
|
|
|
|
print_separator(t!("DragonFly BSD Packages"));
|
2023-10-07 17:13:26 -07:00
|
|
|
let mut cmd = ctx.run_type().execute(sudo);
|
2023-07-25 08:37:03 +08:00
|
|
|
cmd.args(["/usr/local/sbin/pkg", "upgrade"]);
|
|
|
|
|
if ctx.config().yes(Step::System) {
|
|
|
|
|
cmd.arg("-y");
|
|
|
|
|
}
|
|
|
|
|
cmd.status_checked()
|
2019-06-25 22:47:36 -07:00
|
|
|
}
|
|
|
|
|
|
2023-06-03 04:20:42 +08:00
|
|
|
pub fn audit_packages(ctx: &ExecutionContext) -> Result<()> {
|
2024-10-03 12:47:35 +02:00
|
|
|
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
|
2024-01-07 18:40:01 -07:00
|
|
|
|
2024-10-03 12:47:35 +02:00
|
|
|
print_separator(t!("DragonFly BSD Audit"));
|
2024-01-07 18:40:01 -07:00
|
|
|
|
2023-10-07 17:13:26 -07:00
|
|
|
#[allow(clippy::disallowed_methods)]
|
|
|
|
|
if !Command::new(sudo)
|
2023-06-13 22:15:57 +08:00
|
|
|
.args(["/usr/local/sbin/pkg", "audit", "-Fr"])
|
2023-10-07 17:13:26 -07:00
|
|
|
.status()?
|
|
|
|
|
.success()
|
|
|
|
|
{
|
2024-10-03 12:47:35 +02:00
|
|
|
println!(t!(
|
|
|
|
|
"The package audit was successful, but vulnerable packages still remain on the system"
|
|
|
|
|
));
|
2023-10-07 17:13:26 -07:00
|
|
|
}
|
2019-06-25 22:47:36 -07:00
|
|
|
Ok(())
|
|
|
|
|
}
|