private async Task TryTrackMessageAsync( Optional <Snowflake> guild, IMessageCreate?message, Func <ulong, Task> asyncTrackAction) { if (!guild.HasValue) { MessageLogMessages.IgnoringNonGuildMessage(_logger); return; } if (message != null) { var author = message.Author; if ((author.IsBot.HasValue && author.IsBot.Value) || message.WebhookID.HasValue) { MessageLogMessages.IgnoringNonHumanMessage(_logger); return; } if (message.Content.StartsWith("!")) { MessageLogMessages.IgnoringCommandMessage(_logger); return; } } MessageLogMessages.TransactionBeginning(_logger); using var transaction = await _messageRepository.BeginMaintainTransactionAsync(); await asyncTrackAction.Invoke(guild.Value.Value); transaction.Commit(); MessageLogMessages.TransactionCommitted(_logger); }