![]() |
VOOZH | about |
dotnet add package Lirxe.VK --version 1.0.4.1
NuGet\Install-Package Lirxe.VK -Version 1.0.4.1
<PackageReference Include="Lirxe.VK" Version="1.0.4.1" />
<PackageVersion Include="Lirxe.VK" Version="1.0.4.1" />Directory.Packages.props
<PackageReference Include="Lirxe.VK" />Project file
paket add Lirxe.VK --version 1.0.4.1
#r "nuget: Lirxe.VK, 1.0.4.1"
#:package Lirxe.VK@1.0.4.1
#addin nuget:?package=Lirxe.VK&version=1.0.4.1Install as a Cake Addin
#tool nuget:?package=Lirxe.VK&version=1.0.4.1Install as a Cake Tool
Lirxe provides a lightweight and MVC-like way to build your chatbot application using .NET Core.
The base idea of Lirxe is a source (or listener) getting events should be passed to runner which executes an action, or command inside a controller.
private static async Task Main(string[] args)
{
var bot = new
{
AccessToken = "ACCESS_TOKEN",
PublicId = (ulong)1
};
var vk = new VkApi();
vk.Authorize(new ApiAuthParams(){AccessToken = bot.AccessToken});
var source = new LongpoolSource(vk, bot.PublicId);
var run = new Runner(new[] {Assembly.GetExecutingAssembly()});
source.Request += ctx => run.Run(ctx);
await source.RunAsync();
}
Here we are using a LongpoolSource to get events from VK LongPool API (make sure it's enabled in your group's settings), then pass these to Runner, which will execute an action.
Actions are living inside Controllers. This is an example:
public class Controller:BaseController
{
public Controller(ActionContext ctx) : base(ctx) { }
[DefaultAction]
public void Default() => Send("This is default action");
[Action("hello")]
public async void Hello()
{
Send("How you doing?");
Send($"You doing {(await Prompt("no", ()=>{Send("sad"); Default();})).Text}");
}
}
There is the Default action being executed when no actions are matching. You can be creative for putting any "Command not found" text here, or usage help, or maybe just ignore it.
Action attribute is used for defining method as actual action. In this example, it just asks the user about hyd using Prompt (i will explain it later), then returns his input (or "sad" when it cancels prompt using "no" word)
Comming soon.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 net5.0 is compatible. net5.0-windows net5.0-windows was computed. net6.0 net6.0 was computed. net6.0-android net6.0-android was computed. net6.0-ios net6.0-ios was computed. net6.0-maccatalyst net6.0-maccatalyst was computed. net6.0-macos net6.0-macos was computed. net6.0-tvos net6.0-tvos was computed. net6.0-windows net6.0-windows was computed. net7.0 net7.0 was computed. net7.0-android net7.0-android was computed. net7.0-ios net7.0-ios was computed. net7.0-maccatalyst net7.0-maccatalyst was computed. net7.0-macos net7.0-macos was computed. net7.0-tvos net7.0-tvos was computed. net7.0-windows net7.0-windows was computed. net8.0 net8.0 was computed. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 was computed. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.