using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Identity.Client;
using Newtonsoft.Json;
using Sln.Wcs.Model.Configs;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
#region << 版 本 注 释 >>
/*--------------------------------------------------------------------
* 版权所有 (c) 2026 WenJY 保留所有权利。
* CLR版本:4.0.30319.42000
* 机器名称:T14-GEN3-7895
* 命名空间:Sln.Wcs.Repository
* 唯一标识:705f0413-0af8-472c-adea-cf7b42540220
*
* 创建者:WenJY
* 电子邮箱:
* 创建时间:2026-03-19 11:17:45
* 版本:V1.0.0
* 描述:
*
*--------------------------------------------------------------------
* 修改人:
* 时间:
* 修改说明:
*
* 版本:V1.0.0
*--------------------------------------------------------------------*/
#endregion << 版 本 注 释 >>
namespace Sln.Wcs.Repository
{
public static class SqlsugarSetup
{
///
/// 注册SqlSugar
///
///
public static void AddSqlSugarSetup(this IServiceCollection services)
{
services.AddSingleton(x =>
{
var configuration = x.GetService();
List sqlConfigs = JsonConvert.DeserializeObject>(configuration["sqlConfigs"]);
var connectConfigList = new List();
if (sqlConfigs != null)
{
foreach (var item in sqlConfigs)
{
if (item.isFlag)
{
var config = new ConnectionConfig()
{
ConfigId = item.configId,
DbType = (DbType)item.dbType,
ConnectionString = item.connStr,
InitKeyType = InitKeyType.Attribute,
IsAutoCloseConnection = true,
};
connectConfigList.Add(config);
}
}
}
SqlSugarScope Db =
new SqlSugarScope(connectConfigList, db => { db.Aop.OnLogExecuting = (sql, pars) => { }; });
return Db;
});
}
}
}