diff --git a/DysonNetwork.Drive/Migrations/20260101153809_RemoveUploadTask.Designer.cs b/DysonNetwork.Drive/Migrations/20260101153809_RemoveUploadTask.Designer.cs
new file mode 100644
index 0000000..c5ce024
--- /dev/null
+++ b/DysonNetwork.Drive/Migrations/20260101153809_RemoveUploadTask.Designer.cs
@@ -0,0 +1,560 @@
+//
+using System;
+using System.Collections.Generic;
+using DysonNetwork.Drive;
+using DysonNetwork.Shared.Models;
+using Microsoft.EntityFrameworkCore;
+using Microsoft.EntityFrameworkCore.Infrastructure;
+using Microsoft.EntityFrameworkCore.Migrations;
+using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
+using NodaTime;
+using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
+
+#nullable disable
+
+namespace DysonNetwork.Drive.Migrations
+{
+ [DbContext(typeof(AppDatabase))]
+ [Migration("20260101153809_RemoveUploadTask")]
+ partial class RemoveUploadTask
+ {
+ ///
+ protected override void BuildTargetModel(ModelBuilder modelBuilder)
+ {
+#pragma warning disable 612, 618
+ modelBuilder
+ .HasAnnotation("ProductVersion", "10.0.1")
+ .HasAnnotation("Relational:MaxIdentifierLength", 63);
+
+ NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
+
+ modelBuilder.Entity("DysonNetwork.Drive.Billing.QuotaRecord", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AccountId")
+ .HasColumnType("uuid")
+ .HasColumnName("account_id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("Description")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("description");
+
+ b.Property("ExpiredAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("expired_at");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("name");
+
+ b.Property("Quota")
+ .HasColumnType("bigint")
+ .HasColumnName("quota");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.HasKey("Id")
+ .HasName("pk_quota_records");
+
+ b.ToTable("quota_records", (string)null);
+ });
+
+ modelBuilder.Entity("DysonNetwork.Drive.Storage.Model.PersistentTask", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AccountId")
+ .HasColumnType("uuid")
+ .HasColumnName("account_id");
+
+ b.Property("CompletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("completed_at");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("Description")
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("description");
+
+ b.Property("ErrorMessage")
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("error_message");
+
+ b.Property("EstimatedDurationSeconds")
+ .HasColumnType("bigint")
+ .HasColumnName("estimated_duration_seconds");
+
+ b.Property("ExpiredAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("expired_at");
+
+ b.Property("LastActivity")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("last_activity");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("name");
+
+ b.Property>("Parameters")
+ .IsRequired()
+ .HasColumnType("jsonb")
+ .HasColumnName("parameters");
+
+ b.Property("Priority")
+ .HasColumnType("integer")
+ .HasColumnName("priority");
+
+ b.Property("Progress")
+ .HasColumnType("double precision")
+ .HasColumnName("progress");
+
+ b.Property>("Results")
+ .IsRequired()
+ .HasColumnType("jsonb")
+ .HasColumnName("results");
+
+ b.Property("StartedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("started_at");
+
+ b.Property("Status")
+ .HasColumnType("integer")
+ .HasColumnName("status");
+
+ b.Property("TaskId")
+ .IsRequired()
+ .HasMaxLength(64)
+ .HasColumnType("character varying(64)")
+ .HasColumnName("task_id");
+
+ b.Property("Type")
+ .HasColumnType("integer")
+ .HasColumnName("type");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.HasKey("Id")
+ .HasName("pk_tasks");
+
+ b.ToTable("tasks", (string)null);
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.FilePool", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AccountId")
+ .HasColumnType("uuid")
+ .HasColumnName("account_id");
+
+ b.Property("BillingConfig")
+ .IsRequired()
+ .HasColumnType("jsonb")
+ .HasColumnName("billing_config");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("Description")
+ .IsRequired()
+ .HasMaxLength(8192)
+ .HasColumnType("character varying(8192)")
+ .HasColumnName("description");
+
+ b.Property("IsHidden")
+ .HasColumnType("boolean")
+ .HasColumnName("is_hidden");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("name");
+
+ b.Property("PolicyConfig")
+ .IsRequired()
+ .HasColumnType("jsonb")
+ .HasColumnName("policy_config");
+
+ b.Property("StorageConfig")
+ .IsRequired()
+ .HasColumnType("jsonb")
+ .HasColumnName("storage_config");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.HasKey("Id")
+ .HasName("pk_pools");
+
+ b.ToTable("pools", (string)null);
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFile", b =>
+ {
+ b.Property("Id")
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("id");
+
+ b.Property("AccountId")
+ .HasColumnType("uuid")
+ .HasColumnName("account_id");
+
+ b.Property("BundleId")
+ .HasColumnType("uuid")
+ .HasColumnName("bundle_id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("Description")
+ .HasMaxLength(4096)
+ .HasColumnType("character varying(4096)")
+ .HasColumnName("description");
+
+ b.Property("ExpiredAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("expired_at");
+
+ b.Property>("FileMeta")
+ .HasColumnType("jsonb")
+ .HasColumnName("file_meta");
+
+ b.Property("HasCompression")
+ .HasColumnType("boolean")
+ .HasColumnName("has_compression");
+
+ b.Property("HasThumbnail")
+ .HasColumnType("boolean")
+ .HasColumnName("has_thumbnail");
+
+ b.Property("Hash")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("hash");
+
+ b.Property("IsEncrypted")
+ .HasColumnType("boolean")
+ .HasColumnName("is_encrypted");
+
+ b.Property("IsMarkedRecycle")
+ .HasColumnType("boolean")
+ .HasColumnName("is_marked_recycle");
+
+ b.Property("MimeType")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("mime_type");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("name");
+
+ b.Property("PoolId")
+ .HasColumnType("uuid")
+ .HasColumnName("pool_id");
+
+ b.PrimitiveCollection("SensitiveMarks")
+ .HasColumnType("jsonb")
+ .HasColumnName("sensitive_marks");
+
+ b.Property("Size")
+ .HasColumnType("bigint")
+ .HasColumnName("size");
+
+ b.Property("StorageId")
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("storage_id");
+
+ b.Property("StorageUrl")
+ .HasMaxLength(4096)
+ .HasColumnType("character varying(4096)")
+ .HasColumnName("storage_url");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.Property("UploadedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("uploaded_at");
+
+ b.Property>("UserMeta")
+ .HasColumnType("jsonb")
+ .HasColumnName("user_meta");
+
+ b.HasKey("Id")
+ .HasName("pk_files");
+
+ b.HasIndex("BundleId")
+ .HasDatabaseName("ix_files_bundle_id");
+
+ b.HasIndex("PoolId")
+ .HasDatabaseName("ix_files_pool_id");
+
+ b.ToTable("files", (string)null);
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileIndex", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AccountId")
+ .HasColumnType("uuid")
+ .HasColumnName("account_id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("FileId")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("file_id");
+
+ b.Property("Path")
+ .IsRequired()
+ .HasMaxLength(8192)
+ .HasColumnType("character varying(8192)")
+ .HasColumnName("path");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.HasKey("Id")
+ .HasName("pk_file_indexes");
+
+ b.HasIndex("FileId")
+ .HasDatabaseName("ix_file_indexes_file_id");
+
+ b.HasIndex("Path", "AccountId")
+ .HasDatabaseName("ix_file_indexes_path_account_id");
+
+ b.ToTable("file_indexes", (string)null);
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileReference", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("ExpiredAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("expired_at");
+
+ b.Property("FileId")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("file_id");
+
+ b.Property("ResourceId")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("resource_id");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.Property("Usage")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("usage");
+
+ b.HasKey("Id")
+ .HasName("pk_file_references");
+
+ b.HasIndex("FileId")
+ .HasDatabaseName("ix_file_references_file_id");
+
+ b.ToTable("file_references", (string)null);
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnFileBundle", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AccountId")
+ .HasColumnType("uuid")
+ .HasColumnName("account_id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("Description")
+ .HasMaxLength(8192)
+ .HasColumnType("character varying(8192)")
+ .HasColumnName("description");
+
+ b.Property("ExpiredAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("expired_at");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("name");
+
+ b.Property("Passcode")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("passcode");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("slug");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.HasKey("Id")
+ .HasName("pk_bundles");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_bundles_slug");
+
+ b.ToTable("bundles", (string)null);
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFile", b =>
+ {
+ b.HasOne("DysonNetwork.Shared.Models.SnFileBundle", "Bundle")
+ .WithMany("Files")
+ .HasForeignKey("BundleId")
+ .HasConstraintName("fk_files_bundles_bundle_id");
+
+ b.HasOne("DysonNetwork.Shared.Models.FilePool", "Pool")
+ .WithMany()
+ .HasForeignKey("PoolId")
+ .HasConstraintName("fk_files_pools_pool_id");
+
+ b.Navigation("Bundle");
+
+ b.Navigation("Pool");
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileIndex", b =>
+ {
+ b.HasOne("DysonNetwork.Shared.Models.SnCloudFile", "File")
+ .WithMany("FileIndexes")
+ .HasForeignKey("FileId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_file_indexes_files_file_id");
+
+ b.Navigation("File");
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileReference", b =>
+ {
+ b.HasOne("DysonNetwork.Shared.Models.SnCloudFile", "File")
+ .WithMany("References")
+ .HasForeignKey("FileId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_file_references_files_file_id");
+
+ b.Navigation("File");
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFile", b =>
+ {
+ b.Navigation("FileIndexes");
+
+ b.Navigation("References");
+ });
+
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnFileBundle", b =>
+ {
+ b.Navigation("Files");
+ });
+#pragma warning restore 612, 618
+ }
+ }
+}
diff --git a/DysonNetwork.Drive/Migrations/20260101153809_RemoveUploadTask.cs b/DysonNetwork.Drive/Migrations/20260101153809_RemoveUploadTask.cs
new file mode 100644
index 0000000..7a9cb02
--- /dev/null
+++ b/DysonNetwork.Drive/Migrations/20260101153809_RemoveUploadTask.cs
@@ -0,0 +1,155 @@
+using System;
+using System.Collections.Generic;
+using Microsoft.EntityFrameworkCore.Migrations;
+
+#nullable disable
+
+namespace DysonNetwork.Drive.Migrations
+{
+ ///
+ public partial class RemoveUploadTask : Migration
+ {
+ ///
+ protected override void Up(MigrationBuilder migrationBuilder)
+ {
+ migrationBuilder.DropColumn(
+ name: "bundle_id",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "chunk_size",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "chunks_count",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "chunks_uploaded",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "content_type",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "discriminator",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "encrypt_password",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "file_name",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "file_size",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "hash",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "path",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "pool_id",
+ table: "tasks");
+
+ migrationBuilder.DropColumn(
+ name: "uploaded_chunks",
+ table: "tasks");
+ }
+
+ ///
+ protected override void Down(MigrationBuilder migrationBuilder)
+ {
+ migrationBuilder.AddColumn(
+ name: "bundle_id",
+ table: "tasks",
+ type: "uuid",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "chunk_size",
+ table: "tasks",
+ type: "bigint",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "chunks_count",
+ table: "tasks",
+ type: "integer",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "chunks_uploaded",
+ table: "tasks",
+ type: "integer",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "content_type",
+ table: "tasks",
+ type: "character varying(128)",
+ maxLength: 128,
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "discriminator",
+ table: "tasks",
+ type: "character varying(21)",
+ maxLength: 21,
+ nullable: false,
+ defaultValue: "");
+
+ migrationBuilder.AddColumn(
+ name: "encrypt_password",
+ table: "tasks",
+ type: "character varying(256)",
+ maxLength: 256,
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "file_name",
+ table: "tasks",
+ type: "character varying(256)",
+ maxLength: 256,
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "file_size",
+ table: "tasks",
+ type: "bigint",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "hash",
+ table: "tasks",
+ type: "text",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "path",
+ table: "tasks",
+ type: "text",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "pool_id",
+ table: "tasks",
+ type: "uuid",
+ nullable: true);
+
+ migrationBuilder.AddColumn>(
+ name: "uploaded_chunks",
+ table: "tasks",
+ type: "integer[]",
+ nullable: true);
+ }
+ }
+}
diff --git a/DysonNetwork.Drive/Migrations/AppDatabaseModelSnapshot.cs b/DysonNetwork.Drive/Migrations/AppDatabaseModelSnapshot.cs
index 0cf2fb3..14cbaec 100644
--- a/DysonNetwork.Drive/Migrations/AppDatabaseModelSnapshot.cs
+++ b/DysonNetwork.Drive/Migrations/AppDatabaseModelSnapshot.cs
@@ -20,7 +20,7 @@ namespace DysonNetwork.Drive.Migrations
{
#pragma warning disable 612, 618
modelBuilder
- .HasAnnotation("ProductVersion", "9.0.10")
+ .HasAnnotation("ProductVersion", "10.0.1")
.HasAnnotation("Relational:MaxIdentifierLength", 63);
NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
@@ -100,12 +100,6 @@ namespace DysonNetwork.Drive.Migrations
.HasColumnType("character varying(1024)")
.HasColumnName("description");
- b.Property("Discriminator")
- .IsRequired()
- .HasMaxLength(21)
- .HasColumnType("character varying(21)")
- .HasColumnName("discriminator");
-
b.Property("ErrorMessage")
.HasMaxLength(1024)
.HasColumnType("character varying(1024)")
@@ -173,60 +167,6 @@ namespace DysonNetwork.Drive.Migrations
.HasName("pk_tasks");
b.ToTable("tasks", (string)null);
-
- b.HasDiscriminator().HasValue("PersistentTask");
-
- b.UseTphMappingStrategy();
- });
-
- modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileReference", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("uuid")
- .HasColumnName("id");
-
- b.Property("CreatedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("created_at");
-
- b.Property("DeletedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("deleted_at");
-
- b.Property("ExpiredAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("expired_at");
-
- b.Property("FileId")
- .IsRequired()
- .HasMaxLength(32)
- .HasColumnType("character varying(32)")
- .HasColumnName("file_id");
-
- b.Property("ResourceId")
- .IsRequired()
- .HasMaxLength(1024)
- .HasColumnType("character varying(1024)")
- .HasColumnName("resource_id");
-
- b.Property("UpdatedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("updated_at");
-
- b.Property("Usage")
- .IsRequired()
- .HasMaxLength(1024)
- .HasColumnType("character varying(1024)")
- .HasColumnName("usage");
-
- b.HasKey("Id")
- .HasName("pk_file_references");
-
- b.HasIndex("FileId")
- .HasDatabaseName("ix_file_references_file_id");
-
- b.ToTable("file_references", (string)null);
});
modelBuilder.Entity("DysonNetwork.Shared.Models.FilePool", b =>
@@ -361,7 +301,7 @@ namespace DysonNetwork.Drive.Migrations
.HasColumnType("uuid")
.HasColumnName("pool_id");
- b.Property>("SensitiveMarks")
+ b.PrimitiveCollection("SensitiveMarks")
.HasColumnType("jsonb")
.HasColumnName("sensitive_marks");
@@ -450,6 +390,56 @@ namespace DysonNetwork.Drive.Migrations
b.ToTable("file_indexes", (string)null);
});
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileReference", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_at");
+
+ b.Property("DeletedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("deleted_at");
+
+ b.Property("ExpiredAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("expired_at");
+
+ b.Property("FileId")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("file_id");
+
+ b.Property("ResourceId")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("resource_id");
+
+ b.Property("UpdatedAt")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_at");
+
+ b.Property("Usage")
+ .IsRequired()
+ .HasMaxLength(1024)
+ .HasColumnType("character varying(1024)")
+ .HasColumnName("usage");
+
+ b.HasKey("Id")
+ .HasName("pk_file_references");
+
+ b.HasIndex("FileId")
+ .HasDatabaseName("ix_file_references_file_id");
+
+ b.ToTable("file_references", (string)null);
+ });
+
modelBuilder.Entity("DysonNetwork.Shared.Models.SnFileBundle", b =>
{
b.Property("Id")
@@ -509,80 +499,6 @@ namespace DysonNetwork.Drive.Migrations
b.ToTable("bundles", (string)null);
});
- modelBuilder.Entity("DysonNetwork.Drive.Storage.Model.PersistentUploadTask", b =>
- {
- b.HasBaseType("DysonNetwork.Drive.Storage.Model.PersistentTask");
-
- b.Property("BundleId")
- .HasColumnType("uuid")
- .HasColumnName("bundle_id");
-
- b.Property("ChunkSize")
- .HasColumnType("bigint")
- .HasColumnName("chunk_size");
-
- b.Property("ChunksCount")
- .HasColumnType("integer")
- .HasColumnName("chunks_count");
-
- b.Property("ChunksUploaded")
- .HasColumnType("integer")
- .HasColumnName("chunks_uploaded");
-
- b.Property("ContentType")
- .IsRequired()
- .HasMaxLength(128)
- .HasColumnType("character varying(128)")
- .HasColumnName("content_type");
-
- b.Property("EncryptPassword")
- .HasMaxLength(256)
- .HasColumnType("character varying(256)")
- .HasColumnName("encrypt_password");
-
- b.Property("FileName")
- .IsRequired()
- .HasMaxLength(256)
- .HasColumnType("character varying(256)")
- .HasColumnName("file_name");
-
- b.Property("FileSize")
- .HasColumnType("bigint")
- .HasColumnName("file_size");
-
- b.Property("Hash")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("hash");
-
- b.Property("Path")
- .HasColumnType("text")
- .HasColumnName("path");
-
- b.Property("PoolId")
- .HasColumnType("uuid")
- .HasColumnName("pool_id");
-
- b.PrimitiveCollection>("UploadedChunks")
- .IsRequired()
- .HasColumnType("integer[]")
- .HasColumnName("uploaded_chunks");
-
- b.HasDiscriminator().HasValue("PersistentUploadTask");
- });
-
- modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileReference", b =>
- {
- b.HasOne("DysonNetwork.Shared.Models.SnCloudFile", "File")
- .WithMany("References")
- .HasForeignKey("FileId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("fk_file_references_files_file_id");
-
- b.Navigation("File");
- });
-
modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFile", b =>
{
b.HasOne("DysonNetwork.Shared.Models.SnFileBundle", "Bundle")
@@ -612,6 +528,18 @@ namespace DysonNetwork.Drive.Migrations
b.Navigation("File");
});
+ modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFileReference", b =>
+ {
+ b.HasOne("DysonNetwork.Shared.Models.SnCloudFile", "File")
+ .WithMany("References")
+ .HasForeignKey("FileId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_file_references_files_file_id");
+
+ b.Navigation("File");
+ });
+
modelBuilder.Entity("DysonNetwork.Shared.Models.SnCloudFile", b =>
{
b.Navigation("FileIndexes");