Skip to content

Commit

Permalink
feat: Log alarm notification supports the transmission of log data (#342
Browse files Browse the repository at this point in the history
)
  • Loading branch information
wzh425 authored Apr 10, 2024
1 parent e50ae53 commit ba63fca
Show file tree
Hide file tree
Showing 3 changed files with 55 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,20 @@ public class SendAlarmNotificationEventHandler
private readonly INotificationSender _notificationSender;
private readonly IAlarmHistoryRepository _repository;
private readonly IAlarmRuleRepository _alarmRuleRepository;
private readonly ITscClient _tscClient;
private readonly AlarmRuleDomainService _domainService;

public SendAlarmNotificationEventHandler(INotificationSender notificationSender
, IAlarmHistoryRepository repository
, IAlarmRuleRepository alarmRuleRepository)
, IAlarmRuleRepository alarmRuleRepository
, ITscClient tscClient
, AlarmRuleDomainService domainService)
{
_notificationSender = notificationSender;
_repository = repository;
_alarmRuleRepository = alarmRuleRepository;
_tscClient = tscClient;
_domainService = domainService;
}

[EventHandler]
Expand All @@ -35,6 +41,11 @@ public async Task HandleEventAsync(SendAlarmNotificationEvent eto)
if (alarmRule != null)
{
variables.TryAdd(AlertConsts.ALARM_RULE_NAME_NOTIFICATION_TEMPLATE_VAR_NAME, alarmRule.DisplayName);

if (alarmRule.Type == AlarmRuleTypes.Log)
{
await AddLogVariablesAsync(alarmRule, variables);
}
}

await _notificationSender.SendAsync(notificationConfig, variables);
Expand All @@ -43,4 +54,44 @@ public async Task HandleEventAsync(SendAlarmNotificationEvent eto)
alarm.Notification();
await _repository.UpdateAsync(alarm);
}

private async Task AddLogVariablesAsync(AlarmRule alarmRule, Dictionary<string, object> variables)
{
var checkTime = DateTimeOffset.Now;
var latest = await _domainService.GetLatest(alarmRule.Id);
var startTime = alarmRule.GetStartCheckTime(checkTime, latest);
if (startTime == null)
return;

var request = new LogLatestRequest
{
Query = alarmRule.WhereExpression,
Start = startTime.Value.UtcDateTime,
End = checkTime.UtcDateTime,
IsDesc = true
};

var log = await _tscClient.LogService.GetLatestAsync(request);
if (log == null)
return;

var prefix = "Log";
variables.TryAdd($"{prefix}.{nameof(log.Timestamp)}", log.Timestamp);
variables.TryAdd($"{prefix}.{nameof(log.TraceId)}", log.TraceId);
variables.TryAdd($"{prefix}.{nameof(log.SpanId)}", log.SpanId);
variables.TryAdd($"{prefix}.{nameof(log.TraceFlags)}", log.TraceFlags);
variables.TryAdd($"{prefix}.{nameof(log.SeverityText)}", log.SeverityText);
variables.TryAdd($"{prefix}.{nameof(log.SeverityNumber)}", log.SeverityNumber);
variables.TryAdd($"{prefix}.{nameof(log.Body)}", log.Body);

foreach (var resource in log.Resource)
{
variables.TryAdd($"{prefix}.{nameof(log.Resource)}.{nameof(resource.Key)}", resource.Value);
}

foreach (var attribute in log.Attributes)
{
variables.TryAdd($"{prefix}.{nameof(log.Attributes)}.{nameof(attribute.Key)}", attribute.Value);
}
}
}
3 changes: 2 additions & 1 deletion src/Application/Masa.Alert.Application/_Imports.cs
Original file line number Diff line number Diff line change
Expand Up @@ -56,4 +56,5 @@
global using Masa.BuildingBlocks.Caching;
global using Masa.Alert.Domain.Shared.Consts;
global using Masa.BuildingBlocks.Extensions.BackgroundJobs;
global using Masa.Alert.Application.AlarmRules.Commands;
global using Masa.Alert.Application.AlarmRules.Commands;
global using Masa.BuildingBlocks.StackSdks.Tsc.Contracts.Log;
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ protected override void OnModelCreatingExecuting(ModelBuilder builder)
protected override void OnConfiguring(MasaDbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.DbContextOptionsBuilder
.LogTo(Console.WriteLine, LogLevel.Information)
.LogTo(Console.WriteLine, LogLevel.Error)
.EnableSensitiveDataLogging()
.EnableDetailedErrors();
}
Expand Down

0 comments on commit ba63fca

Please sign in to comment.