Доработаны паттерны команд

This commit is contained in:
2025-12-07 11:17:21 +03:00
parent 67de9e197a
commit 7556b3d638
3 changed files with 22 additions and 8 deletions

View File

@@ -67,15 +67,25 @@ internal sealed class CommandsRegistry
/// </summary> /// </summary>
private static Regex ToRegex(string template) private static Regex ToRegex(string template)
{ {
var escaped = Regex.Escape(template) // Заменяем все {name} и {name?} на регулярные группы
.Replace("\\{", "{").Replace("\\}", "}"); var pattern = "^" + Regex.Replace(template, @"\s*\{(\w+)(\?)?\}", m =>
var pattern = "^" + Regex.Replace(escaped, @"\{(\w+)(\?)?\}", m =>
{ {
var name = m.Groups[1].Value; var name = m.Groups[1].Value;
var optional = m.Groups[2].Success; var optional = m.Groups[2].Success;
return optional ? $"(?<{name}>\\S+)?" : $"(?<{name}>\\S+)";
}) + "$"; var argPattern = $"(?:\"(?<{name}>[^\"]+)\"|(?<{name}>\\S+))";
if (optional)
{
// необязательный параметр: пробел + значение целиком необязательны
return $"(?:\\s+{argPattern})?";
}
else
{
// обязательный параметр: пробел обязателен
return $"\\s+{argPattern}";
}
}) + "\\s*$"; // допускаем пробелы/переносы в конце
return new Regex(pattern, RegexOptions.Compiled | RegexOptions.IgnoreCase); return new Regex(pattern, RegexOptions.Compiled | RegexOptions.IgnoreCase);
} }

View File

@@ -66,6 +66,10 @@ public sealed class TelegramAdapter : IMessangerAdapterSetup
var mapped = TelegramUpdateMapper.Map(MessengerType, update, _client); var mapped = TelegramUpdateMapper.Map(MessengerType, update, _client);
if (mapped is not null) if (mapped is not null)
await onUpdate(mapped); await onUpdate(mapped);
if (update.CallbackQuery is not null)
{
await _.AnswerCallbackQuery(update.CallbackQuery.Id);
}
}, },
errorHandler: async (_, ex, ct2) => errorHandler: async (_, ex, ct2) =>

View File

@@ -54,8 +54,8 @@ public sealed class DetailsPage : StatefullPage<string>
await ctx.Navigation.GoToAsync<FilesPage>(ctx, ct); await ctx.Navigation.GoToAsync<FilesPage>(ctx, ct);
} }
internal static string Command => "/create_request {title}"; internal static string Command => "/create_request {title?}";
internal static string CommandDescription => "создание заявки /create_request {title"; internal static string CommandDescription => "создание заявки /create_request {title}";
internal static CommandHandler CommandHandler = async (ctx, args, ct) => internal static CommandHandler CommandHandler = async (ctx, args, ct) =>
{ {
string? title = ""; string? title = "";