diff --git a/RomRepoMgr.Database/Context.cs b/RomRepoMgr.Database/Context.cs index b8f05c2..af47c22 100644 --- a/RomRepoMgr.Database/Context.cs +++ b/RomRepoMgr.Database/Context.cs @@ -58,6 +58,8 @@ namespace RomRepoMgr.Database public DbSet RomSets { get; set; } public DbSet Machines { get; set; } public DbSet FilesByMachines { get; set; } + public DbSet Disks { get; set; } + public DbSet DisksByMachines { get; set; } public static void ReplaceSingleton(string dbPath) => _singleton = Create(dbPath); @@ -129,6 +131,24 @@ namespace RomRepoMgr.Database entity.HasOne(e => e.File).WithMany(e => e.Machines).OnDelete(DeleteBehavior.Cascade); }); + + modelBuilder.Entity(entity => + { + entity.HasIndex(e => e.Md5); + + entity.HasIndex(e => e.Sha1); + + entity.HasIndex(e => e.Size); + }); + + modelBuilder.Entity(entity => + { + entity.HasIndex(e => e.Name); + + entity.HasOne(e => e.Machine).WithMany(e => e.Disks).OnDelete(DeleteBehavior.Cascade); + + entity.HasOne(e => e.Disk).WithMany(e => e.Machines).OnDelete(DeleteBehavior.Cascade); + }); } } } \ No newline at end of file diff --git a/RomRepoMgr.Database/Migrations/20200904011014_AddDisks.Designer.cs b/RomRepoMgr.Database/Migrations/20200904011014_AddDisks.Designer.cs new file mode 100644 index 0000000..66d6166 --- /dev/null +++ b/RomRepoMgr.Database/Migrations/20200904011014_AddDisks.Designer.cs @@ -0,0 +1,311 @@ +// +using System; +using Microsoft.EntityFrameworkCore; +using Microsoft.EntityFrameworkCore.Infrastructure; +using Microsoft.EntityFrameworkCore.Migrations; +using Microsoft.EntityFrameworkCore.Storage.ValueConversion; +using RomRepoMgr.Database; + +namespace RomRepoMgr.Database.Migrations +{ + [DbContext(typeof(Context))] + [Migration("20200904011014_AddDisks")] + partial class AddDisks + { + protected override void BuildTargetModel(ModelBuilder modelBuilder) + { +#pragma warning disable 612, 618 + modelBuilder + .HasAnnotation("ProductVersion", "3.1.7"); + + modelBuilder.Entity("RomRepoMgr.Database.Models.DbDisk", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("INTEGER"); + + b.Property("CreatedOn") + .HasColumnType("TEXT"); + + b.Property("IsInRepo") + .HasColumnType("INTEGER"); + + b.Property("Md5") + .HasColumnType("TEXT") + .HasMaxLength(32); + + b.Property("OriginalFileName") + .HasColumnType("TEXT"); + + b.Property("Sha1") + .HasColumnType("TEXT") + .HasMaxLength(40); + + b.Property("Size") + .HasColumnType("INTEGER"); + + b.Property("UpdatedOn") + .HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("Md5"); + + b.HasIndex("Sha1"); + + b.HasIndex("Size"); + + b.ToTable("Disks"); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.DbFile", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("INTEGER"); + + b.Property("Crc32") + .HasColumnType("TEXT") + .HasMaxLength(8); + + b.Property("CreatedOn") + .HasColumnType("TEXT"); + + b.Property("IsInRepo") + .HasColumnType("INTEGER"); + + b.Property("Md5") + .HasColumnType("TEXT") + .HasMaxLength(32); + + b.Property("OriginalFileName") + .HasColumnType("TEXT"); + + b.Property("Sha1") + .HasColumnType("TEXT") + .HasMaxLength(40); + + b.Property("Sha256") + .HasColumnType("TEXT") + .HasMaxLength(64); + + b.Property("Sha384") + .HasColumnType("TEXT") + .HasMaxLength(96); + + b.Property("Sha512") + .HasColumnType("TEXT") + .HasMaxLength(128); + + b.Property("Size") + .HasColumnType("INTEGER"); + + b.Property("UpdatedOn") + .HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("Crc32"); + + b.HasIndex("Sha1"); + + b.HasIndex("Sha256"); + + b.HasIndex("Sha384"); + + b.HasIndex("Sha512"); + + b.HasIndex("Size"); + + b.ToTable("Files"); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.DiskByMachine", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("INTEGER"); + + b.Property("DiskId") + .HasColumnType("INTEGER"); + + b.Property("MachineId") + .HasColumnType("INTEGER"); + + b.Property("Name") + .IsRequired() + .HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("DiskId"); + + b.HasIndex("MachineId"); + + b.HasIndex("Name"); + + b.ToTable("DisksByMachines"); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.FileByMachine", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("INTEGER"); + + b.Property("FileId") + .HasColumnType("INTEGER"); + + b.Property("MachineId") + .HasColumnType("INTEGER"); + + b.Property("Name") + .IsRequired() + .HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("FileId"); + + b.HasIndex("MachineId"); + + b.HasIndex("Name"); + + b.ToTable("FilesByMachines"); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.Machine", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("INTEGER"); + + b.Property("CreatedOn") + .HasColumnType("TEXT"); + + b.Property("Name") + .IsRequired() + .HasColumnType("TEXT"); + + b.Property("RomSetId") + .HasColumnType("INTEGER"); + + b.Property("UpdatedOn") + .HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("Name"); + + b.HasIndex("RomSetId"); + + b.ToTable("Machines"); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.RomSet", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("INTEGER"); + + b.Property("Author") + .HasColumnType("TEXT"); + + b.Property("Comment") + .HasColumnType("TEXT"); + + b.Property("CreatedOn") + .HasColumnType("TEXT"); + + b.Property("Date") + .HasColumnType("TEXT"); + + b.Property("Description") + .HasColumnType("TEXT"); + + b.Property("Filename") + .IsRequired() + .HasColumnType("TEXT"); + + b.Property("Homepage") + .HasColumnType("TEXT"); + + b.Property("Name") + .HasColumnType("TEXT"); + + b.Property("Sha384") + .IsRequired() + .HasColumnType("TEXT") + .HasMaxLength(96); + + b.Property("UpdatedOn") + .HasColumnType("TEXT"); + + b.Property("Version") + .HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("Author"); + + b.HasIndex("Comment"); + + b.HasIndex("Date"); + + b.HasIndex("Description"); + + b.HasIndex("Filename"); + + b.HasIndex("Homepage"); + + b.HasIndex("Name"); + + b.HasIndex("Sha384"); + + b.HasIndex("Version"); + + b.ToTable("RomSets"); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.DiskByMachine", b => + { + b.HasOne("RomRepoMgr.Database.Models.DbDisk", "Disk") + .WithMany("Machines") + .HasForeignKey("DiskId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("RomRepoMgr.Database.Models.Machine", "Machine") + .WithMany("Disks") + .HasForeignKey("MachineId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.FileByMachine", b => + { + b.HasOne("RomRepoMgr.Database.Models.DbFile", "File") + .WithMany("Machines") + .HasForeignKey("FileId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("RomRepoMgr.Database.Models.Machine", "Machine") + .WithMany("Files") + .HasForeignKey("MachineId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + }); + + modelBuilder.Entity("RomRepoMgr.Database.Models.Machine", b => + { + b.HasOne("RomRepoMgr.Database.Models.RomSet", "RomSet") + .WithMany("Machines") + .HasForeignKey("RomSetId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + }); +#pragma warning restore 612, 618 + } + } +} diff --git a/RomRepoMgr.Database/Migrations/20200904011014_AddDisks.cs b/RomRepoMgr.Database/Migrations/20200904011014_AddDisks.cs new file mode 100644 index 0000000..4c65c0d --- /dev/null +++ b/RomRepoMgr.Database/Migrations/20200904011014_AddDisks.cs @@ -0,0 +1,59 @@ +using System; +using Microsoft.EntityFrameworkCore.Migrations; + +namespace RomRepoMgr.Database.Migrations +{ + public partial class AddDisks : Migration + { + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.CreateTable("Disks", table => new + { + Id = table.Column(nullable: false).Annotation("Sqlite:Autoincrement", true), + CreatedOn = table.Column(nullable: false), + UpdatedOn = table.Column(nullable: false), + Size = table.Column(nullable: true), + Md5 = table.Column(maxLength: 32, nullable: true), + Sha1 = table.Column(maxLength: 40, nullable: true), + IsInRepo = table.Column(nullable: false), + OriginalFileName = table.Column(nullable: true) + }, constraints: table => table.PrimaryKey("PK_Disks", x => x.Id)); + + migrationBuilder.CreateTable("DisksByMachines", table => new + { + Id = table.Column(nullable: false).Annotation("Sqlite:Autoincrement", true), + DiskId = table.Column(nullable: false), + MachineId = table.Column(nullable: false), + Name = table.Column(nullable: false) + }, constraints: table => + { + table.PrimaryKey("PK_DisksByMachines", x => x.Id); + + table.ForeignKey("FK_DisksByMachines_Disks_DiskId", x => x.DiskId, "Disks", "Id", + onDelete: ReferentialAction.Cascade); + + table.ForeignKey("FK_DisksByMachines_Machines_MachineId", x => x.MachineId, "Machines", "Id", + onDelete: ReferentialAction.Cascade); + }); + + migrationBuilder.CreateIndex("IX_Disks_Md5", "Disks", "Md5"); + + migrationBuilder.CreateIndex("IX_Disks_Sha1", "Disks", "Sha1"); + + migrationBuilder.CreateIndex("IX_Disks_Size", "Disks", "Size"); + + migrationBuilder.CreateIndex("IX_DisksByMachines_DiskId", "DisksByMachines", "DiskId"); + + migrationBuilder.CreateIndex("IX_DisksByMachines_MachineId", "DisksByMachines", "MachineId"); + + migrationBuilder.CreateIndex("IX_DisksByMachines_Name", "DisksByMachines", "Name"); + } + + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropTable("DisksByMachines"); + + migrationBuilder.DropTable("Disks"); + } + } +} \ No newline at end of file diff --git a/RomRepoMgr.Database/Migrations/ContextModelSnapshot.cs b/RomRepoMgr.Database/Migrations/ContextModelSnapshot.cs index cc0c371..f35166f 100644 --- a/RomRepoMgr.Database/Migrations/ContextModelSnapshot.cs +++ b/RomRepoMgr.Database/Migrations/ContextModelSnapshot.cs @@ -14,6 +14,35 @@ namespace RomRepoMgr.Database.Migrations #pragma warning disable 612, 618 modelBuilder.HasAnnotation("ProductVersion", "3.1.7"); + modelBuilder.Entity("RomRepoMgr.Database.Models.DbDisk", b => + { + b.Property("Id").ValueGeneratedOnAdd().HasColumnType("INTEGER"); + + b.Property("CreatedOn").HasColumnType("TEXT"); + + b.Property("IsInRepo").HasColumnType("INTEGER"); + + b.Property("Md5").HasColumnType("TEXT").HasMaxLength(32); + + b.Property("OriginalFileName").HasColumnType("TEXT"); + + b.Property("Sha1").HasColumnType("TEXT").HasMaxLength(40); + + b.Property("Size").HasColumnType("INTEGER"); + + b.Property("UpdatedOn").HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("Md5"); + + b.HasIndex("Sha1"); + + b.HasIndex("Size"); + + b.ToTable("Disks"); + }); + modelBuilder.Entity("RomRepoMgr.Database.Models.DbFile", b => { b.Property("Id").ValueGeneratedOnAdd().HasColumnType("INTEGER"); @@ -57,6 +86,27 @@ namespace RomRepoMgr.Database.Migrations b.ToTable("Files"); }); + modelBuilder.Entity("RomRepoMgr.Database.Models.DiskByMachine", b => + { + b.Property("Id").ValueGeneratedOnAdd().HasColumnType("INTEGER"); + + b.Property("DiskId").HasColumnType("INTEGER"); + + b.Property("MachineId").HasColumnType("INTEGER"); + + b.Property("Name").IsRequired().HasColumnType("TEXT"); + + b.HasKey("Id"); + + b.HasIndex("DiskId"); + + b.HasIndex("MachineId"); + + b.HasIndex("Name"); + + b.ToTable("DisksByMachines"); + }); + modelBuilder.Entity("RomRepoMgr.Database.Models.FileByMachine", b => { b.Property("Id").ValueGeneratedOnAdd().HasColumnType("INTEGER"); @@ -148,6 +198,15 @@ namespace RomRepoMgr.Database.Migrations b.ToTable("RomSets"); }); + modelBuilder.Entity("RomRepoMgr.Database.Models.DiskByMachine", b => + { + b.HasOne("RomRepoMgr.Database.Models.DbDisk", "Disk").WithMany("Machines").HasForeignKey("DiskId"). + OnDelete(DeleteBehavior.Cascade).IsRequired(); + + b.HasOne("RomRepoMgr.Database.Models.Machine", "Machine").WithMany("Disks").HasForeignKey("MachineId"). + OnDelete(DeleteBehavior.Cascade).IsRequired(); + }); + modelBuilder.Entity("RomRepoMgr.Database.Models.FileByMachine", b => { b.HasOne("RomRepoMgr.Database.Models.DbFile", "File").WithMany("Machines").HasForeignKey("FileId"). diff --git a/RomRepoMgr.Database/Models/DbDisk.cs b/RomRepoMgr.Database/Models/DbDisk.cs new file mode 100644 index 0000000..e027ba6 --- /dev/null +++ b/RomRepoMgr.Database/Models/DbDisk.cs @@ -0,0 +1,44 @@ +/****************************************************************************** +// RomRepoMgr - ROM repository manager +// ---------------------------------------------------------------------------- +// +// Author(s) : Natalia Portillo +// +// --[ License ] -------------------------------------------------------------- +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as +// published by the Free Software Foundation, either version 3 of the +// License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see . +// +// ---------------------------------------------------------------------------- +// Copyright © 2020 Natalia Portillo +*******************************************************************************/ + +using System.Collections.Generic; +using System.ComponentModel; +using System.ComponentModel.DataAnnotations; + +namespace RomRepoMgr.Database.Models +{ + public class DbDisk : BaseModel + { + public ulong? Size { get; set; } + [StringLength(32, MinimumLength = 32)] + public string Md5 { get; set; } + [StringLength(40, MinimumLength = 40)] + public string Sha1 { get; set; } + [DefaultValue(false)] + public bool IsInRepo { get; set; } + public string OriginalFileName { get; set; } + public virtual ICollection Machines { get; set; } + } +} \ No newline at end of file diff --git a/RomRepoMgr.Database/Models/DiskByMachine.cs b/RomRepoMgr.Database/Models/DiskByMachine.cs new file mode 100644 index 0000000..a0c7df6 --- /dev/null +++ b/RomRepoMgr.Database/Models/DiskByMachine.cs @@ -0,0 +1,41 @@ +/****************************************************************************** +// RomRepoMgr - ROM repository manager +// ---------------------------------------------------------------------------- +// +// Author(s) : Natalia Portillo +// +// --[ License ] -------------------------------------------------------------- +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as +// published by the Free Software Foundation, either version 3 of the +// License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see . +// +// ---------------------------------------------------------------------------- +// Copyright © 2020 Natalia Portillo +*******************************************************************************/ + +using System.ComponentModel.DataAnnotations; + +namespace RomRepoMgr.Database.Models +{ + public class DiskByMachine + { + [Key] + public ulong Id { get; set; } + [Required] + public virtual DbDisk Disk { get; set; } + [Required] + public virtual Machine Machine { get; set; } + [Required] + public string Name { get; set; } + } +} \ No newline at end of file diff --git a/RomRepoMgr.Database/Models/Machine.cs b/RomRepoMgr.Database/Models/Machine.cs index d3ed7ca..952957d 100644 --- a/RomRepoMgr.Database/Models/Machine.cs +++ b/RomRepoMgr.Database/Models/Machine.cs @@ -35,5 +35,6 @@ namespace RomRepoMgr.Database.Models [Required] public virtual RomSet RomSet { get; set; } public virtual ICollection Files { get; set; } + public virtual ICollection Disks { get; set; } } } \ No newline at end of file