You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
2.3 KiB
61 lines
2.3 KiB
using LINGYUN.Abp.IM;
|
|
using LINGYUN.Abp.IM.Messages;
|
|
using LINGYUN.Abp.RealTime;
|
|
using Microsoft.Extensions.Logging;
|
|
using Microsoft.Extensions.Logging.Abstractions;
|
|
using Microsoft.Extensions.Options;
|
|
using System.Threading.Tasks;
|
|
using Volo.Abp.DependencyInjection;
|
|
using Volo.Abp.EventBus.Distributed;
|
|
|
|
namespace LY.MicroService.RealtimeMessage.EventBus.Distributed
|
|
{
|
|
public class ChatMessageEventHandler : IDistributedEventHandler<RealTimeEto<ChatMessage>>, ITransientDependency
|
|
{
|
|
/// <summary>
|
|
/// Reference to <see cref="ILogger<DefaultNotificationDispatcher>"/>.
|
|
/// </summary>
|
|
public ILogger<ChatMessageEventHandler> Logger { get; set; }
|
|
/// <summary>
|
|
/// Reference to <see cref="AbpIMOptions"/>.
|
|
/// </summary>
|
|
protected AbpIMOptions Options { get; }
|
|
|
|
protected IMessageStore MessageStore { get; }
|
|
protected IMessageBlocker MessageBlocker { get; }
|
|
protected IMessageSenderProviderManager MessageSenderProviderManager { get; }
|
|
|
|
public ChatMessageEventHandler(
|
|
IOptions<AbpIMOptions> options,
|
|
IMessageStore messageStore,
|
|
IMessageBlocker messageBlocker,
|
|
IMessageSenderProviderManager messageSenderProviderManager)
|
|
{
|
|
Options = options.Value;
|
|
MessageStore = messageStore;
|
|
MessageBlocker = messageBlocker;
|
|
MessageSenderProviderManager = messageSenderProviderManager;
|
|
|
|
Logger = NullLogger<ChatMessageEventHandler>.Instance;
|
|
}
|
|
|
|
public async virtual Task HandleEventAsync(RealTimeEto<ChatMessage> eventData)
|
|
{
|
|
Logger.LogDebug($"Persistent chat message.");
|
|
|
|
var message = eventData.Data;
|
|
// 消息拦截
|
|
// 扩展敏感词汇过滤
|
|
await MessageBlocker.InterceptAsync(message);
|
|
|
|
await MessageStore.StoreMessageAsync(message);
|
|
|
|
// 发送消息
|
|
foreach (var provider in MessageSenderProviderManager.Providers)
|
|
{
|
|
Logger.LogDebug($"Sending message with provider {provider.Name}");
|
|
await provider.SendMessageAsync(message);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|