mirror of
https://github.com/aliasvault/aliasvault.git
synced 2026-05-10 16:27:59 -04:00
Add major version bump to vault version to prevent runtime errors in older unsupported clients (#1535)
This commit is contained in:
committed by
Leendert de Borst
parent
66e8dbfb27
commit
aec40a4d03
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@@ -1296,6 +1296,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
`;
|
||||
var MIGRATION_SCRIPTS = {
|
||||
1: `\uFEFFBEGIN TRANSACTION;
|
||||
@@ -2492,7 +2498,12 @@ CREATE INDEX "IX_TotpCodes_ItemId" ON "TotpCodes" ("ItemId");
|
||||
COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`,
|
||||
12: `\uFEFFBEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;`
|
||||
};
|
||||
|
||||
// src/sql/VaultVersions.ts
|
||||
@@ -2579,7 +2590,14 @@ var VAULT_VERSIONS = [
|
||||
version: "1.7.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.0",
|
||||
compatibleUpToVersion: "0.26.0"
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
},
|
||||
{
|
||||
revision: 13,
|
||||
version: "2.0.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.1",
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
}
|
||||
];
|
||||
|
||||
|
||||
@@ -1264,6 +1264,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
`;
|
||||
var MIGRATION_SCRIPTS = {
|
||||
1: `\uFEFFBEGIN TRANSACTION;
|
||||
@@ -2460,7 +2466,12 @@ CREATE INDEX "IX_TotpCodes_ItemId" ON "TotpCodes" ("ItemId");
|
||||
COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`,
|
||||
12: `\uFEFFBEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;`
|
||||
};
|
||||
|
||||
// src/sql/VaultVersions.ts
|
||||
@@ -2547,7 +2558,14 @@ var VAULT_VERSIONS = [
|
||||
version: "1.7.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.0",
|
||||
compatibleUpToVersion: "0.26.0"
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
},
|
||||
{
|
||||
revision: 13,
|
||||
version: "2.0.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.1",
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
}
|
||||
];
|
||||
|
||||
|
||||
@@ -1273,6 +1273,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
""".trimIndent()
|
||||
|
||||
/**
|
||||
@@ -2497,6 +2503,13 @@ COMMIT;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
""".trimIndent(),
|
||||
12 to """
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
""".trimIndent(),
|
||||
)
|
||||
|
||||
/**
|
||||
|
||||
@@ -111,7 +111,14 @@ object VaultVersions {
|
||||
version = "1.7.0",
|
||||
description = "Update to Field-Based Data Model",
|
||||
releaseVersion = "0.26.0",
|
||||
compatibleUpToVersion = "0.26.0",
|
||||
compatibleUpToVersion = "0.25.0",
|
||||
),
|
||||
VaultVersion(
|
||||
revision = 13,
|
||||
version = "2.0.0",
|
||||
description = "Update to Field-Based Data Model",
|
||||
releaseVersion = "0.26.1",
|
||||
compatibleUpToVersion = "0.25.0",
|
||||
),
|
||||
)
|
||||
|
||||
|
||||
@@ -1269,6 +1269,12 @@ public struct VaultSql {
|
||||
|
||||
INSERT INTO \"__EFMigrationsHistory\" (\"MigrationId\", \"ProductVersion\")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO \"__EFMigrationsHistory\" (\"MigrationId\", \"ProductVersion\")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
"""
|
||||
|
||||
/// Migration SQL scripts indexed by migration number.
|
||||
@@ -2490,6 +2496,13 @@ public struct VaultSql {
|
||||
|
||||
INSERT INTO \"__EFMigrationsHistory\" (\"MigrationId\", \"ProductVersion\")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
""",
|
||||
12: """
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO \"__EFMigrationsHistory\" (\"MigrationId\", \"ProductVersion\")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
"""
|
||||
]
|
||||
|
||||
|
||||
@@ -109,7 +109,14 @@ public struct VaultVersions {
|
||||
version: "1.7.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.0",
|
||||
compatibleUpToVersion: "0.26.0"
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
),
|
||||
VaultVersion(
|
||||
revision: 13,
|
||||
version: "2.0.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.1",
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
)
|
||||
]
|
||||
|
||||
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
22
apps/mobile-app/utils/dist/core/vault/index.js
vendored
22
apps/mobile-app/utils/dist/core/vault/index.js
vendored
@@ -1296,6 +1296,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
`;
|
||||
var MIGRATION_SCRIPTS = {
|
||||
1: `\uFEFFBEGIN TRANSACTION;
|
||||
@@ -2492,7 +2498,12 @@ CREATE INDEX "IX_TotpCodes_ItemId" ON "TotpCodes" ("ItemId");
|
||||
COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`,
|
||||
12: `\uFEFFBEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;`
|
||||
};
|
||||
|
||||
// src/sql/VaultVersions.ts
|
||||
@@ -2579,7 +2590,14 @@ var VAULT_VERSIONS = [
|
||||
version: "1.7.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.0",
|
||||
compatibleUpToVersion: "0.26.0"
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
},
|
||||
{
|
||||
revision: 13,
|
||||
version: "2.0.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.1",
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
}
|
||||
];
|
||||
|
||||
|
||||
22
apps/mobile-app/utils/dist/core/vault/index.mjs
vendored
22
apps/mobile-app/utils/dist/core/vault/index.mjs
vendored
@@ -1264,6 +1264,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
`;
|
||||
var MIGRATION_SCRIPTS = {
|
||||
1: `\uFEFFBEGIN TRANSACTION;
|
||||
@@ -2460,7 +2466,12 @@ CREATE INDEX "IX_TotpCodes_ItemId" ON "TotpCodes" ("ItemId");
|
||||
COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`,
|
||||
12: `\uFEFFBEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;`
|
||||
};
|
||||
|
||||
// src/sql/VaultVersions.ts
|
||||
@@ -2547,7 +2558,14 @@ var VAULT_VERSIONS = [
|
||||
version: "1.7.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.0",
|
||||
compatibleUpToVersion: "0.26.0"
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
},
|
||||
{
|
||||
revision: 13,
|
||||
version: "2.0.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.1",
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
}
|
||||
];
|
||||
|
||||
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@@ -1296,6 +1296,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
`;
|
||||
var MIGRATION_SCRIPTS = {
|
||||
1: `\uFEFFBEGIN TRANSACTION;
|
||||
@@ -2492,7 +2498,12 @@ CREATE INDEX "IX_TotpCodes_ItemId" ON "TotpCodes" ("ItemId");
|
||||
COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`,
|
||||
12: `\uFEFFBEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;`
|
||||
};
|
||||
|
||||
// src/sql/VaultVersions.ts
|
||||
@@ -2579,7 +2590,14 @@ var VAULT_VERSIONS = [
|
||||
version: "1.7.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.0",
|
||||
compatibleUpToVersion: "0.26.0"
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
},
|
||||
{
|
||||
revision: 13,
|
||||
version: "2.0.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.1",
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
}
|
||||
];
|
||||
|
||||
|
||||
@@ -1264,6 +1264,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
`;
|
||||
var MIGRATION_SCRIPTS = {
|
||||
1: `\uFEFFBEGIN TRANSACTION;
|
||||
@@ -2460,7 +2466,12 @@ CREATE INDEX "IX_TotpCodes_ItemId" ON "TotpCodes" ("ItemId");
|
||||
COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`,
|
||||
12: `\uFEFFBEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;`
|
||||
};
|
||||
|
||||
// src/sql/VaultVersions.ts
|
||||
@@ -2547,7 +2558,14 @@ var VAULT_VERSIONS = [
|
||||
version: "1.7.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.0",
|
||||
compatibleUpToVersion: "0.26.0"
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
},
|
||||
{
|
||||
revision: 13,
|
||||
version: "2.0.0",
|
||||
description: "Update to Field-Based Data Model",
|
||||
releaseVersion: "0.26.1",
|
||||
compatibleUpToVersion: "0.25.0"
|
||||
}
|
||||
];
|
||||
|
||||
|
||||
675
apps/server/Databases/AliasClientDb/Migrations/20260130221620_2.0.0-MajorVersionBump.Designer.cs
generated
Normal file
675
apps/server/Databases/AliasClientDb/Migrations/20260130221620_2.0.0-MajorVersionBump.Designer.cs
generated
Normal file
@@ -0,0 +1,675 @@
|
||||
// <auto-generated />
|
||||
using System;
|
||||
using AliasClientDb;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
|
||||
|
||||
#nullable disable
|
||||
|
||||
namespace AliasClientDb.Migrations
|
||||
{
|
||||
[DbContext(typeof(AliasClientDbContext))]
|
||||
[Migration("20260130221620_2.0.0-MajorVersionBump")]
|
||||
partial class _200MajorVersionBump
|
||||
{
|
||||
/// <inheritdoc />
|
||||
protected override void BuildTargetModel(ModelBuilder modelBuilder)
|
||||
{
|
||||
#pragma warning disable 612, 618
|
||||
modelBuilder
|
||||
.HasAnnotation("ProductVersion", "9.0.4")
|
||||
.HasAnnotation("Proxies:ChangeTracking", false)
|
||||
.HasAnnotation("Proxies:CheckEquality", false)
|
||||
.HasAnnotation("Proxies:LazyLoading", true);
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Attachment", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<byte[]>("Blob")
|
||||
.IsRequired()
|
||||
.HasColumnType("BLOB");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("Filename")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<Guid>("ItemId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("ItemId");
|
||||
|
||||
b.ToTable("Attachments");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.EncryptionKey", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<bool>("IsPrimary")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<string>("PrivateKey")
|
||||
.IsRequired()
|
||||
.HasMaxLength(2000)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("PublicKey")
|
||||
.IsRequired()
|
||||
.HasMaxLength(2000)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.ToTable("EncryptionKeys");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.FieldDefinition", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("ApplicableToTypes")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("EnableHistory")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<string>("FieldType")
|
||||
.IsRequired()
|
||||
.HasMaxLength(50)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<bool>("IsHidden")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<bool>("IsMultiValue")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<string>("Label")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<int>("Weight")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.ToTable("FieldDefinitions");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.FieldHistory", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("ChangedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<Guid?>("FieldDefinitionId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("FieldKey")
|
||||
.HasMaxLength(100)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<Guid>("ItemId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("ValueSnapshot")
|
||||
.IsRequired()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("FieldDefinitionId");
|
||||
|
||||
b.HasIndex("ItemId");
|
||||
|
||||
b.ToTable("FieldHistories");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.FieldValue", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<Guid?>("FieldDefinitionId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("FieldKey")
|
||||
.HasMaxLength(100)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<Guid>("ItemId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("Value")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<int>("Weight")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("FieldDefinitionId");
|
||||
|
||||
b.HasIndex("FieldKey");
|
||||
|
||||
b.HasIndex("ItemId");
|
||||
|
||||
b.HasIndex("ItemId", "FieldKey");
|
||||
|
||||
b.HasIndex("ItemId", "FieldDefinitionId", "Weight");
|
||||
|
||||
b.ToTable("FieldValues");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Folder", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<string>("Name")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<Guid?>("ParentFolderId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<int>("Weight")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("ParentFolderId");
|
||||
|
||||
b.ToTable("Folders");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Item", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime?>("DeletedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<Guid?>("FolderId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<string>("ItemType")
|
||||
.IsRequired()
|
||||
.HasMaxLength(50)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<Guid?>("LogoId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("Name")
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("FolderId");
|
||||
|
||||
b.HasIndex("LogoId");
|
||||
|
||||
b.ToTable("Items");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.ItemTag", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<Guid>("ItemId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<Guid>("TagId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("ItemId");
|
||||
|
||||
b.HasIndex("TagId");
|
||||
|
||||
b.HasIndex("ItemId", "TagId")
|
||||
.IsUnique();
|
||||
|
||||
b.ToTable("ItemTags");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Logo", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime?>("FetchedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<byte[]>("FileData")
|
||||
.HasColumnType("BLOB");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<string>("MimeType")
|
||||
.HasMaxLength(100)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("Source")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("Source")
|
||||
.IsUnique();
|
||||
|
||||
b.ToTable("Logos");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Passkey", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<byte[]>("AdditionalData")
|
||||
.HasColumnType("BLOB");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("DisplayName")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<Guid>("ItemId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<byte[]>("PrfKey")
|
||||
.HasMaxLength(64)
|
||||
.HasColumnType("BLOB");
|
||||
|
||||
b.Property<string>("PrivateKey")
|
||||
.IsRequired()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("PublicKey")
|
||||
.IsRequired()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("RpId")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT")
|
||||
.UseCollation("NOCASE");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<byte[]>("UserHandle")
|
||||
.IsRequired()
|
||||
.HasColumnType("BLOB");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("ItemId");
|
||||
|
||||
b.HasIndex("RpId");
|
||||
|
||||
b.ToTable("Passkeys");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Setting", b =>
|
||||
{
|
||||
b.Property<string>("Key")
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("Value")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Key");
|
||||
|
||||
b.ToTable("Settings");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Tag", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("Color")
|
||||
.HasMaxLength(50)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<int>("DisplayOrder")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<string>("Name")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("Name");
|
||||
|
||||
b.ToTable("Tags");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.TotpCode", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("CreatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("INTEGER");
|
||||
|
||||
b.Property<Guid>("ItemId")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("Name")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<string>("SecretKey")
|
||||
.IsRequired()
|
||||
.HasMaxLength(255)
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.Property<DateTime>("UpdatedAt")
|
||||
.HasColumnType("TEXT");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("ItemId");
|
||||
|
||||
b.ToTable("TotpCodes");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Attachment", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.Item", "Item")
|
||||
.WithMany("Attachments")
|
||||
.HasForeignKey("ItemId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("Item");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.FieldHistory", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.FieldDefinition", "FieldDefinition")
|
||||
.WithMany("FieldHistories")
|
||||
.HasForeignKey("FieldDefinitionId")
|
||||
.OnDelete(DeleteBehavior.Cascade);
|
||||
|
||||
b.HasOne("AliasClientDb.Item", "Item")
|
||||
.WithMany()
|
||||
.HasForeignKey("ItemId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("FieldDefinition");
|
||||
|
||||
b.Navigation("Item");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.FieldValue", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.FieldDefinition", "FieldDefinition")
|
||||
.WithMany("FieldValues")
|
||||
.HasForeignKey("FieldDefinitionId")
|
||||
.OnDelete(DeleteBehavior.Cascade);
|
||||
|
||||
b.HasOne("AliasClientDb.Item", "Item")
|
||||
.WithMany("FieldValues")
|
||||
.HasForeignKey("ItemId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("FieldDefinition");
|
||||
|
||||
b.Navigation("Item");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Folder", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.Folder", "ParentFolder")
|
||||
.WithMany("ChildFolders")
|
||||
.HasForeignKey("ParentFolderId")
|
||||
.OnDelete(DeleteBehavior.Cascade);
|
||||
|
||||
b.Navigation("ParentFolder");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Item", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.Folder", "Folder")
|
||||
.WithMany("Items")
|
||||
.HasForeignKey("FolderId")
|
||||
.OnDelete(DeleteBehavior.SetNull);
|
||||
|
||||
b.HasOne("AliasClientDb.Logo", "Logo")
|
||||
.WithMany("Items")
|
||||
.HasForeignKey("LogoId")
|
||||
.OnDelete(DeleteBehavior.SetNull);
|
||||
|
||||
b.Navigation("Folder");
|
||||
|
||||
b.Navigation("Logo");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.ItemTag", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.Item", "Item")
|
||||
.WithMany("ItemTags")
|
||||
.HasForeignKey("ItemId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("AliasClientDb.Tag", "Tag")
|
||||
.WithMany("ItemTags")
|
||||
.HasForeignKey("TagId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("Item");
|
||||
|
||||
b.Navigation("Tag");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Passkey", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.Item", "Item")
|
||||
.WithMany("Passkeys")
|
||||
.HasForeignKey("ItemId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("Item");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.TotpCode", b =>
|
||||
{
|
||||
b.HasOne("AliasClientDb.Item", "Item")
|
||||
.WithMany("TotpCodes")
|
||||
.HasForeignKey("ItemId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("Item");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.FieldDefinition", b =>
|
||||
{
|
||||
b.Navigation("FieldHistories");
|
||||
|
||||
b.Navigation("FieldValues");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Folder", b =>
|
||||
{
|
||||
b.Navigation("ChildFolders");
|
||||
|
||||
b.Navigation("Items");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Item", b =>
|
||||
{
|
||||
b.Navigation("Attachments");
|
||||
|
||||
b.Navigation("FieldValues");
|
||||
|
||||
b.Navigation("ItemTags");
|
||||
|
||||
b.Navigation("Passkeys");
|
||||
|
||||
b.Navigation("TotpCodes");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Logo", b =>
|
||||
{
|
||||
b.Navigation("Items");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("AliasClientDb.Tag", b =>
|
||||
{
|
||||
b.Navigation("ItemTags");
|
||||
});
|
||||
#pragma warning restore 612, 618
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
// <auto-generated>
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
|
||||
#nullable disable
|
||||
|
||||
namespace AliasClientDb.Migrations
|
||||
{
|
||||
/// <inheritdoc />
|
||||
public partial class _200MajorVersionBump : Migration
|
||||
{
|
||||
/// <inheritdoc />
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1259,3 +1259,9 @@ COMMIT;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
|
||||
|
||||
@@ -0,0 +1,6 @@
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
|
||||
@@ -1265,6 +1265,12 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');
|
||||
|
||||
BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;
|
||||
`;
|
||||
/**
|
||||
* Individual migration SQL scripts
|
||||
@@ -2466,4 +2472,9 @@ COMMIT;
|
||||
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20251213111207_1.7.0-FieldBasedDataModelUpdate', '9.0.4');`,
|
||||
12: `BEGIN TRANSACTION;
|
||||
INSERT INTO "__EFMigrationsHistory" ("MigrationId", "ProductVersion")
|
||||
VALUES ('20260130221620_2.0.0-MajorVersionBump', '9.0.4');
|
||||
|
||||
COMMIT;`,
|
||||
};
|
||||
|
||||
@@ -93,6 +93,13 @@ export const VAULT_VERSIONS: VaultVersion[] = [
|
||||
version: '1.7.0',
|
||||
description: 'Update to Field-Based Data Model',
|
||||
releaseVersion: '0.26.0',
|
||||
compatibleUpToVersion: '0.26.0',
|
||||
compatibleUpToVersion: '0.25.0',
|
||||
},
|
||||
{
|
||||
revision: 13,
|
||||
version: '2.0.0',
|
||||
description: 'Update to Field-Based Data Model',
|
||||
releaseVersion: '0.26.1',
|
||||
compatibleUpToVersion: '0.25.0',
|
||||
},
|
||||
];
|
||||
|
||||
Reference in New Issue
Block a user