quartz_cli/action/
env.rs

1use core::panic;
2use std::process::ExitCode;
3
4use crate::{
5    cli::{EnvCmd as Cmd, HeaderCmd},
6    Ctx, Env, PairMap, QuartzResult, StateField,
7};
8use colored::Colorize;
9
10#[derive(clap::Args, Debug)]
11pub struct CreateArgs {
12    name: String,
13}
14
15#[derive(clap::Args, Debug)]
16pub struct CpArgs {
17    src: String,
18    dest: String,
19}
20
21#[derive(clap::Args, Debug)]
22pub struct SwitchArgs {
23    env: String,
24}
25
26#[derive(clap::Args, Debug)]
27pub struct RmArgs {
28    env: String,
29}
30
31pub fn cmd(ctx: &mut Ctx, command: Cmd) -> QuartzResult {
32    match command {
33        Cmd::Create(args) => create(ctx, args),
34        Cmd::Cp(args) => cp(ctx, args)?,
35        Cmd::Use(args) => switch(ctx, args)?,
36        Cmd::Ls => ls(ctx),
37        Cmd::Rm(args) => rm(ctx, args),
38        Cmd::Header { command } => match command {
39            HeaderCmd::Set { header } => header_set(ctx, header)?,
40            HeaderCmd::Ls => header_ls(ctx)?,
41            HeaderCmd::Rm { key } => header_rm(ctx, key)?,
42            HeaderCmd::Get { key } => header_get(ctx, key)?,
43        },
44    };
45
46    Ok(())
47}
48
49pub fn create(ctx: &Ctx, args: CreateArgs) {
50    let env = Env::new(&args.name);
51
52    if env.exists(ctx) {
53        panic!("a environment named {} already exists", args.name.red());
54    }
55
56    if env.write(ctx).is_err() {
57        panic!("failed to create {} environment", args.name);
58    }
59}
60
61pub fn cp(ctx: &Ctx, args: CpArgs) -> QuartzResult {
62    let src = Env::parse(ctx, &args.src).unwrap_or_else(|_| {
63        panic!("no {} environment found", &args.src);
64    });
65    let mut dest = Env::parse(ctx, &args.dest).unwrap_or(Env::new(&args.dest));
66
67    for (key, value) in src.variables.iter() {
68        dest.variables.insert(key.to_string(), value.to_string());
69    }
70
71    if dest.exists(ctx) {
72        dest.update(ctx)?;
73    } else {
74        dest.write(ctx)?;
75    }
76
77    Ok(())
78}
79
80pub fn switch(ctx: &mut Ctx, args: SwitchArgs) -> QuartzResult {
81    let env = Env::new(&args.env);
82
83    if !env.exists(ctx) {
84        println!("Environment {} doesn't exit", env.name.red());
85        if ctx.confirm("Do you wish to create it?") {
86            create(
87                ctx,
88                CreateArgs {
89                    name: env.name.clone(),
90                },
91            );
92        } else {
93            ctx.code(ExitCode::FAILURE);
94            return Ok(());
95        }
96    }
97
98    if let Ok(()) = StateField::Env.set(ctx, &env.name) {
99        println!("Switched to {} environment", env.name.green());
100    } else {
101        panic!("failed to switch to {} environment", env.name.red());
102    }
103
104    Ok(())
105}
106
107pub fn ls(ctx: &Ctx) {
108    if let Ok(entries) = std::fs::read_dir(ctx.path().join("env")) {
109        for entry in entries {
110            let bytes = entry.unwrap().file_name();
111            let env_name = bytes.to_str().unwrap();
112
113            let state = ctx
114                .state
115                .get(ctx, StateField::Env)
116                .unwrap_or(String::from("default"));
117
118            if state == env_name {
119                println!("* {}", env_name.green());
120            } else {
121                println!("  {}", env_name);
122            }
123        }
124    }
125}
126
127pub fn rm(ctx: &Ctx, args: RmArgs) {
128    let env = Env::new(&args.env);
129
130    if !env.exists(ctx) {
131        panic!("environment {} does not exist", env.name.red());
132    }
133
134    if std::fs::remove_dir_all(env.dir(ctx)).is_ok() {
135        println!("Deleted {} environment", env.name.green());
136    } else {
137        panic!("failed to delete {} environment", env.name.red());
138    }
139}
140
141pub fn print(ctx: &Ctx) {
142    println!(
143        "{}",
144        ctx.state
145            .get(ctx, StateField::Env)
146            .unwrap_or("default".into())
147    );
148}
149pub fn header_set(ctx: &Ctx, args: Vec<String>) -> QuartzResult {
150    let mut env = ctx.require_env();
151    for header in args {
152        env.headers.set(&header);
153    }
154    env.update(ctx)?;
155    Ok(())
156}
157pub fn header_ls(ctx: &Ctx) -> QuartzResult {
158    let env = ctx.require_env();
159    print!("{}", env.headers);
160    Ok(())
161}
162pub fn header_rm(ctx: &Ctx, keys: Vec<String>) -> QuartzResult {
163    for key in keys {
164        let mut env = ctx.require_env();
165        env.headers.remove(&key);
166        env.update(ctx)?;
167    }
168    Ok(())
169}
170pub fn header_get(ctx: &Ctx, key: String) -> QuartzResult {
171    let env = ctx.require_env();
172    let value = env
173        .headers
174        .get(&key)
175        .unwrap_or_else(|| panic!("no header named {key} found"));
176    println!("{value}");
177    Ok(())
178}