1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
use actix_web::{HttpResponse, ResponseError};
use derive_more::Display;
use serde::{Deserialize, Serialize};
use validator::Validate;

#[derive(Serialize, Deserialize, Debug, Clone, Validate)]
pub struct SignUpCustomerBody {
    pub language_code: Option<String>,
    pub menu: String,
    #[validate(email)]
    pub email: String,
    pub password: String,
    pub first_name: String,
    pub last_name: String,
    pub phone: Option<CustomerPhoneBody>,
    pub company: Option<String>,
    pub kind: Option<String>,
    pub activation_status: Option<String>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct CustomerPhoneBody {
    pub country_code: i32,
    pub number: String,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct SignUpCustomerResult {
    pub success: bool,
}

#[derive(Debug, Display)]
pub enum SignUpCustomerError {
    #[display(fmt = "invalid_object_id")]
    InvalidObjectId,
    #[display(fmt = "error_hashing_password")]
    HashPassword,
    #[display(fmt = "email_already_exists")]
    EmailExists,
    Default(String),
}

impl ResponseError for SignUpCustomerError {
    fn error_response(&self) -> HttpResponse {
        match self {
            SignUpCustomerError::InvalidObjectId => {
                HttpResponse::NotAcceptable().body("invalid_object_id")
            }
            SignUpCustomerError::HashPassword => {
                HttpResponse::InternalServerError().body("error_hashing_password")
            }
            SignUpCustomerError::EmailExists => HttpResponse::Conflict().body("email_already_exists"),
            SignUpCustomerError::Default(error) => HttpResponse::BadRequest().body(error),
        }
    }
}