mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Device::save() should return QueryResult instead of bool
This commit is contained in:
		| @@ -46,16 +46,17 @@ fn _refresh_login(data: &ConnectData, _device_type: DeviceType, conn: DbConn) -> | ||||
|     let orgs = UserOrganization::find_by_user(&user.uuid, &conn); | ||||
|  | ||||
|     let (access_token, expires_in) = device.refresh_tokens(&user, orgs); | ||||
|     device.save(&conn); | ||||
|  | ||||
|     Ok(Json(json!({ | ||||
|     match device.save(&conn) { | ||||
|             Ok(()) => Ok(Json(json!({ | ||||
|                           "access_token": access_token, | ||||
|                           "expires_in": expires_in, | ||||
|                           "token_type": "Bearer", | ||||
|                           "refresh_token": device.refresh_token, | ||||
|                           "Key": user.key, | ||||
|                           "PrivateKey": user.private_key, | ||||
|     }))) | ||||
|                       }))), | ||||
|             Err(_) => err!("Failed to add device to user") | ||||
|     } | ||||
| } | ||||
|  | ||||
| fn _password_login(data: &ConnectData, device_type: DeviceType, conn: DbConn, remote: Option<SocketAddr>) -> JsonResult { | ||||
| @@ -128,7 +129,9 @@ fn _password_login(data: &ConnectData, device_type: DeviceType, conn: DbConn, re | ||||
|     let orgs = UserOrganization::find_by_user(&user.uuid, &conn); | ||||
|  | ||||
|     let (access_token, expires_in) = device.refresh_tokens(&user, orgs); | ||||
|     device.save(&conn); | ||||
|     if device.save(&conn).is_err() { | ||||
|         err!("Failed to add device to user") | ||||
|     } | ||||
|  | ||||
|     let mut result = json!({ | ||||
|         "access_token": access_token, | ||||
|   | ||||
| @@ -112,15 +112,11 @@ use db::schema::devices; | ||||
|  | ||||
| /// Database methods | ||||
| impl Device { | ||||
|     pub fn save(&mut self, conn: &DbConn) -> bool { | ||||
|     pub fn save(&mut self, conn: &DbConn) -> QueryResult<()> { | ||||
|         self.updated_at = Utc::now().naive_utc(); | ||||
|  | ||||
|         match diesel::replace_into(devices::table) | ||||
|             .values(&*self) | ||||
|             .execute(&**conn) { | ||||
|             Ok(1) => true, // One row inserted | ||||
|             _ => false, | ||||
|         } | ||||
|         diesel::replace_into(devices::table) | ||||
|             .values(&*self).execute(&**conn).and(Ok(())) | ||||
|     } | ||||
|  | ||||
|     pub fn delete(self, conn: &DbConn) -> QueryResult<()> { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user