You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
184 lines
9.9 KiB
184 lines
9.9 KiB
using Application.Domain.Entities;
|
|
using Infrastructure.Application.Entites.Settings;
|
|
using Infrastructure.Data;
|
|
using Infrastructure.Events;
|
|
using Infrastructure.Extensions;
|
|
using Infrastructure.Security;
|
|
using IoT.Shared;
|
|
using IoT.Shared.Application.Domain.Entities;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.Extensions.Configuration;
|
|
using Microsoft.Extensions.Hosting;
|
|
using Microsoft.Extensions.Logging;
|
|
using System;
|
|
using System.Linq;
|
|
using Permission = Application.Domain.Entities.Permission;
|
|
using PermissionCategory = Application.Domain.Entities.PermissionCategory;
|
|
using User = Application.Domain.Entities.User;
|
|
|
|
namespace IoTNode.Data
|
|
{
|
|
public class IoTNodeDbContext : EfDbContext, IDbConfig
|
|
{
|
|
private readonly IEncryptionService _encryptionService;
|
|
|
|
public IoTNodeDbContext(DbContextOptions options,
|
|
ILogger<EfDbContext> logger,
|
|
IHostEnvironment env,
|
|
IConfiguration cfg,
|
|
IEventPublisher publisher,
|
|
IEncryptionService encryptionService)
|
|
: base(options, logger, env, cfg, publisher)
|
|
{
|
|
this._encryptionService = encryptionService;
|
|
}
|
|
|
|
protected override void OnModelCreating(ModelBuilder modelBuilder)
|
|
{
|
|
IoTSharedDbConfig.OnModelCreating(modelBuilder);
|
|
//Setting
|
|
modelBuilder.Entity<Setting>().HasIndex(o => o.Name).IsUnique();
|
|
//ignore
|
|
modelBuilder.Ignore<Area>();
|
|
modelBuilder.Ignore<Building>();
|
|
modelBuilder.Ignore<Organ>();
|
|
modelBuilder.Ignore<Department>();
|
|
modelBuilder.Ignore<DepartmentUser>();
|
|
modelBuilder.Ignore<Job>();
|
|
modelBuilder.Ignore<Title>();
|
|
modelBuilder.Ignore<OrganUser>();
|
|
modelBuilder.Ignore<OrganRole>();
|
|
modelBuilder.Ignore<OrganRolePermission>();
|
|
modelBuilder.Ignore<OrganUserRole>();
|
|
modelBuilder.Ignore<PermissionCategory>();
|
|
modelBuilder.Ignore<IoTProductCategory>();
|
|
modelBuilder.Ignore<IoTCommand>();
|
|
modelBuilder.Ignore<IoTSceneIoTCommand>();
|
|
modelBuilder.Ignore<IoTScene>();
|
|
modelBuilder.Ignore<IoTTimer>();
|
|
modelBuilder.Ignore<IoTTigger>();
|
|
modelBuilder.Entity<IoTProduct>().Ignore(o => o.DisplayOrder);
|
|
modelBuilder.Entity<IoTApi>().Ignore(o => o.IoTCommands);
|
|
modelBuilder.Entity<IoTGateway>().Ignore(o => o.Building);
|
|
modelBuilder.Entity<IoTDevice>().Ignore(o => o.IoTCommands);
|
|
modelBuilder.Ignore<IoT.Shared.Application.Domain.Entities.User>();
|
|
modelBuilder.Ignore<IoT.Shared.Application.Domain.Entities.PermissionCategory>();
|
|
modelBuilder.Ignore<IoT.Shared.Application.Domain.Entities.Permission>();
|
|
//
|
|
modelBuilder.Ignore<PermissionCategory>();
|
|
modelBuilder.Ignore<Permission>();
|
|
modelBuilder.Ignore<User>();
|
|
modelBuilder.Entity<User>().Property(o => o.UserName).IsRequired();
|
|
modelBuilder.Entity<User>().HasIndex(o => o.UserName).IsUnique();
|
|
modelBuilder.Entity<User>().HasIndex(o => o.Email).IsUnique();
|
|
modelBuilder.Entity<Role>().Property(o => o.Name).IsRequired();
|
|
modelBuilder.Entity<Role>().HasIndex(o => o.Name).IsUnique();
|
|
modelBuilder.Entity<PermissionCategory>().HasOne(o => o.Parent).WithMany(o => o.Children).HasForeignKey(o => o.ParentId).OnDelete(DeleteBehavior.SetNull);
|
|
modelBuilder.Entity<PermissionCategory>().HasIndex(o => o.Number).IsUnique();
|
|
modelBuilder.Entity<Permission>().HasIndex(o => o.Number).IsUnique();
|
|
modelBuilder.Entity<Permission>().HasOne(o => o.Category).WithMany(o => o.Permissions).HasForeignKey(o => o.CategoryId).OnDelete(DeleteBehavior.SetNull);
|
|
modelBuilder.Entity<UserRole>().HasOne(o => o.User).WithMany(o => o.UserRoles).HasForeignKey(o => o.UserId);
|
|
modelBuilder.Entity<UserRole>().HasOne(o => o.Role).WithMany(o => o.UserRoles).HasForeignKey(o => o.RoleId);
|
|
modelBuilder.Entity<UserRole>().HasIndex(o => new { o.UserId, o.RoleId }).IsUnique();
|
|
modelBuilder.Entity<RolePermission>().HasOne(o => o.Role).WithMany(o => o.RolePermissions).HasForeignKey(o => o.RoleId);
|
|
modelBuilder.Entity<RolePermission>().HasOne(o => o.Permission).WithMany(o => o.RolePermissions).HasForeignKey(o => o.PermissionId);
|
|
modelBuilder.Entity<RolePermission>().HasIndex(o => new { o.RoleId, o.PermissionId }).IsUnique();
|
|
base.OnModelCreating(modelBuilder);
|
|
}
|
|
|
|
public void Seed(DbContext db)
|
|
{
|
|
foreach (var item in db.Model.GetEntityTypes())
|
|
{
|
|
var type = item.ClrType;
|
|
var name = type.GetDisplayName();
|
|
var number = type.Name;
|
|
var category = new PermissionCategory
|
|
{
|
|
Name = name,
|
|
Number = type.Name
|
|
};
|
|
category.Permissions.Add(new Permission { Name = $"查看{name}", Number = $"Read-{number}" });
|
|
category.Permissions.Add(new Permission { Name = $"添加{name}", Number = $"Add-{number}" });
|
|
category.Permissions.Add(new Permission { Name = $"修改{name}", Number = $"Edit-{number}" });
|
|
category.Permissions.Add(new Permission { Name = $"删除{name}", Number = $"Delete-{number}" });
|
|
db.Set<PermissionCategory>().Add(category);
|
|
}
|
|
db.SaveChanges();
|
|
|
|
var saRole = new Role { Name = "超级管理员", IsReadOnly = true };
|
|
var adminRole = new Role { Name = "管理员", IsReadOnly = true };
|
|
|
|
var skips = new string[] { "添加Api", "修改Api", "添加分类", "修改分类", "添加参数", "修改参数", "添加产品", "修改产品", "添加节点", "添加权限", "修改权限", "添加权限分类", "修改权限分类", "添加设备" };
|
|
|
|
foreach (var item in db.Set<Permission>())
|
|
{
|
|
saRole.RolePermissions.Add(new RolePermission { Permission = item, IsReadOnly = true });
|
|
if (!item.Name.Contains("删除") && !skips.Contains(item.Name))
|
|
{
|
|
adminRole.RolePermissions.Add(new RolePermission { Permission = item, IsReadOnly = true });
|
|
}
|
|
}
|
|
|
|
var securityStam = "123456";
|
|
db.Set<User>().Add(new User
|
|
{
|
|
UserName = "super",
|
|
SecurityStamp = securityStam,
|
|
PasswordHash = _encryptionService.CreatePasswordHash("123456", securityStam),
|
|
Email = "super@test.com"
|
|
});
|
|
db.Set<User>().Add(new User
|
|
{
|
|
UserName = "admin",
|
|
SecurityStamp = securityStam,
|
|
PasswordHash = _encryptionService.CreatePasswordHash("123456", securityStam),
|
|
Email = "admin@test.com"
|
|
});
|
|
db.SaveChanges();
|
|
//
|
|
var set = db.Set<Setting>();
|
|
set.Add(new Setting { Name = "name", Value = this._cfg.GetValue("seed:NodeName", "网关"), Type = SettingType.String });
|
|
set.Add(new Setting { Name = "logo", Value = "/images/logo.png", Type = SettingType.ImageUrl });
|
|
set.Add(new Setting { Name = "copyright", Value = "Copyright © {0} Company. All rights reserved", Type = SettingType.Html });
|
|
//
|
|
var macAddress = Helper.Instance.GetMacAddress();
|
|
set.Add(new Setting { Name = "sn", Value = macAddress, Type = SettingType.String });
|
|
set.Add(new Setting
|
|
{
|
|
Name = "code",
|
|
Value = this._env.IsDevelopment() ? Helper.Instance.MacEncrypt(Helper.Instance.GetMacAddress()) : "根据mac生成的授权码",
|
|
Type = SettingType.String
|
|
});
|
|
//
|
|
var host = this._cfg.GetValue("seed:host", "localhost");
|
|
var stream = this._cfg.GetValue("seed:stream", "localhost");
|
|
var delay = this._cfg.GetValue("seed:delay", "100");
|
|
set.Add(new Setting { Name = "debug", Value = "false", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "notify:enabled", Value = "true", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "notify:host", Value = $"http://{host}/platform", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "timer.seconds", Value = "180", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "onvif.timer", Value = "1", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "onvif.speed", Value = "0.2", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "camera.usr", Value = "admin", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "camera.pwd", Value = "dsideal123", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "stream.rtmp", Value = stream, Type = SettingType.String });
|
|
set.Add(new Setting { Name = "ffmpeg.args", Value = " -y -threads {0} -rtsp_transport tcp -use_wallclock_as_timestamps 1 -stimeout 3000000 -i \"{1}\" -fflags +genpts -c copy -f flv \"{2}\"", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "fbee.writelist", Value = "", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "camera.writelist", Value = "", Type = SettingType.String });
|
|
set.Add(new Setting { Name = "delay", Value = delay, Type = SettingType.String });
|
|
db.SaveChanges();
|
|
db.Set<IoTGateway>().Add(new IoTGateway
|
|
{
|
|
Id = $"nodeid-{macAddress}".ToGuid(),
|
|
Name = $"节点({macAddress})",
|
|
Number = macAddress,
|
|
IsOnline = true,
|
|
Version = Helper.Instance.GetVersion(),
|
|
Image = "/images/classroom.svg"
|
|
});
|
|
db.SaveChanges();
|
|
}
|
|
}
|
|
}
|