mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-03-30 12:11:56 +00:00
* bugfixes * update fe types * implement new registry types in marketplace and ui * fix marketplace types to have default params * add alt implementation toggle * merge cleanup * more cleanup and notes * fix build * cleanup sync with next/minor * add exver JS parser * parse ValidExVer to string * update types to interface * add VersionRange and comparative functions * Parse ExtendedVersion from string * add conjunction, disjunction, and inversion logic * consider flavor in satisfiedBy fn * consider prerelease for ordering * add compare fn for sorting * rename fns for consistency * refactoring * update compare fn to return null if flavors don't match * begin simplifying dependencies * under construction * wip * add dependency metadata to CurrentDependencyInfo * ditch inheritance for recursive VersionRange constructor. Recursive 'satisfiedBy' fn wip * preprocess manifest * misc fixes * use sdk version as osVersion in manifest * chore: Change the type to just validate and not generate all solutions. * add publishedAt * fix pegjs exports * integrate exver into sdk * misc fixes * complete satisfiedBy fn * refactor - use greaterThanOrEqual and lessThanOrEqual fns * fix tests * update dependency details * update types * remove interim types * rename alt implementation to flavor * cleanup os update * format exver.ts * add s9pk parsing endpoints * fix build * update to exver * exver and bug fixes * update static endpoints + cleanup * cleanup * update static proxy verification * make mocks more robust; fix dep icon fallback; cleanup * refactor alert versions and update fixtures * registry bugfixes * misc fixes * cleanup unused * convert patchdb ui seed to camelCase * update otherVersions type * change otherVersions: null to 'none' * refactor and complete feature * improve static endpoints * fix install params * mask systemd-networkd-wait-online * fix static file fetching * include non-matching versions in otherVersions * convert release notes to modal and clean up displayExver * alert for no other versions * Fix ack-instructions casing * fix indeterminate loader on service install --------- Co-authored-by: Aiden McClelland <me@drbonez.dev> Co-authored-by: Shadowy Super Coder <musashidisciple@proton.me> Co-authored-by: Aiden McClelland <3732071+dr-bonez@users.noreply.github.com> Co-authored-by: J H <dragondef@gmail.com> Co-authored-by: Matt Hill <mattnine@protonmail.com>
65 lines
2.1 KiB
Rust
65 lines
2.1 KiB
Rust
use std::path::Path;
|
|
|
|
use clap::Parser;
|
|
use rpc_toolkit::{from_fn_async, Context, ParentHandler};
|
|
use serde::{Deserialize, Serialize};
|
|
use url::Url;
|
|
|
|
use crate::context::CliContext;
|
|
use crate::prelude::*;
|
|
use crate::s9pk::merkle_archive::source::http::HttpSource;
|
|
use crate::s9pk::merkle_archive::source::multi_cursor_file::MultiCursorFile;
|
|
use crate::s9pk::merkle_archive::source::ArchiveSource;
|
|
use crate::util::io::{open_file, ParallelBlake3Writer};
|
|
use crate::util::serde::Base16;
|
|
use crate::util::{Apply, PathOrUrl};
|
|
use crate::CAP_10_MiB;
|
|
|
|
pub fn util<C: Context>() -> ParentHandler<C> {
|
|
ParentHandler::new().subcommand("b3sum", from_fn_async(b3sum))
|
|
}
|
|
|
|
#[derive(Debug, Deserialize, Serialize, Parser)]
|
|
pub struct B3sumParams {
|
|
#[arg(long = "no-mmap", action = clap::ArgAction::SetFalse)]
|
|
allow_mmap: bool,
|
|
file: String,
|
|
}
|
|
|
|
pub async fn b3sum(
|
|
ctx: CliContext,
|
|
B3sumParams { file, allow_mmap }: B3sumParams,
|
|
) -> Result<Base16<[u8; 32]>, Error> {
|
|
async fn b3sum_source<S: ArchiveSource>(source: S) -> Result<Base16<[u8; 32]>, Error> {
|
|
let mut hasher = ParallelBlake3Writer::new(CAP_10_MiB);
|
|
source.copy_all_to(&mut hasher).await?;
|
|
hasher.finalize().await.map(|h| *h.as_bytes()).map(Base16)
|
|
}
|
|
async fn b3sum_file(
|
|
path: impl AsRef<Path>,
|
|
allow_mmap: bool,
|
|
) -> Result<Base16<[u8; 32]>, Error> {
|
|
let file = MultiCursorFile::from(open_file(path).await?);
|
|
if allow_mmap {
|
|
return file.blake3_mmap().await.map(|h| *h.as_bytes()).map(Base16);
|
|
}
|
|
b3sum_source(file).await
|
|
}
|
|
match file.parse::<PathOrUrl>()? {
|
|
PathOrUrl::Path(path) => b3sum_file(path, allow_mmap).await,
|
|
PathOrUrl::Url(url) => {
|
|
if url.scheme() == "http" || url.scheme() == "https" {
|
|
HttpSource::new(ctx.client.clone(), url)
|
|
.await?
|
|
.apply(b3sum_source)
|
|
.await
|
|
} else {
|
|
Err(Error::new(
|
|
eyre!("unknown scheme: {}", url.scheme()),
|
|
ErrorKind::InvalidRequest,
|
|
))
|
|
}
|
|
}
|
|
}
|
|
}
|