Termin36.LiteStateMachine
0.1.2
See the version list below for details.
dotnet add package Termin36.LiteStateMachine --version 0.1.2
NuGet\Install-Package Termin36.LiteStateMachine -Version 0.1.2
<PackageReference Include="Termin36.LiteStateMachine" Version="0.1.2" />
paket add Termin36.LiteStateMachine --version 0.1.2
#r "nuget: Termin36.LiteStateMachine, 0.1.2"
// Install Termin36.LiteStateMachine as a Cake Addin #addin nuget:?package=Termin36.LiteStateMachine&version=0.1.2 // Install Termin36.LiteStateMachine as a Cake Tool #tool nuget:?package=Termin36.LiteStateMachine&version=0.1.2
О проекте
Проект формирует библиотеку для построения машин конечных состояний (State Machine), с помощью которых возможно строить сложную модель поведения с реакцией на воздействия. Ценность библиотеки в простоте и независимости от окружения, благодаря чему ее можно без сомнений интегрировать например в слой домена (DDD)
Более подробно можно ознакомиться в Wiki По вопросам и развитию ходить сюда
Возможности ядра
- Хранение состояния во внешнем хранилище
- Журнал транзакций (в разработке)
- Обработка событий
- Активация и деактивация состояния (OnActivate и OnDeactivate)
- Вход и выход изи состояния (OnEntry и OnExit)
- Обработка пользовательского события на срабатывание триггера (OnAction, OnActionIf)
- Переходы между состояниями
- Без проверки условий
- Переход с известным конечным состоянием (ChangeState)
- Переход с определением конечного состояния с помощью функции (ChangeStateDynamic)
- Игнорирование перехода (NotChangeState)
- С проверкой условия
- Переход с известным конечным состоянием с проверкой условия (ChangeStateIf)
- Переход с определением конечного состояния с помощью функции с проверкой условия (ChangeStateDynamicIf)
- Игнорирование перехода с условием (NotChangeStateIf)
- Без проверки условий
Пример использования
Устанавливаем пакет
dotnet add package Termin36.LiteStateMachine --version x.x.x
Используем
StateMachine<State, Trigger> stateMachine = new StateMachine<State, Trigger>(State.StateA);
stateMachine.Configuration(State.StateA)
.OnAction(_triggerRegister, RegistrationPeople);
.ChangeState(_triggerMove, State.StateMoving);
stateMachine.Configuration(State.StateMoving)
.ChangeStateIf(_triggerRegister, State.StateA, IsAllowRegistration, "Регистрировать пользователей сейчас нельзя");
stateMachine.ValidateStateMachine();
await stateMachine.Fire(_triggerRegister, new People("Иванов", "Иван");
await stateMachine.Fire(_triggerMove, null);
await stateMachine.Fire(_triggerRegister, new People("Петров", "Петр"); // сработает исключение, так как обработать нельзя
Более подробно можно ознакомиться в Wiki
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. 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. |
-
net7.0
- System.Linq.Async (>= 6.0.1)
- System.Linq.Async.Queryable (>= 6.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Termin36.LiteStateMachine:
Package | Downloads |
---|---|
Termin36.TelegramDialogs
Пакет служит для целей упрощения создания диалогов в Телеграм боте. Основан на машине состояний |
GitHub repositories
This package is not used by any popular GitHub repositories.