188 lines
7.9 KiB
C#
188 lines
7.9 KiB
C#
namespace BLL
|
|
{
|
|
using Model;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Web.UI.WebControls;
|
|
|
|
public static class InterFaceService
|
|
{
|
|
public static Model.SGGLDB db = Funs.DB;
|
|
|
|
/// <summary>
|
|
/// 获取接口设置信息
|
|
/// </summary>
|
|
/// <param name="InterFaceSetId">设置Id</param>
|
|
/// <returns>接口设置信息</returns>
|
|
public static Model.InterFaceSet GetFaceSetById(string InterFaceSetId)
|
|
{
|
|
return Funs.DB.InterFaceSet.FirstOrDefault(e => e.InterFaceSetId == InterFaceSetId);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 增加接口设置信息
|
|
/// </summary>
|
|
/// <param name="faceset">接口设置</param>
|
|
public static void AddFaceSet(Model.InterFaceSet faceset)
|
|
{
|
|
Model.SGGLDB db = Funs.DB;
|
|
string newKeyID = SQLHelper.GetNewID(typeof(Model.InterFaceSet));
|
|
List<InterFaceDetail> detailList = new List<InterFaceDetail>();
|
|
Model.InterFaceSet newSet = new Model.InterFaceSet
|
|
{
|
|
InterFaceSetId = newKeyID,
|
|
InterFaceName = faceset.InterFaceName,
|
|
AuthUnitIds = faceset.AuthUnitIds,
|
|
AuthUnitName = faceset.AuthUnitName,
|
|
InterFaceUrl = faceset.InterFaceUrl,
|
|
InterFaceForUrl = faceset.InterFaceForUrl,
|
|
ValidPeriod = faceset.ValidPeriod,
|
|
UnitId = faceset.UnitId,
|
|
TxtRemarks = faceset.TxtRemarks,
|
|
IsOpen = faceset.IsOpen,
|
|
IsReqPost = faceset.IsReqPost,
|
|
IsCallBack= faceset.IsCallBack,
|
|
InterFaceCallBackUrl= faceset.InterFaceCallBackUrl,
|
|
};
|
|
//明细表
|
|
foreach (var AuthUnitId in newSet.AuthUnitIds.Split(','))
|
|
{
|
|
Model.InterFaceDetail deteil = new Model.InterFaceDetail
|
|
{
|
|
InterFaceDetailId = SQLHelper.GetNewID(typeof(Model.InterFaceDetail)),
|
|
InterFaceName = newSet.InterFaceName,
|
|
UnitId = newSet.UnitId,
|
|
AuthUnitIds = AuthUnitId,
|
|
InterFaceSetlId = newSet.InterFaceSetId,
|
|
ReportState = false,
|
|
GainState = false,
|
|
};
|
|
detailList.Add(deteil);
|
|
}
|
|
db.InterFaceDetail.InsertAllOnSubmit(detailList);
|
|
db.InterFaceSet.InsertOnSubmit(newSet);
|
|
db.SubmitChanges();
|
|
}
|
|
|
|
/// <summary>
|
|
/// 修改接口设置信息
|
|
/// </summary>
|
|
/// <param name="user">接口设置实体</param>
|
|
public static void UpdateFaceSet(Model.InterFaceSet user)
|
|
{
|
|
Model.SGGLDB db = Funs.DB;
|
|
List<InterFaceDetail> detailList = new List<InterFaceDetail>();
|
|
Model.InterFaceSet newSet = db.InterFaceSet.FirstOrDefault(e => e.InterFaceSetId == user.InterFaceSetId);
|
|
if (newSet != null)
|
|
{
|
|
newSet.InterFaceName = user.InterFaceName;
|
|
newSet.AuthUnitIds = user.AuthUnitIds;
|
|
newSet.AuthUnitName = user.AuthUnitName;
|
|
newSet.InterFaceUrl = user.InterFaceUrl;
|
|
newSet.InterFaceForUrl = user.InterFaceForUrl;
|
|
newSet.UnitId = user.UnitId;
|
|
newSet.ValidPeriod = user.ValidPeriod;
|
|
newSet.UnitId = user.UnitId;
|
|
newSet.TxtRemarks = user.TxtRemarks;
|
|
newSet.IsOpen = user.IsOpen;
|
|
newSet.IsReqPost = user.IsReqPost;
|
|
newSet.IsCallBack = user.IsCallBack;
|
|
newSet.InterFaceCallBackUrl= user.InterFaceCallBackUrl;
|
|
var AuthUnitIds = newSet.AuthUnitIds.Split(',');
|
|
//明细表
|
|
List<Model.InterFaceDetail> FaceDetailList = db.InterFaceDetail.Where(e => e.InterFaceSetlId == user.InterFaceSetId).ToList();
|
|
//删除无效明细
|
|
var oldDetails = FaceDetailList.Where(p=> !AuthUnitIds.Equals(p.AuthUnitIds)) ;
|
|
if (oldDetails.Count() > 0)
|
|
{
|
|
db.InterFaceDetail.DeleteAllOnSubmit(oldDetails);
|
|
}
|
|
foreach (var AuthUnitId in AuthUnitIds)
|
|
{
|
|
Model.InterFaceDetail deteil = new Model.InterFaceDetail
|
|
{
|
|
InterFaceDetailId = SQLHelper.GetNewID(typeof(Model.InterFaceDetail)),
|
|
InterFaceName = newSet.InterFaceName,
|
|
UnitId = newSet.UnitId,
|
|
AuthUnitIds = AuthUnitId,
|
|
InterFaceSetlId = newSet.InterFaceSetId,
|
|
};
|
|
var FaceDetail = FaceDetailList.FirstOrDefault(p => p.AuthUnitIds == AuthUnitId);
|
|
if (FaceDetail == null)
|
|
{
|
|
detailList.Add(deteil);
|
|
}
|
|
}
|
|
db.InterFaceDetail.InsertAllOnSubmit(detailList);
|
|
db.SubmitChanges();
|
|
}
|
|
}
|
|
/// <summary>
|
|
/// 根据Id删除信息
|
|
/// </summary>
|
|
/// <param name="SetId"></param>
|
|
public static void DeleteFaceSet(string SetId)
|
|
{
|
|
Model.SGGLDB db = Funs.DB;
|
|
Model.InterFaceSet FaceSet = db.InterFaceSet.FirstOrDefault(e => e.InterFaceSetId == SetId);
|
|
if (FaceSet != null)
|
|
{
|
|
var logs = from x in db.Sys_Log where x.UserId == SetId select x;
|
|
if (logs.Count() > 0)
|
|
{
|
|
db.Sys_Log.DeleteAllOnSubmit(logs);
|
|
}
|
|
db.InterFaceSet.DeleteOnSubmit(FaceSet);
|
|
db.SubmitChanges();
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 保存上报数据记录
|
|
/// </summary>
|
|
/// <param name="newItem">上报数据</param>
|
|
/// <returns></returns>
|
|
public static string SaveUpData(Model.InterFaceItem newItem)
|
|
{
|
|
if (newItem.FaceLogDate.Count() == 0)
|
|
return "数据不可为空!";
|
|
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
|
{
|
|
List<string> InterFaceLogIdList = new List<string>();
|
|
List<Model.InterFaceLog> logList = new List<Model.InterFaceLog>();
|
|
string message = string.Empty;
|
|
var FaceDetailList = db.InterFaceDetail.Where(x => newItem.FaceLogDate.Select(p=>p.UnitId).Equals(x.UnitId));
|
|
foreach (var item in newItem.FaceLogDate)
|
|
{
|
|
//如果配置接口名称存在 进行数据保存
|
|
var faceDetail = FaceDetailList.FirstOrDefault(p => p.InterFaceName == item.InterFaceName);
|
|
if (faceDetail != null)
|
|
{
|
|
faceDetail.ReportDate = DateTime.Now;
|
|
faceDetail.ReportState = true;
|
|
Model.InterFaceLog FaceLog = new Model.InterFaceLog();
|
|
FaceLog.InterFaceLogId = SQLHelper.GetNewID(typeof(Model.InterFaceLog));
|
|
FaceLog.TxtContent = item.TxtContent;
|
|
FaceLog.InterFaceLogDate = Convert.ToDateTime(item.InterFaceLogDate);
|
|
FaceLog.LogSate = false;
|
|
FaceLog.CollCropCode = item.CollCropCode;
|
|
FaceLog.IP = item.IP;
|
|
FaceLog.UnitId = item.UnitId;
|
|
FaceLog.InterFaceDetailId = faceDetail.InterFaceDetailId;
|
|
logList.Add(FaceLog);
|
|
}
|
|
else //配置接口名称不存在 记录反馈给前端提示
|
|
{
|
|
InterFaceLogIdList.Add(item.InterFaceName);
|
|
}
|
|
}
|
|
db.InterFaceLog.InsertAllOnSubmit(logList);
|
|
db.SubmitChanges();
|
|
}
|
|
|
|
return "数据同步成功";
|
|
}
|
|
}
|
|
}
|