|  |  | @ -415,6 +415,32 @@ fn post_attachment(uuid: String, data: Data, content_type: &ContentType, headers | 
			
		
	
		
			
				
					|  |  |  |     Ok(Json(cipher.to_json(&headers.host, &headers.user.uuid, &conn))) | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | #[post("/ciphers/<uuid>/attachment-admin", format = "multipart/form-data", data = "<data>")] | 
			
		
	
		
			
				
					|  |  |  | fn post_attachment_admin(uuid: String, data: Data, content_type: &ContentType, headers: Headers, conn: DbConn) -> JsonResult { | 
			
		
	
		
			
				
					|  |  |  |     post_attachment(uuid, data, content_type, headers, conn) | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | #[post("/ciphers/<uuid>/attachment/<attachment_id>/share", format = "multipart/form-data", data = "<data>")] | 
			
		
	
		
			
				
					|  |  |  | fn post_attachment_share(uuid: String, attachment_id: String, data: Data, content_type: &ContentType, headers: Headers, conn: DbConn) -> JsonResult { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	let cipher = match Cipher::find_by_uuid(&uuid, &conn) { | 
			
		
	
		
			
				
					|  |  |  |         Some(cipher) => cipher, | 
			
		
	
		
			
				
					|  |  |  |         None => err!("Cipher doesn't exist") | 
			
		
	
		
			
				
					|  |  |  |     }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     if !cipher.is_write_accessible_to_user(&headers.user.uuid, &conn) { | 
			
		
	
		
			
				
					|  |  |  |         err!("Cipher is not write accessible") | 
			
		
	
		
			
				
					|  |  |  |     }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     try!(_delete_cipher_attachment_by_uuid(&uuid, &attachment_id, &conn)); | 
			
		
	
		
			
				
					|  |  |  |     post_attachment(uuid, data, content_type, headers, conn) | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | #[post("/ciphers/<uuid>/attachment/<attachment_id>/delete-admin")] | 
			
		
	
		
			
				
					|  |  |  | fn delete_attachment_post_admin(uuid: String, attachment_id: String, headers: Headers, conn: DbConn) -> EmptyResult { | 
			
		
	
		
			
				
					|  |  |  |     delete_attachment(uuid, attachment_id, headers, conn) | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | #[post("/ciphers/<uuid>/attachment/<attachment_id>/delete")] | 
			
		
	
		
			
				
					|  |  |  | fn delete_attachment_post(uuid: String, attachment_id: String, headers: Headers, conn: DbConn) -> EmptyResult { | 
			
		
	
		
			
				
					|  |  |  |     delete_attachment(uuid, attachment_id, headers, conn) | 
			
		
	
	
		
			
				
					|  |  | @ -578,3 +604,20 @@ fn _delete_cipher_by_uuid(uuid: &str, headers: &Headers, conn: &DbConn) -> Empty | 
			
		
	
		
			
				
					|  |  |  |         Err(_) => err!("Failed deleting cipher") | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | fn _delete_cipher_attachment_by_uuid(uuid: &str, attachment_id: &str, conn: &DbConn) -> EmptyResult { | 
			
		
	
		
			
				
					|  |  |  |     let attachment = match Attachment::find_by_id(&attachment_id, &conn) { | 
			
		
	
		
			
				
					|  |  |  |         Some(attachment) => attachment, | 
			
		
	
		
			
				
					|  |  |  |         None => err!("Attachment doesn't exist") | 
			
		
	
		
			
				
					|  |  |  |     }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     if attachment.cipher_uuid != uuid { | 
			
		
	
		
			
				
					|  |  |  |         err!("Attachment from other cipher") | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     // Delete attachment
 | 
			
		
	
		
			
				
					|  |  |  |     match attachment.delete(&conn) { | 
			
		
	
		
			
				
					|  |  |  |         Ok(()) => Ok(()), | 
			
		
	
		
			
				
					|  |  |  |         Err(_) => err!("Deleting attachement failed") | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
	
		
			
				
					|  |  | 
 |