2022-02-14 11:18:58 +00:00
|
|
|
|
using ASC.Core;
|
|
|
|
|
using ASC.Data.Backup.Core.IntegrationEvents.Events;
|
2022-02-23 12:33:42 +00:00
|
|
|
|
using ASC.EventBus.Exceptions;
|
2022-02-14 11:18:58 +00:00
|
|
|
|
|
|
|
|
|
namespace ASC.Data.Backup.IntegrationEvents.EventHandling;
|
|
|
|
|
|
|
|
|
|
[Scope]
|
|
|
|
|
public class BackupRequesteIntegrationEventHandler : IIntegrationEventHandler<BackupRequestIntegrationEvent>
|
|
|
|
|
{
|
|
|
|
|
private readonly BackupAjaxHandler _backupAjaxHandler;
|
|
|
|
|
private readonly ILog _logger;
|
|
|
|
|
private readonly TenantManager _tenantManager;
|
|
|
|
|
private readonly SecurityContext _securityContext;
|
|
|
|
|
private readonly AuthManager _authManager;
|
|
|
|
|
|
|
|
|
|
public BackupRequesteIntegrationEventHandler(
|
|
|
|
|
BackupAjaxHandler backupAjaxHandler,
|
|
|
|
|
IOptionsMonitor<ILog> logger,
|
|
|
|
|
TenantManager tenantManager,
|
|
|
|
|
SecurityContext securityContext,
|
|
|
|
|
AuthManager authManager
|
|
|
|
|
)
|
|
|
|
|
{
|
|
|
|
|
_tenantManager = tenantManager;
|
|
|
|
|
_authManager = authManager;
|
|
|
|
|
_securityContext = securityContext;
|
|
|
|
|
_backupAjaxHandler = backupAjaxHandler;
|
|
|
|
|
_logger = logger.CurrentValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task Handle(BackupRequestIntegrationEvent @event)
|
|
|
|
|
{
|
2022-02-23 12:33:42 +00:00
|
|
|
|
_logger.InfoFormat("----- Handling integration event: {IntegrationEventId} at {AppName} - ({@IntegrationEvent})", @event.Id, Program.AppName, @event);
|
|
|
|
|
|
2022-02-14 11:18:58 +00:00
|
|
|
|
_tenantManager.SetCurrentTenant(@event.TenantId);
|
|
|
|
|
|
|
|
|
|
_securityContext.AuthenticateMeWithoutCookie(_authManager.GetAccountByID(@event.TenantId, @event.CreateBy));
|
|
|
|
|
|
|
|
|
|
_backupAjaxHandler.StartBackup(@event.StorageType, @event.StorageParams, @event.BackupMail);
|
|
|
|
|
|
2022-02-23 12:33:42 +00:00
|
|
|
|
throw new IntegrationEventRejectExeption("Backup service is very busy");
|
|
|
|
|
|
2022-02-14 11:18:58 +00:00
|
|
|
|
await Task.CompletedTask;
|
2022-02-23 12:33:42 +00:00
|
|
|
|
|
2022-02-14 11:18:58 +00:00
|
|
|
|
}
|
|
|
|
|
}
|