1
0
mirror of https://github.com/bitwarden/server.git synced 2025-04-05 05:00:19 -05:00

[PM-14590] Modify Notification database table (#5361)

* Added notification type enum

Added option type to entity

* created migration files

* made sprocs backward compatible

* made sprocs backward compatible

* Fixed linting

* Altered table to require an optional taskId

* formatted code

* Added foreignkey

* Formatted code

* fixed order
This commit is contained in:
SmithThe4th 2025-02-10 11:39:48 -05:00 committed by GitHub
parent e4d862fe6e
commit bde11dae31
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
16 changed files with 9330 additions and 6 deletions

View File

@ -20,6 +20,7 @@ public class Notification : ITableObject<Guid>
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; }
public void SetNewId() public void SetNewId()
{ {

View File

@ -30,6 +30,10 @@ public class NotificationEntityTypeConfiguration : IEntityTypeConfiguration<Noti
.HasIndex(n => n.UserId) .HasIndex(n => n.UserId)
.IsClustered(false); .IsClustered(false);
builder
.HasIndex(n => n.TaskId)
.IsClustered(false);
builder.ToTable(nameof(Notification)); builder.ToTable(nameof(Notification));
} }
} }

View File

@ -1,6 +1,7 @@
using AutoMapper; using AutoMapper;
using Bit.Infrastructure.EntityFramework.AdminConsole.Models; using Bit.Infrastructure.EntityFramework.AdminConsole.Models;
using Bit.Infrastructure.EntityFramework.Models; using Bit.Infrastructure.EntityFramework.Models;
using Bit.Infrastructure.EntityFramework.Vault.Models;
namespace Bit.Infrastructure.EntityFramework.NotificationCenter.Models; namespace Bit.Infrastructure.EntityFramework.NotificationCenter.Models;
@ -8,6 +9,7 @@ public class Notification : Core.NotificationCenter.Entities.Notification
{ {
public virtual User User { get; set; } public virtual User User { get; set; }
public virtual Organization Organization { get; set; } public virtual Organization Organization { get; set; }
public virtual SecurityTask Task { get; set; }
} }
public class NotificationMapperProfile : Profile public class NotificationMapperProfile : Profile

View File

@ -8,7 +8,8 @@ CREATE PROCEDURE [dbo].[Notification_Create]
@Title NVARCHAR(256), @Title NVARCHAR(256),
@Body NVARCHAR(MAX), @Body NVARCHAR(MAX),
@CreationDate DATETIME2(7), @CreationDate DATETIME2(7),
@RevisionDate DATETIME2(7) @RevisionDate DATETIME2(7),
@TaskId UNIQUEIDENTIFIER = NULL
AS AS
BEGIN BEGIN
SET NOCOUNT ON SET NOCOUNT ON
@ -23,7 +24,8 @@ BEGIN
[Title], [Title],
[Body], [Body],
[CreationDate], [CreationDate],
[RevisionDate] [RevisionDate],
[TaskId]
) )
VALUES ( VALUES (
@Id, @Id,
@ -35,6 +37,7 @@ BEGIN
@Title, @Title,
@Body, @Body,
@CreationDate, @CreationDate,
@RevisionDate @RevisionDate,
@TaskId
) )
END END

View File

@ -8,7 +8,8 @@ CREATE PROCEDURE [dbo].[Notification_Update]
@Title NVARCHAR(256), @Title NVARCHAR(256),
@Body NVARCHAR(MAX), @Body NVARCHAR(MAX),
@CreationDate DATETIME2(7), @CreationDate DATETIME2(7),
@RevisionDate DATETIME2(7) @RevisionDate DATETIME2(7),
@TaskId UNIQUEIDENTIFIER = NULL
AS AS
BEGIN BEGIN
SET NOCOUNT ON SET NOCOUNT ON
@ -22,6 +23,7 @@ BEGIN
[Title] = @Title, [Title] = @Title,
[Body] = @Body, [Body] = @Body,
[CreationDate] = @CreationDate, [CreationDate] = @CreationDate,
[RevisionDate] = @RevisionDate [RevisionDate] = @RevisionDate,
[TaskId] = @TaskId
WHERE [Id] = @Id WHERE [Id] = @Id
END END

View File

@ -10,9 +10,11 @@ CREATE TABLE [dbo].[Notification]
[Body] NVARCHAR (MAX) NULL, [Body] NVARCHAR (MAX) NULL,
[CreationDate] DATETIME2 (7) NOT NULL, [CreationDate] DATETIME2 (7) NOT NULL,
[RevisionDate] DATETIME2 (7) NOT NULL, [RevisionDate] DATETIME2 (7) NOT NULL,
[TaskId] UNIQUEIDENTIFIER NULL,
CONSTRAINT [PK_Notification] PRIMARY KEY CLUSTERED ([Id] ASC), CONSTRAINT [PK_Notification] PRIMARY KEY CLUSTERED ([Id] ASC),
CONSTRAINT [FK_Notification_Organization] FOREIGN KEY ([OrganizationId]) REFERENCES [dbo].[Organization] ([Id]), CONSTRAINT [FK_Notification_Organization] FOREIGN KEY ([OrganizationId]) REFERENCES [dbo].[Organization] ([Id]),
CONSTRAINT [FK_Notification_User] FOREIGN KEY ([UserId]) REFERENCES [dbo].[User] ([Id]) CONSTRAINT [FK_Notification_User] FOREIGN KEY ([UserId]) REFERENCES [dbo].[User] ([Id]),
CONSTRAINT [FK_Notification_SecurityTask] FOREIGN KEY ([TaskId]) REFERENCES [dbo].[SecurityTask] ([Id])
); );
@ -30,3 +32,6 @@ GO
CREATE NONCLUSTERED INDEX [IX_Notification_OrganizationId] CREATE NONCLUSTERED INDEX [IX_Notification_OrganizationId]
ON [dbo].[Notification]([OrganizationId] ASC) WHERE OrganizationId IS NOT NULL; ON [dbo].[Notification]([OrganizationId] ASC) WHERE OrganizationId IS NOT NULL;
GO
CREATE NONCLUSTERED INDEX [IX_Notification_TaskId]
ON [dbo].[Notification] ([TaskId] ASC) WHERE TaskId IS NOT NULL;

View File

@ -0,0 +1,107 @@
-- Add optional TaskId column to Notification table
IF COL_LENGTH('[dbo].[Notification]', 'TaskId') IS NULL
BEGIN
ALTER TABLE [dbo].[Notification]
ADD [TaskId] UNIQUEIDENTIFIER NULL
ALTER TABLE [dbo].[Notification]
ADD CONSTRAINT [FK_Notification_SecurityTask] FOREIGN KEY ([TaskId]) REFERENCES [dbo].[SecurityTask] ([Id])
END
GO
IF NOT EXISTS (SELECT *
FROM sys.indexes
WHERE name = 'IX_Notification_TaskId')
BEGIN
CREATE NONCLUSTERED INDEX [IX_Notification_TaskId]
ON [dbo].[Notification] ([TaskId] ASC) WHERE TaskId IS NOT NULL;
END
GO
-- Alter Notification_Create and Notification_Update stored procedures to include TaskId
CREATE OR ALTER PROCEDURE [dbo].[Notification_Create]
@Id UNIQUEIDENTIFIER OUTPUT,
@Priority TINYINT,
@Global BIT,
@ClientType TINYINT,
@UserId UNIQUEIDENTIFIER,
@OrganizationId UNIQUEIDENTIFIER,
@Title NVARCHAR(256),
@Body NVARCHAR(MAX),
@CreationDate DATETIME2(7),
@RevisionDate DATETIME2(7),
@TaskId UNIQUEIDENTIFIER = NULL
AS
BEGIN
SET NOCOUNT ON
INSERT INTO [dbo].[Notification] (
[Id],
[Priority],
[Global],
[ClientType],
[UserId],
[OrganizationId],
[Title],
[Body],
[CreationDate],
[RevisionDate],
[TaskId]
)
VALUES (
@Id,
@Priority,
@Global,
@ClientType,
@UserId,
@OrganizationId,
@Title,
@Body,
@CreationDate,
@RevisionDate,
@TaskId
)
END
GO
CREATE OR ALTER PROCEDURE [dbo].[Notification_Update]
@Id UNIQUEIDENTIFIER,
@Priority TINYINT,
@Global BIT,
@ClientType TINYINT,
@UserId UNIQUEIDENTIFIER,
@OrganizationId UNIQUEIDENTIFIER,
@Title NVARCHAR(256),
@Body NVARCHAR(MAX),
@CreationDate DATETIME2(7),
@RevisionDate DATETIME2(7),
@TaskId UNIQUEIDENTIFIER = NULL
AS
BEGIN
SET NOCOUNT ON
UPDATE [dbo].[Notification]
SET [Priority] = @Priority,
[Global] = @Global,
[ClientType] = @ClientType,
[UserId] = @UserId,
[OrganizationId] = @OrganizationId,
[Title] = @Title,
[Body] = @Body,
[CreationDate] = @CreationDate,
[RevisionDate] = @RevisionDate,
[TaskId] = @TaskId
WHERE [Id] = @Id
END
GO
-- Recreate NotificationView
CREATE OR ALTER VIEW [dbo].[NotificationView]
AS
SELECT
*
FROM
[dbo].[Notification]
GO

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,48 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace Bit.MySqlMigrations.Migrations;
/// <inheritdoc />
public partial class AddOptionalNotifificationTaskId : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<Guid>(
name: "TaskId",
table: "Notification",
type: "char(36)",
nullable: true,
collation: "ascii_general_ci");
migrationBuilder.CreateIndex(
name: "IX_Notification_TaskId",
table: "Notification",
column: "TaskId");
migrationBuilder.AddForeignKey(
name: "FK_Notification_SecurityTask_TaskId",
table: "Notification",
column: "TaskId",
principalTable: "SecurityTask",
principalColumn: "Id");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_Notification_SecurityTask_TaskId",
table: "Notification");
migrationBuilder.DropIndex(
name: "IX_Notification_TaskId",
table: "Notification");
migrationBuilder.DropColumn(
name: "TaskId",
table: "Notification");
}
}

View File

@ -1674,6 +1674,9 @@ namespace Bit.MySqlMigrations.Migrations
b.Property<DateTime>("RevisionDate") b.Property<DateTime>("RevisionDate")
.HasColumnType("datetime(6)"); .HasColumnType("datetime(6)");
b.Property<Guid?>("TaskId")
.HasColumnType("char(36)");
b.Property<string>("Title") b.Property<string>("Title")
.HasMaxLength(256) .HasMaxLength(256)
.HasColumnType("varchar(256)"); .HasColumnType("varchar(256)");
@ -1687,6 +1690,9 @@ namespace Bit.MySqlMigrations.Migrations
b.HasIndex("OrganizationId") b.HasIndex("OrganizationId")
.HasAnnotation("SqlServer:Clustered", false); .HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("TaskId")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("UserId") b.HasIndex("UserId")
.HasAnnotation("SqlServer:Clustered", false); .HasAnnotation("SqlServer:Clustered", false);
@ -2628,12 +2634,18 @@ namespace Bit.MySqlMigrations.Migrations
.WithMany() .WithMany()
.HasForeignKey("OrganizationId"); .HasForeignKey("OrganizationId");
b.HasOne("Bit.Infrastructure.EntityFramework.Vault.Models.SecurityTask", "Task")
.WithMany()
.HasForeignKey("TaskId");
b.HasOne("Bit.Infrastructure.EntityFramework.Models.User", "User") b.HasOne("Bit.Infrastructure.EntityFramework.Models.User", "User")
.WithMany() .WithMany()
.HasForeignKey("UserId"); .HasForeignKey("UserId");
b.Navigation("Organization"); b.Navigation("Organization");
b.Navigation("Task");
b.Navigation("User"); b.Navigation("User");
}); });

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,47 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace Bit.PostgresMigrations.Migrations;
/// <inheritdoc />
public partial class AddOptionalNotifificationTaskId : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<Guid>(
name: "TaskId",
table: "Notification",
type: "uuid",
nullable: true);
migrationBuilder.CreateIndex(
name: "IX_Notification_TaskId",
table: "Notification",
column: "TaskId");
migrationBuilder.AddForeignKey(
name: "FK_Notification_SecurityTask_TaskId",
table: "Notification",
column: "TaskId",
principalTable: "SecurityTask",
principalColumn: "Id");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_Notification_SecurityTask_TaskId",
table: "Notification");
migrationBuilder.DropIndex(
name: "IX_Notification_TaskId",
table: "Notification");
migrationBuilder.DropColumn(
name: "TaskId",
table: "Notification");
}
}

View File

@ -1680,6 +1680,9 @@ namespace Bit.PostgresMigrations.Migrations
b.Property<DateTime>("RevisionDate") b.Property<DateTime>("RevisionDate")
.HasColumnType("timestamp with time zone"); .HasColumnType("timestamp with time zone");
b.Property<Guid?>("TaskId")
.HasColumnType("uuid");
b.Property<string>("Title") b.Property<string>("Title")
.HasMaxLength(256) .HasMaxLength(256)
.HasColumnType("character varying(256)"); .HasColumnType("character varying(256)");
@ -1693,6 +1696,9 @@ namespace Bit.PostgresMigrations.Migrations
b.HasIndex("OrganizationId") b.HasIndex("OrganizationId")
.HasAnnotation("SqlServer:Clustered", false); .HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("TaskId")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("UserId") b.HasIndex("UserId")
.HasAnnotation("SqlServer:Clustered", false); .HasAnnotation("SqlServer:Clustered", false);
@ -2634,12 +2640,18 @@ namespace Bit.PostgresMigrations.Migrations
.WithMany() .WithMany()
.HasForeignKey("OrganizationId"); .HasForeignKey("OrganizationId");
b.HasOne("Bit.Infrastructure.EntityFramework.Vault.Models.SecurityTask", "Task")
.WithMany()
.HasForeignKey("TaskId");
b.HasOne("Bit.Infrastructure.EntityFramework.Models.User", "User") b.HasOne("Bit.Infrastructure.EntityFramework.Models.User", "User")
.WithMany() .WithMany()
.HasForeignKey("UserId"); .HasForeignKey("UserId");
b.Navigation("Organization"); b.Navigation("Organization");
b.Navigation("Task");
b.Navigation("User"); b.Navigation("User");
}); });

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,47 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace Bit.SqliteMigrations.Migrations;
/// <inheritdoc />
public partial class AddOptionalNotifificationTaskId : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<Guid>(
name: "TaskId",
table: "Notification",
type: "TEXT",
nullable: true);
migrationBuilder.CreateIndex(
name: "IX_Notification_TaskId",
table: "Notification",
column: "TaskId");
migrationBuilder.AddForeignKey(
name: "FK_Notification_SecurityTask_TaskId",
table: "Notification",
column: "TaskId",
principalTable: "SecurityTask",
principalColumn: "Id");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_Notification_SecurityTask_TaskId",
table: "Notification");
migrationBuilder.DropIndex(
name: "IX_Notification_TaskId",
table: "Notification");
migrationBuilder.DropColumn(
name: "TaskId",
table: "Notification");
}
}

View File

@ -1663,6 +1663,9 @@ namespace Bit.SqliteMigrations.Migrations
b.Property<DateTime>("RevisionDate") b.Property<DateTime>("RevisionDate")
.HasColumnType("TEXT"); .HasColumnType("TEXT");
b.Property<Guid?>("TaskId")
.HasColumnType("TEXT");
b.Property<string>("Title") b.Property<string>("Title")
.HasMaxLength(256) .HasMaxLength(256)
.HasColumnType("TEXT"); .HasColumnType("TEXT");
@ -1676,6 +1679,9 @@ namespace Bit.SqliteMigrations.Migrations
b.HasIndex("OrganizationId") b.HasIndex("OrganizationId")
.HasAnnotation("SqlServer:Clustered", false); .HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("TaskId")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("UserId") b.HasIndex("UserId")
.HasAnnotation("SqlServer:Clustered", false); .HasAnnotation("SqlServer:Clustered", false);
@ -2617,12 +2623,18 @@ namespace Bit.SqliteMigrations.Migrations
.WithMany() .WithMany()
.HasForeignKey("OrganizationId"); .HasForeignKey("OrganizationId");
b.HasOne("Bit.Infrastructure.EntityFramework.Vault.Models.SecurityTask", "Task")
.WithMany()
.HasForeignKey("TaskId");
b.HasOne("Bit.Infrastructure.EntityFramework.Models.User", "User") b.HasOne("Bit.Infrastructure.EntityFramework.Models.User", "User")
.WithMany() .WithMany()
.HasForeignKey("UserId"); .HasForeignKey("UserId");
b.Navigation("Organization"); b.Navigation("Organization");
b.Navigation("Task");
b.Navigation("User"); b.Navigation("User");
}); });