3 schema::password_reset_request::dsl::*,
4 source::password_reset_request::*,
7 use diesel::{dsl::*, result::Error, PgConnection, *};
8 use sha2::{Digest, Sha256};
10 impl Crud for PasswordResetRequest {
11 type Form = PasswordResetRequestForm;
13 fn read(conn: &PgConnection, password_reset_request_id: i32) -> Result<Self, Error> {
14 password_reset_request
15 .find(password_reset_request_id)
18 fn create(conn: &PgConnection, form: &PasswordResetRequestForm) -> Result<Self, Error> {
19 insert_into(password_reset_request)
21 .get_result::<Self>(conn)
25 password_reset_request_id: i32,
26 form: &PasswordResetRequestForm,
27 ) -> Result<Self, Error> {
28 diesel::update(password_reset_request.find(password_reset_request_id))
30 .get_result::<Self>(conn)
34 impl PasswordResetRequest {
37 from_local_user_id: LocalUserId,
39 ) -> Result<PasswordResetRequest, Error> {
40 let mut hasher = Sha256::new();
42 let token_hash: String = bytes_to_hex(hasher.finalize().to_vec());
44 let form = PasswordResetRequestForm {
45 local_user_id: from_local_user_id,
46 token_encrypted: token_hash,
49 Self::create(conn, &form)
51 pub fn read_from_token(conn: &PgConnection, token: &str) -> Result<PasswordResetRequest, Error> {
52 let mut hasher = Sha256::new();
54 let token_hash: String = bytes_to_hex(hasher.finalize().to_vec());
55 password_reset_request
56 .filter(token_encrypted.eq(token_hash))
57 .filter(published.gt(now - 1.days()))
62 fn bytes_to_hex(bytes: Vec<u8>) -> String {
63 let mut str = String::new();
65 str = format!("{}{:02x}", str, byte);
73 establish_unpooled_connection,
75 local_user::{LocalUser, LocalUserForm},
76 password_reset_request::PasswordResetRequest,
81 use serial_test::serial;
86 let conn = establish_unpooled_connection();
88 let new_person = PersonForm {
89 name: "thommy prw".into(),
90 ..PersonForm::default()
93 let inserted_person = Person::create(&conn, &new_person).unwrap();
95 let new_local_user = LocalUserForm {
96 person_id: inserted_person.id,
97 password_encrypted: "pass".to_string(),
98 ..LocalUserForm::default()
101 let inserted_local_user = LocalUser::create(&conn, &new_local_user).unwrap();
104 let token_encrypted_ = "ca3704aa0b06f5954c79ee837faa152d84d6b2d42838f0637a15eda8337dbdce";
106 let inserted_password_reset_request =
107 PasswordResetRequest::create_token(&conn, inserted_local_user.id, token).unwrap();
109 let expected_password_reset_request = PasswordResetRequest {
110 id: inserted_password_reset_request.id,
111 local_user_id: inserted_local_user.id,
112 token_encrypted: token_encrypted_.to_string(),
113 published: inserted_password_reset_request.published,
116 let read_password_reset_request = PasswordResetRequest::read_from_token(&conn, token).unwrap();
117 let num_deleted = Person::delete(&conn, inserted_person.id).unwrap();
119 assert_eq!(expected_password_reset_request, read_password_reset_request);
121 expected_password_reset_request,
122 inserted_password_reset_request
124 assert_eq!(1, num_deleted);