Frank.BedrockSlim.Server
1.1.0
See the version list below for details.
dotnet add package Frank.BedrockSlim.Server --version 1.1.0
NuGet\Install-Package Frank.BedrockSlim.Server -Version 1.1.0
<PackageReference Include="Frank.BedrockSlim.Server" Version="1.1.0" />
paket add Frank.BedrockSlim.Server --version 1.1.0
#r "nuget: Frank.BedrockSlim.Server, 1.1.0"
// Install Frank.BedrockSlim.Server as a Cake Addin #addin nuget:?package=Frank.BedrockSlim.Server&version=1.1.0 // Install Frank.BedrockSlim.Server as a Cake Tool #tool nuget:?package=Frank.BedrockSlim.Server&version=1.1.0
Frank.BedrockSlim
The purpose of this project is to provide a starting point for building a web application using the Bedrock Framework. It is intended to be used as a starting point for building servers and clients, using minimal dependencies, and providing a simple, consistent, and easy to use API.
ASP.NET Core is the core of this library, but very little of the actual "basics" are added, so its only providing "server infrastructure" and "client infrastructure" for the most part. The rest is up to you.
Getting Started
Installing
To install the latest version of this library, run one or both of the following commands:
dotnet add package Frank.BedrockSlim.Server
dotnet add package Frank.BedrockSlim.Client
Sample Projects
There are two sample projects included in this repository, one for the server, and one for the client. They are both console applications, and can be used to test the library.
To run the sample projects, just run the following commands run the 'run-samples.ps1' script:
pwsh ./run-samples.ps1
The script will build the library, and then run the server saple project and wait 5 seconds before running the client sample project, then close them after 15 seconds.
Server
The server is a simple console application that hosts a web server. It is configured using the Host.CreateDefaultBuilder
method, which provides a default configuration, logging, and dependency injection setup. The ConfigureWebHostDefaults
method configures the web host using the Startup
class, which is where you can configure the server.
Program.cs
var builder = WebApplication.CreateEmptyBuilder(new WebApplicationOptions( ));
builder.UseTcpConnectionHandler<MyCustomProcessor>(6667);
builder.Logging.AddConsole();
var app = builder.Build();
await app.RunAsync();
MyCustomProcessor.cs
public class MyCustomProcessor : IConnectionProcessor
{
private readonly ILogger<MyCustomProcessor> _logger;
public MyCustomProcessor(ILogger<MyCustomProcessor> logger)
{
_logger = logger;
}
public async Task<ReadOnlyMemory<byte>> ProcessAsync(ReadOnlyMemory<byte> input)
{
var stringInput = Encoding.UTF8.GetString(input.ToArray());
_logger.LogInformation("Received: {Input}", stringInput);
return new ReadOnlyMemory<byte>("OK"u8.ToArray());
}
}
Client
The client is a simple interface called ITcpClient
that provides a simple API for connecting to a server and sending and receiving data. It has an extension method called AddTcpClient
that can be used to configure the client in your Startup
class or Program
class.
Program.cs
var builder = Host.CreateApplicationBuilder(args);
builder.Services.AddTcpClient(options =>
{
options.Timeout = TimeSpan.FromSeconds(5);
});
builder.Services.AddHostedService<Worker>();
var host = builder.Build();
host.Run();
Worker.cs
public class Worker : BackgroundService
{
private readonly ILogger<Worker> _logger;
private readonly ITcpClient _tcpClient;
public Worker(ILogger<Worker> logger, ITcpClient tcpClient)
{
_logger = logger;
_tcpClient = tcpClient;
}
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
while (!stoppingToken.IsCancellationRequested)
{
if (_logger.IsEnabled(LogLevel.Information))
{
var response = await _tcpClient.SendAsync(IPAddress.Loopback, 6667, "Hello World"u8.ToArray());
if (response.Length > 0)
{
_logger.LogInformation("Received: {Response}", Encoding.UTF8.GetString(response.ToArray()));
}
}
await Task.Delay(1000, stoppingToken);
}
}
}
Lack of Tests
Except for the sample projects, there are no tests. This is because theres very little to test. The XUnit project is there to make it easy to start testing, but the actual test cases are not very clear at this time.
Contributing
Not all contributions are code! We welcome contributions from everyone, but please see our contributing guide for more information.
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. |
-
net8.0
- No dependencies.
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.1.3-preview | 65 | 11/3/2024 |
1.1.0 | 145 | 1/21/2024 |
1.0.1-preview | 113 | 1/2/2024 |
1.0.0 | 148 | 12/20/2023 |
0.1.3-preview | 109 | 12/20/2023 |
0.1.0 | 121 | 12/20/2023 |