|
|
@ -1189,16 +1189,17 @@ async fn post_auth_request(
|
|
|
|
})))
|
|
|
|
})))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[get("/auth-requests/<uuid>")]
|
|
|
|
#[get("/auth-requests/<auth_request_id>")]
|
|
|
|
async fn get_auth_request(uuid: &str, headers: Headers, mut conn: DbConn) -> JsonResult {
|
|
|
|
async fn get_auth_request(auth_request_id: AuthRequestId, headers: Headers, mut conn: DbConn) -> JsonResult {
|
|
|
|
let Some(auth_request) = AuthRequest::find_by_uuid_and_user(uuid, &headers.user.uuid, &mut conn).await else {
|
|
|
|
let Some(auth_request) = AuthRequest::find_by_uuid_and_user(&auth_request_id, &headers.user.uuid, &mut conn).await
|
|
|
|
|
|
|
|
else {
|
|
|
|
err!("AuthRequest doesn't exist", "Record not found or user uuid does not match")
|
|
|
|
err!("AuthRequest doesn't exist", "Record not found or user uuid does not match")
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
let response_date_utc = auth_request.response_date.map(|response_date| format_date(&response_date));
|
|
|
|
let response_date_utc = auth_request.response_date.map(|response_date| format_date(&response_date));
|
|
|
|
|
|
|
|
|
|
|
|
Ok(Json(json!({
|
|
|
|
Ok(Json(json!({
|
|
|
|
"id": uuid,
|
|
|
|
"id": &auth_request_id,
|
|
|
|
"publicKey": auth_request.public_key,
|
|
|
|
"publicKey": auth_request.public_key,
|
|
|
|
"requestDeviceType": DeviceType::from_i32(auth_request.device_type).to_string(),
|
|
|
|
"requestDeviceType": DeviceType::from_i32(auth_request.device_type).to_string(),
|
|
|
|
"requestIpAddress": auth_request.request_ip,
|
|
|
|
"requestIpAddress": auth_request.request_ip,
|
|
|
@ -1221,9 +1222,9 @@ struct AuthResponseRequest {
|
|
|
|
request_approved: bool,
|
|
|
|
request_approved: bool,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[put("/auth-requests/<uuid>", data = "<data>")]
|
|
|
|
#[put("/auth-requests/<auth_request_id>", data = "<data>")]
|
|
|
|
async fn put_auth_request(
|
|
|
|
async fn put_auth_request(
|
|
|
|
uuid: &str,
|
|
|
|
auth_request_id: AuthRequestId,
|
|
|
|
data: Json<AuthResponseRequest>,
|
|
|
|
data: Json<AuthResponseRequest>,
|
|
|
|
headers: Headers,
|
|
|
|
headers: Headers,
|
|
|
|
mut conn: DbConn,
|
|
|
|
mut conn: DbConn,
|
|
|
@ -1231,7 +1232,9 @@ async fn put_auth_request(
|
|
|
|
nt: Notify<'_>,
|
|
|
|
nt: Notify<'_>,
|
|
|
|
) -> JsonResult {
|
|
|
|
) -> JsonResult {
|
|
|
|
let data = data.into_inner();
|
|
|
|
let data = data.into_inner();
|
|
|
|
let Some(mut auth_request) = AuthRequest::find_by_uuid_and_user(uuid, &headers.user.uuid, &mut conn).await else {
|
|
|
|
let Some(mut auth_request) =
|
|
|
|
|
|
|
|
AuthRequest::find_by_uuid_and_user(&auth_request_id, &headers.user.uuid, &mut conn).await
|
|
|
|
|
|
|
|
else {
|
|
|
|
err!("AuthRequest doesn't exist", "Record not found or user uuid does not match")
|
|
|
|
err!("AuthRequest doesn't exist", "Record not found or user uuid does not match")
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
@ -1258,7 +1261,7 @@ async fn put_auth_request(
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Ok(Json(json!({
|
|
|
|
Ok(Json(json!({
|
|
|
|
"id": uuid,
|
|
|
|
"id": &auth_request_id,
|
|
|
|
"publicKey": auth_request.public_key,
|
|
|
|
"publicKey": auth_request.public_key,
|
|
|
|
"requestDeviceType": DeviceType::from_i32(auth_request.device_type).to_string(),
|
|
|
|
"requestDeviceType": DeviceType::from_i32(auth_request.device_type).to_string(),
|
|
|
|
"requestIpAddress": auth_request.request_ip,
|
|
|
|
"requestIpAddress": auth_request.request_ip,
|
|
|
@ -1272,14 +1275,14 @@ async fn put_auth_request(
|
|
|
|
})))
|
|
|
|
})))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[get("/auth-requests/<uuid>/response?<code>")]
|
|
|
|
#[get("/auth-requests/<auth_request_id>/response?<code>")]
|
|
|
|
async fn get_auth_request_response(
|
|
|
|
async fn get_auth_request_response(
|
|
|
|
uuid: &str,
|
|
|
|
auth_request_id: AuthRequestId,
|
|
|
|
code: &str,
|
|
|
|
code: &str,
|
|
|
|
client_headers: ClientHeaders,
|
|
|
|
client_headers: ClientHeaders,
|
|
|
|
mut conn: DbConn,
|
|
|
|
mut conn: DbConn,
|
|
|
|
) -> JsonResult {
|
|
|
|
) -> JsonResult {
|
|
|
|
let Some(auth_request) = AuthRequest::find_by_uuid(uuid, &mut conn).await else {
|
|
|
|
let Some(auth_request) = AuthRequest::find_by_uuid(&auth_request_id, &mut conn).await else {
|
|
|
|
err!("AuthRequest doesn't exist", "User not found")
|
|
|
|
err!("AuthRequest doesn't exist", "User not found")
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
@ -1293,7 +1296,7 @@ async fn get_auth_request_response(
|
|
|
|
let response_date_utc = auth_request.response_date.map(|response_date| format_date(&response_date));
|
|
|
|
let response_date_utc = auth_request.response_date.map(|response_date| format_date(&response_date));
|
|
|
|
|
|
|
|
|
|
|
|
Ok(Json(json!({
|
|
|
|
Ok(Json(json!({
|
|
|
|
"id": uuid,
|
|
|
|
"id": &auth_request_id,
|
|
|
|
"publicKey": auth_request.public_key,
|
|
|
|
"publicKey": auth_request.public_key,
|
|
|
|
"requestDeviceType": DeviceType::from_i32(auth_request.device_type).to_string(),
|
|
|
|
"requestDeviceType": DeviceType::from_i32(auth_request.device_type).to_string(),
|
|
|
|
"requestIpAddress": auth_request.request_ip,
|
|
|
|
"requestIpAddress": auth_request.request_ip,
|
|
|
|