summaryrefslogtreecommitdiffstats
path: root/src/command/register.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/command/register.rs')
-rw-r--r--src/command/register.rs31
1 files changed, 4 insertions, 27 deletions
diff --git a/src/command/register.rs b/src/command/register.rs
index 1126645a..acf9b1a3 100644
--- a/src/command/register.rs
+++ b/src/command/register.rs
@@ -1,10 +1,10 @@
-use std::collections::HashMap;
use std::fs::File;
use std::io::prelude::*;
-use eyre::{eyre, Result};
+use eyre::Result;
use structopt::StructOpt;
+use atuin_client::api_client;
use atuin_client::settings::Settings;
#[derive(StructOpt)]
@@ -21,34 +21,11 @@ pub struct Cmd {
}
pub fn run(settings: &Settings, username: &str, email: &str, password: &str) -> Result<()> {
- let mut map = HashMap::new();
- map.insert("username", username);
- map.insert("email", email);
- map.insert("password", password);
-
- let url = format!("{}/user/{}", settings.sync_address, username);
- let resp = reqwest::blocking::get(url)?;
-
- if resp.status().is_success() {
- println!("Username is already in use! Please try another.");
- return Ok(());
- }
-
- let url = format!("{}/register", settings.sync_address);
- let client = reqwest::blocking::Client::new();
- let resp = client.post(url).json(&map).send()?;
-
- if !resp.status().is_success() {
- println!("Failed to register user - please check your details and try again");
- return Err(eyre!("failed to register user"));
- }
-
- let session = resp.json::<HashMap<String, String>>()?;
- let session = session["session"].clone();
+ let session = api_client::register(settings.sync_address.as_str(), username, email, password)?;
let path = settings.session_path.as_str();
let mut file = File::create(path)?;
- file.write_all(session.as_bytes())?;
+ file.write_all(session.session.as_bytes())?;
Ok(())
}