oxen-cli 0.48.1

Oxen is a fast, unstructured data version control, to help version large machine learning datasets written in Rust.
use async_trait::async_trait;
use clap::{Arg, Command};
use liboxen::error::OxenError;
use liboxen::model::LocalRepository;
use liboxen::opts::fetch_opts::FetchOpts;
use liboxen::repositories;

use crate::helpers::{
    check_remote_version_blocking, check_repo_migration_needed, get_scheme_and_host_from_repo,
};

use crate::cmd::RunCmd;
pub const NAME: &str = "fetch";
pub struct FetchCmd;

#[async_trait]
impl RunCmd for FetchCmd {
    fn name(&self) -> &str {
        NAME
    }

    fn args(&self) -> Command {
        Command::new(NAME)
            .about("Download objects and refs from the remote repository")
            .arg(
                Arg::new("branch")
                    .short('b')
                    .long("branch")
                    .help("Specify the branch to fetch")
                    .value_name("BRANCH"),
            )
            .arg(
                Arg::new("all")
                    .long("all")
                    .help("This fetches the full commit history, all the data files, and all the commit databases. Useful if you want to have the entire history locally or push to a new remote.")
                    .action(clap::ArgAction::SetTrue),
            )
            .arg(
                Arg::new("missing-files")
                    .long("missing-files")
                    .help("Re-download any version files that are missing locally (useful after fsck --clean or a failed fetch)")
                    .action(clap::ArgAction::SetTrue),
            )
    }

    async fn run(&self, args: &clap::ArgMatches) -> Result<(), OxenError> {
        let repository = LocalRepository::from_current_dir()?;
        let (scheme, host) = get_scheme_and_host_from_repo(&repository)?;

        check_repo_migration_needed(&repository)?;
        check_remote_version_blocking(scheme.clone(), host.clone()).await?;
        let mut fetch_opts = FetchOpts::new();
        let subtrees = repository.subtree_paths();
        fetch_opts.subtree_paths = subtrees;
        fetch_opts.all = args.get_flag("all");
        fetch_opts.missing_files = args.get_flag("missing-files");
        if let Some(branch) = args.get_one::<String>("branch") {
            fetch_opts.branch = branch.clone();
            repositories::fetch_branch(&repository, &fetch_opts).await?;
        } else {
            repositories::fetch_all(&repository, &fetch_opts).await?;
        }

        Ok(())
    }
}