Files
himalaya/src/jmap/identity/create.rs
T
Clément DOUIN 6ae09790aa chore: cargo fmt
2026-05-20 23:48:27 +02:00

70 lines
2.3 KiB
Rust

// This file is part of Himalaya, a CLI to manage emails.
//
// Copyright (C) 2022-2026 soywod <pimalaya.org@posteo.net>
//
// This program is free software: you can redistribute it and/or modify it under
// the terms of the GNU Affero General Public License as published by the Free
// Software Foundation, either version 3 of the License, or (at your option) any
// later version.
//
// This program is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
// details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
use anyhow::{Result, bail};
use clap::Parser;
use io_jmap::rfc8621::{identity::IdentityCreate, identity_set::JmapIdentitySetArgs};
use pimalaya_cli::printer::{Message, Printer};
use crate::jmap::{client::JmapClient, error::format_set_error};
/// Create a JMAP sender identity (Identity/set).
#[derive(Debug, Parser)]
pub struct JmapIdentityCreateCommand {
/// Display name for the sender.
pub name: String,
/// Email address for the sender.
pub email: String,
/// Plaintext signature to append to outgoing emails.
#[arg(long)]
pub text_signature: Option<String>,
/// HTML signature to append to outgoing emails.
#[arg(long)]
pub html_signature: Option<String>,
}
impl JmapIdentityCreateCommand {
pub fn execute(self, printer: &mut impl Printer, mut client: JmapClient) -> Result<()> {
let identity = IdentityCreate {
name: self.name.clone(),
email: self.email.clone(),
reply_to: None,
bcc: None,
text_signature: self.text_signature,
html_signature: self.html_signature,
};
let create_id = "new";
let mut args = JmapIdentitySetArgs::default();
args.create(create_id, identity);
let output = client.identity_set(args)?;
if let Some(err) = output.not_created.get(create_id) {
let mut msg = format!("Create identity for `{}` error", self.email);
msg.push_str(&format_set_error(err));
bail!(msg);
}
printer.out(Message::new("Identity successfully created"))
}
}