Get Help

Got issues, questions, suggestions? Please read this page carefully to understand how you can get help working with RestSharp.

Questions

The most effective way to resolve questions about using RestSharp is StackOverflow.

RestSharp has a large user base. Tens of thousands of projects and hundreds of thousands of developers use RestSharp on a daily basis. So, asking questions on StackOverflow with restsharpopen in new window tag would most definitely lead you to a solution.

WARNING

Please do not use GitHub issues to ask question about using RestSharp.

Discussions

We have a mail listopen in new window at Google Groups dedicated to discussions about using RestSharp, feature proposals and similar topics. It is perfectly fine to ask questions about using RestSharp at that group too.

Please check the group and engage with the community if you feel a need to discuss things that you struggle with or want to improve.

Bugs and issues

The last resort to get help when you experience some unexpected behaviour, a crash or anything else that you consider a bug, is submitting an issue at our GitHub repository.

WARNING

Please do not ignore our contribution guidelines, otherwise you risk your issue to be closed without being considered. Respect the maintainers, be specific and provide as many details about the issue as you can.

Ensure you provide the following in the issue:

  • Expected behaviour
  • Actual behaviour
  • Why do you think it is an issue, not a misunderstanding
  • How the issue can be reproduced: a repository or at least a code snippet
  • If RestSharp unexpectedly throws an exception, provide the stack trace

Contributing

Although issues are considered as contributions, we strongly suggest helping the community by solving issues that you experienced by submitting a pull request.

Here are contribution guidelines:

  • Make each pull request atomic and exclusive; don't send pull requests for a laundry list of changes.
  • Even better, commit in small manageable chunks.
  • Use the supplied .DotSettings file to format the code.
  • Any change must be accompanied by a unit test covering the change.
  • New tests are preferred to use Shoudly.
  • No regions except for license header
  • Code must build for .NET Standard 2.0 and .NET Framework 4.5.2.
  • Test must run on .NET Core 3.1 and .NET Framework 4.5.2
  • Use autocrlf=true (git config --global core.autocrlf true [http://help.github.com/dealing-with-lineendings/])

You can also support maintainers and motivate them by contributing financially at Open Collectiveopen in new window.

Common Issues

Before opening an issue on GitHub, please check the list of known issues below.

Connection closed with SSL

When connecting via HTTPS, you get an exception:

The underlying connection was closed: An unexpected error occurred on a send

The exception is thrown by WebRequest so you need to tell the .NET Framework to accept more certificate types than it does by default.

Adding this line somewhere in your application, where it gets called once, should solve the issue:

ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12 | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls;
1

Setting the User Agent

Setting the user agent on the request won't work when you use AddHeader.

Instead, please use the RestClient.UserAgent property.

Empty Response

We regularly get issues where developers complain that their requests get executed and they get a proper raw response, but the RestResponse<T> instance doesn't have a deserialized object set.

In other situations, the raw response is also empty.

All those issues are caused by the design choice to swallow exceptions that occur when RestSharp makes the request and processes the response. Instead, RestSharp produces so-called error response.

You can check the response status to find out if there're any errors. The following properties can tell you about those errors:

  • IsSuccessful
  • ResponseStatus
  • StatusCode
  • ErrorMessage
  • ErrorException

It could be that the request was executed and you got 200 OK status code back and some content, but the typed Data property is empty.

In that case, you probably got deserialization issues. By default, RestSharp will just return an empty (null) result in the Data property. Deserialization errors can be also populated to the error response. To do that, set the client.FailOnDeserializationError property to true.

It is also possible to force RestSharp to throw an exception.

If you set client.ThrowOnDeserializationError, RestSharp will throw a DeserializationException when the serializer throws. The exception has the internal exception and the response.

Finally, by setting ThrowOnAnyError you can force RestSharp to re-throw any exception that happens when making the request and processing the response.