-
Notifications
You must be signed in to change notification settings - Fork 220
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Serialization error causing 400 Bad Request with GitHub API #4995
Comments
Thank you for reporting this issue . |
Well, I'm not positive, but I think that may be the problem. I could be leading you on a bit of a wild goose chase here, but let's talk about it. Pasting the Kiota-given payload (with escapes) into the otherwise successful curl request, like:
gives a 422 instead of the 400 I'm seeing through the SDK:
Which is not intuitive to me: I'd expect to see a 400 here like we're seeing in the SDK. However, simply removing all the backslashes from the curl command makes the request 204 as we'd expect. I'm unable to do the reverse (remove the backslashes from the outgoing request while debugging the SDK) as the kiota-abstractions-go.RequestInformation type doesn't seem to allow editing in the debugger: Do you have thoughts on how I might troubleshoot this further? |
Maybe this is something you could use the dev proxy for. Although I couldn't find an example in the documentation to instruct it to simply log request bodies @waldekmastykarz Alternatively you could use ngrok as a proxy, and leverage the console page at http://127.0.0.1:4040/ to observe the request bodies. |
I'm not saying the presence of backslashes is impossible, but I'd be surprised for it to be the case since we have thousands of applications using the Microsoft Graph Go SDK in production for over a year now. I suspect if we had an issue along those lines, it'd have come up already. |
Hmm...do you have any idea of what else might be the cause of the 400 Bad Request in that case? |
Alright, so if I update your sample by replacing the call to the API by // and adding this import kjson "github.com/microsoft/kiota-abstractions-go/serialization"
serializedValue, err := kjson.SerializeToJson(patchRequestBody)
if err != nil {
log.Fatalf("error serializing request body: %v", err)
}
strSerValue := string(serializedValue)
log.Printf("serialized request body: %v", strSerValue) I get |
This one sent me down a rabbit hole... Hardcoding the client.go client initialization to this fixed the issue. // GetDefaultClientOptions returns a new instance of ClientOptions with default values.
// This is used in the NewApiClient constructor before applying user-defined custom options.
func GetDefaultClientOptions() *ClientOptions {
options, _ := kiotaHttp.GetDefaultMiddlewaresWithOptions(kiotaHttp.NewCompressionOptions(false))
return &ClientOptions{
UserAgent: "octokit/go-sdk",
APIVersion: "2022-11-28",
Middleware: options,
}
} |
My recommendation here is to talk to the owning team so they implement support for content encoding. Not to disable it in the SDK. |
Oh interesting, thank you for spelling it out! I somehow didn't catch that Kiota gzipped everything by default. Do you mind giving me a brief explanation of what the ramifications of disabling compression in the SDK might be? I imagine payloads would be larger and therefore slower by some factor (.25? 2?). I'm pursuing API support, though that historically has been much slower and more difficult for us to change than spec and SDK issues (especially for changes that could be considered breaking, like this one). |
Also, am I crazy or does this not seem to be an option in the .NET helpers the way it is in the Go helpers? Is there a difference in the way this is handled by the underlying .NET libraries by default? |
The main reason why I though about looking into this one is because I was going through an inventory of where we were at for request body compression. And you're correct, at the moment only Go has it implemented, not dotnet. microsoft/kiota-dotnet#304
We didn't run our own comparisons as it's widely documented on the web 1 2 3. It varies based on the payload between a 75% reduction at best, to ~30% at worst. So non-negligeable benefits. While the CPU takes a small hit for doing the extra work, it's largely compensated by the reduction of transfer time. |
This issue has been automatically marked as stale because it has been marked as requiring author feedback but has not had any activity for 4 days. It will be closed if no further activity occurs within 3 days of this comment. |
What are you generating using Kiota, clients or plugins?
API Client/SDK
In what context or format are you using Kiota?
Nuget tool
Client library/SDK language
Go
Describe the bug
I am trying to call client.Repos().ByOwnerId("my-owner-id").ByRepoId("my-repo-id").Properties().Values().Patch(context.Background(), patchRequestBody, nil) with Kiota version
1.14.0+fc4b39c65d89f7bfc8c7f1813c197e95e206da09
.Alternately, this can be reproduced using octokit/go-sdk@v0.0.21.
The serialized payload going out looks like:
and returns a 400 Bad Request error.
Expected behavior
I expect a 200 to come back from the API. Using the equivalent curl request:
The request is successful, no output is returned, and repository custom properties are updated.
How to reproduce
cmd/token-example/main.go
with the following:go run cmd/token-example/main.go
and see the request return a 400 error. Debug for more information.Open API description file
https://raw.githubusercontent.com/github/rest-api-description/main/descriptions/api.github.com/api.github.com.json
Kiota Version
1.14.0+fc4b39c65d89f7bfc8c7f1813c197e95e206da09
Latest Kiota version known to work for scenario above?(Not required)
No response
Known Workarounds
N/A
Configuration
N/A
Debug output
N/A
Other information
It might be a red herring, but the request that Kiota sends out is:
and a successful request in curl looks like:
'{"properties":[{"property_name":"environment","value":"test-from-curl"}]}'
I'm not sure if the quotes and/or backslashes make a difference when serializing/sending the information to the API, but it's worth thinking about.
The text was updated successfully, but these errors were encountered: