BaseHost 1.2.36
dotnet add package BaseHost --version 1.2.36
NuGet\Install-Package BaseHost -Version 1.2.36
<PackageReference Include="BaseHost" Version="1.2.36" />
<PackageVersion Include="BaseHost" Version="1.2.36" />
<PackageReference Include="BaseHost" />
paket add BaseHost --version 1.2.36
#r "nuget: BaseHost, 1.2.36"
#:package BaseHost@1.2.36
#addin nuget:?package=BaseHost&version=1.2.36
#tool nuget:?package=BaseHost&version=1.2.36
Purpose
This is used as the foundation of my other C# projects. It provides some common bits of setup with are often needed. It sets up a configured host which uses my config module, my console module, Autofac and NLog. There is also a code generator which will create builders for any class [BuilderPattern].
How to use
Host
This is how a host can be setup, you'll need to add your own nlog config
public class Host : ConsoleHost{
public static void Main(string[] args) => new Host().Start(args);
protected override void Setup(ContainerBuilder builder){
builder.AutoActivateWith<Controller>(i => i.Start());
}
public class Controller{
public Controller(ILogger logger){...}
public void Start(){...}
}
}
Builder Generator
The generator will create a builder class, also add methods for each public property with a private mutator, With(value), Update(Func<value,value>). It will also make special use of ImmutableArray, ImmutableDictionary and ImmutableHashSet
Example model class
[BuilderPattern]
public partial class Model
{
public string Value { get; private set; }
}
generated class
public partial class Model
{
private Model () { }
public Builder AsBuilder() => Builder.BasedOn(this);
public static Builder CreateBuilder() => Builder.Instance();
public Mutable AsMutable() => new Mutable(){
Value = this.Value,
};
public Model WithValue(string value) => AsBuilder().WithValue(value).Build();
public Model UpdateValue(Func<string,string> valueFunc) => AsBuilder().UpdateValue(valueFunc).Build();
public sealed partial class Builder {
private Model _instance = new Model();
private Builder() { }
internal static Builder Instance () => new Builder();
internal static Builder BasedOn(Model reference) => Instance ()
.WithValue(reference.Value);
public Builder WithValue(string value){
_instance.Value = value;
return this;
}
public Builder UpdateValue(Func<string,string> valueFunc){
_instance.Value = valueFunc(_instance.Value);
return this;
}
public Model Build() {
var local = _instance;
_instance = null;
local = local.GetValidatedInstance();
return local;
}
}
public sealed class Mutable {
public string Value {get; set; }
public Model AsImmutable() => Model.CreateBuilder()
.WithValue(this.Value)
.Build();
}}}
Console
There are shells, console and commands. shells run on a console, and have access to commands. new commands can be registered and them will be accessible from all the consoles. There are some commands included, for shutdown/get-starting-args/config and more commands can be registered in ICommandManager
There is also a websocket interface for this.
var shutdown = new Shutdown();
_commandManager.Register("get-starting-args",args);
Config
A config can be given in the form of a json file (Host.config.json), if no json file is provided one will be generated and saved in output at runtime. Config is specified as below:
[ConfigValue(Name = "ws_pokemon_server_path", DefaultString = "ws:bhah.blah.blah:12")]
private static string ConnectionString => Config.ws_pokemon_server_path; //Config is generated at build time
Extension Methods
Lots of extension methods, covering a variety of functionality, enumerable/observables/functions ..., not really much structure, just whatever I've found useful
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. 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. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Autofac (>= 8.2.0)
- CommandLineParser (>= 2.9.1)
- GraphQL.Server.Ui.GraphiQL (>= 8.2.0)
- JetBrains.Annotations (>= 2024.3.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 9.0.0)
- Microsoft.Extensions.Configuration.Binder (>= 9.0.0)
- Microsoft.Extensions.Configuration.Json (>= 9.0.0)
- Newtonsoft.Json (>= 13.0.3)
- NLog (>= 5.3.4)
- System.Collections.Immutable (>= 9.0.0)
- System.ComponentModel.Annotations (>= 5.0.0)
- System.Reactive (>= 6.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on BaseHost:
| Package | Downloads |
|---|---|
|
BaseHost.Web
Configured host, with generators, modules for logging, console and config |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.2.36 | 194 | 12/21/2024 |
| 1.2.35 | 160 | 12/12/2024 |
| 1.2.34 | 133 | 12/5/2024 |
| 1.2.33 | 148 | 11/28/2024 |
| 1.2.32 | 139 | 11/22/2024 |
| 1.2.31 | 128 | 11/19/2024 |
| 1.2.29 | 136 | 11/18/2024 |
| 1.2.26 | 119 | 11/4/2024 |
| 1.2.25 | 108 | 11/3/2024 |
| 1.2.24 | 133 | 11/3/2024 |
| 1.2.23 | 137 | 10/22/2024 |
| 1.2.22 | 110 | 10/4/2024 |
| 1.2.21 | 128 | 9/25/2024 |
| 1.2.20 | 135 | 9/12/2024 |
| 1.2.19 | 147 | 9/2/2024 |
| 1.2.18 | 123 | 8/15/2024 |
| 1.2.17 | 138 | 8/15/2024 |
| 1.2.16 | 118 | 8/9/2024 |
| 1.2.15 | 123 | 8/9/2024 |
| 1.2.14 | 128 | 8/9/2024 |