SolTechnology.Core
0.1.0
dotnet add package SolTechnology.Core --version 0.1.0
NuGet\Install-Package SolTechnology.Core -Version 0.1.0
<PackageReference Include="SolTechnology.Core" Version="0.1.0" />
<PackageVersion Include="SolTechnology.Core" Version="0.1.0" />
<PackageReference Include="SolTechnology.Core" />
paket add SolTechnology.Core --version 0.1.0
#r "nuget: SolTechnology.Core, 0.1.0"
#:package SolTechnology.Core@0.1.0
#addin nuget:?package=SolTechnology.Core&version=0.1.0
#tool nuget:?package=SolTechnology.Core&version=0.1.0
<p align="center"> <img alt="SolTechnology-logo" src="./docs/logo.png" width="200"> </p>
<h2 align="center"> SolTechnology.Core </h2>
<p align="center"> <a>Modern readable coding</a> </p>
<p align="center"> <a href="https://dotnet.microsoft.com/download/dotnet/10.0"><img src="https://img.shields.io/badge/.NET-10.0-512BD4?logo=microsoft"></a> <a href="https://www.nuget.org/packages?q=SolTechnology"> <img src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fraw.githubusercontent.com%2FAdrianStrugala%2FSolTechnology.Core%2Fmaster%2Fnuget-stats.json&query=%24.totals.downloads&label=NuGet%20Downloads&logo=nuget&color=blue&suffix=%20total"> </a> <a href="https://github.com/AdrianStrugala/SolTechnology.Core/actions"><img src="https://img.shields.io/github/actions/workflow/status/AdrianStrugala/SolTechnology.Core/publishPackages.yml?branch=master&logo=github&label=build%26tests"></a> </p>
<i> <p align="center"> "Clean code is simple and direct. Clean code reads like well-written prose. Clean code never obscures the designer's intent but rather is full of crisp abstractions and straightforward lines of control." </p> <p align="right"> ~Grady Booch, author of 'Object-Oriented Analysis and Design with Applications' </p> </i>
Core Libraries
The SolTechnology.Core repository contains a set of shared libraries. This is a foundation for CQRS-driven applications using basic Azure technologies. The libraries support a modern coding approach presented in the example applications.
| Documentation | Tags | NuGet |
|---|---|---|
| Core (foundation) | Result, Error, Foundation |
<a href="https://www.nuget.org/packages/SolTechnology.Core/"><img src="https://badgen.net/nuget/v/SolTechnology.Core?icon=nuget&color=blue"></a> |
| API | API, Web, Controllers |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Api/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Api?icon=nuget&color=blue"></a> |
| HTTP Clients | HTTP, Client, REST |
<a href="https://www.nuget.org/packages/SolTechnology.Core.ApiClient/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.ApiClient?icon=nuget&color=blue"></a> |
| AUID | GUID, UUID, ID, Identifier |
<a href="https://www.nuget.org/packages/SolTechnology.Core.AUID/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.AUID?icon=nuget&color=blue"></a> |
| Authentication | Auth, Security, Basic, API key |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Authentication/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Authentication?icon=nuget&color=blue"></a> |
| Blob Storage | Azure, Blob, Storage, no-SQL |
<a href="https://www.nuget.org/packages/SolTechnology.Core.BlobStorage/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.BlobStorage?icon=nuget&color=blue"></a> |
| Cache | Cache, Memory, Performance |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Cache/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Cache?icon=nuget&color=blue"></a> |
| CQRS | CQRS, Patterns, Architecture |
<a href="https://www.nuget.org/packages/SolTechnology.Core.CQRS/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.CQRS?icon=nuget&color=blue"></a> |
| Hangfire | Hangfire, Events, Jobs, Cron |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Hangfire/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Hangfire?icon=nuget&color=blue"></a> |
| Story Framework | Workflow, Interactive, Tale Code |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Story/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Story?icon=nuget&color=blue"></a> |
| Logging | Logging, Diagnostics, Tracing |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Logging/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Logging?icon=nuget&color=blue"></a> |
| Message Bus | Azure, Messaging, Async, Queue |
<a href="https://www.nuget.org/packages/SolTechnology.Core.MessageBus/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.MessageBus?icon=nuget&color=blue"></a> |
| SQL Database | Database, SQL, ORM, Dapper, EF |
<a href="https://www.nuget.org/packages/SolTechnology.Core.SQL/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.SQL?icon=nuget&color=blue"></a> |
Testing companions
Modular NUnit .Testing packages for component / integration tests — one companion per concern, all on
the shared SolTechnology.Core.Testing foundation. Reference from test projects only.
| Documentation | Tags | NuGet |
|---|---|---|
| Testing (foundation) | Testing, NUnit, AutoFixture |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Testing/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Testing?icon=nuget&color=blue"></a> |
| API Testing | TestServer, Integration |
<a href="https://www.nuget.org/packages/SolTechnology.Core.API.Testing/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.API.Testing?icon=nuget&color=blue"></a> |
| SQL Testing | SQL, Postgres, Testcontainers |
<a href="https://www.nuget.org/packages/SolTechnology.Core.SQL.Testing/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.SQL.Testing?icon=nuget&color=blue"></a> |
| HTTP Testing | HTTP, WireMock, Mocks |
<a href="https://www.nuget.org/packages/SolTechnology.Core.HTTP.Testing/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.HTTP.Testing?icon=nuget&color=blue"></a> |
| Redis Testing | Redis, Cache, Testcontainers |
<a href="https://www.nuget.org/packages/SolTechnology.Core.Redis.Testing/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.Redis.Testing?icon=nuget&color=blue"></a> |
| Blob Storage Testing | Azure, Blob, Azurite |
<a href="https://www.nuget.org/packages/SolTechnology.Core.BlobStorage.Testing/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.BlobStorage.Testing?icon=nuget&color=blue"></a> |
| Service Bus Testing | Azure, Service Bus, Emulator |
<a href="https://www.nuget.org/packages/SolTechnology.Core.ServiceBus.Testing/"><img src="https://badgen.net/nuget/v/SolTechnology.Core.ServiceBus.Testing?icon=nuget&color=blue"></a> |
Tale Code
The idea of clean and readable code has stayed with me from the very beginning of my career. As a book lover and amateur writer, this is the most natural part of programming.
In the Tale Code approach, I am trying to summarize all the information about coding, design, automation, and configuration that I have learned over the years. The Tale Code rule is simple:
<i> <p align="center"> "Make your code a pleasure to read, like a tale." </p> <p align="right"> ~Adrian Aleksander Strugała </p> </i>
The sample application is the most common case that came to my mind. It's built of a user-facing API and a background worker responsible for fetching data and feeding the SQL database. The communication between these two is asynchronous and based on messages, as shown in the picture:
<p> <b>Code design is the main goal</b> of Tale Code. Logical flow and code structure are described in detail, and it reads like a well-written story:
public class CalculateBestPathTale(IServiceProvider serviceProvider, ILogger<CalculateBestPathTale> logger)
: StoryHandler<CalculateBestPathQuery, CalculateBestPathContext, CalculateBestPathResult>(serviceProvider, logger),
IQueryHandler<CalculateBestPathQuery, CalculateBestPathResult>
{
protected override Tale<CalculateBestPathResult> Tell() =>
Open<InitiateContext>()
.Expect(ctx => ctx.NoOfCities > 1,
new NotFoundError { Message = "A route needs at least two cities." })
.Read<DownloadRoadData>()
.Read<FindProfitablePath>()
.Otherwise<JustOrderCities>() // no profitable route → just order by distance
.Read<SolveTsp>()
.WhenLost(error => logger.LogWarning("Best path calculation failed: {Error}", error.Message))
.Read<FormCalculateBestPathResult>()
.Finale(ctx => ctx.Output);
}
I have summarized the knowledge and decisions into three chapters.
Enjoy your reading!
</p>
1. The Design
2. The Automation
3. The Quality
Some ending words
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. 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. |
-
net10.0
- Microsoft.Extensions.Configuration (>= 10.0.1)
- Microsoft.Extensions.Configuration.Binder (>= 10.0.1)
- Microsoft.Extensions.DependencyInjection (>= 10.0.1)
- Microsoft.Extensions.Options (>= 10.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on SolTechnology.Core:
| Package | Downloads |
|---|---|
|
SolTechnology.Core.Story
Story Framework - Unified workflow orchestration for multi-step business processes. Supports both simple automated chains and pausable workflows with persistence. Features Tale Code philosophy with StoryHandler, Chapters, and Context for readable, maintainable business logic. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 0.1.0 | 79 | 6/19/2026 |