first commit -push

This commit is contained in:
dungtt
2025-10-15 15:15:53 +07:00
parent 674ae395be
commit a9577c5756
885 changed files with 74595 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
using RobotNet.Script.Shares;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
namespace RobotNet.ScriptManager.Data;
#nullable disable
[Table("InstanceMissions")]
public class InstanceMission
{
[Column("Id", TypeName = "uniqueidentifier")]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
[Key]
[Required]
public Guid Id { get; set; }
[Column("MissionName", TypeName = "varchar(126)")]
[Required]
public string MissionName { get; set; }
[Column("CreatedAt", TypeName = "datetime2")]
[Required]
public DateTime CreatedAt { get; set; }
[Column("Parameters", TypeName = "nvarchar(max)")]
public string Parameters { get; set; }
[Column("Status", TypeName = "int")]
[Required]
public MissionStatus Status { get; set; }
[Column("StopedAt", TypeName = "datetime2")]
[Required]
public DateTime StopedAt { get; set; }
[Column("Log", TypeName = "nvarchar(max)")]
public string Log { get; set; }
}

View File

@@ -0,0 +1,61 @@
// <auto-generated />
using System;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
using RobotNet.ScriptManager.Data;
#nullable disable
namespace RobotNet.ScriptManager.Data.Migrations
{
[DbContext(typeof(ScriptManagerDbContext))]
[Migration("20250630100458_InitScriptManagerDbContext")]
partial class InitScriptManagerDbContext
{
/// <inheritdoc />
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "9.0.6")
.HasAnnotation("Relational:MaxIdentifierLength", 128);
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
modelBuilder.Entity("RobotNet.ScriptManager.Data.InstanceMission", b =>
{
b.Property<Guid>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("uniqueidentifier")
.HasColumnName("Id");
b.Property<DateTime>("CreatedAt")
.HasColumnType("datetime2")
.HasColumnName("CreatedAt");
b.Property<string>("Log")
.HasColumnType("nvarchar(max)")
.HasColumnName("Log");
b.Property<string>("MissionName")
.IsRequired()
.HasColumnType("varchar(126)")
.HasColumnName("MissionName");
b.Property<int>("Status")
.HasColumnType("int")
.HasColumnName("Status");
b.HasKey("Id");
b.HasIndex("CreatedAt");
b.ToTable("InstanceMissions");
});
#pragma warning restore 612, 618
}
}
}

View File

@@ -0,0 +1,42 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace RobotNet.ScriptManager.Data.Migrations
{
/// <inheritdoc />
public partial class InitScriptManagerDbContext : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "InstanceMissions",
columns: table => new
{
Id = table.Column<Guid>(type: "uniqueidentifier", nullable: false),
MissionName = table.Column<string>(type: "varchar(126)", nullable: false),
CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false),
Status = table.Column<int>(type: "int", nullable: false),
Log = table.Column<string>(type: "nvarchar(max)", nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_InstanceMissions", x => x.Id);
});
migrationBuilder.CreateIndex(
name: "IX_InstanceMissions_CreatedAt",
table: "InstanceMissions",
column: "CreatedAt");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "InstanceMissions");
}
}
}

View File

@@ -0,0 +1,65 @@
// <auto-generated />
using System;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
using RobotNet.ScriptManager.Data;
#nullable disable
namespace RobotNet.ScriptManager.Data.Migrations
{
[DbContext(typeof(ScriptManagerDbContext))]
[Migration("20250701130724_AddParametersToInstanceMission")]
partial class AddParametersToInstanceMission
{
/// <inheritdoc />
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "9.0.6")
.HasAnnotation("Relational:MaxIdentifierLength", 128);
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
modelBuilder.Entity("RobotNet.ScriptManager.Data.InstanceMission", b =>
{
b.Property<Guid>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("uniqueidentifier")
.HasColumnName("Id");
b.Property<DateTime>("CreatedAt")
.HasColumnType("datetime2")
.HasColumnName("CreatedAt");
b.Property<string>("Log")
.HasColumnType("nvarchar(max)")
.HasColumnName("Log");
b.Property<string>("MissionName")
.IsRequired()
.HasColumnType("varchar(126)")
.HasColumnName("MissionName");
b.Property<string>("Parameters")
.HasColumnType("nvarchar(max)")
.HasColumnName("Parameters");
b.Property<int>("Status")
.HasColumnType("int")
.HasColumnName("Status");
b.HasKey("Id");
b.HasIndex("CreatedAt");
b.ToTable("InstanceMissions");
});
#pragma warning restore 612, 618
}
}
}

View File

@@ -0,0 +1,28 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace RobotNet.ScriptManager.Data.Migrations
{
/// <inheritdoc />
public partial class AddParametersToInstanceMission : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<string>(
name: "Parameters",
table: "InstanceMissions",
type: "nvarchar(max)",
nullable: true);
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropColumn(
name: "Parameters",
table: "InstanceMissions");
}
}
}

View File

@@ -0,0 +1,69 @@
// <auto-generated />
using System;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
using RobotNet.ScriptManager.Data;
#nullable disable
namespace RobotNet.ScriptManager.Data.Migrations
{
[DbContext(typeof(ScriptManagerDbContext))]
[Migration("20250814072909_AddStopedAtToInstanceMission")]
partial class AddStopedAtToInstanceMission
{
/// <inheritdoc />
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "9.0.7")
.HasAnnotation("Relational:MaxIdentifierLength", 128);
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
modelBuilder.Entity("RobotNet.ScriptManager.Data.InstanceMission", b =>
{
b.Property<Guid>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("uniqueidentifier")
.HasColumnName("Id");
b.Property<DateTime>("CreatedAt")
.HasColumnType("datetime2")
.HasColumnName("CreatedAt");
b.Property<string>("Log")
.HasColumnType("nvarchar(max)")
.HasColumnName("Log");
b.Property<string>("MissionName")
.IsRequired()
.HasColumnType("varchar(126)")
.HasColumnName("MissionName");
b.Property<string>("Parameters")
.HasColumnType("nvarchar(max)")
.HasColumnName("Parameters");
b.Property<int>("Status")
.HasColumnType("int")
.HasColumnName("Status");
b.Property<DateTime>("StopedAt")
.HasColumnType("datetime2")
.HasColumnName("StopedAt");
b.HasKey("Id");
b.HasIndex("CreatedAt");
b.ToTable("InstanceMissions");
});
#pragma warning restore 612, 618
}
}
}

View File

@@ -0,0 +1,30 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace RobotNet.ScriptManager.Data.Migrations
{
/// <inheritdoc />
public partial class AddStopedAtToInstanceMission : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<DateTime>(
name: "StopedAt",
table: "InstanceMissions",
type: "datetime2",
nullable: false,
defaultValue: new DateTime(1, 1, 1, 0, 0, 0, 0, DateTimeKind.Unspecified));
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropColumn(
name: "StopedAt",
table: "InstanceMissions");
}
}
}

View File

@@ -0,0 +1,66 @@
// <auto-generated />
using System;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
using RobotNet.ScriptManager.Data;
#nullable disable
namespace RobotNet.ScriptManager.Data.Migrations
{
[DbContext(typeof(ScriptManagerDbContext))]
partial class ScriptManagerDbContextModelSnapshot : ModelSnapshot
{
protected override void BuildModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "9.0.7")
.HasAnnotation("Relational:MaxIdentifierLength", 128);
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
modelBuilder.Entity("RobotNet.ScriptManager.Data.InstanceMission", b =>
{
b.Property<Guid>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("uniqueidentifier")
.HasColumnName("Id");
b.Property<DateTime>("CreatedAt")
.HasColumnType("datetime2")
.HasColumnName("CreatedAt");
b.Property<string>("Log")
.HasColumnType("nvarchar(max)")
.HasColumnName("Log");
b.Property<string>("MissionName")
.IsRequired()
.HasColumnType("varchar(126)")
.HasColumnName("MissionName");
b.Property<string>("Parameters")
.HasColumnType("nvarchar(max)")
.HasColumnName("Parameters");
b.Property<int>("Status")
.HasColumnType("int")
.HasColumnName("Status");
b.Property<DateTime>("StopedAt")
.HasColumnType("datetime2")
.HasColumnName("StopedAt");
b.HasKey("Id");
b.HasIndex("CreatedAt");
b.ToTable("InstanceMissions");
});
#pragma warning restore 612, 618
}
}
}

View File

@@ -0,0 +1,16 @@
using Microsoft.EntityFrameworkCore;
namespace RobotNet.ScriptManager.Data;
public class ScriptManagerDbContext(DbContextOptions<ScriptManagerDbContext> options) : DbContext(options)
{
public DbSet<InstanceMission> InstanceMissions { get; private set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<InstanceMission>()
.HasIndex(im => im.CreatedAt);
}
}

View File

@@ -0,0 +1,17 @@
using Microsoft.EntityFrameworkCore;
namespace RobotNet.ScriptManager.Data;
public static class ScriptManagerDbExtensions
{
public static async Task SeedScriptManagerDbAsync(this IServiceProvider serviceProvider)
{
using var scope = serviceProvider.GetRequiredService<IServiceScopeFactory>().CreateScope();
using var appDb = scope.ServiceProvider.GetRequiredService<ScriptManagerDbContext>();
await appDb.Database.MigrateAsync();
//await appDb.Database.EnsureCreatedAsync();
await appDb.SaveChangesAsync();
}
}