CoreSharp.Http.FluentApi
                              
                            
                                8.0.1
                            
                        
                    dotnet add package CoreSharp.Http.FluentApi --version 8.0.1
NuGet\Install-Package CoreSharp.Http.FluentApi -Version 8.0.1
        
        
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
                    
    
    <PackageReference Include="CoreSharp.Http.FluentApi" Version="8.0.1" />
        
        
For projects that support PackageReference, copy this XML node into the project file to reference the package.
                    
    
    <PackageVersion Include="CoreSharp.Http.FluentApi" Version="8.0.1" />
<PackageReference Include="CoreSharp.Http.FluentApi" />
        
        
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
                    
    
    paket add CoreSharp.Http.FluentApi --version 8.0.1
        
        
 The NuGet Team does not provide support for this client. Please contact its maintainers for support.
                    
    
    #r "nuget: CoreSharp.Http.FluentApi, 8.0.1"
        
        
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
                    
    
    #:package CoreSharp.Http.FluentApi@8.0.1
        
        
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
                    
    
    #addin nuget:?package=CoreSharp.Http.FluentApi&version=8.0.1
#tool nuget:?package=CoreSharp.Http.FluentApi&version=8.0.1
        
        
 The NuGet Team does not provide support for this client. Please contact its maintainers for support.
                    
    
    CoreSharp.Http.FluentApi
HttpClient fluent request framework.
Features
- Strongly typed fluent syntax.
- Automatic JSON conversions using Text.JsonorJson.NET.
- In-memory response caching for safe HTTP methods.
- Specific and more meaningful exceptions (HttpResponseException,TimeoutException).
- Use of Streamwhere applicable instead of eager converting entities to string. [Optimizes memory consumption]
- Use of HttpCompletionOption.ResponseHeadersReadby default to all requests. [Optimizes memory consumption and response times]
Installation
Install the package with Nuget.
dotnet add package CoreSharp.Http.FluentApi
Use cases
Table of Contents
- Start a request chain
- Headers
- Ignore error
- HttpCompletionOption
- Timeout
- Endpoint
- Query parameters
- HTTP method
- Request body
- Response deserialization
- Response caching
Start a request chain
HttpClient client = GetClient();
var request = client.Request();
Headers
var response = client
	.Request()
	.WithHeader("Cache-Control", "max-age=3600")
	.WithEndpoint("users")
	.Get()
	.SendAsync();
IDictionary<string, string> headers = GetHeaders();
var response = client
	.Request()
	.WithHeaders(headers)
	.WithEndpoint("users")
	.Get()
	.SendAsync();
Accept
// Accept: text/xml
var response = client
	.Request()
	.Accept("text/xml")
	.WithEndpoint("users")
	.Get()
	.SendAsync();
// Accept: application/json
var response = client
	.Request()
	.AcceptJson()
	.WithEndpoint("users")
	.Get()
	.SendAsync();
// Accept: application/xml
var response = client
	.Request()
	.AcceptXml()
	.WithEndpoint("users")
	.Get()
	.SendAsync();
Authorization
// Authorization: 0imfnc8mVLWwsAawjYr4Rx
var response = client
	.Request()
	.WithAuthorization("0imfnc8mVLWwsAawjYr4Rx")
	.WithEndpoint("users")
	.Get()
	.SendAsync();
// Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9
var response = client
	.Request()
	.WithBearerToken("eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9")
	.WithEndpoint("users")
	.Get()
	.SendAsync();
Ignore error
// Propagates / throws exception
var response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.SendAsync();
// Silence / does not throw exception
var response = client
	.Request()
	.IgnoreError()
	.WithEndpoint("users")
	.Get()
	.SendAsync();
HttpCompletionOption
var response = client
	.Request()
	.WithCompletionOption(HttpCompletionOption.ResponseContentRead)
	.WithEndpoint("users")
	.Get()
	.SendAsync();
Timeout
try
{
	var response = client
		.Request()
		.WithTimeout(TimeSpan.FromSeconds(15))
		.WithEndpoint("users")
		.Get()
		.SendAsync();
}
catch (TimeoutException timeoutException)
{
}
Endpoint
// GET /users/
var response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.SendAsync();
// GET /users/1/
int id = 1;
var response = client
	.Request()
	.WithEndpoint("users", id)
	.Get()
	.SendAsync();
// GET /users/1/
long id = 1;
var response = client
	.Request()
	.WithEndpoint("users", id)
	.Get()
	.SendAsync();
// GET /users/570ffbae-d1b8-4fad-9fef-5d058a283329/
Guid id = Guid.New();
var response = client
	.Request()
	.WithEndpoint("users", id)
	.Get()
	.SendAsync();
// GET /users/filter/new/
var response = client
	.Request()
	.WithEndpoint(new [] {"users", "filter", "new" })
	.Get()
	.SendAsync();
Query parameters
// GET > /users/?Id=1&Name="Makis"
var response = client
	.Request()
	.WithEndpoint("users")
	.WithQuery("Id", 1)
	.WithQuery("Name","Makis")
	.Get()
	.SendAsync();
// GET > /users/?Id=1&Name="Makis"
var response = client
	.Request()
	.WithEndpoint("users")
	.WithQuery(new
	{
		Id = 1,
		Name = "Makis"
	})
	.Get()
	.SendAsync();
// GET > /users/?Id=1&Name="Makis"
var queryParameters = new Dictionary<string, object>()
{
	{ "Id", 1 },
	{ "Name", "Makis" }
};
var response = client
	.Request()
	.WithEndpoint("users")
	.WithQuery(queryParameters)
	.Get()
	.SendAsync();
HTTP method
Safe methods
var response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.SendAsync();
var response = client
	.Request()
	.WithEndpoint("users")
	.Head()
	.SendAsync();
var response = client
	.Request()
	.WithEndpoint("users")
	.Options()
	.SendAsync();
var response = client
	.Request()
	.WithEndpoint("users")
	.Trace()
	.SendAsync();
Unsafe methods
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.SendAsync();
var response = client
	.Request()
	.WithEndpoint("users")
	.Put()
	.SendAsync();
var response = client
	.Request()
	.WithEndpoint("users")
	.Patch()
	.SendAsync();
var response = client
	.Request()
	.WithEndpoint("users")
	.Delete()
	.SendAsync();
Request body
(supported only with unsafe methods)
HttpContent content = GetHttpContent();
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.WithBody(content)
	.SendAsync();
string content = "data";
string mediaType = MediaTypeNames.Text.Plain;
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.WithBody(content, mediaType)
	.SendAsync();
JSON request body
// Sets request Content-Type: application/json
// and HttpContent to StringContent.
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.WithJsonBody(@"
	{
		""Name"": ""Dave""
	}")
	.SendAsync();
// Serialize object to JSON stream,
// sets request Content-Type: application/json
// and HttpContent to StreamContent.
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.WithJsonBody(new
	{
		Name = "Dave"
	})
	.SendAsync();
// Sets request Content-Type: application/json
// and HttpContent to StreamContent.
Stream stream = GetJsonStream(new
{
	Name = "Dave"
});
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.WithJsonBody(stream)
	.SendAsync();
XML request body
// Serialize object to XML stream,
// sets request Content-Type: application/xml
// and HttpContent to StreamContent.
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.WithXmlBody(new
	{
		Name = "Dave"
	})
	.SendAsync();
// Sets request Content-Type: application/xml
// and HttpContent to StreamContent.
Stream stream = GetXmlStream(new
{
	Name = "Dave"
});
var response = client
	.Request()
	.WithEndpoint("users")
	.Post()
	.WithXmlBody(stream)
	.SendAsync();
Response deserialization
HttpResponseMessage response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.SendAsync();
byte[] response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.ToBytes()
	.SendAsync();
Stream response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.ToStream()
	.SendAsync();
string response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.ToString()
	.SendAsync();
// Deserializes JSON with System.Text.Json by default
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithJsonDeserialize<User>()
	.SendAsync();
// Deserialize JSON with System.Text.Json
System.Text.Json.JsonSerializerOptions options = new();
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithJsonDeserialize<User>(options)
	.SendAsync();
// Deserialize JSON with Newtonsoft.Json
Newtonsoft.Json.JsonSerializerSettings settings = new();
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithJsonDeserialize<User>(settings)
	.SendAsync();
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithXmlDeserialize<User>()
	.SendAsync();
// Deserialize from string
static User Deserialize(String response) => ...;
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithGenericDeserialize(Deserialize)
	.SendAsync();
// Deserialize from Stream
static User Deserialize(Stream response) => ...;
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithGenericDeserialize(Deserialize)
	.SendAsync();
Response caching
(supported only with safe methods that return anything but  HttpResponseMessage)
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithJsonDeserialize<User>()
	.WithCache(TimeSpan.FromMinutes(15))
	.SendAsync();
static bool CacheInvalidationFactory() = ...;
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithJsonDeserialize<User>()
	.WithCache(TimeSpan.FromMinutes(15))
	.WithCacheInvalidation(CacheInvalidationFactory)
	.SendAsync();
static Task<bool> CacheInvalidationFactory() = ...;
User response = client
	.Request()
	.WithEndpoint("users")
	.Get()
	.WithJsonDeserialize<User>()
	.WithCache(TimeSpan.FromMinutes(15))
	.WithCacheInvalidation(CacheInvalidationFactory)
	.SendAsync();
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
        
        Compatible target framework(s)
    
    
        
        Included target framework(s) (in package)
    
    Learn more about Target Frameworks and .NET Standard.
- 
                                                    net8.0- CoreSharp (>= 7.5.1)
- Microsoft.Extensions.Caching.Abstractions (>= 7.0.0)
- Microsoft.Extensions.Caching.Memory (>= 7.0.0)
- Microsoft.Extensions.Http (>= 7.0.0)
 
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 8.0.1 | 244 | 6/4/2024 | 
-Refactorings and unit tests revisiting.