Доработан стартер адаптеров
This commit is contained in:
@@ -21,32 +21,44 @@ namespace BotPages.Telegram;
|
||||
/// Адаптер для Telegram на базе Telegram.Bot.
|
||||
/// Реализует отправку текста, кнопок, файлов, альбомов и прогресса.
|
||||
/// </summary>
|
||||
public sealed class TelegramAdapter : IMessengerAdapter
|
||||
public sealed class TelegramAdapter : IMessangerAdapterSetup
|
||||
{
|
||||
private readonly ILogger _logger;
|
||||
private TelegramBotClient? _client;
|
||||
private string _token;
|
||||
private string _messagerType;
|
||||
|
||||
/// <summary>Создать адаптер Telegram.</summary>
|
||||
public TelegramAdapter(ILogger logger) => _logger = logger;
|
||||
public TelegramAdapter(ILogger logger, string token)
|
||||
{
|
||||
_logger = logger;
|
||||
_token = token;
|
||||
_messagerType = "Telegram: " + Guid.NewGuid().ToString();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
///Идентификатор мессенджера / адаптера
|
||||
/// </summary>
|
||||
public string MessagerType => _messagerType;
|
||||
|
||||
/// <summary>
|
||||
/// Запустить polling для приема обновлений от Telegram.
|
||||
/// </summary>
|
||||
public async Task StartPollingAsync(string token, Func<UpdateContext, Task> onUpdate, CancellationToken ct)
|
||||
public async Task StartAdapterAsync(Func<UpdateContext, Task> onUpdate, CancellationToken ct)
|
||||
{
|
||||
_client = new TelegramBotClient(token);
|
||||
_client = new TelegramBotClient(_token);
|
||||
|
||||
_client.StartReceiving(
|
||||
updateHandler: async (_, update, ct2) =>
|
||||
{
|
||||
var mapped = TelegramUpdateMapper.Map(update, _client);
|
||||
var mapped = TelegramUpdateMapper.Map(_messagerType, update, _client);
|
||||
if (mapped is not null)
|
||||
await onUpdate(mapped);
|
||||
},
|
||||
|
||||
errorHandler: async (_, ex, ct2) =>
|
||||
{
|
||||
_logger.Log(LogLevel.Warn, "Telegram error.", ex);
|
||||
_logger.Log(LogLevel.Warn, $"{_messagerType} error.", ex);
|
||||
await Task.CompletedTask;
|
||||
},
|
||||
|
||||
@@ -55,7 +67,7 @@ public sealed class TelegramAdapter : IMessengerAdapter
|
||||
|
||||
|
||||
var me = await _client.GetMe();
|
||||
_logger.Log(LogLevel.Info, $"Telegram started: @{me.Username}");
|
||||
_logger.Log(LogLevel.Info, $"{_messagerType} started: @{me.Username}");
|
||||
|
||||
return;
|
||||
}
|
||||
@@ -67,7 +79,7 @@ public sealed class TelegramAdapter : IMessengerAdapter
|
||||
{
|
||||
if (_client is null)
|
||||
{
|
||||
_logger.Log(LogLevel.Critical, "Telegram client is not initialized.");
|
||||
_logger.Log(LogLevel.Critical, $"{_messagerType} client is not initialized.");
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -137,7 +149,7 @@ public sealed class TelegramAdapter : IMessengerAdapter
|
||||
{
|
||||
if (_client is null)
|
||||
{
|
||||
_logger.Log(LogLevel.Critical, "Telegram client is not initialized.");
|
||||
_logger.Log(LogLevel.Critical, $"{_messagerType} client is not initialized.");
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -192,7 +204,7 @@ public sealed class TelegramAdapter : IMessengerAdapter
|
||||
{
|
||||
if (_client is null)
|
||||
{
|
||||
_logger.Log(LogLevel.Critical, "Telegram client is not initialized.");
|
||||
_logger.Log(LogLevel.Critical, $"{_messagerType} client is not initialized.");
|
||||
return null;
|
||||
}
|
||||
|
||||
@@ -216,7 +228,7 @@ public sealed class TelegramAdapter : IMessengerAdapter
|
||||
{
|
||||
if (_client is null)
|
||||
{
|
||||
_logger.Log(LogLevel.Critical, "Telegram client is not initialized.");
|
||||
_logger.Log(LogLevel.Critical, $"{_messagerType} client is not initialized.");
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user