FluffySpoon.Ngrok
1.112.0
Prefix Reserved
See the version list below for details.
dotnet add package FluffySpoon.Ngrok --version 1.112.0
NuGet\Install-Package FluffySpoon.Ngrok -Version 1.112.0
<PackageReference Include="FluffySpoon.Ngrok" Version="1.112.0" />
paket add FluffySpoon.Ngrok --version 1.112.0
#r "nuget: FluffySpoon.Ngrok, 1.112.0"
// Install FluffySpoon.Ngrok as a Cake Addin #addin nuget:?package=FluffySpoon.Ngrok&version=1.112.0 // Install FluffySpoon.Ngrok as a Cake Tool #tool nuget:?package=FluffySpoon.Ngrok&version=1.112.0
FluffySpoon.Ngrok
A NuGet package used to start Ngrok programmatically and fetch the tunnel URL. Useful to enable for local development when a public URL is needed.
Examples
Console application
Add AddNgrok
to your service registration
var services = new ServiceCollection();
services.AddNgrok();
var serviceProvider = services.BuildServiceProvider();
var ngrokService = serviceProvider.GetService<INgrokService>();
//this downloads the Ngrok executable, starts it in
//the background, and opens a tunnel for the given URL
var tunnel = await ngrokService.StartAsync(new Uri("http://localhost:80"));
Console.WriteLine("Ngrok tunnel URL for localhost:80 is: " + tunnel.PublicUrl);
//the active tunnel can also be accessed using ngrokService.ActiveTunnel.
//we may stop the tunnel as well.
await ngrokService.StopAsync();
ASP .NET Core application
For this example, the FluffySpoon.Ngrok.AspNet
package has to be installed.
var builder = WebApplication.CreateBuilder();
//this is the line that is needed to automatically start the tunnel with your ASP .NET Core application.
builder.Services.AddNgrokHostedService();
builder.Services.AddControllersWithViews();
var app = builder.Build();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.MapControllerRoute(
name: "default",
pattern: "{controller=Home}/{action=Index}/{id?}");
await app.RunAsync();
Getting the tunnel URL
To get the tunnel URL in an ASP .NET Core application, you can just inject a INgrokService
into your controller or class.
public class HomeController : Controller
{
private readonly INgrokService _ngrokService;
public HomeController(INgrokService ngrokService)
{
_ngrokService = ngrokService;
}
public IActionResult Index()
{
var tunnel = await _ngrokService.ActiveTunnel;
Console.WriteLine("Tunnel URL is: " + tunnel.PublicUrl);
return View();
}
}
Waiting for the tunnel to be ready
On the INgrokService
, you can call a method to wait for the tunnel to be ready.
await ngrokService.WaitUntilReadyAsync();
Registering lifetime hooks
These are useful if you want to debug things like webhooks etc locally.
class SomeLifetimeHook : INgrokLifetimeHook
{
public Task OnCreatedAsync(TunnelResponse tunnel, CancellationToken cancellationToken)
{
//TODO: do something when a tunnel has been created. for instance, here you could register a webhook for "tunnel.PublicUrl".
return Task.CompletedTask;
}
public Task OnDestroyedAsync(TunnelResponse tunnel, CancellationToken cancellationToken)
{
//TODO: do something when a tunnel has been destroyed. for instance, here you could unregister a webhook for "tunnel.PublicUrl".
return Task.CompletedTask;
}
}
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
- Flurl.Http (>= 3.2.2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 6.0.0)
- Microsoft.Extensions.Http (>= 6.0.0)
- Microsoft.Extensions.Logging (>= 6.0.0)
- NgrokApi (>= 0.6.0)
- System.Linq.Async (>= 6.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on FluffySpoon.Ngrok:
Package | Downloads |
---|---|
FluffySpoon.Ngrok.AspNet
Integration of Ngrok with the AspNetCore pipeline. Tools to automatically create ngrok tunnels on application startup |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.164.0 | 5,763 | 1/13/2024 |
1.163.0 | 1,647 | 3/4/2023 |
1.162.0 | 296 | 3/4/2023 |
1.160.0 | 239 | 3/4/2023 |
1.159.0 | 255 | 3/4/2023 |
1.157.0 | 376 | 2/25/2023 |
1.156.0 | 340 | 2/25/2023 |
1.155.0 | 394 | 2/24/2023 |
1.154.0 | 261 | 2/24/2023 |
1.153.0 | 254 | 2/24/2023 |
1.152.0 | 259 | 2/24/2023 |
1.151.0 | 574 | 2/22/2023 |
1.148.0 | 262 | 2/22/2023 |
1.147.0 | 258 | 2/22/2023 |
1.146.0 | 254 | 2/21/2023 |
1.133.0 | 277 | 2/21/2023 |
1.132.0 | 287 | 2/21/2023 |
1.131.0 | 281 | 2/21/2023 |
1.128.0 | 285 | 2/20/2023 |
1.119.0 | 682 | 1/22/2023 |
1.118.0 | 656 | 11/20/2022 |
1.117.0 | 337 | 11/20/2022 |
1.116.0 | 485 | 11/8/2022 |
1.115.0 | 1,821 | 3/12/2022 |
1.114.0 | 431 | 3/12/2022 |
1.112.0 | 1,715 | 3/12/2022 |