From 7d124286d07ee12bcf1e8a759c7adfdee4df67e0 Mon Sep 17 00:00:00 2001 From: paradox8599 Date: Fri, 18 Oct 2024 02:16:54 +1100 Subject: [PATCH] fix: invalid text 'null' in request when no args given (#29) * fix: invalid text 'null' in request when no args given in these requests, if the optional args are None, instead of passing a empty request body, a text 'null' will be added, which results in 400 response saying ``` { "error": { "message": "JSON failed to parse.", "status_code": 400 } } ``` * Revert "fix: invalid text 'null' in request when no args given" This reverts commit da82cf912e37affb713b74b1faf28bd763c7a3d0. * fix: invalid text 'null' in request when no args given In these requests, if the optional args are None, instead of passing a empty request body, a text 'null' will be added, which results in 400 response saying ``` { "error": { "message": "JSON failed to parse.", "status_code": 400 } } ``` This fix checks for the optional args, and only write to the request body if they have values. It is mainly for `finish_file_data_upload` as it allows an emty body, but the other two will still fail anyway. * regenerate from 1.18.5 spec Signed-off-by: C0D3 M4513R <28912031+C0D3-M4513R@users.noreply.github.com> --------- Signed-off-by: C0D3 M4513R <28912031+C0D3-M4513R@users.noreply.github.com> Co-authored-by: C0D3 M4513R <28912031+C0D3-M4513R@users.noreply.github.com> --- generate.sh | 3 +++ src/apis/files_api.rs | 12 +++++++++--- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/generate.sh b/generate.sh index 552f7fc..d0c6acf 100755 --- a/generate.sh +++ b/generate.sh @@ -39,6 +39,9 @@ cat patches/2FA_Current_User.rs >> src/models/current_user.rs sed -i 's/pub use self::current_user::CurrentUser;/pub use self::current_user::{EitherUserOrTwoFactor, CurrentUser};/g' src/models/mod.rs sed -i 's/Result>/Result>/g' src/apis/authentication_api.rs +# https://github.com/vrchatapi/vrchatapi-rust/pull/29 +sed -i "s/local_var_req_builder = local_var_req_builder.json(&\(.*\));/if let Some(\1) = \1 { \0 }/g" src/apis/files_api.rs + cargo fmt cargo build cargo test diff --git a/src/apis/files_api.rs b/src/apis/files_api.rs index 09646c8..7648f3d 100644 --- a/src/apis/files_api.rs +++ b/src/apis/files_api.rs @@ -104,7 +104,9 @@ pub async fn create_file( local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone()); } - local_var_req_builder = local_var_req_builder.json(&create_file_request); + if let Some(create_file_request) = create_file_request { + local_var_req_builder = local_var_req_builder.json(&create_file_request); + } let local_var_req = local_var_req_builder.build()?; let local_var_resp = local_var_client.execute(local_var_req).await?; @@ -148,7 +150,9 @@ pub async fn create_file_version( local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone()); } - local_var_req_builder = local_var_req_builder.json(&create_file_version_request); + if let Some(create_file_version_request) = create_file_version_request { + local_var_req_builder = local_var_req_builder.json(&create_file_version_request); + } let local_var_req = local_var_req_builder.build()?; let local_var_resp = local_var_client.execute(local_var_req).await?; @@ -326,7 +330,9 @@ pub async fn finish_file_data_upload( local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone()); } - local_var_req_builder = local_var_req_builder.json(&finish_file_data_upload_request); + if let Some(finish_file_data_upload_request) = finish_file_data_upload_request { + local_var_req_builder = local_var_req_builder.json(&finish_file_data_upload_request); + } let local_var_req = local_var_req_builder.build()?; let local_var_resp = local_var_client.execute(local_var_req).await?;