2025-07-24 15:07:03 +08:00
|
|
|
using DMS.Core.Interfaces.Repositories;
|
2025-07-21 22:02:42 +08:00
|
|
|
using DMS.Core.Models;
|
2025-07-21 23:04:28 +08:00
|
|
|
using DMS.Infrastructure.Configurations;
|
2025-07-21 22:02:42 +08:00
|
|
|
using DMS.Infrastructure.Data;
|
|
|
|
|
using DMS.Infrastructure.Entities;
|
|
|
|
|
using SqlSugar;
|
|
|
|
|
|
2025-07-24 15:07:03 +08:00
|
|
|
namespace DMS.Infrastructure.Repositories;
|
2025-07-21 22:02:42 +08:00
|
|
|
|
2025-07-24 15:07:03 +08:00
|
|
|
public class InitializeRepository : IInitializeRepository
|
2025-07-21 22:02:42 +08:00
|
|
|
{
|
|
|
|
|
private readonly SqlSugarDbContext _dbContext;
|
|
|
|
|
private readonly SqlSugarClient _db;
|
|
|
|
|
|
2025-07-24 15:07:03 +08:00
|
|
|
public InitializeRepository(SqlSugarDbContext dbContext)
|
2025-07-21 22:02:42 +08:00
|
|
|
{
|
|
|
|
|
_dbContext = dbContext;
|
|
|
|
|
_db = _dbContext.GetInstance();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void InitializeTables()
|
|
|
|
|
{
|
|
|
|
|
_db.DbMaintenance.CreateDatabase();
|
|
|
|
|
_db.CodeFirst.InitTables<DbNlog>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbDevice>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbVariableTable>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbVariable>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbVariableHistory>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbUser>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbMqttServer>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbVariableMqttAlias>();
|
|
|
|
|
_db.CodeFirst.InitTables<DbMenu>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void InitializeTableIndex()
|
|
|
|
|
{
|
|
|
|
|
_db.DbMaintenance.CreateIndex(nameof(DbDevice),new []
|
|
|
|
|
{
|
|
|
|
|
nameof(DbDevice.Name),
|
|
|
|
|
nameof(DbDevice.OpcUaServerUrl),
|
|
|
|
|
},true);
|
|
|
|
|
|
|
|
|
|
_db.DbMaintenance.CreateIndex(nameof(DbVariable),new []
|
|
|
|
|
{
|
|
|
|
|
nameof(DbVariable.OpcUaNodeId)
|
|
|
|
|
},true);
|
|
|
|
|
_db.DbMaintenance.CreateIndex(nameof(DbMqttServer),new []
|
|
|
|
|
{
|
|
|
|
|
nameof(DbMqttServer.ServerName)
|
|
|
|
|
},true);
|
|
|
|
|
}
|
2025-07-21 23:04:28 +08:00
|
|
|
|
|
|
|
|
public bool IsAnyTable(string tableName)
|
|
|
|
|
{
|
|
|
|
|
return _db.DbMaintenance.IsAnyTable(tableName, false);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public bool IsAnyIndex(string indexName)
|
|
|
|
|
{
|
|
|
|
|
return _db.DbMaintenance.IsAnyIndex(indexName);
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-21 22:02:42 +08:00
|
|
|
public void InitializeMenus()
|
|
|
|
|
{
|
|
|
|
|
var settings = AppSettings.Load();
|
|
|
|
|
if (settings.Menus.Any())
|
|
|
|
|
{
|
|
|
|
|
return ;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
settings.Menus.Add(new MenuBean() { Id=1, Header = "主页", Icon = "Home", ParentId = 0 });
|
|
|
|
|
settings.Menus.Add(new MenuBean() { Id = 2, Header = "设备", Icon = "Devices3", ParentId = 0 });
|
|
|
|
|
settings.Menus.Add(new MenuBean() { Id = 3, Header = "数据转换", Icon = "ChromeSwitch", ParentId = 0 });
|
|
|
|
|
settings.Menus.Add(new MenuBean() { Id = 4, Header = "Mqtt服务器", Icon = "Cloud", ParentId = 0 });
|
|
|
|
|
settings.Menus.Add(new MenuBean() { Id = 5, Header = "设置", Icon = "Settings", ParentId = 0 });
|
|
|
|
|
settings.Menus.Add(new MenuBean() { Id = 6, Header = "关于", Icon = "Info", ParentId = 0 });
|
|
|
|
|
|
|
|
|
|
settings.Save();
|
|
|
|
|
|
|
|
|
|
return ;
|
|
|
|
|
}
|
|
|
|
|
}
|