mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Change text/plain API responses to application/json
				
					
				
			Recent versions of the Bitwarden clients (see bitwarden/clients#3574) won't parse non-JSON responses. The most noticeable consequence is that `/api/accounts/revision-date` responses won't be parsed, leading to `/api/sync` always being called, even when it's not necessary.
This commit is contained in:
		
				
					committed by
					
						 Daniel García
						Daniel García
					
				
			
			
				
	
			
			
			
						parent
						
							1198c36a2b
						
					
				
				
					commit
					1c8749eb4d
				
			| @@ -660,9 +660,9 @@ async fn delete_account(data: JsonUpcase<PasswordData>, headers: Headers, mut co | ||||
| } | ||||
|  | ||||
| #[get("/accounts/revision-date")] | ||||
| fn revision_date(headers: Headers) -> String { | ||||
| fn revision_date(headers: Headers) -> JsonResult { | ||||
|     let revision_date = headers.user.updated_at.timestamp_millis(); | ||||
|     revision_date.to_string() | ||||
|     Ok(Json(json!(revision_date))) | ||||
| } | ||||
|  | ||||
| #[derive(Deserialize)] | ||||
| @@ -792,14 +792,11 @@ async fn rotate_api_key(data: JsonUpcase<SecretVerificationRequest>, headers: He | ||||
| } | ||||
|  | ||||
| #[get("/devices/knowndevice/<email>/<uuid>")] | ||||
| async fn get_known_device(email: String, uuid: String, mut conn: DbConn) -> String { | ||||
| async fn get_known_device(email: String, uuid: String, mut conn: DbConn) -> JsonResult { | ||||
|     // This endpoint doesn't have auth header | ||||
|     let mut result = false; | ||||
|     if let Some(user) = User::find_by_mail(&email, &mut conn).await { | ||||
|         match Device::find_by_uuid_and_user(&uuid, &user.uuid, &mut conn).await { | ||||
|             Some(_) => String::from("true"), | ||||
|             _ => String::from("false"), | ||||
|         } | ||||
|     } else { | ||||
|         String::from("false") | ||||
|         result = Device::find_by_uuid_and_user(&uuid, &user.uuid, &mut conn).await.is_some(); | ||||
|     } | ||||
|     Ok(Json(json!(result))) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user