1
0
mirror of https://github.com/bitwarden/server.git synced 2024-12-02 13:53:23 +01:00
bitwarden-server/src/Notifications/AzureQueueHostedService.cs

95 lines
3.3 KiB
C#
Raw Normal View History

2018-08-02 18:14:33 +02:00
using System;
2018-08-02 23:23:37 +02:00
using System.Linq;
2018-08-02 18:14:33 +02:00
using System.Threading;
using System.Threading.Tasks;
2018-08-02 23:23:37 +02:00
using Bit.Core;
using Bit.Core.Models;
2018-08-02 18:14:33 +02:00
using Microsoft.AspNetCore.SignalR;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
2018-08-02 23:23:37 +02:00
using Microsoft.WindowsAzure.Storage;
using Microsoft.WindowsAzure.Storage.Queue;
using Newtonsoft.Json;
2018-08-02 18:14:33 +02:00
2018-08-16 19:45:31 +02:00
namespace Bit.Notifications
2018-08-02 18:14:33 +02:00
{
2018-08-03 05:13:06 +02:00
public class AzureQueueHostedService : IHostedService, IDisposable
2018-08-02 18:14:33 +02:00
{
private readonly ILogger _logger;
2018-08-16 19:45:31 +02:00
private readonly IHubContext<NotificationsHub> _hubContext;
2018-08-02 23:23:37 +02:00
private readonly GlobalSettings _globalSettings;
2018-08-02 18:14:33 +02:00
2018-08-02 23:23:37 +02:00
private Task _executingTask;
private CancellationTokenSource _cts;
private CloudQueue _queue;
2018-08-16 19:45:31 +02:00
public AzureQueueHostedService(
2018-08-21 15:37:09 +02:00
ILogger<AzureQueueHostedService> logger,
2018-08-16 19:45:31 +02:00
IHubContext<NotificationsHub> hubContext,
2018-08-02 23:23:37 +02:00
GlobalSettings globalSettings)
2018-08-02 18:14:33 +02:00
{
_logger = logger;
_hubContext = hubContext;
2018-08-02 23:23:37 +02:00
_globalSettings = globalSettings;
2018-08-02 18:14:33 +02:00
}
public Task StartAsync(CancellationToken cancellationToken)
{
2018-08-02 23:23:37 +02:00
_cts = CancellationTokenSource.CreateLinkedTokenSource(cancellationToken);
_executingTask = ExecuteAsync(_cts.Token);
return _executingTask.IsCompleted ? _executingTask : Task.CompletedTask;
2018-08-02 18:14:33 +02:00
}
2018-08-02 23:23:37 +02:00
public async Task StopAsync(CancellationToken cancellationToken)
2018-08-02 18:14:33 +02:00
{
2018-08-02 23:23:37 +02:00
if(_executingTask == null)
{
return;
}
_cts.Cancel();
await Task.WhenAny(_executingTask, Task.Delay(-1, cancellationToken));
cancellationToken.ThrowIfCancellationRequested();
2018-08-02 18:14:33 +02:00
}
2018-08-02 23:23:37 +02:00
public void Dispose()
2018-08-21 15:37:09 +02:00
{ }
2018-08-02 18:14:33 +02:00
2018-08-02 23:23:37 +02:00
private async Task ExecuteAsync(CancellationToken cancellationToken)
2018-08-02 18:14:33 +02:00
{
2018-08-16 19:45:31 +02:00
var storageAccount = CloudStorageAccount.Parse(_globalSettings.Notifications.ConnectionString);
2018-08-02 23:23:37 +02:00
var queueClient = storageAccount.CreateCloudQueueClient();
2018-08-16 19:35:16 +02:00
_queue = queueClient.GetQueueReference("notifications");
2018-08-02 23:23:37 +02:00
2018-08-24 17:23:39 +02:00
_logger.LogInformation("starting queue read");
try
2018-08-02 23:23:37 +02:00
{
2018-08-24 17:23:39 +02:00
while(!cancellationToken.IsCancellationRequested)
2018-08-02 23:23:37 +02:00
{
2018-08-24 17:23:39 +02:00
var messages = await _queue.GetMessagesAsync(32, TimeSpan.FromMinutes(1),
null, null, cancellationToken);
if(messages.Any())
2018-08-02 23:23:37 +02:00
{
2018-08-24 17:23:39 +02:00
foreach(var message in messages)
{
var notificationJson = message.AsString;
var notification = JsonConvert.DeserializeObject<PushNotificationData<object>>(
notificationJson);
await HubHelpers.SendNotificationToHubAsync(notification.Type, notificationJson,
_hubContext, cancellationToken);
await _queue.DeleteMessageAsync(message);
}
}
else
{
await Task.Delay(TimeSpan.FromSeconds(5), cancellationToken);
2018-08-02 23:23:37 +02:00
}
}
2018-08-24 17:23:39 +02:00
}
catch(Exception e)
{
_logger.LogError(e, "error from queue");
2018-08-02 23:23:37 +02:00
}
2018-08-02 18:14:33 +02:00
}
}
}