You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							91 lines
						
					
					
						
							3.5 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							91 lines
						
					
					
						
							3.5 KiB
						
					
					
				| use super::User; | |
| use crate::db::schema::favorites; | |
| #[derive(Identifiable, Queryable, Insertable)] | |
| #[diesel(table_name = favorites)] | |
| #[diesel(primary_key(user_uuid, cipher_uuid))] | |
| pub struct Favorite { | |
|     pub user_uuid: String, | |
|     pub cipher_uuid: String, | |
| } | |
|  | |
| use crate::db::DbConn; | |
|  | |
| use crate::api::EmptyResult; | |
| use crate::error::MapResult; | |
|  | |
| impl Favorite { | |
|     // Returns whether the specified cipher is a favorite of the specified user. | |
|     pub async fn is_favorite(cipher_uuid: &str, user_uuid: &str, conn: &DbConn) -> bool { | |
|         db_run! { conn: { | |
|             let query = favorites::table | |
|                 .filter(favorites::cipher_uuid.eq(cipher_uuid)) | |
|                 .filter(favorites::user_uuid.eq(user_uuid)) | |
|                 .count(); | |
|  | |
|             query.first::<i64>(conn).ok().unwrap_or(0) != 0 | |
|         }} | |
|     } | |
|  | |
|     // Sets whether the specified cipher is a favorite of the specified user. | |
|     pub async fn set_favorite(favorite: bool, cipher_uuid: &str, user_uuid: &str, conn: &DbConn) -> EmptyResult { | |
|         let (old, new) = (Self::is_favorite(cipher_uuid, user_uuid, conn).await, favorite); | |
|         match (old, new) { | |
|             (false, true) => { | |
|                 User::update_uuid_revision(user_uuid, conn).await; | |
|                 db_run! { conn: { | |
|                 diesel::insert_into(favorites::table) | |
|                     .values(( | |
|                         favorites::user_uuid.eq(user_uuid), | |
|                         favorites::cipher_uuid.eq(cipher_uuid), | |
|                     )) | |
|                     .execute(conn) | |
|                     .map_res("Error adding favorite") | |
|                 }} | |
|             } | |
|             (true, false) => { | |
|                 User::update_uuid_revision(user_uuid, conn).await; | |
|                 db_run! { conn: { | |
|                     diesel::delete( | |
|                         favorites::table | |
|                             .filter(favorites::user_uuid.eq(user_uuid)) | |
|                             .filter(favorites::cipher_uuid.eq(cipher_uuid)) | |
|                     ) | |
|                     .execute(conn) | |
|                     .map_res("Error removing favorite") | |
|                 }} | |
|             } | |
|             // Otherwise, the favorite status is already what it should be. | |
|             _ => Ok(()), | |
|         } | |
|     } | |
|  | |
|     // Delete all favorite entries associated with the specified cipher. | |
|     pub async fn delete_all_by_cipher(cipher_uuid: &str, conn: &DbConn) -> EmptyResult { | |
|         db_run! { conn: { | |
|             diesel::delete(schema::favorites::table.filter(favorites::cipher_uuid.eq(cipher_uuid))) | |
|                 .execute(conn) | |
|                 .map_res("Error removing favorites by cipher") | |
|         }} | |
|     } | |
|  | |
|     // Delete all favorite entries associated with the specified user. | |
|     pub async fn delete_all_by_user(user_uuid: &str, conn: &DbConn) -> EmptyResult { | |
|         db_run! { conn: { | |
|             diesel::delete(schema::favorites::table.filter(favorites::user_uuid.eq(user_uuid))) | |
|                 .execute(conn) | |
|                 .map_res("Error removing favorites by user") | |
|         }} | |
|     } | |
|  | |
|     /// Return a vec with (cipher_uuid) this will only contain favorite flagged ciphers | |
|     /// This is used during a full sync so we only need one query for all favorite cipher matches. | |
|     pub async fn get_all_cipher_uuid_by_user(user_uuid: &str, conn: &DbConn) -> Vec<String> { | |
|         db_run! { conn: { | |
|             schema::favorites::table | |
|                 .filter(favorites::user_uuid.eq(user_uuid)) | |
|                 .select(favorites::cipher_uuid) | |
|                 .load::<String>(conn) | |
|                 .unwrap_or_default() | |
|         }} | |
|     } | |
| }
 | |
| 
 |