WebCLI 1.0.3
dotnet add package WebCLI --version 1.0.3
NuGet\Install-Package WebCLI -Version 1.0.3
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="WebCLI" Version="1.0.3" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="WebCLI" Version="1.0.3" />
<PackageReference Include="WebCLI" />
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 WebCLI --version 1.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: WebCLI, 1.0.3"
#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 WebCLI@1.0.3
#: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=WebCLI&version=1.0.3
#tool nuget:?package=WebCLI&version=1.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
WebCLI is a lightweight library for building command line UI in a web browser for AspNetCore web application. Good for making administration panels without frontend development.
Features
- Easy to configure
- No frontend development required
- Create command, register it as service and pass to "UseWebCli" and you're good to go
- Based on jQuery Terminal library, it includes its usability features (history in browser, text navigation, hot keys, etc.)
- Provide intermediate output during complex commands execution (see example AsyncMultistepOperationCommand)
- Replace previous output to refresh provided information (see example ProgressBarCommand)
Pre Requirements
Can be installed into web application based on ASP.NET Core 8.0+
Getting started
- Install NuGet package:
Install-Package WebCLI - Create some command:
namespace App.Commands { public class HelloWorldCommand : CommandBase<HelloWorldCommand.Options> { [Verb("helloworld")] public class Options { } public override Task<string> ExecuteAsync(Options options) { return Task.FromResult("Hello world!"); } } } - Register command in IServiceCollection:
var builder = WebApplication.CreateBuilder(args); builder.Services.AddTransient<HelloWorldCommand>(); var app = builder.Build(); - Enable WebCLI, by calling "UseWebCli" with options:
var app = builder.Build(); app.UseWebCli(new WebCliOptions( [typeof(HelloWorldCommand)] )); await app.RunAsync(); - Run application, open
<app url> + /webcliin browser (e.g.http://localhost:5275/webcli) and enterhelloworldto see the result
Examples
For command & configuration examples take a look at WebCLI.Examples project. It contains:
- Installation - shows how to connect WebCLI to your application
- HelloWorldCommand - minimal required command configuration
- AsyncOperationCommand - command that performs async operation
- AsyncMultistepOperationCommand - command with intermediate output (doing some async work, printing output, doing more async work, printing more output, etc.)
- ProgressBarCommand - command with output rewriting
- InterruptableCommand - command with operation, that can check on certain steps if user wants to cancel it
- InterruptableActiveCommand - command with operation, that uses cancellation token (which can be used with various async APIs) indicating that user wants to cancel it
| 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
- CommandLineParser (>= 2.9.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.