mod barbfile; use jsonformat::{format_json, Indentation}; use barbfile::BarbFile; use clap::Parser; use std::collections::HashMap; use std::env; use std::fs; use std::str::FromStr; use ureq; struct Context { vars: HashMap, } impl Context { pub fn new() -> Context { Context { vars: HashMap::new(), } } pub fn get_var(&self, name: String) -> Option { self.vars .get(&name) .map(|val| val.clone()) .or_else(|| env::var(name).ok()) } pub fn execute(&self, bfile: BarbFile) -> Result { let req = ureq::request(bfile.method_as_string().as_str(), &bfile.url()); match bfile.method().takes_body() { true => match bfile.body() { Some(body) => req.send_string(body.as_str()), None => req.call(), }, false => req.call(), } .map_err(|_| String::from("Error")) } } #[derive(Parser, Debug)] #[clap(version)] struct Args { #[clap(short, long)] headers: bool, #[clap(short, long)] body: bool, #[clap(short, long)] raw: bool, files: Vec, } impl Args { pub fn print_headers(&self) -> bool { self.headers || !self.body } pub fn print_body(&self) -> bool { !self.headers || self.body } pub fn raw_body(&self) -> bool { self.raw } } fn main() { let args = Args::parse(); let context = Context::new(); let bfile = BarbFile::from_str( fs::read_to_string("test.barb") .expect("Failed to read file") .as_str(), ) .expect("Failed to parse file"); let response = context.execute(bfile).unwrap(); if args.print_headers() { println!("{} {}", response.status(), response.status_text()); for header_name in response.headers_names() { println!( "{}: {}", header_name, response.header(header_name.as_str()).unwrap() ); } } if args.print_body() { println!( "{}", match args.raw_body() { true => String::from(response.into_string().unwrap().as_str()), false => format_json( response.into_string().unwrap().as_str(), Indentation::Default ), } ); } }