增加 Reporter 结构体,用于存储所有更新统计
Signed-off-by: Jia Chao <jiachao2130@126.com>
This commit is contained in:
parent
b3f2204a88
commit
adf2180d11
|
@ -12,7 +12,7 @@ clap = { version = "4.0", features = ["derive"] }
|
||||||
serde = { version = "1", features = ["serde_derive"] }
|
serde = { version = "1", features = ["serde_derive"] }
|
||||||
serde_json = { version = "1.0" }
|
serde_json = { version = "1.0" }
|
||||||
toml = { version = "0.8" }
|
toml = { version = "0.8" }
|
||||||
updateinfo-xmlparser = { git = "https://git.zhgsun.com:8089/jiachao2130/updateinfo-xmlparser.git", version = "0.1.0" }
|
updateinfo-xmlparser = { git = "https://git.zhgsun.com:8089/jiachao2130/updateinfo-xmlparser.git", version = "0.1.1" }
|
||||||
cvrf-xmlparser = { git = "https://git.zhgsun.com:8089/jiachao2130/cvrf-xmlparser.git", version = "0.1.0" }
|
cvrf-xmlparser = { git = "https://git.zhgsun.com:8089/jiachao2130/cvrf-xmlparser.git", version = "0.1.0" }
|
||||||
rpm-rs = { git = "https://git.zhgsun.com:8089/jiachao2130/rpm-rs.git", version = "0.1.0" }
|
rpm-rs = { git = "https://git.zhgsun.com:8089/jiachao2130/rpm-rs.git", version = "0.1.0" }
|
||||||
lazy_static = { version = "1.5" }
|
lazy_static = { version = "1.5" }
|
||||||
|
|
|
@ -30,6 +30,60 @@ lazy_static! {
|
||||||
|
|
||||||
pub mod db;
|
pub mod db;
|
||||||
|
|
||||||
|
struct Reporter {
|
||||||
|
// 已修复的安全更新
|
||||||
|
fixed: HashMap<CUSA, HashSet<RpmInfo>>,
|
||||||
|
|
||||||
|
// 可用的安全更新
|
||||||
|
avaliable: HashMap<CUSA, HashSet<RpmInfo>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Reporter {
|
||||||
|
// 新建一个空的 Reporter
|
||||||
|
pub fn new() -> Self {
|
||||||
|
let fixed = HashMap::new();
|
||||||
|
let avaliable = HashMap::new();
|
||||||
|
|
||||||
|
Self {
|
||||||
|
fixed, avaliable
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// get fixed, 不可写
|
||||||
|
pub fn get_fixed(&self) -> &HashMap<CUSA, HashSet<RpmInfo>> {
|
||||||
|
&self.fixed
|
||||||
|
}
|
||||||
|
|
||||||
|
// get avaliable, 只读
|
||||||
|
pub fn get_avaliable(&self) -> &HashMap<CUSA, HashSet<RpmInfo>> {
|
||||||
|
&self.avaliable
|
||||||
|
}
|
||||||
|
|
||||||
|
// 添加包到已修复
|
||||||
|
pub fn add_to_fixed(&mut self, cusa: &CUSA, rpm: RpmInfo) {
|
||||||
|
// 可以找到则直接 insert
|
||||||
|
if let Some(rpms) = self.fixed.get_mut(cusa) {
|
||||||
|
rpms.insert(rpm);
|
||||||
|
} else {
|
||||||
|
let mut rpms = HashSet::new();
|
||||||
|
rpms.insert(rpm);
|
||||||
|
self.fixed.insert(cusa.clone(), rpms);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 添加包到可用更新
|
||||||
|
pub fn add_to_avaliable(&mut self, cusa: &CUSA, rpm: RpmInfo) {
|
||||||
|
// 可以找到则直接 insert
|
||||||
|
if let Some(rpms) = self.avaliable.get_mut(cusa) {
|
||||||
|
rpms.insert(rpm);
|
||||||
|
} else {
|
||||||
|
let mut rpms = HashSet::new();
|
||||||
|
rpms.insert(rpm);
|
||||||
|
self.avaliable.insert(cusa.clone(), rpms);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn cuvat_run(cli: &Cli) -> crate::Result<()> {
|
pub fn cuvat_run(cli: &Cli) -> crate::Result<()> {
|
||||||
// 只报告 cve 相关
|
// 只报告 cve 相关
|
||||||
if cli.cves {
|
if cli.cves {
|
||||||
|
@ -51,7 +105,8 @@ pub fn cuvat_run(cli: &Cli) -> crate::Result<()> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn list_cves(cli: &Cli) -> crate::Result<()> {
|
fn list_cves(cli: &Cli) -> crate::Result<()> {
|
||||||
let avaliable = get_avaliable()?;
|
let reporter = _reporter()?;
|
||||||
|
let avaliable = reporter.get_avaliable();
|
||||||
let severity = Severity::from_str(&cli.severity)?;
|
let severity = Severity::from_str(&cli.severity)?;
|
||||||
let mut _cves = HashSet::new();
|
let mut _cves = HashSet::new();
|
||||||
cli.sources.iter().for_each(|id| { _cves.insert(id); });
|
cli.sources.iter().for_each(|id| { _cves.insert(id); });
|
||||||
|
@ -60,7 +115,7 @@ fn list_cves(cli: &Cli) -> crate::Result<()> {
|
||||||
let mut msg = String::new();
|
let mut msg = String::new();
|
||||||
|
|
||||||
// 仅针对可用更新
|
// 仅针对可用更新
|
||||||
for (cusa, _) in &avaliable {
|
for (cusa, _) in avaliable {
|
||||||
// 过滤
|
// 过滤
|
||||||
if cusa.severity() < &severity {
|
if cusa.severity() < &severity {
|
||||||
continue;
|
continue;
|
||||||
|
@ -92,7 +147,8 @@ fn list_cves(cli: &Cli) -> crate::Result<()> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn list_sas(cli: &Cli) -> crate::Result<()> {
|
fn list_sas(cli: &Cli) -> crate::Result<()> {
|
||||||
let avaliable = get_avaliable()?;
|
let reporter = _reporter()?;
|
||||||
|
let avaliable = reporter.get_avaliable();
|
||||||
let severity = Severity::from_str(&cli.severity)?;
|
let severity = Severity::from_str(&cli.severity)?;
|
||||||
let mut _sas = HashSet::new();
|
let mut _sas = HashSet::new();
|
||||||
cli.sources.iter().for_each(|id| { _sas.insert(id); });
|
cli.sources.iter().for_each(|id| { _sas.insert(id); });
|
||||||
|
@ -101,7 +157,7 @@ fn list_sas(cli: &Cli) -> crate::Result<()> {
|
||||||
let mut msg = String::new();
|
let mut msg = String::new();
|
||||||
|
|
||||||
// 仅针对可用更新
|
// 仅针对可用更新
|
||||||
for (cusa, _) in &avaliable {
|
for (cusa, _) in avaliable {
|
||||||
// 过滤
|
// 过滤
|
||||||
if cusa.severity() < &severity {
|
if cusa.severity() < &severity {
|
||||||
continue;
|
continue;
|
||||||
|
@ -130,20 +186,28 @@ fn list_sas(cli: &Cli) -> crate::Result<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 最为详尽的报告,包括当前系统中软件包所涉及到,已修复和可用但未修复
|
||||||
|
// 的所有软件包的列表。
|
||||||
fn repoter(cli: &Cli) -> crate::Result<()> {
|
fn repoter(cli: &Cli) -> crate::Result<()> {
|
||||||
|
let reporter = _reporter()?;
|
||||||
|
let fixed = reporter.get_fixed();
|
||||||
|
let avaliable = reporter.get_avaliable();
|
||||||
|
let _ = fixed;
|
||||||
|
let _ = avaliable;
|
||||||
println!("TODO...");
|
println!("TODO...");
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn summary(cli: &Cli) -> crate::Result<()> {
|
fn summary(cli: &Cli) -> crate::Result<()> {
|
||||||
let avaliable = get_avaliable()?;
|
let reporter = _reporter()?;
|
||||||
|
let avaliable = reporter.get_avaliable();
|
||||||
let severity = Severity::from_str(&cli.severity)?;
|
let severity = Severity::from_str(&cli.severity)?;
|
||||||
let mut total = 0;
|
let mut total = 0;
|
||||||
let mut res = vec![0; 5];
|
let mut res = vec![0; 5];
|
||||||
let mut lists = vec![vec![]; 5];
|
let mut lists = vec![vec![]; 5];
|
||||||
let mut msg = String::new();
|
let mut msg = String::new();
|
||||||
|
|
||||||
for (cusa, rpms) in &avaliable {
|
for (cusa, _) in avaliable {
|
||||||
// 过滤
|
// 过滤
|
||||||
if cusa.severity() < &severity {
|
if cusa.severity() < &severity {
|
||||||
continue;
|
continue;
|
||||||
|
@ -183,9 +247,8 @@ fn summary(cli: &Cli) -> crate::Result<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取当前可用的更新,所有安全检查均基于此
|
fn _reporter() -> crate::Result<Reporter> {
|
||||||
fn get_avaliable() -> crate::Result<HashMap<CUSA, Vec<RpmInfo>>> {
|
let mut reporter = Reporter::new();
|
||||||
let mut avaliable: HashMap<CUSA, Vec<RpmInfo>> = HashMap::new();
|
|
||||||
// 当前系统所有已安装的 rpm 包
|
// 当前系统所有已安装的 rpm 包
|
||||||
let installed = get_installed_packages();
|
let installed = get_installed_packages();
|
||||||
// installed 已被消费掉
|
// installed 已被消费掉
|
||||||
|
@ -211,34 +274,29 @@ fn get_avaliable() -> crate::Result<HashMap<CUSA, Vec<RpmInfo>>> {
|
||||||
if update.arch() != pkg.arch().unwrap() {
|
if update.arch() != pkg.arch().unwrap() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
let sainfo = sadb.db().get(update.sa()).unwrap();
|
||||||
// epoch 判断
|
// epoch 判断
|
||||||
match (update.epoch(), pkg.epoch()) {
|
match (update.epoch(), pkg.epoch()) {
|
||||||
(Some(_), None) => {
|
(Some(_), None) => {
|
||||||
_add_to_avaliable(&mut avaliable, update.sa(), update.clone());
|
reporter.add_to_avaliable(&sainfo, update.clone());
|
||||||
|
}
|
||||||
|
(None, Some(_)) => {
|
||||||
|
reporter.add_to_fixed(&sainfo, update.clone());
|
||||||
}
|
}
|
||||||
(None, Some(_)) => continue,
|
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
|
|
||||||
// evr 对比
|
// evr 对比
|
||||||
if rpmvercmp(&update.evr(), &pkg.evr()) > 0 {
|
if rpmvercmp(&update.evr(), &pkg.evr()) > 0 {
|
||||||
_add_to_avaliable(&mut avaliable, update.sa(), update.clone());
|
reporter.add_to_avaliable(&sainfo, update.clone());
|
||||||
|
} else {
|
||||||
|
reporter.add_to_fixed(&sainfo, update.clone());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(avaliable)
|
Ok(reporter)
|
||||||
}
|
|
||||||
|
|
||||||
fn _add_to_avaliable(avaliable: &mut HashMap<CUSA, Vec<RpmInfo>>, sa: &str, rpm: RpmInfo) {
|
|
||||||
let sainfo = sadb.db().get(sa).unwrap();
|
|
||||||
if let Some(rpms) = avaliable.get_mut(sainfo) {
|
|
||||||
rpms.push(rpm);
|
|
||||||
} else {
|
|
||||||
let rpms = vec![rpm];
|
|
||||||
avaliable.insert(sainfo.clone(), rpms);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 对比两个 rpm Package 的版本,返回最新的一个
|
// 对比两个 rpm Package 的版本,返回最新的一个
|
||||||
|
|
Loading…
Reference in New Issue
Block a user