cubic 0.18.0

Cubic is a lightweight command line manager for virtual machines. It has a simple, daemon-less and rootless design. All Cubic virtual machines run isolated in the user context. Cubic is built on top of QEMU, KVM and cloud-init. https://cubic-vm.org https://github.com/cubic-vm/cubic Show all supported images: $ cubic images Create a new virtual machine instance: $ cubic create mymachine --image ubuntu:noble List all virtual machine instances: $ cubic instances Start an instance: $ cubic start <instance name> Stop an instance: $ cubic stop <instance name> Open a shell in the instance: $ cubic ssh <machine name> Copy a file from the host to the instance: $ cubic scp <path/to/host/file> <machine>:<path/to/guest/file> Copy a file from the instance to the hots: $ cubic scp <machine>:<path/to/guest/file> <path/to/host/file>
use crate::commands::{Command, image::fetch_image_info};
use crate::env::Environment;
use crate::error::Error;
use crate::image::{ImageName, ImageStore};
use crate::instance::InstanceStore;
use crate::view::{Console, MapView};
use clap::Parser;

/// Show image information
#[derive(Parser)]
pub struct ShowImageCommand {
    /// Name of the virtual machine image
    pub name: ImageName,
}

impl Command for ShowImageCommand {
    fn run(
        &self,
        console: &mut dyn Console,
        env: &Environment,
        _image_store: &dyn ImageStore,
        _instance_store: &dyn InstanceStore,
    ) -> Result<(), Error> {
        let image = fetch_image_info(env, &self.name)?;
        let mut view = MapView::new();
        view.add("Name", &image.get_image_names());
        view.add("Image URL", &image.image_url);
        view.add("Checksum URL", &image.checksum_url);
        view.print(console);
        Ok(())
    }
}