mirror of
https://github.com/bitwarden/server.git
synced 2025-04-04 12:40:22 -05:00
[PM-17563] Add missing TaskId and HubHelper for PendingSecurityTasks (#5591)
* [PM-17563] Add case for PushType.PendingSecurityTasks * [PM-17563] Add missing TaskId property to NotificationStatusDetails and NotificationResponseModel * [PM-17563] Add migration script to re-create NotificationStatusDetailsView to include TaskId column * [PM-17563] Select explicit columns for NotificationStatusDetailsView and fix migration script
This commit is contained in:
parent
7b2b62e794
commit
d4a3cd00be
@ -22,6 +22,7 @@ public class NotificationResponseModel : ResponseModel
|
|||||||
Title = notificationStatusDetails.Title;
|
Title = notificationStatusDetails.Title;
|
||||||
Body = notificationStatusDetails.Body;
|
Body = notificationStatusDetails.Body;
|
||||||
Date = notificationStatusDetails.RevisionDate;
|
Date = notificationStatusDetails.RevisionDate;
|
||||||
|
TaskId = notificationStatusDetails.TaskId;
|
||||||
ReadDate = notificationStatusDetails.ReadDate;
|
ReadDate = notificationStatusDetails.ReadDate;
|
||||||
DeletedDate = notificationStatusDetails.DeletedDate;
|
DeletedDate = notificationStatusDetails.DeletedDate;
|
||||||
}
|
}
|
||||||
@ -40,6 +41,8 @@ public class NotificationResponseModel : ResponseModel
|
|||||||
|
|
||||||
public DateTime Date { get; set; }
|
public DateTime Date { get; set; }
|
||||||
|
|
||||||
|
public Guid? TaskId { get; set; }
|
||||||
|
|
||||||
public DateTime? ReadDate { get; set; }
|
public DateTime? ReadDate { get; set; }
|
||||||
|
|
||||||
public DateTime? DeletedDate { get; set; }
|
public DateTime? DeletedDate { get; set; }
|
||||||
|
@ -19,6 +19,7 @@ public class NotificationStatusDetails
|
|||||||
public string? Body { get; set; }
|
public string? Body { get; set; }
|
||||||
public DateTime CreationDate { get; set; }
|
public DateTime CreationDate { get; set; }
|
||||||
public DateTime RevisionDate { get; set; }
|
public DateTime RevisionDate { get; set; }
|
||||||
|
public Guid? TaskId { get; set; }
|
||||||
// Notification Status fields
|
// Notification Status fields
|
||||||
public DateTime? ReadDate { get; set; }
|
public DateTime? ReadDate { get; set; }
|
||||||
public DateTime? DeletedDate { get; set; }
|
public DateTime? DeletedDate { get; set; }
|
||||||
|
@ -52,6 +52,7 @@ public class NotificationStatusDetailsViewQuery(Guid userId, ClientType clientTy
|
|||||||
ClientType = x.n.ClientType,
|
ClientType = x.n.ClientType,
|
||||||
UserId = x.n.UserId,
|
UserId = x.n.UserId,
|
||||||
OrganizationId = x.n.OrganizationId,
|
OrganizationId = x.n.OrganizationId,
|
||||||
|
TaskId = x.n.TaskId,
|
||||||
Title = x.n.Title,
|
Title = x.n.Title,
|
||||||
Body = x.n.Body,
|
Body = x.n.Body,
|
||||||
CreationDate = x.n.CreationDate,
|
CreationDate = x.n.CreationDate,
|
||||||
|
@ -135,6 +135,11 @@ public static class HubHelpers
|
|||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
case PushType.PendingSecurityTasks:
|
||||||
|
var pendingTasksData = JsonSerializer.Deserialize<PushNotificationData<UserPushNotification>>(notificationJson, _deserializerOptions);
|
||||||
|
await hubContext.Clients.User(pendingTasksData.Payload.UserId.ToString())
|
||||||
|
.SendAsync(_receiveMessageMethod, pendingTasksData, cancellationToken);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,20 @@
|
|||||||
CREATE VIEW [dbo].[NotificationStatusDetailsView]
|
CREATE VIEW [dbo].[NotificationStatusDetailsView]
|
||||||
AS
|
AS
|
||||||
SELECT
|
SELECT
|
||||||
N.*,
|
N.[Id],
|
||||||
NS.UserId AS NotificationStatusUserId,
|
N.[Priority],
|
||||||
NS.ReadDate,
|
N.[Global],
|
||||||
NS.DeletedDate
|
N.[ClientType],
|
||||||
|
N.[UserId],
|
||||||
|
N.[OrganizationId],
|
||||||
|
N.[Title],
|
||||||
|
N.[Body],
|
||||||
|
N.[CreationDate],
|
||||||
|
N.[RevisionDate],
|
||||||
|
N.[TaskId],
|
||||||
|
NS.[UserId] AS [NotificationStatusUserId],
|
||||||
|
NS.[ReadDate],
|
||||||
|
NS.[DeletedDate]
|
||||||
FROM
|
FROM
|
||||||
[dbo].[Notification] AS N
|
[dbo].[Notification] AS N
|
||||||
LEFT JOIN
|
LEFT JOIN
|
||||||
|
@ -67,6 +67,7 @@ public class NotificationsControllerTests
|
|||||||
Assert.Equal(expectedNotificationStatusDetails.RevisionDate, notificationResponseModel.Date);
|
Assert.Equal(expectedNotificationStatusDetails.RevisionDate, notificationResponseModel.Date);
|
||||||
Assert.Equal(expectedNotificationStatusDetails.ReadDate, notificationResponseModel.ReadDate);
|
Assert.Equal(expectedNotificationStatusDetails.ReadDate, notificationResponseModel.ReadDate);
|
||||||
Assert.Equal(expectedNotificationStatusDetails.DeletedDate, notificationResponseModel.DeletedDate);
|
Assert.Equal(expectedNotificationStatusDetails.DeletedDate, notificationResponseModel.DeletedDate);
|
||||||
|
Assert.Equal(expectedNotificationStatusDetails.TaskId, notificationResponseModel.TaskId);
|
||||||
});
|
});
|
||||||
Assert.Null(listResponse.ContinuationToken);
|
Assert.Null(listResponse.ContinuationToken);
|
||||||
|
|
||||||
@ -116,6 +117,7 @@ public class NotificationsControllerTests
|
|||||||
Assert.Equal(expectedNotificationStatusDetails.RevisionDate, notificationResponseModel.Date);
|
Assert.Equal(expectedNotificationStatusDetails.RevisionDate, notificationResponseModel.Date);
|
||||||
Assert.Equal(expectedNotificationStatusDetails.ReadDate, notificationResponseModel.ReadDate);
|
Assert.Equal(expectedNotificationStatusDetails.ReadDate, notificationResponseModel.ReadDate);
|
||||||
Assert.Equal(expectedNotificationStatusDetails.DeletedDate, notificationResponseModel.DeletedDate);
|
Assert.Equal(expectedNotificationStatusDetails.DeletedDate, notificationResponseModel.DeletedDate);
|
||||||
|
Assert.Equal(expectedNotificationStatusDetails.TaskId, notificationResponseModel.TaskId);
|
||||||
});
|
});
|
||||||
Assert.Equal("2", listResponse.ContinuationToken);
|
Assert.Equal("2", listResponse.ContinuationToken);
|
||||||
|
|
||||||
@ -164,6 +166,7 @@ public class NotificationsControllerTests
|
|||||||
Assert.Equal(expectedNotificationStatusDetails.RevisionDate, notificationResponseModel.Date);
|
Assert.Equal(expectedNotificationStatusDetails.RevisionDate, notificationResponseModel.Date);
|
||||||
Assert.Equal(expectedNotificationStatusDetails.ReadDate, notificationResponseModel.ReadDate);
|
Assert.Equal(expectedNotificationStatusDetails.ReadDate, notificationResponseModel.ReadDate);
|
||||||
Assert.Equal(expectedNotificationStatusDetails.DeletedDate, notificationResponseModel.DeletedDate);
|
Assert.Equal(expectedNotificationStatusDetails.DeletedDate, notificationResponseModel.DeletedDate);
|
||||||
|
Assert.Equal(expectedNotificationStatusDetails.TaskId, notificationResponseModel.TaskId);
|
||||||
});
|
});
|
||||||
Assert.Null(listResponse.ContinuationToken);
|
Assert.Null(listResponse.ContinuationToken);
|
||||||
|
|
||||||
|
@ -26,6 +26,7 @@ public class NotificationResponseModelTests
|
|||||||
ClientType = ClientType.All,
|
ClientType = ClientType.All,
|
||||||
Title = "Test Title",
|
Title = "Test Title",
|
||||||
Body = "Test Body",
|
Body = "Test Body",
|
||||||
|
TaskId = Guid.NewGuid(),
|
||||||
RevisionDate = DateTime.UtcNow - TimeSpan.FromMinutes(3),
|
RevisionDate = DateTime.UtcNow - TimeSpan.FromMinutes(3),
|
||||||
ReadDate = DateTime.UtcNow - TimeSpan.FromMinutes(1),
|
ReadDate = DateTime.UtcNow - TimeSpan.FromMinutes(1),
|
||||||
DeletedDate = DateTime.UtcNow,
|
DeletedDate = DateTime.UtcNow,
|
||||||
@ -39,5 +40,6 @@ public class NotificationResponseModelTests
|
|||||||
Assert.Equal(model.Date, notificationStatusDetails.RevisionDate);
|
Assert.Equal(model.Date, notificationStatusDetails.RevisionDate);
|
||||||
Assert.Equal(model.ReadDate, notificationStatusDetails.ReadDate);
|
Assert.Equal(model.ReadDate, notificationStatusDetails.ReadDate);
|
||||||
Assert.Equal(model.DeletedDate, notificationStatusDetails.DeletedDate);
|
Assert.Equal(model.DeletedDate, notificationStatusDetails.DeletedDate);
|
||||||
|
Assert.Equal(model.TaskId, notificationStatusDetails.TaskId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,25 @@
|
|||||||
|
-- Recreate the NotificationStatusView to include the Notification.TaskId column
|
||||||
|
CREATE OR ALTER VIEW [dbo].[NotificationStatusDetailsView]
|
||||||
|
AS
|
||||||
|
SELECT
|
||||||
|
N.[Id],
|
||||||
|
N.[Priority],
|
||||||
|
N.[Global],
|
||||||
|
N.[ClientType],
|
||||||
|
N.[UserId],
|
||||||
|
N.[OrganizationId],
|
||||||
|
N.[Title],
|
||||||
|
N.[Body],
|
||||||
|
N.[CreationDate],
|
||||||
|
N.[RevisionDate],
|
||||||
|
N.[TaskId],
|
||||||
|
NS.[UserId] AS [NotificationStatusUserId],
|
||||||
|
NS.[ReadDate],
|
||||||
|
NS.[DeletedDate]
|
||||||
|
FROM
|
||||||
|
[dbo].[Notification] AS N
|
||||||
|
LEFT JOIN
|
||||||
|
[dbo].[NotificationStatus] as NS
|
||||||
|
ON
|
||||||
|
N.[Id] = NS.[NotificationId]
|
||||||
|
GO
|
Loading…
x
Reference in New Issue
Block a user