use anyhow::anyhow;
use crate::action::{ControlFlow, State};
use crate::parser::BuiltinCommand;
pub async fn run_connect(
mut cmd: BuiltinCommand,
state: &mut State,
) -> Result<ControlFlow, anyhow::Error> {
let name = cmd.args.string("name")?;
let url = cmd.args.string("url")?;
let password = cmd.args.opt_string("password");
cmd.args.done()?;
let opts_url = mysql_async::Opts::from_url(&url)
.map_err(|_| anyhow!("Unable to parse MySQL URL {}", url))?;
let opts = mysql_async::OptsBuilder::from_opts(opts_url).pass(password.clone());
let pool = mysql_async::Pool::new(opts);
let conn = pool
.get_conn()
.await
.map_err(|_| anyhow!("Unable to connect to MySQL server at {}", url))?;
state.mysql_clients.insert(name.clone(), conn);
Ok(ControlFlow::Continue)
}