1
0
mirror of https://github.com/bitwarden/server synced 2025-12-06 00:03:34 +00:00
Files
server/util/Migrator/DbScripts/2025-09-26_00_SM_AddSecretVersioningTable.sql
cd-bitwarden 2965b499e9 [SM-1591] Adding SecretVersion table to server (#6406)
* Adding SecretVersion table to server

* making the names singular not plural for new table

* removing migration

* fixing migration

* Adding indexes for serviceacct and orguserId

* indexes for sqllite

* fixing migrations

* adding indexes to secretVeriosn.sql

* tests

* removing tests

* adding GO
2025-10-16 15:35:14 -04:00

84 lines
2.6 KiB
Transact-SQL

SET ANSI_NULLS ON;
SET QUOTED_IDENTIFIER ON;
GO
IF NOT EXISTS (SELECT 1 FROM sys.tables WHERE name = 'SecretVersion' AND schema_id = SCHEMA_ID('dbo'))
BEGIN
CREATE TABLE [dbo].[SecretVersion] (
[Id] UNIQUEIDENTIFIER NOT NULL,
[SecretId] UNIQUEIDENTIFIER NOT NULL,
[Value] NVARCHAR (MAX) NOT NULL,
[VersionDate] DATETIME2 (7) NOT NULL,
[EditorServiceAccountId] UNIQUEIDENTIFIER NULL,
[EditorOrganizationUserId] UNIQUEIDENTIFIER NULL,
CONSTRAINT [PK_SecretVersion] PRIMARY KEY CLUSTERED ([Id] ASC)
);
END
GO
-- Ensure foreign keys exist
IF NOT EXISTS (
SELECT 1 FROM sys.foreign_keys WHERE name = 'FK_SecretVersion_OrganizationUser'
)
BEGIN
ALTER TABLE [dbo].[SecretVersion]
ADD CONSTRAINT [FK_SecretVersion_OrganizationUser]
FOREIGN KEY ([EditorOrganizationUserId])
REFERENCES [dbo].[OrganizationUser] ([Id])
ON DELETE SET NULL;
END
GO
IF NOT EXISTS (
SELECT 1 FROM sys.foreign_keys WHERE name = 'FK_SecretVersion_Secret'
)
BEGIN
ALTER TABLE [dbo].[SecretVersion]
ADD CONSTRAINT [FK_SecretVersion_Secret]
FOREIGN KEY ([SecretId])
REFERENCES [dbo].[Secret] ([Id])
ON DELETE CASCADE;
END
GO
IF NOT EXISTS (
SELECT 1 FROM sys.foreign_keys WHERE name = 'FK_SecretVersion_ServiceAccount'
)
BEGIN
ALTER TABLE [dbo].[SecretVersion]
ADD CONSTRAINT [FK_SecretVersion_ServiceAccount]
FOREIGN KEY ([EditorServiceAccountId])
REFERENCES [dbo].[ServiceAccount] ([Id])
ON DELETE SET NULL;
END
GO
IF NOT EXISTS (
SELECT 1 FROM sys.indexes WHERE name = 'IX_SecretVersion_SecretId' AND object_id = OBJECT_ID('[dbo].[SecretVersion]')
)
BEGIN
CREATE NONCLUSTERED INDEX [IX_SecretVersion_SecretId]
ON [dbo].[SecretVersion]([SecretId] ASC);
END
GO
IF NOT EXISTS (
SELECT 1 FROM sys.indexes WHERE name = 'IX_SecretVersion_EditorServiceAccountId' AND object_id = OBJECT_ID('[dbo].[SecretVersion]')
)
BEGIN
CREATE NONCLUSTERED INDEX [IX_SecretVersion_EditorServiceAccountId]
ON [dbo].[SecretVersion]([EditorServiceAccountId] ASC)
WHERE [EditorServiceAccountId] IS NOT NULL;
END
GO
IF NOT EXISTS (
SELECT 1 FROM sys.indexes WHERE name = 'IX_SecretVersion_EditorOrganizationUserId' AND object_id = OBJECT_ID('[dbo].[SecretVersion]')
)
BEGIN
CREATE NONCLUSTERED INDEX [IX_SecretVersion_EditorOrganizationUserId]
ON [dbo].[SecretVersion]([EditorOrganizationUserId] ASC)
WHERE [EditorOrganizationUserId] IS NOT NULL;
END
GO