upgrade_verify

Crates.ioupgrade_verify
lib.rsupgrade_verify
version0.1.2
created_at2025-06-18 07:26:38.999637+00
updated_at2025-06-18 07:26:38.999637+00
descriptionupgrade_verify
homepagehttps://github.com/i18n-site/rust/tree/dev/upgrade_verify
repositoryhttps://github.com/i18n-site/rust.git
max_upload_size
id1716724
size32,771
i18n.site (i18nsite)

documentation

README

upgrade_verify

#![feature(doc_auto_cfg)]
#![feature(doc_cfg)]

use std::{
  env,
  fs::{self, File},
  io,
  io::{BufReader, Write},
  path::{Path, PathBuf},
};

use ed25519_dalek::{Signature, VerifyingKey};
use sha3::{Digest, Sha3_512};
use aok::Result;

pub fn check<P: AsRef<Path>>(
  version: impl AsRef<[u8]>,
  tar_path: P,
  pk: [u8; 32],
) -> Result<Option<PathBuf>> {
  let tar_path = tar_path.as_ref();
  let dir = env::temp_dir().join("upgradeVerify").join(
    tar_path
      .file_name()
      .map(|i| i.to_str())
      .unwrap_or(None)
      .unwrap_or("_"),
  );
  // 解压
  {
    if dir.exists() {
      fs::remove_dir_all(&dir)?;
    }
    fs::create_dir_all(&dir)?;

    let tar_file = File::open(tar_path)?;
    let mut archive = tar::Archive::new(tar_file);
    archive.unpack(&dir)?;
  }

  let tar_zst = dir.join("tar.zst");
  let sign = dir.join("sign");

  if !tar_zst.exists() || !sign.exists() {
    return Ok(None);
  }

  // 计算散列
  let file = File::open(tar_zst)?;
  let mut reader = BufReader::new(file);
  let mut hasher = Sha3_512::new();
  hasher.write_all(version.as_ref())?;
  io::copy(&mut reader, &mut hasher)?;
  let sign = fs::read(sign)?;
  if let Ok(sign) = sign.try_into() {
    let public_key = VerifyingKey::from_bytes(&pk)?;
    let sign = Signature::from_bytes(&sign);
    public_key.verify_prehashed(hasher, None, &sign)?;
    return Ok(Some(dir));
  }
  Ok(None)
}

About

This project is an open-source component of i18n.site ⋅ Internationalization Solution.

关于

本项目为 i18n.site ⋅ 国际化解决方案 的开源组件。

Commit count: 68

cargo fmt