PiBox.Hosting.WebHost
1.0.85
dotnet add package PiBox.Hosting.WebHost --version 1.0.85
NuGet\Install-Package PiBox.Hosting.WebHost -Version 1.0.85
<PackageReference Include="PiBox.Hosting.WebHost" Version="1.0.85" />
paket add PiBox.Hosting.WebHost --version 1.0.85
#r "nuget: PiBox.Hosting.WebHost, 1.0.85"
// Install PiBox.Hosting.WebHost as a Cake Addin #addin nuget:?package=PiBox.Hosting.WebHost&version=1.0.85 // Install PiBox.Hosting.WebHost as a Cake Tool #tool nuget:?package=PiBox.Hosting.WebHost&version=1.0.85
PiBox.Hosting.Webhost
PiBox.Hosting.WebHost is the core package
that allows dotnet dev's
to use the pibox web host and pibox plugins
.
This package is mandatory, without it you can't use any plugins
Installation
To install the nuget package follow these steps:
dotnet add package PiBox.Hosting.Generator # this is required so the web host can discover & load the plugins
dotnet add package PiBox.Hosting.WebHost
or add as package reference to your .csproj
<PackageReference Include="PiBox.Hosting.Generator" Version="" />
<PackageReference Include="PiBox.Hosting.WebHost" Version="" />
Rewrite the Entrypoint Program.cs to have following code:
using PiBox.Hosting.WebHost;
PluginWebHostBuilder.RunDefault(PiBox.Generated.PiBoxPluginTypes.All);
Config files and ENV vars
PiBox will try to load config files and values in the following order
appsettings.json
appsettings.yaml
appsettings.yml
appsettings.*.json
appsettings.*.yaml
appsettings.*.yml
appsettings.secrets.yml
appsettings.*.secrets.yml
9ENV variables
NOTE: All settings (does not matter which file extension) will be ordered by node length. And the secret files will be loaded as last (except the environment variables).
Example:
- appsettings.yaml
- appsettings.api.yaml
- appsettings.api.host.yaml
- appsettings.secrets.yaml
- apssettings.api.secrets.yaml
- appsettings.api.host.secrets.yaml
- ENV Variables
File names must always start with appsettings
or they will be ignored!
Nested settings use _
to build their hierarchy as ENV variables
host:
urls: http://+:5300 # optional, default is 8080;separate multiple urls with ","
becomes
HOST_URLS=http://+:5300 # optional, default is 8080;separate multiple urls with ","
General settings
Configure your config file with these properties
host:
urls: http://+:5300 # optional, default is 8080;separate multiple urls with ","
maxRequestSize: 8388608 # optional, default is 8 MB
or as ENV variables
HOST_URLS=http://+:5300 # optional, default is 8080;separate multiple urls with ","
HOST_MAXREQUESTSIZE=8388608 # optional, default is 8 MB
Logging
Configure your appsettings.logging.yml with these properties
serilog:
minimumLevel: Debug # or Warn or Info
override:
System: Error # or Warning or Information
Microsoft: Error # or Warning or Information
or as ENV variables
SERIOLOG_minimumLevel=Debug
SERIOLOG_OVERRIDE_SYSTEM=Error
SERIOLOG_OVERRIDE_MICROSOFT=Error
Usage
Rewrite your entrypoint Program.cs to have following code:
PiBox.Hosting.WebHostPluginWebHostBuilder.RunDefault(PiBox.Generated.PiBoxPluginTypes.All);
Now you can add additional plugins as nuget packages to your project and configure them via config files/settings and/or in your web host plugin
Metrics
Pibox uses open telemetry for it's metrics capabilities. Further info can be found here
Tracing settings
Pibox uses open telemetry for it's tracing capabilities. Further info can be found here
https://opentelemetry.io/docs/instrumentation/net/getting-started/
If there is a tracing host configured, the service will try to send any traces to this host. it will also enrich the log messages with SpanIds and TraceIds.
tracing:
host: http://localhost:3333
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. |
-
net8.0
- AspNetCore.HealthChecks.System (>= 8.0.0)
- AspNetCoreRateLimit (>= 5.0.0)
- Chronos.Net (>= 2.0.24)
- NetEscapades.Configuration.Yaml (>= 3.1.0)
- OpenTelemetry.Exporter.OpenTelemetryProtocol (>= 1.7.0)
- OpenTelemetry.Exporter.Prometheus.AspNetCore (>= 1.7.0-rc.1)
- OpenTelemetry.Extensions.Hosting (>= 1.7.0)
- OpenTelemetry.Instrumentation.AspNetCore (>= 1.7.1)
- OpenTelemetry.Instrumentation.Http (>= 1.7.1)
- OpenTelemetry.Instrumentation.Process (>= 0.5.0-beta.4)
- OpenTelemetry.Instrumentation.Runtime (>= 1.7.0)
- PiBox.Hosting.Abstractions (>= 1.0.85)
- Serilog.AspNetCore (>= 8.0.1)
- Serilog.Enrichers.Span (>= 3.1.0)
- Serilog.Enrichers.Thread (>= 3.1.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.85 | 53 | 1/15/2025 |
1.0.79 | 61 | 12/20/2024 |
1.0.73 | 62 | 10/22/2024 |
1.0.66 | 193 | 10/15/2024 |
1.0.64 | 84 | 10/14/2024 |
1.0.61 | 99 | 10/1/2024 |
1.0.60 | 93 | 9/27/2024 |
1.0.54 | 173 | 4/30/2024 |
1.0.51 | 193 | 2/27/2024 |
1.0.49 | 65 | 2/27/2024 |
1.0.47 | 90 | 2/21/2024 |
1.0.45 | 74 | 2/20/2024 |
1.0.43 | 89 | 2/13/2024 |
1.0.41 | 79 | 2/13/2024 |
1.0.39 | 86 | 2/8/2024 |
1.0.38 | 87 | 2/8/2024 |
1.0.37 | 80 | 2/8/2024 |
1.0.35 | 77 | 2/2/2024 |
1.0.32 | 79 | 1/30/2024 |
1.0.25 | 145 | 12/27/2023 |
1.0.23 | 94 | 12/19/2023 |
1.0.22 | 84 | 12/19/2023 |
1.0.21 | 78 | 12/19/2023 |
1.0.19 | 92 | 12/11/2023 |
1.0.17 | 128 | 11/23/2023 |
1.0.7 | 87 | 11/23/2023 |
1.0.5 | 87 | 11/23/2023 |
1.0.3 | 90 | 11/23/2023 |
1.0.0 | 94 | 11/21/2023 |
0.9.9 | 84 | 11/21/2023 |
0.9.7 | 89 | 11/21/2023 |
0.9.6 | 106 | 11/21/2023 |