Altairis.Services.Cloudflare
1.0.0
dotnet add package Altairis.Services.Cloudflare --version 1.0.0
NuGet\Install-Package Altairis.Services.Cloudflare -Version 1.0.0
<PackageReference Include="Altairis.Services.Cloudflare" Version="1.0.0" />
paket add Altairis.Services.Cloudflare --version 1.0.0
#r "nuget: Altairis.Services.Cloudflare, 1.0.0"
// Install Altairis.Services.Cloudflare as a Cake Addin #addin nuget:?package=Altairis.Services.Cloudflare&version=1.0.0 // Install Altairis.Services.Cloudflare as a Cake Tool #tool nuget:?package=Altairis.Services.Cloudflare&version=1.0.0
Cloudflare proxy support for ASP.NET Core
Cloudlfare is a popular service providing (among others) reverse proxy/CDN services. That means that the web server is hidden behind Cloudflare's servers and does not have direct access to client IP address.
ASP.NET Core has a solution for this: the Forwarded Headers Middleware, which can read X-Forwarded-For
and similar headers and set HttpContext.Connection.RemoteIpAddress
property accordingly.
For these two to work together, one needs to set properly IP ranges of known networks, as published by Cloudflare. This library automates this process, by downloading list of IPv4 and IPv6 ranges and applying them.
Basic usage
First, install the Altairis.Services.Cloudflare
package.
Then, in your Program.cs
, call the UseCloudflare
method. This is the minimal sample application:
using Altairis.Services.Cloudflare;
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
// Configure to use Cloudflare proxy
app.UseCloudflare();
// Show assumed client IP
app.MapGet("/", (HttpContext context) => context.Connection?.RemoteIpAddress?.ToString());
// Run application
app.Run();
Advanced usage
You may use the static method CloudflareForwardedHeadersConfigurator.GetForwardedHeadersOptions
to get ForwardedHeadersOptions
class configured for CloudFlare and then configure the Forwarded Headers Middleware yourself.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. 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. |
-
net6.0
- Microsoft.AspNetCore.HttpOverrides (>= 2.2.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 |
---|---|---|
1.0.0 | 1,090 | 9/4/2022 |