VistarStarDataIntegration/admin.net.pro/Admin.NET/Vistar.Application/Common/DataValidationService.cs

305 lines
12 KiB
C#

// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
//
// 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
//
// 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
using Admin.NET.Core;
using DocumentFormat.OpenXml.Drawing.Spreadsheet;
using Furion.DependencyInjection;
using Furion.DynamicApiController;
using Microsoft.AspNetCore.Server.IISIntegration;
using NewLife;
using RazorEngine;
using RazorEngine.Compilation.ImpromptuInterface;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Vistar.Application.Entity;
using Vistar.Application.SapService.Dto;
using static SKIT.FlurlHttpClient.Wechat.Api.Models.CgibinAccountGetAccountBasicInfoResponse.Types;
namespace Vistar.Application.Common;
public class DataValidationService : IDynamicApiController, ITransient
{
private readonly SqlSugarRepository<Obj110> _obj110Rep;
public SqlSugarRepository<Obj118> _obj118Rep;
public SqlSugarRepository<Obj109> _obj109Rep;
public SqlSugarRepository<Obj112> _obj112Rep;
public SqlSugarRepository<Obj133> _obj133Rep;
public SqlSugarRepository<Obj122> _obj122Rep;
public SqlSugarRepository<Obj137> _obj137Rep;
public SqlSugarRepository<ObjectTypeCheckList> _objectTypeCheckListRep;
public SqlSugarRepository<ConfigurationData> _configurationDataRep;
public DataValidationService(
SqlSugarRepository<Obj110> obj110Rep,
SqlSugarRepository<Obj109> obj109Rep,
SqlSugarRepository<Obj112> obj112Rep,
SqlSugarRepository<Obj133> obj133Rep,
SqlSugarRepository<Obj122> obj122Rep,
SqlSugarRepository<Obj137> obj137Rep,
SqlSugarRepository<ObjectTypeCheckList> objectTypeCheckList,
SqlSugarRepository<ConfigurationData> configurationDataRep
)
{
_obj110Rep = obj110Rep;
_obj109Rep = obj109Rep;
_obj112Rep = obj112Rep;
_obj133Rep = obj133Rep;
_obj122Rep = obj122Rep;
_obj137Rep = obj137Rep;
_objectTypeCheckListRep = objectTypeCheckList;
_configurationDataRep = configurationDataRep;
}
/// <summary>
/// 验证物料是否存在
/// </summary>
/// <param name="objId">对象id</param>
/// <param name="materialCode">物料编码</param>
/// <param name="recordGuid">物料guid</param>
/// <returns></returns>
public async Task<string> VerificationMaterial(long objId, string materialCode, string recordGuid)
{
string verification = "不存在";
var tasks = new List<Task<int>>();
switch (objId)
{
case 110:
tasks.Add(_obj110Rep.AsQueryable().Where(x => x._System_objNBS == materialCode && x.deleted == false && x.RecordGuid == recordGuid).CountAsync());
break;
case 109:
tasks.Add(_obj109Rep.AsQueryable().Where(x => x._System_objNBS == materialCode && x.deleted == false && x.RecordGuid == recordGuid).CountAsync());
break;
case 112:
tasks.Add(_obj112Rep.AsQueryable().Where(x => x._System_objNBS == materialCode && x.deleted == false && x.RecordGuid == recordGuid).CountAsync());
break;
case 133:
tasks.Add(_obj133Rep.AsQueryable().Where(x => x._System_objNBS == materialCode && x.deleted == false && x.RecordGuid == recordGuid).CountAsync());
break;
case 122:
tasks.Add(_obj122Rep.AsQueryable().Where(x => x._System_objNBS == materialCode && x.deleted == false && x.RecordGuid == recordGuid).CountAsync());
break;
case 137:
tasks.Add(_obj137Rep.AsQueryable().Where(x => x._System_objNBS == materialCode && x.deleted == false && x.RecordGuid == recordGuid).CountAsync());
break;
}
if (tasks.Count > 0)
{
var result = await Task.WhenAll(tasks);
verification = result.Any(count => count > 0) ? "存在" : "不存在";
}
return verification;
}
/// <summary>
/// 查询ecn编号
/// </summary>
/// <param name="idRecord"></param>
/// <returns></returns>
public async Task<List<EcnItemData>> ChangeModuleMaterial(long idRecord)
{
var encodingList = new List<EcnItemData>();
// 获取符合条件的检查列表项
var checkList = await _objectTypeCheckListRep.AsQueryable()
.Where(x => x.ParentIdRecord == idRecord && (x.ColumnId == 4638 || x.ColumnId == 6002))
.ToListAsync();
// 遍历检查列表
foreach (var item in checkList)
{
var recordGuid = item.RecordGuid;
var objectId = item.ObjectId;
dynamic data = null; // 使用 dynamic 类型来通用处理不同的仓储查询
// 根据 ObjectId 选择相应的仓储并查询数据
switch (objectId)
{
case 110:
data = await _obj110Rep.AsQueryable()
.Where(x => x.RecordGuid == recordGuid && x.deleted == false)
.FirstAsync();
break;
case 109:
data = await _obj109Rep.AsQueryable()
.Where(x => x.RecordGuid == recordGuid && x.deleted == false)
.FirstAsync();
break;
case 112:
data = await _obj112Rep.AsQueryable()
.Where(x => x.RecordGuid == recordGuid && x.deleted == false)
.FirstAsync();
break;
case 133:
data = await _obj133Rep.AsQueryable()
.Where(x => x.RecordGuid == recordGuid && x.deleted == false)
.FirstAsync();
break;
case 122:
data = await _obj122Rep.AsQueryable()
.Where(x => x.RecordGuid == recordGuid && x.deleted == false)
.FirstAsync();
break;
case 137:
data = await _obj137Rep.AsQueryable()
.Where(x => x.RecordGuid == recordGuid && x.deleted == false)
.FirstAsync();
break;
default:
continue; // 如果 ObjectId 不匹配,跳过本次循环
}
// 创建新的 EcnItemData 对象并添加到列表中
encodingList.Add(new EcnItemData
{
Matnr = data._System_objNBS
});
}
// 返回编码列表
return encodingList;
}
/// <summary>
/// 获取单位
/// </summary>
/// <param name="objid"></param>
/// <param name="ChildGuid"></param>
/// <returns></returns>
public async Task<string> GetUnit(long objid, string ChildGuid)
{
var unit = "";
if (objid == 137)
{
var data = await _obj137Rep.AsQueryable().Where(x => x.RecordGuid == ChildGuid && x.deleted == false).OrderByDescending(x => x.VersionIndex).FirstAsync();
unit = data._SWPDM_126_SW___;
}
if (objid == 112)
{
var data = await _obj112Rep.AsQueryable().Where(x => x.RecordGuid == ChildGuid && x.deleted == false).OrderByDescending(x => x.VersionIndex).FirstAsync();
unit = data.fld004594;
}
return unit;
}
/// <summary>
/// 获取记录ID
/// </summary>
/// <param name="objId">对象id</param>
/// <param name="recordGuid">物料guid</param>
/// <returns></returns>
public async Task<long> GetRecordId(long objId, string recordGuid)
{
long idRecord = 0;
if (objId == 137)
{
var data = await _obj137Rep.AsQueryable().Where(x => x.RecordGuid == recordGuid && x.deleted == false).OrderByDescending(x => x.VersionIndex).FirstAsync();
idRecord = data.idRecord;
}
if (objId == 112)
{
var data = await _obj112Rep.AsQueryable().Where(x => x.RecordGuid == recordGuid && x.deleted == false).OrderByDescending(x => x.VersionIndex).FirstAsync();
idRecord = data.idRecord;
}
return idRecord;
}
/// <summary>
/// 通过id和对象id获取物料编码
/// </summary>
/// <param name="objId">对象id</param>
/// <param name="id">物料guid</param>
/// <returns></returns>
public async Task<string> GetCoding(long objId, long id)
{
string coding = "编码不存在";
if (objId == 137)
{
var data = await _obj137Rep.AsQueryable().Where(x => x.idRecord == id).FirstAsync();
coding = data._System_objNBS;
}
if (objId == 112)
{
var data = await _obj112Rep.AsQueryable().Where(x => x.idRecord == id).FirstAsync();
coding = data._System_objNBS;
}
return coding;
}
/// <summary>
/// 获取行号
/// </summary>
/// <param name="objId">对象id</param>
/// <param name="recordGuid">guid</param>
/// <param name="versionIndex">版本</param>
/// <param name="configId">配置id</param>
/// <returns></returns>
public async Task<int> GetLineNumber(long objId, string recordGuid, int versionIndex, int configId)
{
int lineNumber = 0;
if (objId==118)
{
lineNumber = await _configurationDataRep.AsQueryable().Where(x => x.ParentGuid == recordGuid && x.isDeleted == false && x.ParentVersion == versionIndex && x.ConfigId == configId && x.isSuppressed == false && x.inContext == false).CountAsync();
}
return lineNumber;
}
/// <summary>
/// 生成guid
/// </summary>
/// <returns></returns>
public async Task<string> GetGuid()
{
await Task.Delay(0);
// 生成一个新的Guid实例
Guid guid = Guid.NewGuid();
// 将Guid转换为字符串形式
string uuidString = guid.ToString();
return uuidString;
}
/// <summary>
/// 对比物料版本
/// </summary>
/// <param name="objId"></param>
/// <param name="recordGuid"></param>
/// <param name="newVersion"></param>
/// <param name="olderVersion"></param>
/// <returns></returns>
public async Task<string> ComparativeVersion(long objId, string recordGuid, int newVersion, int olderVersion)
{
string contrastResult ="";
if (objId == 137)
{
var contrastNewData = await _obj137Rep.AsQueryable().Where(x => x.RecordGuid == recordGuid && x.deleted == false && x.VersionIndex == newVersion).FirstAsync();
var contrastOlderData = await _obj137Rep.AsQueryable().Where(x => x.RecordGuid == recordGuid && x.deleted == false && x.VersionIndex == olderVersion).FirstAsync();
if (contrastNewData.revision != contrastOlderData.revision)
{
contrastResult = "是";
}
}
//if (objId == 112)
//{
// var contrastNewData = await _obj112Rep.AsQueryable().Where(x => x.RecordGuid == recordGuid && x.deleted == false && x.VersionIndex == newVersion).FirstAsync();
// var contrastOlderData = await _obj112Rep.AsQueryable().Where(x => x.RecordGuid == recordGuid && x.deleted == false && x.VersionIndex == olderVersion).FirstAsync();
// if (contrastNewData.revision == contrastOlderData.revision)
// {
// contrastResult = "是";
// }
//}
return contrastResult;
}
}