using DocumentFormat.OpenXml.EMMA;
using DocumentFormat.OpenXml.Office2010.Excel;
using Learun.Application.TwoDevelopment.ZZDT_EC;
using Learun.Util;
using Learun.Util.SqlSugar;
using Org.BouncyCastle.Ocsp;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.Http;
namespace Learun.Application.Web.AppApi
{
///
/// 关联关系的接口(By YuXH)。只需要给rel data的操作,rel type的操作放到mvc的API即可,暂时不需要给插件端开放
///
[RoutePrefix("api/RelApi")]
[HandlerApiLogin(FilterMode.Ignore)]
public class RelApiController : WebApiControllerBase
{
#region 模块对象
private ec_reltypeIBLL ec_reltypeIBLL = new ec_reltypeBLL();
private ec_enginedata_relIBLL ec_relDataBLL = new ec_enginedata_relBLL();
#endregion
#region refDef本身,只给查询,编辑放在网页端里
///
/// 根据关联关系的名字拿关联关系的Id
///
///
///
///
[HttpGet]
public IHttpActionResult GetRelDefByName(string RelName, string projId)
{
var data = ec_reltypeIBLL.GetList("{\"ProjectId\":\"" + projId + "\", \"RelTypeName\": \"" + RelName + "\"}").FirstOrDefault();
return Success(data);
}
///
/// 所有Rel
///
///
///
///
[HttpGet]
public IHttpActionResult GetRelDefs(string projId)
{
var data = ec_reltypeIBLL.GetList("{\"ProjectId\":\"" + projId + "\"}");
return Success(data);
}
#endregion
#region engineData_rel
///
/// 增加 对象和对象之间的关系。(BY YUXH)
/// 请求的Body中带上Json格式的ec_enginedata_relEntity数据集合(End2IDs里放多个)
///
///
///
[HttpPost]
[HandlerApiLogin(FilterMode.Enforce)]
public IHttpActionResult SaveRelDataBatch(string ProjectId)
{
var asyncContent = Request.Content.ReadAsStringAsync().Result;
try
{
var entityCol = asyncContent.ToObject>();
foreach (var relData in entityCol)
{
if (relData.End2IDs == null || relData.End2IDs.Count == 0)
{
relData.End2IDs = new List
{
relData.RelEngineData2ID
};
}
ec_relDataBLL.SaveEntitys(ProjectId, relData.RelTypeID, relData.RelEngineData1ID, relData.End2IDs);
}
return Success("创建成功");
}
catch (Exception ex)
{
return Fail(ex.Message);
}
}
///
/// 根据主键,删除某条关联关系
///
///
///
///
[HttpGet]
[HandlerApiLogin(FilterMode.Enforce)]
public IHttpActionResult RemoveRelData(string ProjectId, string RelDataId)
{
ec_relDataBLL.DeleteEntity(ProjectId, RelDataId);
return Success("delete成功");
}
///
/// 主力查询
///
///
///
/// 1端的ID
///
///
[HttpGet]
[HandlerApiLogin(FilterMode.Ignore)]
public IHttpActionResult GetRelCollection(string ProjectId, string RelTypeId, string ID1 = "", int seq = 0)
{
if (!string.IsNullOrEmpty(ID1))
{
//查单一记录
var res = ec_relDataBLL.GetList("{ProjectId:\"" + ProjectId + "\",RelTypeID:\"" + RelTypeId + "\",RelEngineDataID:\"" + ID1 + "\"}");
return Success(res);
}
else
{
var res = ec_relDataBLL.GetList("{ProjectId:\"" + ProjectId + "\",RelTypeID:\"" + RelTypeId + "\"}");
return Success(res);
}
}
#endregion
#region Cable连接关系
///
/// 查询电缆两侧的连接关系(BY YUXH)
///
///
/// 集合(图纸id,电缆句柄)
///
[HttpPost]
[HandlerApiLogin(FilterMode.Enforce)]
public IHttpActionResult GetCableConn(string ProjectId, [FromBody] List CablePixelIDs)
{
if (CablePixelIDs == null) { return Success(""); }
var RelTypeServ = new ec_reltypeBLL();
var relBll = new ec_enginedata_relBLL();
//relType是不是有
var RelTypeID = RelTypeServ.GetList("{\"ProjectId\":\"" + ProjectId + "\", \"RelType\": \"" + (int)enum_RelType.设备_电缆 + "\"}").Select(x => x.RelTypeID).FirstOrDefault();
if (RelTypeID == null || RelTypeID.Count() == 0)
{
return Fail($"项目的关联类型中,找不到“设备_电缆”,其RelType应该为0。");
}
var res = new List();
//var asyncContent = Request.Content.ReadAsStringAsync().Result;
try
{
//var relDataCol = asyncContent.ToObject>();
foreach (var CablePixelID in CablePixelIDs)
{
res.Add(relBll.GetCableConn(CablePixelID, ProjectId));
}
return Success(res);
}
catch (Exception ex)
{
return Fail(ex.Message);
}
}
///
/// 查询电缆整个链路上的连接(BY YUXH)
///
///
/// 集合(图纸id,电缆句柄)
///
[HttpPost]
[HandlerApiLogin(FilterMode.Enforce)]
public IHttpActionResult GetCableWay(string ProjectId, [FromBody] List CablePixelIDs)
{
if (CablePixelIDs == null) { return Success(""); }
//serv
var pixelServ = new ec_enginedata_pixelService();
var RelTypeServ = new ec_reltypeBLL();
//relType是不是有
var RelTypeID = RelTypeServ.GetList("{\"ProjectId\":\"" + ProjectId + "\", \"RelType\": \"" + (int)enum_RelType.设备_电缆 + "\"}").Select(x => x.RelTypeID).FirstOrDefault();
if (RelTypeID == null || RelTypeID.Count() == 0)
{
return Fail($"项目的关联类型中,找不到“设备_电缆”,其RelType应该为0。");
}
var res = new LinkedList