2022-03-02 15:25:28 +00:00
|
|
|
|
using ASC.EventBus.Exceptions;
|
|
|
|
|
|
|
|
|
|
namespace ASC.Data.Backup.IntegrationEvents.EventHandling;
|
2022-02-14 11:18:58 +00:00
|
|
|
|
|
|
|
|
|
[Scope]
|
2022-02-24 16:53:49 +00:00
|
|
|
|
public class BackupRequestIntegrationEventHandler : IIntegrationEventHandler<BackupRequestIntegrationEvent>
|
2022-02-14 11:18:58 +00:00
|
|
|
|
{
|
|
|
|
|
private readonly BackupAjaxHandler _backupAjaxHandler;
|
|
|
|
|
private readonly ILog _logger;
|
|
|
|
|
private readonly TenantManager _tenantManager;
|
|
|
|
|
private readonly SecurityContext _securityContext;
|
|
|
|
|
private readonly AuthManager _authManager;
|
2022-02-24 16:53:49 +00:00
|
|
|
|
private readonly BackupWorker _backupWorker;
|
2022-02-14 11:18:58 +00:00
|
|
|
|
|
2022-02-24 16:53:49 +00:00
|
|
|
|
public BackupRequestIntegrationEventHandler(
|
2022-02-14 11:18:58 +00:00
|
|
|
|
BackupAjaxHandler backupAjaxHandler,
|
|
|
|
|
IOptionsMonitor<ILog> logger,
|
|
|
|
|
TenantManager tenantManager,
|
|
|
|
|
SecurityContext securityContext,
|
2022-02-24 16:53:49 +00:00
|
|
|
|
AuthManager authManager,
|
|
|
|
|
BackupWorker backupWorker)
|
2022-02-14 11:18:58 +00:00
|
|
|
|
{
|
|
|
|
|
_tenantManager = tenantManager;
|
|
|
|
|
_authManager = authManager;
|
|
|
|
|
_securityContext = securityContext;
|
|
|
|
|
_backupAjaxHandler = backupAjaxHandler;
|
2022-02-24 16:53:49 +00:00
|
|
|
|
_logger = logger.CurrentValue;
|
|
|
|
|
_backupWorker = backupWorker;
|
2022-02-14 11:18:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
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-03-02 15:25:28 +00:00
|
|
|
|
if (!@event.Redelivered)
|
|
|
|
|
{
|
2022-04-01 14:37:21 +00:00
|
|
|
|
if (_backupWorker.IsInstanceTooBusy())
|
2022-03-02 15:25:28 +00:00
|
|
|
|
{
|
|
|
|
|
throw new IntegrationEventRejectExeption(@event.Id);
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-02-14 11:18:58 +00:00
|
|
|
|
|
2022-03-02 15:25:28 +00:00
|
|
|
|
_tenantManager.SetCurrentTenant(@event.TenantId);
|
2022-02-14 11:18:58 +00:00
|
|
|
|
_securityContext.AuthenticateMeWithoutCookie(_authManager.GetAccountByID(@event.TenantId, @event.CreateBy));
|
2022-03-01 12:57:49 +00:00
|
|
|
|
|
2022-02-24 16:53:49 +00:00
|
|
|
|
if (@event.IsScheduled)
|
|
|
|
|
{
|
|
|
|
|
_backupWorker.StartScheduledBackup(new EF.Model.BackupSchedule
|
|
|
|
|
{
|
|
|
|
|
BackupMail = @event.BackupMail,
|
|
|
|
|
BackupsStored = @event.BackupsStored,
|
|
|
|
|
StorageBasePath = @event.StorageBasePath,
|
|
|
|
|
StorageParams = JsonConvert.SerializeObject(@event.StorageParams),
|
|
|
|
|
StorageType = @event.StorageType,
|
|
|
|
|
TenantId = @event.TenantId
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
_backupAjaxHandler.StartBackup(@event.StorageType, @event.StorageParams, @event.BackupMail);
|
|
|
|
|
}
|
2022-02-23 12:33:42 +00:00
|
|
|
|
|
2022-02-14 11:18:58 +00:00
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
}
|