jira-terminal 2.5.0

This is a command line application that can be used as a personal productivity tool for interacting with JIRA
use crate::config;
use crate::jira::api;

fn get_object_by_name(list: &json::JsonValue, name: String) -> Option<json::JsonValue> {
    for member in list.members() {
        if member["name"]
            .as_str()
            .unwrap_or("")
            .to_string()
            .to_lowercase()
            == name.to_lowercase()
        {
            return Some(member.to_owned());
        }
    }
    None
}

fn get_object_lists_from_value(list: &json::JsonValue, value: String) -> Vec<json::JsonValue> {
    let mut selected_entries: Vec<json::JsonValue> = vec![];
    for name in value.split(',') {
        let object = get_object_by_name(list, config::get_alias_or(name.to_string()));
        if let Some(entry) = object {
            selected_entries.push(entry);
        }
    }
    selected_entries
}

pub fn update_jira_ticket(ticket: String, key: String, entry: String) {
    let value = config::get_alias_or(entry);
    let update_key = config::get_alias_or(key);
    let fields_response = api::get_call_v2(format!("issue/{ticket}/editmeta"));
    if fields_response.is_err() {
        eprintln!("Error occurred while updating the ticket.");
        std::process::exit(1);
    }
    let fields = &fields_response.unwrap()["fields"][update_key.clone()];
    let mut update_json = json::object! {};
    if fields.is_null() {
        eprintln!("Cannot fetch fields");
        std::process::exit(1);
    }
    if !fields["autoCompleteUrl"].is_null() {
        eprintln!("Cannot update provided key.");
        std::process::exit(1);
    }
    if update_key == "comment" || update_key == "assignee" {
        eprintln!("Comment and assignee has their own section. Please check help for details.");
        std::process::exit(1);
    }

    if fields["allowedValues"].is_array() {
        if fields["schema"]["type"] == "array" {
            let update_json_value = get_object_lists_from_value(&fields["allowedValues"], value);
            update_json[update_key] = update_json_value.into();
        } else if fields["schema"]["type"] == "option" {
            let custom = json::object! {"value": value };
            update_json[update_key] = custom;
        } else {
            let update_json_value = get_object_by_name(&fields["allowedValues"], value);
            update_json[update_key] = update_json_value.into();
        }
    } else if fields["schema"]["type"] == "array" {
        let values: Vec<&str> = value.split(',').collect();
        update_json[update_key] = values.into();
    } else if fields["schema"]["type"] == "number" {
        match value.parse::<f64>() {
            Ok(number) => update_json[update_key] = number.into(),
            Err(_) => {
                eprintln!("Cannot parse value as a number.");
                std::process::exit(1);
            }
        }
    } else {
        update_json[update_key] = value.into();
    }

    let payload = json::object! {
        "fields": update_json
    };
    let update_response = api::put_call(format!("issue/{ticket}"), payload, 3);
    if update_response.is_err() {
        eprintln!("Error occurred while updating the ticket");
        std::process::exit(1);
    }
    let response = update_response.unwrap();
    println!("Successfully Updated {response}");
}