HttpRequestService.cs 147 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793
  1. using System.Collections.Generic;
  2. using System.Linq;
  3. using System.Threading.Tasks;
  4. using System.Threading;
  5. using IMCS.CCS.Entitys;
  6. using IMCS.CCS.Models.vo;
  7. using IMCS.CCS.Models;
  8. using IMCS.CCS.DeviceProtocol;
  9. using System;
  10. using S7.Net;
  11. using IMCS_CCS.Utils;
  12. using Newtonsoft.Json;
  13. using IMCS_CCS.Utils.DeviceProtocol;
  14. using HslCommunication.Profinet.Siemens;
  15. using Microsoft.Extensions.Configuration;
  16. using IMCS.CCS.Service;
  17. using IMCS_CCS.Model.vo;
  18. using FTP;
  19. using HslCommunication;
  20. using System.Text.RegularExpressions;
  21. using System.IO;
  22. using Org.BouncyCastle.Ocsp;
  23. using MySqlX.XDevAPI.Common;
  24. using IMCS_CCS.Service.Impl;
  25. using IMCS_CCS.Service;
  26. using IMCS_CCS.Entitys;
  27. using static Google.Protobuf.Reflection.SourceCodeInfo.Types;
  28. using Newtonsoft.Json.Linq;
  29. using static AutoMapper.Internal.ExpressionFactory;
  30. using Microsoft.EntityFrameworkCore.Internal;
  31. namespace IMCS.CCS.Services
  32. {
  33. public class HttpRequestService : IHttpRequestService
  34. {
  35. private readonly IDeviceService _deviceService;
  36. private readonly ITaskCallbackService _taskCallbackService;
  37. private readonly ICcsActionService _ccsActionService;
  38. private readonly ICcsTagValueService _ccsTagValueService;
  39. private readonly IEquipmentMonitorService _equipmentMonitorService;
  40. private readonly ICcsActionAddressService _ccsActionAddressService;
  41. private readonly ITaskJobService _taskJobService;
  42. private readonly ICcsActionDeviceSourceCheckService _ccsActionDeviceSourceCheckService;
  43. private int SLEEP_TIME = 100;
  44. string LocalPath = "D:\\PROG";
  45. private string fanucUrlContext;
  46. private string opcuacUrlContext;
  47. private string hdhUrlContext;
  48. private string ecsRootUrlContext;
  49. public IConfiguration Configuration { get; }
  50. private readonly IApiRequestService _apiRequestService;
  51. // 物料装载站
  52. private static Dictionary<string, string> shangLiaoQaingQiu = new Dictionary<string, string>();
  53. private static Dictionary<string, string> xiaLiaoQaingQiu = new Dictionary<string, string>();
  54. private static Dictionary<string, string> shangLiaoZhuangTai = new Dictionary<string, string>();
  55. private static Dictionary<string, string> xiaLiaoZhuangTai = new Dictionary<string, string>();
  56. // 刀具装载站
  57. private static Dictionary<string, string> cutterPutRequest = new Dictionary<string, string>();
  58. private static Dictionary<string, string> cutterTakeRequest = new Dictionary<string, string>();
  59. private static Dictionary<string, string> cutterPutStatus = new Dictionary<string, string>();
  60. private static Dictionary<string, string> cutterTakeStatus = new Dictionary<string, string>();
  61. public HttpRequestService(IDeviceService deviceService, ITaskCallbackService taskCallbackService,
  62. ICcsActionService ccsActionService, ICcsTagValueService ccsTagValueService,
  63. IEquipmentMonitorService equipmentMonitorService, ICcsActionAddressService ccsActionAddressService,
  64. IApiRequestService apiRequestService, ITaskJobService taskJobService, ICcsActionDeviceSourceCheckService ccsActionDeviceSourceCheckService,
  65. IConfiguration configuration)
  66. {
  67. _deviceService = deviceService;
  68. _taskCallbackService = taskCallbackService;
  69. _ccsActionService = ccsActionService;
  70. _ccsTagValueService = ccsTagValueService;
  71. _equipmentMonitorService = equipmentMonitorService;
  72. _ccsActionAddressService = ccsActionAddressService;
  73. _apiRequestService = apiRequestService;
  74. _taskJobService = taskJobService;
  75. _ccsActionDeviceSourceCheckService = ccsActionDeviceSourceCheckService;
  76. Configuration = configuration;
  77. fanucUrlContext = Configuration.GetConnectionString("fanucUrlContext");
  78. opcuacUrlContext = Configuration.GetConnectionString("opcuacUrlContext");
  79. hdhUrlContext = Configuration.GetConnectionString("hdhUrlContext");
  80. ecsRootUrlContext = Configuration.GetConnectionString("ecsRootUrlContext");
  81. if (shangLiaoQaingQiu.Count == 0) {
  82. shangLiaoQaingQiu.Add("LAUP000101", "DB1001.784.1");
  83. shangLiaoQaingQiu.Add("LAUP000102", "DB1001.784.2");
  84. }
  85. if (xiaLiaoQaingQiu.Count == 0) {
  86. xiaLiaoQaingQiu.Add("LAUP000101", "DB1001.782.1");
  87. xiaLiaoQaingQiu.Add("LAUP000102", "DB1001.782.2");
  88. }
  89. if (shangLiaoZhuangTai.Count == 0) {
  90. shangLiaoZhuangTai.Add("LAUP000101", "DB1000.294.1");
  91. shangLiaoZhuangTai.Add("LAUP000102", "DB1000.294.2");
  92. }
  93. if (xiaLiaoZhuangTai.Count == 0) {
  94. xiaLiaoZhuangTai.Add("LAUP000101", "DB1000.296.1");
  95. xiaLiaoZhuangTai.Add("LAUP000102", "DB1000.296.2");
  96. }
  97. if (cutterPutRequest.Count == 0)
  98. {
  99. cutterPutRequest.Add("LAUPT00101", "DB1001.788.1");
  100. cutterPutRequest.Add("LAUPT00102", "DB1001.788.2");
  101. }
  102. if (cutterTakeRequest.Count == 0)
  103. {
  104. cutterTakeRequest.Add("LAUPT00101", "DB1001.786.1");
  105. cutterTakeRequest.Add("LAUPT00102", "DB1001.786.2");
  106. }
  107. if (cutterPutStatus.Count == 0) {
  108. cutterPutStatus.Add("LAUPT00101", "DB1000.322.1");
  109. cutterPutStatus.Add("LAUPT00102", "DB1000.322.2");
  110. }
  111. if (cutterTakeStatus.Count == 0)
  112. {
  113. cutterTakeStatus.Add("LAUPT00101", "DB1000.324.1");
  114. cutterTakeStatus.Add("LAUPT00102", "DB1000.324.2");
  115. }
  116. }
  117. /// <summary>
  118. /// 获取状态当前值
  119. /// </summary>
  120. public string GetTagValue(RequestTagValueData req)
  121. {
  122. CcsTagValue queryParam = new CcsTagValue();
  123. queryParam.Ip = req.ip;
  124. queryParam.Address = req.tagname;
  125. List<CcsTagValue> tagValues = _ccsTagValueService.GetList(queryParam);
  126. string tagValue = "0";
  127. if (tagValues != null && tagValues.Count > 0)
  128. {
  129. tagValue = tagValues[0].TagValue;
  130. }
  131. return tagValue;
  132. }
  133. /// <summary>
  134. /// 益模调用接口,显示3D
  135. /// </summary>
  136. public async Task<List<ResponseDigitalTwinsData>> GetDigitalTwins()
  137. {
  138. List<Device> devices = _deviceService.GetDeviceList();
  139. List<ResponseDigitalTwinsData> list = new List<ResponseDigitalTwinsData>();
  140. String query3dUrl = ecsRootUrlContext + "/api/authority/agv/agvCallbackService/query3dResouceDataInfo";
  141. var result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, query3dUrl, new Object(), null);
  142. ResponsePageData<ResponseDigitalTwinsData> responseData = JsonConvert.DeserializeObject<ResponsePageData<ResponseDigitalTwinsData>>(result.Message);
  143. list = responseData.Data;
  144. foreach(ResponseDigitalTwinsData responseDigitalTwinsData in list)
  145. {
  146. EquipmentMonitor equipmentMonitor = await _equipmentMonitorService.GetById(long.Parse(responseDigitalTwinsData.resourceId));
  147. if (equipmentMonitor==null || equipmentMonitor.IP == null)
  148. {
  149. continue;
  150. }
  151. Device device = devices.Where(x => x.Ip.Equals(equipmentMonitor.IP)).FirstOrDefault();
  152. if (null!=device && equipmentMonitor.Type == "HEIDEHAIN")
  153. {
  154. RequestHeidhData hdhReq = new RequestHeidhData();
  155. hdhReq.ServerUrl = device.ServerUrl;
  156. hdhReq.MachineName = device.UserName;
  157. hdhReq.Type = "Collect";
  158. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  159. if (Result.IsSuccess)
  160. {
  161. ResponseHeidhData retData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  162. if (!string.IsNullOrEmpty(retData.runDatasInfo.Trim()))
  163. {
  164. ResponseDigitalTwinsData twinsData = JsonConvert.DeserializeObject<ResponseDigitalTwinsData>(retData.runDatasInfo);
  165. responseDigitalTwinsData.feedRate = !string.IsNullOrEmpty(twinsData.feedRate)? twinsData.feedRate : "0";
  166. responseDigitalTwinsData.spindleMagnification = !string.IsNullOrEmpty(twinsData.spindleMagnification)? twinsData.spindleMagnification:"0";
  167. responseDigitalTwinsData.spindleSpeed = !string.IsNullOrEmpty(twinsData.spindleSpeed) ? twinsData.spindleSpeed + "00" : "0";
  168. responseDigitalTwinsData.spindleLoad = !string.IsNullOrEmpty(twinsData.spindleLoad) ? twinsData.spindleMagnification : "-";
  169. }
  170. }
  171. }
  172. else if(null != device && equipmentMonitor.Type == "FANUC")
  173. {
  174. string Url = fanucUrlContext + "?ip=" + device.Ip + "&port=" + device.Port;
  175. //调用发那科接口
  176. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Get, Url + "&fun=All", null, null);
  177. if (Result.IsSuccess)
  178. {
  179. ResponseFanucData responseFanucData = JsonConvert.DeserializeObject<ResponseFanucData>(Result.Message);
  180. responseDigitalTwinsData.feedRate = !string.IsNullOrEmpty(responseFanucData.ActFeed)? responseFanucData.ActFeed:"0";
  181. responseDigitalTwinsData.spindleMagnification = !string.IsNullOrEmpty(responseFanucData.SpindleMagnification)? responseFanucData.SpindleMagnification:"0";
  182. responseDigitalTwinsData.spindleSpeed = !string.IsNullOrEmpty(responseFanucData.ActSpindle)? responseFanucData.ActSpindle : "0";
  183. responseDigitalTwinsData.spindleLoad = !string.IsNullOrEmpty(responseFanucData.SpindleLoad)? responseFanucData.SpindleLoad : "-";
  184. }
  185. }
  186. }
  187. return list;
  188. }
  189. /// <summary>
  190. /// 查询设备状态
  191. /// </summary>
  192. public async Task<List<EquipmentMonitor>> GetEquipMent()
  193. {
  194. return await _equipmentMonitorService.GetList();
  195. }
  196. /// <summary>
  197. /// 机器人取放动作
  198. /// </summary>
  199. public async Task<ResponseECSData> RobotAction(RequestData<LocationData> req)
  200. {
  201. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId,"执行成功");
  202. SiemensS7Net s7 = null;
  203. try
  204. {
  205. // 获取所有在线的设备
  206. List<Device> devices = _deviceService.GetDeviceList();
  207. // 比较在线设备是否在其中
  208. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  209. if (device == null)
  210. {
  211. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  212. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  213. responseData.result = "false";
  214. responseData.resultMsg = "设备已离线:"+ req.url;
  215. return responseData;
  216. }
  217. // 根据ip查询设备
  218. CcsAction actionQuery = new CcsAction();
  219. actionQuery.OperateType = ActionTypeEnum.RobotAction.ToString();
  220. actionQuery.Ip = req.url;
  221. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  222. // 进行plc的连接
  223. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  224. OperateResult ConnectionResult = s7.ConnectServer();
  225. if (!ConnectionResult.IsSuccess)
  226. {
  227. s7.ConnectClose();
  228. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  229. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  230. responseData.result = "false";
  231. responseData.resultMsg = ActionTypeEnum.RobotAction + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  232. return responseData;
  233. }
  234. // 检查出发地,目的地比对数据开始====
  235. if (req.data.LocationDevice != null)
  236. { // 判断取料设备是否满足条件
  237. CcsActionDeviceSourceCheck ccsActionDeviceSourceCheck = new CcsActionDeviceSourceCheck();
  238. ccsActionDeviceSourceCheck.Type = CcsActionDeviceSourceCheckTypeEnum.CHECK.ToString();
  239. ccsActionDeviceSourceCheck.ActionId = actionInfo.Id;
  240. ccsActionDeviceSourceCheck.DeviceCode = req.data.LocationDevice;
  241. ccsActionDeviceSourceCheck.DeviceSource = "out";
  242. ResponseECSCallbackData callbackData = _ccsActionDeviceSourceCheckService.checkDataAddress(ccsActionDeviceSourceCheck, s7);
  243. if (!callbackData.isSuccess)
  244. {
  245. s7.ConnectClose();
  246. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====" + callbackData.msg + "====" + JsonConvert.SerializeObject(req),
  247. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  248. responseData.result = "false";
  249. responseData.resultMsg = callbackData.msg;
  250. return responseData;
  251. }
  252. }
  253. if (req.data.DestLocationDevice != null)
  254. {
  255. CcsActionDeviceSourceCheck ccsActionDeviceSourceCheck = new CcsActionDeviceSourceCheck();
  256. ccsActionDeviceSourceCheck.Type = CcsActionDeviceSourceCheckTypeEnum.CHECK.ToString();
  257. ccsActionDeviceSourceCheck.ActionId = actionInfo.Id;
  258. ccsActionDeviceSourceCheck.DeviceCode = req.data.DestLocationDevice;
  259. ccsActionDeviceSourceCheck.DeviceSource = "in";
  260. ResponseECSCallbackData callbackData = _ccsActionDeviceSourceCheckService.checkDataAddress(ccsActionDeviceSourceCheck, s7);
  261. if (!callbackData.isSuccess)
  262. {
  263. s7.ConnectClose();
  264. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====" + callbackData.msg + "====" + JsonConvert.SerializeObject(req),
  265. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  266. responseData.result = "false";
  267. responseData.resultMsg = callbackData.msg;
  268. return responseData;
  269. }
  270. }
  271. // 检查出发地,目的地比对数据结束===
  272. //=========================上下料站请求判断 开始======================
  273. // 目标点位是上下料站的判断下料请求是否为true,上料请求为false,
  274. // 如果不是判断上料请求是否为true,
  275. // 是提示状态不对,否则写下料请求状态
  276. // 上料料请求
  277. if (shangLiaoQaingQiu.ContainsKey(req.data.DestLocation)) {
  278. string shangliaoqingqiuDB = shangLiaoQaingQiu[req.data.DestLocation];
  279. string xialiaoqingqiuDB = xiaLiaoQaingQiu[req.data.DestLocation];
  280. string shangliaoyunxuDB = shangLiaoZhuangTai[req.data.DestLocation];
  281. string xialiaoyunxuDB = xiaLiaoZhuangTai[req.data.DestLocation];
  282. string shangliaoqingqiu = s7.ReadBool(shangliaoqingqiuDB).Content.ToString();
  283. string xialiaoqingqiu = s7.ReadBool(xialiaoqingqiuDB).Content.ToString();
  284. string shangliaoyunxu = s7.ReadBool(shangliaoyunxuDB).Content.ToString();
  285. string xialiaoyunxu = s7.ReadBool(xialiaoyunxuDB).Content.ToString();
  286. if (shangliaoqingqiu == "False" && xialiaoqingqiu == "False")
  287. {
  288. s7.Write(shangliaoqingqiuDB, true);
  289. s7.ConnectClose();
  290. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====已发送上料请求,等待上料允许====" + JsonConvert.SerializeObject(req),
  291. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  292. responseData.result = "false";
  293. responseData.resultMsg = "已发送上料请求,等待上料允许";
  294. return responseData;
  295. }
  296. else if (shangliaoqingqiu == "False" && xialiaoqingqiu == "True")
  297. {
  298. s7.ConnectClose();
  299. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====状态不对,现在下料请求状态,等待下料任务完成====" + JsonConvert.SerializeObject(req),
  300. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  301. responseData.result = "false";
  302. responseData.resultMsg = "已被下料请求占用,等待下料任务完成";
  303. return responseData;
  304. }
  305. else if (shangliaoqingqiu == "True" && shangliaoyunxu == "False")
  306. {
  307. s7.ConnectClose();
  308. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====已经发送上料请求,上料允许状态不满足====" + JsonConvert.SerializeObject(req),
  309. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  310. responseData.result = "false";
  311. responseData.resultMsg = "已经发送上料请求,上料允许状态不满";
  312. return responseData;
  313. }
  314. }
  315. // 下料允许
  316. if (xiaLiaoQaingQiu.ContainsKey(req.data.Location))
  317. {
  318. string shangliaoqingqiuDB = shangLiaoQaingQiu[req.data.Location];
  319. string xialiaoqingqiuDB = xiaLiaoQaingQiu[req.data.Location];
  320. string shangliaoyunxuDB = shangLiaoZhuangTai[req.data.Location];
  321. string xialiaoyunxuDB = xiaLiaoZhuangTai[req.data.Location];
  322. string shangliaoqingqiu = s7.ReadBool(shangliaoqingqiuDB).Content.ToString();
  323. string xialiaoqingqiu = s7.ReadBool(xialiaoqingqiuDB).Content.ToString();
  324. string shangliaoyunxu = s7.ReadBool(shangliaoyunxuDB).Content.ToString();
  325. string xialiaoyunxu = s7.ReadBool(xialiaoyunxuDB).Content.ToString();
  326. if (shangliaoqingqiu == "False" && xialiaoqingqiu == "False")
  327. {
  328. s7.Write(xialiaoqingqiuDB, true);
  329. s7.ConnectClose();
  330. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====已发送下料请求,等待下料允许====" + JsonConvert.SerializeObject(req),
  331. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  332. responseData.result = "false";
  333. responseData.resultMsg = "已发送上料请求,等待上料允许";
  334. return responseData;
  335. }else if (shangliaoqingqiu == "True" && xialiaoqingqiu == "False")
  336. {
  337. s7.ConnectClose();
  338. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====状态不对,现在上料请求状态,等待上料任务完成====" + JsonConvert.SerializeObject(req),
  339. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  340. responseData.result = "false";
  341. responseData.resultMsg = "已被上料请求占用,等待上料任务完成";
  342. return responseData;
  343. }
  344. else if (xialiaoqingqiu == "True" && xialiaoyunxu == "False") {
  345. s7.ConnectClose();
  346. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "====已经发送下料请求,下料允许状态不满足====" + JsonConvert.SerializeObject(req),
  347. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  348. responseData.result = "false";
  349. responseData.resultMsg = "已经发送下料请求,下料允许状态不满足";
  350. return responseData;
  351. }
  352. }
  353. //=========================上下料站请求判断 结束======================
  354. // 查询需要操作的plc的db块
  355. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  356. actionAddressQuery.ActionId = actionInfo.Id;
  357. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  358. //查询出需要检查的地址列表
  359. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  360. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  361. {
  362. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  363. {
  364. string operateResult = "";
  365. if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.BOOL.ToString()))
  366. {
  367. operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  368. }
  369. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.SHORT.ToString()))
  370. {
  371. operateResult = s7.ReadInt16(actionAddress.Address).Content.ToString();
  372. }
  373. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.String.ToString()))
  374. {
  375. operateResult = s7.ReadString(actionAddress.Address).Content.ToString();
  376. }
  377. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.Byte.ToString()))
  378. {
  379. operateResult = s7.ReadByte(actionAddress.Address).Content.ToString();
  380. }
  381. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  382. {
  383. s7.ConnectClose();
  384. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult +",要查询的参数"+ JsonConvert.SerializeObject(actionAddress) +", 请求参数"+ JsonConvert.SerializeObject(req),
  385. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  386. responseData.result = "false";
  387. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  388. return responseData;
  389. }
  390. }
  391. }
  392. //查询需要写入地址列表
  393. List<CcsActionAddress> CcsActionAddressWrites = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.WRITE.ToString()).ToList();
  394. foreach (CcsActionAddress actionAddress in CcsActionAddressWrites)
  395. {
  396. if (!string.IsNullOrEmpty(actionAddress.Address))
  397. {
  398. string parValue = "";
  399. // 写入取放点位、需要进行点位拼接
  400. if (actionAddress.Sort == 1)
  401. {
  402. //区域块为七位,点位为三位
  403. //parValue = req.data.LocationArea.PadRight(7,'0')+ req.data.Location.PadLeft(3, '0') + req.data.DestLocationArea.PadRight(7, '0') + req.data.DestLocation.PadLeft(3, '0');
  404. parValue =req.data.Location + req.data.DestLocation;
  405. s7.Write(actionAddress.Address, Convert.ToString(parValue));
  406. }
  407. else if (actionAddress.Sort == 2)
  408. {
  409. // 需要写入启动状态
  410. parValue = actionAddress.Value;
  411. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  412. }
  413. // 同步TagValue数据状态
  414. CcsTagValue tagValueQuery = new CcsTagValue();
  415. tagValueQuery.Ip = req.url;
  416. tagValueQuery.Address = actionAddress.Address;
  417. CcsTagValue tagValue = _ccsTagValueService.GetList(tagValueQuery).ToList().FirstOrDefault();
  418. if (tagValue != null)
  419. {
  420. tagValue.TagValue = parValue;
  421. await _ccsTagValueService.Update(tagValue);
  422. }
  423. Thread.Sleep(SLEEP_TIME);
  424. }
  425. }
  426. s7.ConnectClose();
  427. //插入回调
  428. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.RobotAction.ToString(),
  429. EnumHelper.GetDescription(ActionTypeEnum.RobotAction), req.taskId, req.taskNodeId);
  430. taskCallbackData = setCallBackValue(CcsActionAddresses, taskCallbackData);
  431. // 保存数据
  432. await _taskCallbackService.CreateOrUpdateAndCache(taskCallbackData);
  433. Log.Instance.WriteLogAdd(EnumHelper.GetDescription(ActionTypeEnum.RobotAction) + "取成功===>>" + JsonConvert.SerializeObject(req)
  434. , EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  435. return responseData;
  436. }
  437. catch (Exception ex)
  438. {
  439. // 记录日志
  440. Log.Instance.WriteLogAdd(ActionTypeEnum.RobotAction + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  441. EnumHelper.GetDescription(ActionTypeEnum.RobotAction));
  442. responseData.resultMsg = ActionTypeEnum.RobotAction + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req);
  443. responseData.result = "false";
  444. // 关闭plc连接
  445. if (s7 != null)
  446. {
  447. s7.ConnectClose();
  448. }
  449. return responseData;
  450. }
  451. }
  452. /// <summary>
  453. /// 天轨机器人取放动作
  454. /// </summary>
  455. ///
  456. public async Task<ResponseECSData> CutterRobotAction(RequestData<CutterLocationData> req)
  457. {
  458. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "执行成功");
  459. SiemensS7Net s7 = null;
  460. try
  461. {
  462. // 获取所有在线的设备
  463. List<Device> devices = _deviceService.GetDeviceList();
  464. // 比较在线设备是否在其中
  465. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  466. if (device == null)
  467. {
  468. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  469. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  470. responseData.result = "false";
  471. responseData.resultMsg = "设备已离线:" + req.url;
  472. return responseData;
  473. }
  474. // 根据ip查询设备
  475. CcsAction actionQuery = new CcsAction();
  476. actionQuery.OperateType = ActionTypeEnum.CutterRobotAction.ToString();
  477. actionQuery.Ip = req.url;
  478. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  479. // 进行plc的连接
  480. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  481. OperateResult ConnectionResult = s7.ConnectServer();
  482. if (!ConnectionResult.IsSuccess)
  483. {
  484. s7.ConnectClose();
  485. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  486. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  487. responseData.result = "false";
  488. responseData.resultMsg = ActionTypeEnum.CutterRobotAction + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  489. return responseData;
  490. }
  491. // 检查出发地,目的地比对数据开始====
  492. if (req.data.LocationDevice != null)
  493. { // 判断取料设备是否满足条件
  494. CcsActionDeviceSourceCheck ccsActionDeviceSourceCheck = new CcsActionDeviceSourceCheck();
  495. ccsActionDeviceSourceCheck.Type = CcsActionDeviceSourceCheckTypeEnum.CHECK.ToString();
  496. ccsActionDeviceSourceCheck.ActionId = actionInfo.Id;
  497. ccsActionDeviceSourceCheck.DeviceCode = req.data.LocationDevice;
  498. ccsActionDeviceSourceCheck.DeviceSource = "out";
  499. ResponseECSCallbackData callbackData = _ccsActionDeviceSourceCheckService.checkDataAddress(ccsActionDeviceSourceCheck, s7);
  500. if (!callbackData.isSuccess)
  501. {
  502. s7.ConnectClose();
  503. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====" + callbackData.msg + "====" + JsonConvert.SerializeObject(req),
  504. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  505. responseData.result = "false";
  506. responseData.resultMsg = callbackData.msg;
  507. return responseData;
  508. }
  509. }
  510. if (req.data.DestLocationDevice != null)
  511. {
  512. CcsActionDeviceSourceCheck ccsActionDeviceSourceCheck = new CcsActionDeviceSourceCheck();
  513. ccsActionDeviceSourceCheck.Type = CcsActionDeviceSourceCheckTypeEnum.CHECK.ToString();
  514. ccsActionDeviceSourceCheck.ActionId = actionInfo.Id;
  515. ccsActionDeviceSourceCheck.DeviceCode = req.data.DestLocationDevice;
  516. ccsActionDeviceSourceCheck.DeviceSource = "in";
  517. ResponseECSCallbackData callbackData = _ccsActionDeviceSourceCheckService.checkDataAddress(ccsActionDeviceSourceCheck, s7);
  518. if (!callbackData.isSuccess)
  519. {
  520. s7.ConnectClose();
  521. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====" + callbackData.msg + "====" + JsonConvert.SerializeObject(req),
  522. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  523. responseData.result = "false";
  524. responseData.resultMsg = callbackData.msg;
  525. return responseData;
  526. }
  527. }
  528. // 检查出发地,目的地比对数据结束===
  529. //=========================上下料站请求判断 开始======================
  530. // 目标点位是上下料站的判断下料请求是否为true,上料请求为false,
  531. // 如果不是判断上料请求是否为true,
  532. // 是提示状态不对,否则写下料请求状态
  533. // 上料料请求
  534. if (cutterPutRequest.ContainsKey(req.data.DestLocation))
  535. {
  536. string shangliaoqingqiuDB = cutterPutRequest[req.data.DestLocation];
  537. string xialiaoqingqiuDB = cutterTakeRequest[req.data.DestLocation];
  538. string shangliaoyunxuDB = cutterPutStatus[req.data.DestLocation];
  539. string xialiaoyunxuDB = cutterTakeStatus[req.data.DestLocation];
  540. string shangliaoqingqiu = s7.ReadBool(shangliaoqingqiuDB).Content.ToString();
  541. string xialiaoqingqiu = s7.ReadBool(xialiaoqingqiuDB).Content.ToString();
  542. string shangliaoyunxu = s7.ReadBool(shangliaoyunxuDB).Content.ToString();
  543. string xialiaoyunxu = s7.ReadBool(xialiaoyunxuDB).Content.ToString();
  544. if (shangliaoqingqiu == "False" && xialiaoqingqiu == "False")
  545. {
  546. s7.Write(shangliaoqingqiuDB, true);
  547. s7.ConnectClose();
  548. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已发送上料请求,等待上料允许====" + JsonConvert.SerializeObject(req),
  549. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  550. responseData.result = "false";
  551. responseData.resultMsg = "已发送上料请求,等待上料允许";
  552. return responseData;
  553. }
  554. else if (shangliaoqingqiu == "False" && xialiaoqingqiu == "True")
  555. {
  556. s7.ConnectClose();
  557. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====状态不对,现在下料请求状态,等待下料任务完成====" + JsonConvert.SerializeObject(req),
  558. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  559. responseData.result = "false";
  560. responseData.resultMsg = "已被下料请求占用,等待下料任务完成";
  561. return responseData;
  562. }
  563. else if (shangliaoqingqiu == "True" && shangliaoyunxu == "False")
  564. {
  565. s7.ConnectClose();
  566. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已经发送上料请求,上料允许状态不满足====" + JsonConvert.SerializeObject(req),
  567. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  568. responseData.result = "false";
  569. responseData.resultMsg = "已经发送上料请求,上料允许状态不满";
  570. return responseData;
  571. }
  572. }
  573. // 下料允许
  574. if (cutterTakeRequest.ContainsKey(req.data.Location))
  575. {
  576. string shangliaoqingqiuDB = cutterPutRequest[req.data.Location];
  577. string xialiaoqingqiuDB = cutterTakeRequest[req.data.Location];
  578. string shangliaoyunxuDB = cutterPutStatus[req.data.Location];
  579. string xialiaoyunxuDB = cutterTakeStatus[req.data.Location];
  580. string shangliaoqingqiu = s7.ReadBool(shangliaoqingqiuDB).Content.ToString();
  581. string xialiaoqingqiu = s7.ReadBool(xialiaoqingqiuDB).Content.ToString();
  582. string shangliaoyunxu = s7.ReadBool(shangliaoyunxuDB).Content.ToString();
  583. string xialiaoyunxu = s7.ReadBool(xialiaoyunxuDB).Content.ToString();
  584. if (shangliaoqingqiu == "False" && xialiaoqingqiu == "False")
  585. {
  586. s7.Write(xialiaoqingqiuDB, true);
  587. s7.ConnectClose();
  588. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已发送下料请求,等待下料允许====" + JsonConvert.SerializeObject(req),
  589. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  590. responseData.result = "false";
  591. responseData.resultMsg = "已发送下料请求,等待下料允许";
  592. return responseData;
  593. }
  594. else if (shangliaoqingqiu == "True" && xialiaoqingqiu == "False")
  595. {
  596. s7.ConnectClose();
  597. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====状态不对,现在上料请求状态,等待上料任务完成====" + JsonConvert.SerializeObject(req),
  598. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  599. responseData.result = "false";
  600. responseData.resultMsg = "已被上料请求占用,等待上料任务完成";
  601. return responseData;
  602. }
  603. else if (xialiaoqingqiu == "True" && xialiaoyunxu == "False")
  604. {
  605. s7.ConnectClose();
  606. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已经发送下料请求,下料允许状态不满足====" + JsonConvert.SerializeObject(req),
  607. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  608. responseData.result = "false";
  609. responseData.resultMsg = "已经发送下料请求,下料允许状态不满足";
  610. return responseData;
  611. }
  612. }
  613. //=========================上下料站请求判断 结束======================
  614. // 查询需要操作的plc的db块
  615. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  616. actionAddressQuery.ActionId = actionInfo.Id;
  617. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  618. //查询出需要检查的地址列表
  619. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  620. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  621. {
  622. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  623. {
  624. string operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  625. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  626. {
  627. s7.ConnectClose();
  628. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(req),
  629. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  630. responseData.result = "false";
  631. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  632. return responseData;
  633. }
  634. }
  635. }
  636. //查询需要写入地址列表
  637. List<CcsActionAddress> CcsActionAddressWrites = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.WRITE.ToString()).ToList();
  638. foreach (CcsActionAddress actionAddress in CcsActionAddressWrites)
  639. {
  640. if (!string.IsNullOrEmpty(actionAddress.Address))
  641. {
  642. string parValue = "";
  643. // 写入取放点位、需要进行点位拼接
  644. if (actionAddress.Sort == 1)
  645. {
  646. //区域块为七位,点位为三位
  647. //parValue = req.data.LocationArea.PadRight(7,'0')+ req.data.Location.PadLeft(3, '0') + req.data.DestLocationArea.PadRight(7, '0') + req.data.DestLocation.PadLeft(3, '0');
  648. parValue = req.data.Location + req.data.DestLocation;
  649. s7.Write(actionAddress.Address, Convert.ToString(parValue));
  650. }
  651. else if (actionAddress.Sort == 2)
  652. {
  653. // 需要写入启动状态
  654. parValue = actionAddress.Value;
  655. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  656. }
  657. else if (actionAddress.Sort == 3)
  658. {
  659. // 写入源刀位号
  660. parValue = req.data.LocationNo;
  661. if (req.data.LocationNo == null || req.data.LocationNo == "")
  662. {
  663. parValue = "0";
  664. }
  665. s7.Write(actionAddress.Address, Convert.ToByte(parValue));
  666. }
  667. else if (actionAddress.Sort == 4)
  668. {
  669. // 写入目的刀位号
  670. parValue = req.data.DestLocationNo;
  671. if (req.data.DestLocationNo == null || req.data.DestLocationNo == "")
  672. {
  673. parValue = "0";
  674. }
  675. s7.Write(actionAddress.Address, Convert.ToByte(parValue));
  676. }
  677. else if (actionAddress.Sort == 5) {
  678. parValue = req.data.rfid;
  679. s7.Write(actionAddress.Address, Convert.ToInt16(parValue));
  680. }
  681. // 同步TagValue数据状态
  682. CcsTagValue tagValueQuery = new CcsTagValue();
  683. tagValueQuery.Ip = req.url;
  684. tagValueQuery.Address = actionAddress.Address;
  685. CcsTagValue tagValue = _ccsTagValueService.GetList(tagValueQuery).ToList().FirstOrDefault();
  686. if (tagValue != null)
  687. {
  688. tagValue.TagValue = parValue;
  689. await _ccsTagValueService.Update(tagValue);
  690. }
  691. Thread.Sleep(SLEEP_TIME);
  692. }
  693. }
  694. s7.ConnectClose();
  695. //插入回调
  696. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.CutterRobotAction.ToString(),
  697. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction), req.taskId, req.taskNodeId);
  698. taskCallbackData = setCallBackValue(CcsActionAddresses, taskCallbackData);
  699. // 保存数据
  700. await _taskCallbackService.CreateOrUpdateAndCache(taskCallbackData);
  701. Log.Instance.WriteLogAdd(EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction) + "取成功===>>" + JsonConvert.SerializeObject(req)
  702. , EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  703. return responseData;
  704. }
  705. catch (Exception ex)
  706. {
  707. // 记录日志
  708. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  709. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  710. responseData.resultMsg = ActionTypeEnum.CutterRobotAction + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req);
  711. responseData.result = "false";
  712. // 关闭plc连接
  713. if (s7 != null)
  714. {
  715. s7.ConnectClose();
  716. }
  717. return responseData;
  718. }
  719. }
  720. /// <summary>
  721. /// CNC刀具库请求上下料动作
  722. /// </summary>
  723. /// <param name="req"></param>
  724. /// <returns></returns>
  725. public async Task<ResponseECSData> CutterDeviceTakeOrPutRequest(RequestData<CutterLocationData> req)
  726. {
  727. Log.Instance.WriteLogAdd("CNC刀具库请求上下料动作===>> " + JsonConvert.SerializeObject(req), "CNC刀具库请求上下料动作");
  728. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "执行成功");
  729. SiemensS7Net s7 = null;
  730. try
  731. {
  732. // 获取所有在线的设备
  733. List<Device> devices = _deviceService.GetDeviceList();
  734. // 比较在线设备是否在其中
  735. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  736. if (device == null)
  737. {
  738. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterCncDeviceAction + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  739. EnumHelper.GetDescription(ActionTypeEnum.CutterCncDeviceAction));
  740. responseData.result = "false";
  741. responseData.resultMsg = "设备已离线:" + req.url;
  742. return responseData;
  743. }
  744. // 根据ip查询设备
  745. CcsAction actionQuery = new CcsAction();
  746. actionQuery.OperateType = ActionTypeEnum.CutterCncDeviceAction.ToString();
  747. actionQuery.Ip = req.url;
  748. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  749. // 进行plc的连接
  750. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  751. OperateResult ConnectionResult = s7.ConnectServer();
  752. if (!ConnectionResult.IsSuccess)
  753. {
  754. s7.ConnectClose();
  755. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterCncDeviceAction + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  756. EnumHelper.GetDescription(ActionTypeEnum.CutterCncDeviceAction));
  757. responseData.result = "false";
  758. responseData.resultMsg = ActionTypeEnum.CutterCncDeviceAction + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  759. return responseData;
  760. }
  761. // 查询需要操作的plc的db块
  762. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  763. actionAddressQuery.ActionId = actionInfo.Id;
  764. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  765. //查询出需要检查的地址列表
  766. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  767. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  768. {
  769. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  770. {
  771. string operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  772. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  773. {
  774. s7.ConnectClose();
  775. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterCncDeviceAction + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(req),
  776. EnumHelper.GetDescription(ActionTypeEnum.CutterCncDeviceAction));
  777. responseData.result = "false";
  778. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  779. return responseData;
  780. }
  781. }
  782. }
  783. //查询需要写入地址列表
  784. List<CcsActionAddress> CcsActionAddressWrites = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.WRITE.ToString()).ToList();
  785. foreach (CcsActionAddress actionAddress in CcsActionAddressWrites)
  786. {
  787. if (!string.IsNullOrEmpty(actionAddress.Address))
  788. {
  789. string parValue = "";
  790. // 写入取放点位、需要进行点位拼接
  791. if (actionAddress.Sort == 1)
  792. {
  793. string before = "EMPTY00000";
  794. if (req.data.Location != null && req.data.Location.Length>0) {
  795. int separatorIndex = req.data.LocationNo.IndexOf(".");
  796. string substring = req.data.LocationNo.Substring(separatorIndex+1); // 从第7个字符开始截取5个字符
  797. int num = int.Parse(substring);
  798. string formatted = num.ToString("D2");
  799. before = "ATC00" + formatted + req.data.Location.Substring(7, 3);
  800. }
  801. string theTail = "EMPTY00000";
  802. if (req.data.DestLocation != null && req.data.DestLocation.Length>0) {
  803. int separatorIndex = req.data.DestLocationNo.IndexOf(".");
  804. string substring = req.data.DestLocationNo.Substring(separatorIndex+1); // 从第7个字符开始截取5个字符
  805. int num = int.Parse(substring);
  806. string formatted = num.ToString("D2");
  807. theTail = "ATC00" + formatted + req.data.DestLocation.Substring(7, 3);
  808. }
  809. parValue = before + theTail;
  810. s7.Write(actionAddress.Address, Convert.ToString(parValue));
  811. }
  812. else if (actionAddress.Sort == 2)
  813. {
  814. // 需要写入启动状态
  815. parValue = actionAddress.Value;
  816. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  817. }
  818. // 同步TagValue数据状态
  819. CcsTagValue tagValueQuery = new CcsTagValue();
  820. tagValueQuery.Ip = req.url;
  821. tagValueQuery.Address = actionAddress.Address;
  822. CcsTagValue tagValue = _ccsTagValueService.GetList(tagValueQuery).ToList().FirstOrDefault();
  823. if (tagValue != null)
  824. {
  825. tagValue.TagValue = parValue;
  826. await _ccsTagValueService.Update(tagValue);
  827. }
  828. Thread.Sleep(SLEEP_TIME);
  829. }
  830. }
  831. s7.ConnectClose();
  832. return responseData;
  833. }
  834. catch (Exception ex)
  835. {
  836. // 记录日志
  837. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterCncDeviceAction + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  838. EnumHelper.GetDescription(ActionTypeEnum.CutterCncDeviceAction));
  839. responseData.resultMsg = ActionTypeEnum.CutterCncDeviceAction + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req);
  840. responseData.result = "false";
  841. // 关闭plc连接
  842. if (s7 != null)
  843. {
  844. s7.ConnectClose();
  845. }
  846. return responseData;
  847. }
  848. }
  849. /// <summary>
  850. /// 上传文件
  851. /// </summary>
  852. public async Task<ResponseECSData> UploadFile(RequestData<UploadFileData> req)
  853. {
  854. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId);
  855. try
  856. {
  857. List<Device> devices = _deviceService.GetDeviceList();
  858. Device deviceFtp = devices.Where(x => x.Ip.Equals(req.url)
  859. && x.ProtocolType.Equals(ProtocalTypeEnum.FTP.ToString())).FirstOrDefault();
  860. Device deviceOpcUa = devices.Where(x => x.Ip.Equals(req.url)
  861. && x.ProtocolType.Equals(ProtocalTypeEnum.OPCUA.ToString())).FirstOrDefault();
  862. Device deviceHeidenhain = devices.Where(x => x.Ip.Equals(req.url)
  863. && x.ProtocolType.Equals(ProtocalTypeEnum.HEIDEHAIN.ToString())).FirstOrDefault();
  864. if (deviceOpcUa == null && deviceHeidenhain == null)
  865. {
  866. Log.Instance.WriteLogAdd(ActionTypeEnum.UploadFile + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  867. EnumHelper.GetDescription(ActionTypeEnum.UploadFile));
  868. responseData.result = "false";
  869. responseData.resultMsg = ActionTypeEnum.UploadFile + "设备已离线===>>" + JsonConvert.SerializeObject(req);
  870. return responseData;
  871. }
  872. //西门子系统上传
  873. if (deviceOpcUa != null)
  874. {
  875. RequestOpcUaData opcUaReq = new RequestOpcUaData();
  876. opcUaReq.ServerUrl = deviceOpcUa.ServerUrl;
  877. opcUaReq.UserName = deviceOpcUa.UserName;
  878. opcUaReq.Password = deviceOpcUa.Password;
  879. opcUaReq.Path = req.data.fileName;
  880. opcUaReq.Type = OpcUaActionTypeEnum.Upload.ToString();
  881. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, opcuacUrlContext, opcUaReq, null);
  882. ResponseOpcUaData responseOpcUaData = JsonConvert.DeserializeObject<ResponseOpcUaData>(Result.Message);
  883. if (!Result.IsSuccess || !responseOpcUaData.result)
  884. {
  885. Log.Instance.WriteLogAdd(ActionTypeEnum.UploadFile + "上传异常===>>" + JsonConvert.SerializeObject(req),
  886. EnumHelper.GetDescription(ActionTypeEnum.UploadFile));
  887. responseData.result = "false";
  888. responseData.resultMsg = Result.Message;
  889. return responseData;
  890. }
  891. }
  892. else if(deviceHeidenhain != null)
  893. {
  894. RequestHeidhData hdhReq = new RequestHeidhData();
  895. hdhReq.ServerUrl = deviceHeidenhain.ServerUrl;
  896. hdhReq.MachineName = deviceHeidenhain.UserName;
  897. hdhReq.Path = req.data.fileName;
  898. hdhReq.Type = OpcUaActionTypeEnum.Upload.ToString();
  899. //远程机床相对路径
  900. hdhReq.Address = req.data.remotePath;
  901. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  902. ResponseHeidhData responseHeidhData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  903. if (!Result.IsSuccess || !responseHeidhData.result)
  904. {
  905. Log.Instance.WriteLogAdd(ActionTypeEnum.UploadFile + "预上传异常===>>" + JsonConvert.SerializeObject(req),
  906. EnumHelper.GetDescription(ActionTypeEnum.UploadFile));
  907. responseData.result = "false";
  908. responseData.resultMsg = responseHeidhData.msg;
  909. return responseData;
  910. }
  911. }
  912. //插入回调
  913. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.UploadFile.ToString(),
  914. EnumHelper.GetDescription(ActionTypeEnum.UploadFile), req.taskId, req.taskNodeId);
  915. await _taskCallbackService.CreateOrUpdateAndCache(taskCallbackData);
  916. Log.Instance.WriteLogAdd(ActionTypeEnum.UploadFile + "上传成功===>>" + JsonConvert.SerializeObject(req),
  917. EnumHelper.GetDescription(ActionTypeEnum.UploadFile));
  918. return responseData;
  919. }
  920. catch (Exception ex)
  921. {
  922. Log.Instance.WriteLogAdd(ActionTypeEnum.UploadFile + "上传异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  923. EnumHelper.GetDescription(ActionTypeEnum.UploadFile));
  924. responseData.resultMsg = ActionTypeEnum.UploadFile + "上传异常===>>" + ex.Message + JsonConvert.SerializeObject(req);
  925. responseData.result = "false";
  926. return responseData;
  927. }
  928. }
  929. /// <summary>
  930. /// 启动机床程序
  931. /// </summary>
  932. public async Task<ResponseECSData> StartNCProgram(RequestData<StartNCProgramData> req)
  933. {
  934. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId);
  935. try
  936. {
  937. List<Device> devices = _deviceService.GetDeviceList();
  938. Device device = devices.Where(x => x.Ip.Equals(req.url) && x.Port.Equals(req.port)).FirstOrDefault();
  939. if (device == null)
  940. {
  941. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  942. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  943. responseData.result = "false";
  944. responseData.resultMsg = ActionTypeEnum.StartNCProgram + "设备已离线===>>" + JsonConvert.SerializeObject(req);
  945. return responseData;
  946. }
  947. CcsAction actionQuery = new CcsAction();
  948. actionQuery.OperateType = ActionTypeEnum.StartNCProgram.ToString();
  949. actionQuery.Ip = req.url;
  950. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  951. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  952. actionAddressQuery.ActionId = actionInfo.Id;
  953. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  954. //opcua启动程序
  955. if (actionInfo.ProtocolType == ProtocalTypeEnum.OPCUA.ToString())
  956. {
  957. //插入回调
  958. //获取启动前放的 工位
  959. TaskCallback queryTaskCallBack = new TaskCallback();
  960. queryTaskCallBack.IP = actionInfo.PlcIp;
  961. queryTaskCallBack.Description = ProtocalTypeEnum.OPCUA.ToString();
  962. TaskCallback TaskBean = await _taskCallbackService.GetRobotActionList(queryTaskCallBack);
  963. TaskCallback taskCallbackData = new TaskCallback(actionInfo.PlcIp, ActionTypeEnum.StartNCProgram.ToString(),
  964. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram), req.taskId, req.taskNodeId);
  965. taskCallbackData = setCallBackValue(CcsActionAddresses, taskCallbackData);
  966. taskCallbackData.Description = ProtocalTypeEnum.OPCUA.ToString();
  967. if(TaskBean != null)
  968. {
  969. taskCallbackData.Data = TaskBean.Data;
  970. }
  971. else
  972. {
  973. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "失败,上一放动作 没有工位信息===>>" + JsonConvert.SerializeObject(req),
  974. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  975. return responseData;
  976. }
  977. await _taskCallbackService.CreateOrUpdateAndCache(taskCallbackData);
  978. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "启动成功===>>" + JsonConvert.SerializeObject(req),
  979. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  980. return responseData;
  981. } else if (actionInfo.ProtocolType == ProtocalTypeEnum.HEIDEHAIN.ToString())
  982. {
  983. //调用机器人plc启动海德汉程序
  984. //SiemensS7Net s7 = DevicePlcS7.SiemensS7(actionInfo.PlcIp);
  985. //OperateResult ConnectionResult = s7.ConnectServer();
  986. //if (!ConnectionResult.IsSuccess)
  987. //{
  988. // s7.ConnectClose();
  989. // Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "启动程序异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  990. // EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  991. // responseData.result = "false";
  992. // return responseData;
  993. //}
  994. ////查询条件
  995. //List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  996. //foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  997. //{
  998. // if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  999. // {
  1000. // string operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  1001. // if (actionAddress.CheckType ? operateResult.Equals(actionAddress.Value) : operateResult != actionAddress.Value)
  1002. // {
  1003. // s7.ConnectClose();
  1004. // Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "启动程序异常===>>" + "条件不满足" + JsonConvert.SerializeObject(req),
  1005. // EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  1006. // responseData.result = "false";
  1007. // return responseData;
  1008. // }
  1009. // }
  1010. //}
  1011. //s7.ConnectClose();
  1012. RequestHeidhData hdhReq = new RequestHeidhData();
  1013. hdhReq.ServerUrl = device.ServerUrl;
  1014. hdhReq.MachineName = device.UserName;
  1015. hdhReq.Path = req.data.remotePath;
  1016. hdhReq.Type = OpcUaActionTypeEnum.StartNcProgram.ToString();
  1017. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "启动参数===>>" + JsonConvert.SerializeObject(hdhReq),
  1018. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  1019. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  1020. ResponseHeidhData responseHeidhData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  1021. if (!Result.IsSuccess || !responseHeidhData.result)
  1022. {
  1023. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "启动异常===>>" + JsonConvert.SerializeObject(req),
  1024. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  1025. responseData.result = "false";
  1026. responseData.resultMsg = responseHeidhData.msg;
  1027. responseData.resultMsg = ActionTypeEnum.StartNCProgram + "启动异常===>>" + JsonConvert.SerializeObject(req);
  1028. return responseData;
  1029. }
  1030. //插入回调
  1031. TaskCallback taskCallbackData = new TaskCallback(actionInfo.PlcIp, ActionTypeEnum.StartNCProgram.ToString(),
  1032. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram), req.taskId, req.taskNodeId);
  1033. await _taskCallbackService.CreateOrUpdateAndCache(setCallBackValue(CcsActionAddresses, taskCallbackData));
  1034. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "启动成功===>>" + JsonConvert.SerializeObject(req),
  1035. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  1036. return responseData;
  1037. }
  1038. else
  1039. {
  1040. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "启动异常===>>" + JsonConvert.SerializeObject(req),
  1041. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  1042. responseData.result = "false";
  1043. responseData.resultMsg = ActionTypeEnum.StartNCProgram + "启动异常===>>" + JsonConvert.SerializeObject(req);
  1044. return responseData;
  1045. }
  1046. }
  1047. catch (Exception ex)
  1048. {
  1049. Log.Instance.WriteLogAdd(ActionTypeEnum.StartNCProgram + "程序异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1050. EnumHelper.GetDescription(ActionTypeEnum.StartNCProgram));
  1051. responseData.result = "false";
  1052. return responseData;
  1053. }
  1054. }
  1055. /// <summary>
  1056. /// 启动清洗机
  1057. /// </summary>
  1058. public async Task<ResponseECSData> StartCleanMachine(RequestData<object> req)
  1059. {
  1060. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId);
  1061. try
  1062. {
  1063. List<Device> devices = _deviceService.GetDeviceList();
  1064. Device device = devices.Where(x => x.Ip.Equals(req.url) && x.Port.Equals(req.port)).FirstOrDefault();
  1065. if (device == null)
  1066. {
  1067. Log.Instance.WriteLogAdd(ActionTypeEnum.StartCleanMachine + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  1068. EnumHelper.GetDescription(ActionTypeEnum.StartCleanMachine));
  1069. responseData.result = "false";
  1070. responseData.resultMsg= ActionTypeEnum.StartCleanMachine + "设备已离线===>>" + JsonConvert.SerializeObject(req);
  1071. return responseData;
  1072. }
  1073. CcsAction actionQuery = new CcsAction();
  1074. actionQuery.OperateType = ActionTypeEnum.StartCleanMachine.ToString();
  1075. actionQuery.Ip = req.url;
  1076. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  1077. SiemensS7Net s7 = DevicePlcS7.SiemensS7(req.url);
  1078. HslCommunication.OperateResult ConnectionResult = s7.ConnectServer();
  1079. if (!ConnectionResult.IsSuccess)
  1080. {
  1081. s7.ConnectClose();
  1082. Log.Instance.WriteLogAdd(ActionTypeEnum.StartCleanMachine + "启动故障===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  1083. EnumHelper.GetDescription(ActionTypeEnum.StartCleanMachine));
  1084. responseData.result = "false";
  1085. return responseData;
  1086. }
  1087. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  1088. actionAddressQuery.ActionId = actionInfo.Id;
  1089. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  1090. s7.ConnectClose();
  1091. //插入回调
  1092. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.StartCleanMachine.ToString(),
  1093. EnumHelper.GetDescription(ActionTypeEnum.StartCleanMachine), req.taskId, req.taskNodeId);
  1094. await _taskCallbackService.CreateOrUpdateAndCache(setCallBackValue(CcsActionAddresses, taskCallbackData));
  1095. Log.Instance.WriteLogAdd(EnumHelper.GetDescription(ActionTypeEnum.StartCleanMachine) + "启动成功===>>" + JsonConvert.SerializeObject(req)
  1096. , EnumHelper.GetDescription(ActionTypeEnum.StartCleanMachine));
  1097. return responseData;
  1098. }
  1099. catch (Exception ex)
  1100. {
  1101. Log.Instance.WriteLogAdd(ActionTypeEnum.StartCleanMachine + "启动故障===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1102. EnumHelper.GetDescription(ActionTypeEnum.StartCleanMachine));
  1103. responseData.result = "false";
  1104. return responseData;
  1105. }
  1106. }
  1107. /// <summary>
  1108. /// 启动吹干
  1109. /// </summary>
  1110. public async Task<ResponseECSData> StartDryMachine(RequestData<object> req)
  1111. {
  1112. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId);
  1113. try
  1114. {
  1115. List<Device> devices = _deviceService.GetDeviceList();
  1116. Device device = devices.Where(x => x.Ip.Equals(req.url) && x.Port.Equals(req.port)).FirstOrDefault();
  1117. if (device == null)
  1118. {
  1119. Log.Instance.WriteLogAdd(ActionTypeEnum.StartDryMachine + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  1120. EnumHelper.GetDescription(ActionTypeEnum.StartDryMachine));
  1121. responseData.result = "false";
  1122. return responseData;
  1123. }
  1124. CcsAction actionQuery = new CcsAction();
  1125. actionQuery.OperateType = ActionTypeEnum.StartDryMachine.ToString();
  1126. actionQuery.Ip = req.url;
  1127. CcsAction action = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  1128. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  1129. actionAddressQuery.ActionId = action.Id;
  1130. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  1131. SiemensS7Net s7 = DevicePlcS7.SiemensS7(req.url);
  1132. HslCommunication.OperateResult ConnectionResult = s7.ConnectServer();
  1133. if (!ConnectionResult.IsSuccess)
  1134. {
  1135. s7.ConnectClose();
  1136. Log.Instance.WriteLogAdd(ActionTypeEnum.StartDryMachine + "启动吹干机异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  1137. EnumHelper.GetDescription(ActionTypeEnum.StartDryMachine));
  1138. responseData.result = "false";
  1139. return responseData;
  1140. }
  1141. s7.ConnectClose();
  1142. //插入回调
  1143. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.StartDryMachine.ToString(),
  1144. EnumHelper.GetDescription(ActionTypeEnum.StartDryMachine), req.taskId, req.taskNodeId);
  1145. await _taskCallbackService.CreateOrUpdateAndCache(setCallBackValue(CcsActionAddresses, taskCallbackData));
  1146. Log.Instance.WriteLogAdd(EnumHelper.GetDescription(ActionTypeEnum.StartDryMachine) + "启动吹干机成功===>>" + JsonConvert.SerializeObject(req)
  1147. , EnumHelper.GetDescription(ActionTypeEnum.StartDryMachine));
  1148. return responseData;
  1149. }
  1150. catch (Exception ex)
  1151. {
  1152. Log.Instance.WriteLogAdd(ActionTypeEnum.StartDryMachine + "启动吹干机故障===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1153. EnumHelper.GetDescription(ActionTypeEnum.StartDryMachine));
  1154. responseData.result = "false";
  1155. return responseData;
  1156. }
  1157. }
  1158. /// <summary>
  1159. /// 刀具接口列表
  1160. /// </summary>
  1161. public async Task<List<ResponseToolData>> GetTools(RequestToolData req)
  1162. {
  1163. List<Device> devices = _deviceService.GetDeviceList();
  1164. List<Device> deviceList = devices.Where(x => x.Ip.Equals(req.url) && x.Port.Equals(req.port)).ToList();
  1165. if (deviceList ==null || deviceList.Count <= 0) {
  1166. throw new InvalidOperationException("没查询到在线设备数据");
  1167. }
  1168. Device device = deviceList.FirstOrDefault();
  1169. List<ResponseToolData> list = new List<ResponseToolData>();
  1170. if (device.ProtocolType == ProtocalTypeEnum.OPCUA.ToString())
  1171. {
  1172. CcsTagValue tagValueQuery = new CcsTagValue();
  1173. tagValueQuery.Ip = req.url;
  1174. tagValueQuery.Component = "刀具";
  1175. List<CcsTagValue> tagValues = _ccsTagValueService.GetList(tagValueQuery);
  1176. List<CcsTagValue> toolNumberList = tagValues.GroupBy(x => x.ComponentNumber)
  1177. .Select(group => new CcsTagValue
  1178. {
  1179. ComponentNumber = group.Key
  1180. }).ToList();
  1181. foreach (CcsTagValue toolNumber in toolNumberList)
  1182. {
  1183. ResponseToolData toolData = new ResponseToolData();
  1184. foreach (CcsTagValue tagValue in tagValues)
  1185. {
  1186. if (toolNumber.ComponentNumber == tagValue.ComponentNumber)
  1187. {
  1188. toolData.number = toolNumber.ComponentNumber;
  1189. if (tagValue.Description == "刀具寿命预警")
  1190. {
  1191. toolData.warnLife = tagValue.TagValue;
  1192. }
  1193. else if (tagValue.Description == "刀具寿命目标值")
  1194. {
  1195. toolData.targetLife = tagValue.TagValue;
  1196. }
  1197. else if (tagValue.Description == "工件数")
  1198. {
  1199. toolData.workPiece = tagValue.TagValue;
  1200. }
  1201. else if (tagValue.Description == "工件数预警值")
  1202. {
  1203. toolData.workPieceWarn = tagValue.TagValue;
  1204. }
  1205. else if (tagValue.Description == "工件数目标值")
  1206. {
  1207. toolData.workPieceTarget = tagValue.TagValue;
  1208. }
  1209. else if (tagValue.Description == "磨损量")
  1210. {
  1211. toolData.wear = tagValue.TagValue;
  1212. }
  1213. else if (tagValue.Description == "磨损量预警值")
  1214. {
  1215. toolData.wearWarn = tagValue.TagValue;
  1216. }
  1217. else if (tagValue.Description == "磨损量目标值")
  1218. {
  1219. toolData.wearTarget = tagValue.TagValue;
  1220. }
  1221. else if (tagValue.Description == "刀具名称")
  1222. {
  1223. toolData.name = tagValue.TagValue;
  1224. }
  1225. }
  1226. }
  1227. list.Add(toolData);
  1228. }
  1229. }
  1230. else if (device.ProtocolType == ProtocalTypeEnum.FANUC.ToString())
  1231. {
  1232. string Url = fanucUrlContext + "?ip=" + device.Ip + "&port=" + device.Port;
  1233. //调用发那科接口
  1234. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Get, Url + "&fun=ToolList", null, null);
  1235. if (Result.IsSuccess)
  1236. {
  1237. List<ResponseToolData> responseFanucData = JsonConvert.DeserializeObject<List<ResponseToolData>>(Result.Message);
  1238. //list = JsonConvert.DeserializeObject<List<ResponseToolData>>(Result.Message.ToolLife);
  1239. //list = JsonConvert.DeserializeObject<List<ResponseToolData>>(responseFanucData.ToolLife);
  1240. list = responseFanucData;
  1241. }
  1242. }else if(device.ProtocolType == ProtocalTypeEnum.HEIDEHAIN.ToString())
  1243. {
  1244. RequestHeidhData hdhReq = new RequestHeidhData();
  1245. hdhReq.ServerUrl = device.ServerUrl;
  1246. hdhReq.MachineName = device.UserName;
  1247. hdhReq.Type = "ToolList";
  1248. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  1249. if (Result.IsSuccess)
  1250. {
  1251. ResponseHeidhData responseData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  1252. list = JsonConvert.DeserializeObject<List<ResponseToolData>>(responseData.toolsInfo);
  1253. }
  1254. }
  1255. return list;
  1256. }
  1257. /// <summary>
  1258. /// 设备上线离线
  1259. /// </summary>
  1260. public async Task<ResponseCommonData> UpdateDeviceState(RequestDeviceUpdateData req)
  1261. {
  1262. ResponseCommonData responseData = new ResponseCommonData();
  1263. List<Device> devices = _deviceService.GetDevices();
  1264. try
  1265. {
  1266. Device device = devices.Where(x => x.Ip == req.ip).FirstOrDefault();
  1267. if (device == null)
  1268. {
  1269. responseData.msg = "设备不存在";
  1270. responseData.result = "false";
  1271. return responseData;
  1272. }
  1273. device.UseState = req.useState;
  1274. device.OfflineUpdateTime = DateTime.Now;
  1275. await _deviceService.UpdateAndCache(device);
  1276. return responseData;
  1277. }
  1278. catch (Exception ex)
  1279. {
  1280. responseData.msg = ex.Message;
  1281. responseData.result = "false";
  1282. return responseData;
  1283. }
  1284. }
  1285. /// <summary>
  1286. /// 获取回调列表
  1287. /// </summary>
  1288. public async Task<List<TaskCallback>> GetCallBackListByCondition(RequestCallBackData vo)
  1289. {
  1290. List<TaskCallback> list = new List<TaskCallback>();
  1291. try {
  1292. TaskCallback taskCallback = new TaskCallback();
  1293. if (!string.IsNullOrEmpty(vo.IP))
  1294. {
  1295. taskCallback.IP = vo.IP;
  1296. }
  1297. if (!string.IsNullOrEmpty(vo.TaskId))
  1298. {
  1299. taskCallback.TaskId = vo.TaskId;
  1300. }
  1301. if (!string.IsNullOrEmpty(vo.TaskNodeId))
  1302. {
  1303. taskCallback.TaskNodeId = vo.TaskNodeId;
  1304. }
  1305. list = await _taskCallbackService.GetListByCondition(taskCallback);
  1306. }
  1307. catch (Exception ex)
  1308. {
  1309. return list;
  1310. }
  1311. return list;
  1312. }
  1313. //设置回调值
  1314. private TaskCallback setCallBackValue(List<CcsActionAddress> CcsActionAddresses, TaskCallback taskCallbackData)
  1315. {
  1316. List<CcsActionAddress> CcsActionAddressCallBacks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CALLBACK.ToString()).ToList();
  1317. List<CcsActionAddress> CcsActionAddressCallBackFails = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CALLBACK_FAIL.ToString()).ToList();
  1318. List<CcsActionAddress> CcsActionAddressCallBackResets = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.RESET.ToString()).ToList();
  1319. foreach (CcsActionAddress actionAddress in CcsActionAddressCallBacks)
  1320. {
  1321. if (actionAddress.Sort == 1)
  1322. {
  1323. taskCallbackData.Address = actionAddress.Address;
  1324. taskCallbackData.CallbackValue = actionAddress.Value;
  1325. }
  1326. else if (actionAddress.Sort == 2)
  1327. {
  1328. taskCallbackData.Address2 = actionAddress.Address;
  1329. taskCallbackData.CallbackValue2 = actionAddress.Value;
  1330. }
  1331. else if (actionAddress.Sort == 3)
  1332. {
  1333. taskCallbackData.Address3 = actionAddress.Address;
  1334. taskCallbackData.CallbackValue3 = actionAddress.Value;
  1335. }
  1336. }
  1337. foreach (CcsActionAddress actionAddress in CcsActionAddressCallBackFails)
  1338. {
  1339. if (actionAddress.Sort == 1)
  1340. {
  1341. taskCallbackData.FailAddress = actionAddress.Address;
  1342. taskCallbackData.CallbackFailValue = actionAddress.Value;
  1343. }
  1344. else if (actionAddress.Sort == 2)
  1345. {
  1346. taskCallbackData.FailAddress2 = actionAddress.Address;
  1347. taskCallbackData.CallbackFailValue2 = actionAddress.Value;
  1348. }
  1349. else if (actionAddress.Sort == 3)
  1350. {
  1351. taskCallbackData.FailAddress3 = actionAddress.Address;
  1352. taskCallbackData.CallbackFailValue3 = actionAddress.Value;
  1353. }
  1354. }
  1355. foreach (CcsActionAddress actionAddress in CcsActionAddressCallBackResets)
  1356. {
  1357. if (actionAddress.Sort == 1)
  1358. {
  1359. taskCallbackData.SuccessResetAddress = actionAddress.Address;
  1360. taskCallbackData.SuccessResetValue = actionAddress.Value;
  1361. }
  1362. else if (actionAddress.Sort == 2)
  1363. {
  1364. taskCallbackData.SuccessResetAddress2 = actionAddress.Address;
  1365. taskCallbackData.SuccessResetValue2 = actionAddress.Value;
  1366. }
  1367. }
  1368. return taskCallbackData;
  1369. }
  1370. public async Task<ResponseECSData> PushPushToMachine(RequestData<CutterTestData> req)
  1371. {
  1372. Log.Instance.WriteLogAdd("机外对刀仪数据接受===>> "+ JsonConvert.SerializeObject(req),"机外对刀仪");
  1373. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  1374. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId);
  1375. try
  1376. {
  1377. List<Device> devices = _deviceService.GetDeviceList();
  1378. Device device = devices.Where(x => x.Ip.Equals(req.url) && x.Port.Equals(req.port)).FirstOrDefault();
  1379. if (device == null)
  1380. {
  1381. Log.Instance.WriteLogAdd(ActionTypeEnum.StartCleanMachine + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  1382. EnumHelper.GetDescription(ActionTypeEnum.StartCleanMachine));
  1383. responseData.result = "false";
  1384. responseData.resultMsg = ActionTypeEnum.StartCleanMachine + "设备已离线===>>" + JsonConvert.SerializeObject(req);
  1385. return responseData;
  1386. }
  1387. if (device.ProtocolType == ProtocalTypeEnum.HEIDEHAIN.ToString())
  1388. {
  1389. RequestHeidhData hdhReq = new RequestHeidhData();
  1390. hdhReq.ServerUrl = device.ServerUrl;
  1391. hdhReq.MachineName = device.UserName;
  1392. hdhReq.Type = "ReadAndWriteTool";
  1393. hdhReq.CutterData = JsonConvert.SerializeObject(req.data);
  1394. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  1395. ResponseHeidhData responseHeidhData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  1396. JObject jsonObject = JObject.Parse(Result.Message);
  1397. if (!Result.IsSuccess || !responseHeidhData.result)
  1398. {
  1399. Log.Instance.WriteLogAdd(ActionTypeEnum.UploadFile + "机外对刀仪数据上传异常===>>" + JsonConvert.SerializeObject(req)+"======结果数据:"+ Result, "机外对刀仪");
  1400. responseData.result = "false";
  1401. responseData.resultMsg = jsonObject.GetValue("msg").ToString();
  1402. }
  1403. else
  1404. {
  1405. if (jsonObject.GetValue("result")!=null && bool.Parse(jsonObject.GetValue("result").ToString())) {
  1406. responseData.result = "true";
  1407. responseData.resultMsg = jsonObject.GetValue("msg").ToString();
  1408. responseData.returnData = jsonObject.GetValue("returnData").ToString();
  1409. }
  1410. else {
  1411. Log.Instance.WriteLogAdd(ActionTypeEnum.UploadFile + "机外对刀仪数据上传异常===>>" + JsonConvert.SerializeObject(req) + "======结果数据:" + Result, "机外对刀仪");
  1412. responseData.result = "false";
  1413. responseData.resultMsg = jsonObject.GetValue("msg").ToString();
  1414. }
  1415. }
  1416. }
  1417. else {
  1418. responseData.result = "false";
  1419. responseData.resultMsg = "没找到对应的类型方法";
  1420. }
  1421. }
  1422. catch (Exception ex) {
  1423. Log.Instance.WriteLogAdd(ActionTypeEnum.StartDryMachine + "任务下发异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1424. EnumHelper.GetDescription(ActionTypeEnum.StartDryMachine));
  1425. responseData.result = "false";
  1426. responseData.resultMsg = ex.Message;
  1427. return responseData;
  1428. }
  1429. return responseData;
  1430. }
  1431. /// <summary>
  1432. /// 查询三坐标是否允许取
  1433. /// </summary>
  1434. public async Task<ResponseECSData> GetMiddleThreeCoordinates(RequestData<RequestToolData> req) {
  1435. Log.Instance.WriteLogAdd("查询三坐标是否允许取===>> " + JsonConvert.SerializeObject(req), "机外对刀仪");
  1436. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  1437. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "允许下料");
  1438. SiemensS7Net s7 = null;
  1439. try
  1440. {
  1441. // 获取所有在线的设备
  1442. List<Device> devices = _deviceService.GetDeviceList();
  1443. // 比较在线设备是否在其中
  1444. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  1445. if (device == null)
  1446. {
  1447. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalTakeStatus + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  1448. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalTakeStatus));
  1449. responseData.result = "false";
  1450. responseData.resultMsg = "设备已离线:" + req.url;
  1451. return responseData;
  1452. }
  1453. // 根据ip查询配置的字节数据
  1454. CcsAction actionQuery = new CcsAction();
  1455. actionQuery.OperateType = ActionTypeEnum.ThreeDimensionalTakeStatus.ToString();
  1456. actionQuery.Ip = req.url;
  1457. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  1458. // 进行plc的连接
  1459. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  1460. OperateResult ConnectionResult = s7.ConnectServer();
  1461. if (!ConnectionResult.IsSuccess)
  1462. {
  1463. s7.ConnectClose();
  1464. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalTakeStatus + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  1465. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalTakeStatus));
  1466. responseData.result = "false";
  1467. responseData.resultMsg = ActionTypeEnum.ThreeDimensionalTakeStatus + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  1468. return responseData;
  1469. }
  1470. // 查询需要操作的plc的db块
  1471. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  1472. actionAddressQuery.ActionId = actionInfo.Id;
  1473. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  1474. //查询出需要检查的地址列表
  1475. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  1476. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  1477. {
  1478. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  1479. {
  1480. string operateResult = "";
  1481. if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.BOOL.ToString()))
  1482. {
  1483. operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  1484. }
  1485. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.SHORT.ToString()))
  1486. {
  1487. operateResult = s7.ReadInt16(actionAddress.Address).Content.ToString();
  1488. }
  1489. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.String.ToString()))
  1490. {
  1491. operateResult = s7.ReadString(actionAddress.Address).Content.ToString();
  1492. }
  1493. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.Byte.ToString()))
  1494. {
  1495. operateResult = s7.ReadByte(actionAddress.Address).Content.ToString();
  1496. }
  1497. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  1498. {
  1499. s7.ConnectClose();
  1500. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalTakeStatus + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(req),
  1501. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalTakeStatus));
  1502. responseData.result = "false";
  1503. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  1504. return responseData;
  1505. }
  1506. }
  1507. }
  1508. // 关闭连接
  1509. s7.ConnectClose();
  1510. }
  1511. catch (Exception ex)
  1512. {
  1513. s7.ConnectClose();
  1514. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalTakeStatus + "任务下发异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1515. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalTakeStatus));
  1516. responseData.result = "false";
  1517. responseData.resultMsg = ex.Message;
  1518. return responseData;
  1519. }
  1520. return responseData;
  1521. }
  1522. /// <summary>
  1523. /// 查询三坐标是否允许放
  1524. /// </summary>
  1525. public async Task<ResponseECSData> QueryThreeCoordinatesFreePos(RequestData<RequestToolData> req) {
  1526. Log.Instance.WriteLogAdd("查询三坐标是否允许放===>> " + JsonConvert.SerializeObject(req), "机外对刀仪");
  1527. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  1528. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "允许上料");
  1529. SiemensS7Net s7 = null;
  1530. try
  1531. {
  1532. // 获取所有在线的设备
  1533. List<Device> devices = _deviceService.GetDeviceList();
  1534. // 比较在线设备是否在其中
  1535. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  1536. if (device == null)
  1537. {
  1538. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalPutStatus + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  1539. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalPutStatus));
  1540. responseData.result = "false";
  1541. responseData.resultMsg = "设备已离线:" + req.url;
  1542. return responseData;
  1543. }
  1544. // 根据ip查询配置的字节数据
  1545. CcsAction actionQuery = new CcsAction();
  1546. actionQuery.OperateType = ActionTypeEnum.ThreeDimensionalPutStatus.ToString();
  1547. actionQuery.Ip = req.url;
  1548. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  1549. // 进行plc的连接
  1550. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  1551. OperateResult ConnectionResult = s7.ConnectServer();
  1552. if (!ConnectionResult.IsSuccess)
  1553. {
  1554. s7.ConnectClose();
  1555. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalPutStatus + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  1556. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalPutStatus));
  1557. responseData.result = "false";
  1558. responseData.resultMsg = ActionTypeEnum.ThreeDimensionalPutStatus + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  1559. return responseData;
  1560. }
  1561. // 查询需要操作的plc的db块
  1562. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  1563. actionAddressQuery.ActionId = actionInfo.Id;
  1564. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  1565. //查询出需要检查的地址列表
  1566. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  1567. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  1568. {
  1569. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  1570. {
  1571. string operateResult = "";
  1572. if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.BOOL.ToString()))
  1573. {
  1574. operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  1575. }
  1576. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.SHORT.ToString()))
  1577. {
  1578. operateResult = s7.ReadInt16(actionAddress.Address).Content.ToString();
  1579. }
  1580. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.String.ToString()))
  1581. {
  1582. operateResult = s7.ReadString(actionAddress.Address).Content.ToString();
  1583. }
  1584. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.Byte.ToString()))
  1585. {
  1586. operateResult = s7.ReadByte(actionAddress.Address).Content.ToString();
  1587. }
  1588. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  1589. {
  1590. s7.ConnectClose();
  1591. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalPutStatus + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(req),
  1592. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalPutStatus));
  1593. responseData.result = "false";
  1594. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  1595. return responseData;
  1596. }
  1597. }
  1598. }
  1599. // 关闭连接
  1600. s7.ConnectClose();
  1601. }
  1602. catch (Exception ex)
  1603. {
  1604. // 关闭连接
  1605. s7.ConnectClose();
  1606. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalPutStatus + "任务下发异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1607. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalPutStatus));
  1608. responseData.result = "false";
  1609. responseData.resultMsg = ex.Message;
  1610. return responseData;
  1611. }
  1612. return responseData;
  1613. }
  1614. /// <summary>
  1615. /// 三坐标启动
  1616. /// </summary>
  1617. public async Task<ResponseECSData> SendThreeCoordinates(RequestData<ThreeDimensional> req)
  1618. {
  1619. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "执行成功");
  1620. SiemensS7Net s7 = null;
  1621. try
  1622. {
  1623. // 获取所有在线的设备
  1624. List<Device> devices = _deviceService.GetDeviceList();
  1625. // 比较在线设备是否在其中
  1626. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  1627. if (device == null)
  1628. {
  1629. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalRun + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  1630. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalRun));
  1631. responseData.result = "false";
  1632. responseData.resultMsg = "设备已离线:" + req.url;
  1633. return responseData;
  1634. }
  1635. // 根据ip查询设备
  1636. CcsAction actionQuery = new CcsAction();
  1637. actionQuery.OperateType = ActionTypeEnum.ThreeDimensionalRun.ToString();
  1638. actionQuery.Ip = req.url;
  1639. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  1640. // 进行plc的连接
  1641. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  1642. OperateResult ConnectionResult = s7.ConnectServer();
  1643. if (!ConnectionResult.IsSuccess)
  1644. {
  1645. s7.ConnectClose();
  1646. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalRun + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  1647. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalRun));
  1648. responseData.result = "false";
  1649. responseData.resultMsg = ActionTypeEnum.ThreeDimensionalRun + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  1650. return responseData;
  1651. }
  1652. // 查询需要操作的plc的db块
  1653. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  1654. actionAddressQuery.ActionId = actionInfo.Id;
  1655. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  1656. //查询出需要检查的地址列表
  1657. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  1658. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  1659. {
  1660. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  1661. {
  1662. string operateResult = s7.ReadByte(actionAddress.Address).Content.ToString();
  1663. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  1664. {
  1665. s7.ConnectClose();
  1666. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalRun + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(req),
  1667. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalRun));
  1668. responseData.result = "false";
  1669. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  1670. return responseData;
  1671. }
  1672. }
  1673. }
  1674. //查询需要写入地址列表
  1675. List<CcsActionAddress> CcsActionAddressWrites = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.WRITE.ToString()).ToList();
  1676. foreach (CcsActionAddress actionAddress in CcsActionAddressWrites)
  1677. {
  1678. if (!string.IsNullOrEmpty(actionAddress.Address))
  1679. {
  1680. string parValue = "";
  1681. // 写入取放点位、需要进行点位拼接
  1682. if (actionAddress.Sort == 1)
  1683. {
  1684. parValue = req.data.workType;
  1685. s7.Write(actionAddress.Address, Convert.ToString(parValue));
  1686. }
  1687. else if (actionAddress.Sort == 2)
  1688. {
  1689. // 需要写入启动状态
  1690. parValue = actionAddress.Value;
  1691. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  1692. }
  1693. // 同步TagValue数据状态
  1694. CcsTagValue tagValueQuery = new CcsTagValue();
  1695. tagValueQuery.Ip = req.url;
  1696. tagValueQuery.Address = actionAddress.Address;
  1697. CcsTagValue tagValue = _ccsTagValueService.GetList(tagValueQuery).ToList().FirstOrDefault();
  1698. if (tagValue != null)
  1699. {
  1700. tagValue.TagValue = parValue;
  1701. await _ccsTagValueService.Update(tagValue);
  1702. }
  1703. Thread.Sleep(SLEEP_TIME);
  1704. }
  1705. }
  1706. s7.ConnectClose();
  1707. // 睡100毫秒,保证plc那边进行数据处理完成,防止回调时候,plc状态不是最新状态
  1708. Thread.Sleep(100);
  1709. //插入回调
  1710. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.ThreeDimensionalRun.ToString(),
  1711. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalRun), req.taskId, req.taskNodeId);
  1712. taskCallbackData = setCallBackValue(CcsActionAddresses, taskCallbackData);
  1713. // 保存数据
  1714. await _taskCallbackService.CreateOrUpdateAndCache(taskCallbackData);
  1715. Log.Instance.WriteLogAdd(EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalRun) + "取成功===>>" + JsonConvert.SerializeObject(req)
  1716. , EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalRun));
  1717. return responseData;
  1718. }
  1719. catch (Exception ex)
  1720. {
  1721. // 记录日志
  1722. Log.Instance.WriteLogAdd(ActionTypeEnum.ThreeDimensionalRun + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1723. EnumHelper.GetDescription(ActionTypeEnum.ThreeDimensionalRun));
  1724. responseData.resultMsg = ActionTypeEnum.ThreeDimensionalRun + "取放异常===>>" + ex.Message + JsonConvert.SerializeObject(req);
  1725. responseData.result = "false";
  1726. // 关闭plc连接
  1727. if (s7 != null)
  1728. {
  1729. s7.ConnectClose();
  1730. }
  1731. return responseData;
  1732. }
  1733. }
  1734. /// <summary>
  1735. /// 坐标系偏移量设置
  1736. /// </summary>
  1737. public async Task<ResponseECSData> SendOffsetSetting(RequestData<ThreeDimensionalOffset> req)
  1738. {
  1739. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId,"设置成功");
  1740. try
  1741. {
  1742. List<Device> devices = _deviceService.GetDeviceList();
  1743. Device deviceHeidenhain = devices.Where(x => x.Ip.Equals(req.url)
  1744. && x.ProtocolType.Equals(ProtocalTypeEnum.HEIDEHAIN.ToString())).FirstOrDefault();
  1745. if (deviceHeidenhain == null)
  1746. {
  1747. Log.Instance.WriteLogAdd(ActionTypeEnum.WriteDeviationValue + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  1748. EnumHelper.GetDescription(ActionTypeEnum.WriteDeviationValue));
  1749. responseData.result = "false";
  1750. responseData.resultMsg = ActionTypeEnum.WriteDeviationValue + "设备已离线===>>" + JsonConvert.SerializeObject(req);
  1751. return responseData;
  1752. }
  1753. if (deviceHeidenhain != null)
  1754. {
  1755. RequestHeidhData hdhReq = new RequestHeidhData();
  1756. hdhReq.ServerUrl = deviceHeidenhain.ServerUrl;
  1757. hdhReq.MachineName = deviceHeidenhain.UserName;
  1758. hdhReq.Type = OpcUaActionTypeEnum.WriteDeviationValue.ToString();
  1759. hdhReq.DeviationValue = JsonConvert.SerializeObject(req.data);
  1760. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  1761. ResponseHeidhData responseHeidhData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  1762. if (!Result.IsSuccess || !responseHeidhData.result)
  1763. {
  1764. Log.Instance.WriteLogAdd(ActionTypeEnum.WriteDeviationValue + "坐标系偏差值设置失败===>>" + JsonConvert.SerializeObject(req) + "======结果数据:" + Result, "机外对刀仪");
  1765. responseData.result = "false";
  1766. responseData.resultMsg = Result.Message;
  1767. return responseData;
  1768. }
  1769. else
  1770. {
  1771. responseData.result = "true";
  1772. responseData.resultMsg = "消费成功";
  1773. }
  1774. }
  1775. else
  1776. {
  1777. responseData.result = "false";
  1778. responseData.resultMsg = "没找到对应的类型方法";
  1779. return responseData;
  1780. }
  1781. //插入回调
  1782. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.WriteDeviationValue.ToString(),
  1783. EnumHelper.GetDescription(ActionTypeEnum.WriteDeviationValue), req.taskId, req.taskNodeId);
  1784. await _taskCallbackService.CreateOrUpdateAndCache(taskCallbackData);
  1785. Log.Instance.WriteLogAdd(ActionTypeEnum.WriteDeviationValue + "设置成功===>>" + JsonConvert.SerializeObject(req),
  1786. EnumHelper.GetDescription(ActionTypeEnum.WriteDeviationValue));
  1787. return responseData;
  1788. }
  1789. catch (Exception ex)
  1790. {
  1791. Log.Instance.WriteLogAdd(ActionTypeEnum.WriteDeviationValue + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  1792. EnumHelper.GetDescription(ActionTypeEnum.WriteDeviationValue));
  1793. responseData.resultMsg = ActionTypeEnum.WriteDeviationValue + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(req);
  1794. responseData.result = "false";
  1795. return responseData;
  1796. }
  1797. }
  1798. public async Task<ResponseECSData> findRfidData(RequestData<RequestToolData> reqs)
  1799. {
  1800. Log.Instance.WriteLogAdd("查询rfid数据===>> " + JsonConvert.SerializeObject(reqs), "查询rfid数据");
  1801. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  1802. ResponseECSData responseData = new ResponseECSData(reqs.taskId, reqs.taskNodeId, "执行成功");
  1803. SiemensS7Net s7 = null;
  1804. try
  1805. {
  1806. // 获取所有在线的设备
  1807. List<Device> devices = _deviceService.GetDeviceList();
  1808. // 比较在线设备是否在其中
  1809. Device device = devices.Where(x => x.Ip == reqs.url && x.Port == reqs.port).FirstOrDefault();
  1810. if (device == null)
  1811. {
  1812. Log.Instance.WriteLogAdd(ActionTypeEnum.RfidRead + "设备已离线===>>" + JsonConvert.SerializeObject(reqs),
  1813. EnumHelper.GetDescription(ActionTypeEnum.RfidRead));
  1814. responseData.result = "false";
  1815. responseData.resultMsg = "设备已离线:" + reqs.url;
  1816. return responseData;
  1817. }
  1818. // 根据ip查询设备
  1819. CcsAction actionQuery = new CcsAction();
  1820. actionQuery.OperateType = ActionTypeEnum.RfidRead.ToString();
  1821. actionQuery.Ip = reqs.url;
  1822. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  1823. // 进行plc的连接
  1824. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  1825. OperateResult ConnectionResult = s7.ConnectServer();
  1826. if (!ConnectionResult.IsSuccess)
  1827. {
  1828. s7.ConnectClose();
  1829. Log.Instance.WriteLogAdd(ActionTypeEnum.RfidRead + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(reqs),
  1830. EnumHelper.GetDescription(ActionTypeEnum.RfidRead));
  1831. responseData.result = "false";
  1832. responseData.resultMsg = ActionTypeEnum.RfidRead + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(reqs);
  1833. return responseData;
  1834. }
  1835. // 查询需要操作的plc的db块
  1836. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  1837. actionAddressQuery.ActionId = actionInfo.Id;
  1838. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  1839. //查询出需要检查的地址列表
  1840. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  1841. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  1842. {
  1843. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  1844. {
  1845. string operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  1846. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  1847. {
  1848. s7.ConnectClose();
  1849. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(reqs),
  1850. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  1851. responseData.result = "false";
  1852. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  1853. return responseData;
  1854. }
  1855. }
  1856. }
  1857. // 查询需要读取的地址列表
  1858. List<CcsActionAddress> CcsActionAddressReads = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.READ.ToString()).ToList();
  1859. Dictionary<string, string> map = new Dictionary<string, string>();
  1860. int i = 1;
  1861. foreach (CcsActionAddress actionAddress in CcsActionAddressReads)
  1862. {
  1863. if (string.IsNullOrEmpty(actionAddress.Address)) {
  1864. continue;
  1865. }
  1866. string operateResult = "";
  1867. if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.BOOL.ToString()))
  1868. {
  1869. operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  1870. }
  1871. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.SHORT.ToString()))
  1872. {
  1873. operateResult = s7.ReadInt16(actionAddress.Address).Content.ToString();
  1874. }
  1875. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.String.ToString()))
  1876. {
  1877. operateResult = s7.ReadString(actionAddress.Address).Content.ToString();
  1878. }
  1879. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.Byte.ToString()))
  1880. {
  1881. operateResult = s7.ReadByte(actionAddress.Address).Content.ToString();
  1882. }
  1883. map.Add("par"+1, operateResult);
  1884. }
  1885. responseData.returnData = JsonConvert.SerializeObject(map, Formatting.Indented);
  1886. //查询需要写入地址列表
  1887. List<CcsActionAddress> CcsActionAddressWrites = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.WRITE.ToString()).ToList();
  1888. foreach (CcsActionAddress actionAddress in CcsActionAddressWrites)
  1889. {
  1890. if (!string.IsNullOrEmpty(actionAddress.Address))
  1891. {
  1892. string parValue = "";
  1893. if (actionAddress.Sort == 1)
  1894. {
  1895. parValue = actionAddress.Value;
  1896. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  1897. }
  1898. else if (actionAddress.Sort == 2)
  1899. {
  1900. parValue = actionAddress.Value;
  1901. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  1902. }
  1903. // 同步TagValue数据状态
  1904. CcsTagValue tagValueQuery = new CcsTagValue();
  1905. tagValueQuery.Ip = reqs.url;
  1906. tagValueQuery.Address = actionAddress.Address;
  1907. CcsTagValue tagValue = _ccsTagValueService.GetList(tagValueQuery).ToList().FirstOrDefault();
  1908. if (tagValue != null)
  1909. {
  1910. tagValue.TagValue = parValue;
  1911. await _ccsTagValueService.Update(tagValue);
  1912. }
  1913. Thread.Sleep(SLEEP_TIME);
  1914. }
  1915. }
  1916. s7.ConnectClose();
  1917. Log.Instance.WriteLogAdd(EnumHelper.GetDescription(ActionTypeEnum.RfidRead) + "取成功===>>" + JsonConvert.SerializeObject(reqs)
  1918. , EnumHelper.GetDescription(ActionTypeEnum.RfidRead));
  1919. return responseData;
  1920. }
  1921. catch (Exception ex)
  1922. {
  1923. s7.ConnectClose();
  1924. Log.Instance.WriteLogAdd(ActionTypeEnum.RfidRead + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(reqs),
  1925. EnumHelper.GetDescription(ActionTypeEnum.RfidRead));
  1926. responseData.resultMsg = ActionTypeEnum.RfidRead + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(reqs);
  1927. responseData.result = "false";
  1928. return responseData;
  1929. }
  1930. }
  1931. public async Task<ResponseECSData> rfidReset(RequestData<RequestToolData> reqs)
  1932. {
  1933. Log.Instance.WriteLogAdd("rfid重置===>> " + JsonConvert.SerializeObject(reqs), "查询rfid数据");
  1934. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  1935. ResponseECSData responseData = new ResponseECSData(reqs.taskId, reqs.taskNodeId, "执行成功");
  1936. SiemensS7Net s7 = null;
  1937. try
  1938. {
  1939. // 获取所有在线的设备
  1940. List<Device> devices = _deviceService.GetDeviceList();
  1941. // 比较在线设备是否在其中
  1942. Device device = devices.Where(x => x.Ip == reqs.url && x.Port == reqs.port).FirstOrDefault();
  1943. if (device == null)
  1944. {
  1945. Log.Instance.WriteLogAdd(ActionTypeEnum.RfidReset + "设备已离线===>>" + JsonConvert.SerializeObject(reqs),
  1946. EnumHelper.GetDescription(ActionTypeEnum.RfidReset));
  1947. responseData.result = "false";
  1948. responseData.resultMsg = "设备已离线:" + reqs.url;
  1949. return responseData;
  1950. }
  1951. // 根据ip查询设备
  1952. CcsAction actionQuery = new CcsAction();
  1953. actionQuery.OperateType = ActionTypeEnum.RfidReset.ToString();
  1954. actionQuery.Ip = reqs.url;
  1955. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  1956. // 进行plc的连接
  1957. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  1958. OperateResult ConnectionResult = s7.ConnectServer();
  1959. if (!ConnectionResult.IsSuccess)
  1960. {
  1961. s7.ConnectClose();
  1962. Log.Instance.WriteLogAdd(ActionTypeEnum.RfidReset + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(reqs),
  1963. EnumHelper.GetDescription(ActionTypeEnum.RfidReset));
  1964. responseData.result = "false";
  1965. responseData.resultMsg = ActionTypeEnum.RfidReset + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(reqs);
  1966. return responseData;
  1967. }
  1968. // 查询需要操作的plc的db块
  1969. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  1970. actionAddressQuery.ActionId = actionInfo.Id;
  1971. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  1972. //查询需要写入地址列表
  1973. List<CcsActionAddress> CcsActionAddressWrites = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.WRITE.ToString()).ToList();
  1974. foreach (CcsActionAddress actionAddress in CcsActionAddressWrites)
  1975. {
  1976. if (!string.IsNullOrEmpty(actionAddress.Address))
  1977. {
  1978. string parValue = "";
  1979. if (actionAddress.Sort == 1)
  1980. {
  1981. parValue = actionAddress.Value;
  1982. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  1983. }
  1984. else if (actionAddress.Sort == 2)
  1985. {
  1986. parValue = actionAddress.Value;
  1987. s7.Write(actionAddress.Address, Convert.ToBoolean(parValue));
  1988. }
  1989. // 同步TagValue数据状态
  1990. CcsTagValue tagValueQuery = new CcsTagValue();
  1991. tagValueQuery.Ip = reqs.url;
  1992. tagValueQuery.Address = actionAddress.Address;
  1993. CcsTagValue tagValue = _ccsTagValueService.GetList(tagValueQuery).ToList().FirstOrDefault();
  1994. if (tagValue != null)
  1995. {
  1996. tagValue.TagValue = parValue;
  1997. await _ccsTagValueService.Update(tagValue);
  1998. }
  1999. Thread.Sleep(SLEEP_TIME);
  2000. }
  2001. }
  2002. s7.ConnectClose();
  2003. Log.Instance.WriteLogAdd(EnumHelper.GetDescription(ActionTypeEnum.RfidReset) + "取成功===>>" + JsonConvert.SerializeObject(reqs)
  2004. , EnumHelper.GetDescription(ActionTypeEnum.RfidReset));
  2005. return responseData;
  2006. }
  2007. catch (Exception ex)
  2008. {
  2009. s7.ConnectClose();
  2010. Log.Instance.WriteLogAdd(ActionTypeEnum.RfidReset + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(reqs),
  2011. EnumHelper.GetDescription(ActionTypeEnum.RfidReset));
  2012. responseData.resultMsg = ActionTypeEnum.RfidReset + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(reqs);
  2013. responseData.result = "false";
  2014. return responseData;
  2015. }
  2016. }
  2017. /// <summary>
  2018. /// 查询刀具上下料站、机床刀具位是否允许取
  2019. /// </summary>
  2020. /// <returns></returns>
  2021. public async Task<ResponseECSData> getCutterDeviceIsTake(RequestData<RequestToolData> req)
  2022. {
  2023. Log.Instance.WriteLogAdd("查询刀具上下料站、机床刀具位是否允许取===>> " + JsonConvert.SerializeObject(req), "刀具取放状态");
  2024. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  2025. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "允许下料");
  2026. SiemensS7Net s7 = null;
  2027. try
  2028. {
  2029. // 获取所有在线的设备
  2030. List<Device> devices = _deviceService.GetDeviceList();
  2031. // 比较在线设备是否在其中
  2032. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  2033. if (device == null)
  2034. {
  2035. Log.Instance.WriteLogAdd("CutterTake" + req.data.location + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  2036. "刀具取放状态");
  2037. responseData.result = "false";
  2038. responseData.resultMsg = "设备已离线:" + req.url;
  2039. return responseData;
  2040. }
  2041. // 根据ip查询配置的字节数据
  2042. CcsAction actionQuery = new CcsAction();
  2043. actionQuery.OperateType = "CutterTake" + req.data.location.ToString();
  2044. actionQuery.Ip = req.url;
  2045. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  2046. if (actionInfo == null)
  2047. {
  2048. Log.Instance.WriteLogAdd("CutterPut" + req.data.location + "异常===>>" + "没有查询到配置方法,默认通过" + JsonConvert.SerializeObject(req),
  2049. "刀具取放状态");
  2050. responseData.result = "true";
  2051. responseData.resultMsg = "CutterPut" + req.data.location + "异常===>>" + "没有查询到配置方法,默认通过" + JsonConvert.SerializeObject(req);
  2052. return responseData;
  2053. }
  2054. // 进行plc的连接
  2055. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  2056. OperateResult ConnectionResult = s7.ConnectServer();
  2057. if (!ConnectionResult.IsSuccess)
  2058. {
  2059. s7.ConnectClose();
  2060. Log.Instance.WriteLogAdd("CutterTake" + req.data.location + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  2061. "刀具取放状态");
  2062. responseData.result = "false";
  2063. responseData.resultMsg = "CutterTake" + req.data.location + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  2064. return responseData;
  2065. }
  2066. //=========================上下料站请求判断 开始======================
  2067. // 目标点位是上下料站的判断下料请求是否为true,上料请求为false,
  2068. // 如果不是判断上料请求是否为true,
  2069. // 是提示状态不对,否则写下料请求状态
  2070. // 下料允许
  2071. if (cutterTakeRequest.ContainsKey(req.data.location))
  2072. {
  2073. string shangliaoqingqiuDB = cutterPutRequest[req.data.location];
  2074. string xialiaoqingqiuDB = cutterTakeRequest[req.data.location];
  2075. string shangliaoyunxuDB = cutterPutStatus[req.data.location];
  2076. string xialiaoyunxuDB = cutterTakeStatus[req.data.location];
  2077. string shangliaoqingqiu = s7.ReadBool(shangliaoqingqiuDB).Content.ToString();
  2078. string xialiaoqingqiu = s7.ReadBool(xialiaoqingqiuDB).Content.ToString();
  2079. string shangliaoyunxu = s7.ReadBool(shangliaoyunxuDB).Content.ToString();
  2080. string xialiaoyunxu = s7.ReadBool(xialiaoyunxuDB).Content.ToString();
  2081. if (shangliaoqingqiu == "False" && xialiaoqingqiu == "False")
  2082. {
  2083. s7.Write(xialiaoqingqiuDB, true);
  2084. s7.ConnectClose();
  2085. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已发送下料请求,等待下料允许====" + JsonConvert.SerializeObject(req),
  2086. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  2087. responseData.result = "false";
  2088. responseData.resultMsg = "已发送下料请求,等待下料允许";
  2089. return responseData;
  2090. }
  2091. else if (shangliaoqingqiu == "True" && xialiaoqingqiu == "False")
  2092. {
  2093. s7.ConnectClose();
  2094. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====状态不对,现在上料请求状态,等待上料任务完成====" + JsonConvert.SerializeObject(req),
  2095. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  2096. responseData.result = "false";
  2097. responseData.resultMsg = "已被上料请求占用,等待上料任务完成";
  2098. return responseData;
  2099. }
  2100. else if (xialiaoqingqiu == "True" && xialiaoyunxu == "False")
  2101. {
  2102. s7.ConnectClose();
  2103. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已经发送下料请求,下料允许状态不满足====" + JsonConvert.SerializeObject(req),
  2104. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  2105. responseData.result = "false";
  2106. responseData.resultMsg = "已经发送下料请求,下料允许状态不满足";
  2107. return responseData;
  2108. }
  2109. }
  2110. //=========================上下料站请求判断 结束======================
  2111. // 查询需要操作的plc的db块
  2112. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  2113. actionAddressQuery.ActionId = actionInfo.Id;
  2114. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  2115. //查询出需要检查的地址列表
  2116. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  2117. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  2118. {
  2119. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  2120. {
  2121. string operateResult = "";
  2122. if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.BOOL.ToString()))
  2123. {
  2124. operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  2125. }
  2126. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.SHORT.ToString()))
  2127. {
  2128. operateResult = s7.ReadInt16(actionAddress.Address).Content.ToString();
  2129. }
  2130. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.String.ToString()))
  2131. {
  2132. operateResult = s7.ReadString(actionAddress.Address).Content.ToString();
  2133. }
  2134. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.Byte.ToString()))
  2135. {
  2136. operateResult = s7.ReadByte(actionAddress.Address).Content.ToString();
  2137. }
  2138. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  2139. {
  2140. s7.ConnectClose();
  2141. Log.Instance.WriteLogAdd("CutterTake" + req.data.location + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(req),
  2142. "刀具取放状态");
  2143. responseData.result = "false";
  2144. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  2145. return responseData;
  2146. }
  2147. }
  2148. }
  2149. // 关闭连接
  2150. s7.ConnectClose();
  2151. }
  2152. catch (Exception ex)
  2153. {
  2154. // 关闭连接
  2155. s7.ConnectClose();
  2156. Log.Instance.WriteLogAdd("CutterTake" + req.data.location + "任务下发异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  2157. "刀具取放状态");
  2158. responseData.result = "false";
  2159. responseData.resultMsg = ex.Message;
  2160. return responseData;
  2161. }
  2162. return responseData;
  2163. }
  2164. /// <summary>
  2165. /// 查询刀具上下料站、机床刀具位是否允许放
  2166. /// </summary>
  2167. /// <returns></returns>
  2168. public async Task<ResponseECSData> getCutterDeviceIsPut(RequestData<RequestToolData> req)
  2169. {
  2170. Log.Instance.WriteLogAdd("查询刀具上下料站、机床刀具位是否允许放===>> " + JsonConvert.SerializeObject(req), "刀具取放状态");
  2171. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  2172. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "允许下料");
  2173. SiemensS7Net s7 = null;
  2174. try
  2175. {
  2176. // 获取所有在线的设备
  2177. List<Device> devices = _deviceService.GetDeviceList();
  2178. // 比较在线设备是否在其中
  2179. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  2180. if (device == null)
  2181. {
  2182. Log.Instance.WriteLogAdd("CutterPut" + req.data.location + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  2183. "刀具取放状态");
  2184. responseData.result = "false";
  2185. responseData.resultMsg = "设备已离线:" + req.url;
  2186. return responseData;
  2187. }
  2188. // 根据ip查询配置的字节数据
  2189. CcsAction actionQuery = new CcsAction();
  2190. actionQuery.OperateType = "CutterPut" + req.data.location.ToString();
  2191. actionQuery.Ip = req.url;
  2192. CcsAction actionInfo = _ccsActionService.GetList(actionQuery).FirstOrDefault();
  2193. if (actionInfo == null) {
  2194. Log.Instance.WriteLogAdd("CutterPut" + req.data.location + "异常===>>" + "没有查询到配置方法,默认通过" + JsonConvert.SerializeObject(req),
  2195. "刀具取放状态");
  2196. responseData.result = "true";
  2197. responseData.resultMsg = "CutterPut" + req.data.location + "异常===>>" + "没有查询到配置方法,默认通过" + JsonConvert.SerializeObject(req);
  2198. return responseData;
  2199. }
  2200. // 进行plc的连接
  2201. s7 = DevicePlcS7.SiemensS7(actionInfo.Ip);
  2202. OperateResult ConnectionResult = s7.ConnectServer();
  2203. if (!ConnectionResult.IsSuccess)
  2204. {
  2205. s7.ConnectClose();
  2206. Log.Instance.WriteLogAdd("CutterPut" + req.data.location + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req),
  2207. "刀具取放状态");
  2208. responseData.result = "false";
  2209. responseData.resultMsg = "CutterPut" + req.data.location + "异常===>>" + "PLC连接不上" + JsonConvert.SerializeObject(req);
  2210. return responseData;
  2211. }
  2212. //=========================上下料站请求判断 开始======================
  2213. // 目标点位是上下料站的判断下料请求是否为true,上料请求为false,
  2214. // 如果不是判断上料请求是否为true,
  2215. // 是提示状态不对,否则写下料请求状态
  2216. // 上料料请求
  2217. if (cutterPutRequest.ContainsKey(req.data.location))
  2218. {
  2219. string shangliaoqingqiuDB = cutterPutRequest[req.data.location];
  2220. string xialiaoqingqiuDB = cutterTakeRequest[req.data.location];
  2221. string shangliaoyunxuDB = cutterPutStatus[req.data.location];
  2222. string xialiaoyunxuDB = cutterTakeStatus[req.data.location];
  2223. string shangliaoqingqiu = s7.ReadBool(shangliaoqingqiuDB).Content.ToString();
  2224. string xialiaoqingqiu = s7.ReadBool(xialiaoqingqiuDB).Content.ToString();
  2225. string shangliaoyunxu = s7.ReadBool(shangliaoyunxuDB).Content.ToString();
  2226. string xialiaoyunxu = s7.ReadBool(xialiaoyunxuDB).Content.ToString();
  2227. if (shangliaoqingqiu == "False" && xialiaoqingqiu == "False")
  2228. {
  2229. s7.Write(shangliaoqingqiuDB, true);
  2230. s7.ConnectClose();
  2231. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已发送上料请求,等待上料允许====" + JsonConvert.SerializeObject(req),
  2232. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  2233. responseData.result = "false";
  2234. responseData.resultMsg = "已发送上料请求,等待上料允许";
  2235. return responseData;
  2236. }
  2237. else if (shangliaoqingqiu == "False" && xialiaoqingqiu == "True")
  2238. {
  2239. s7.ConnectClose();
  2240. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====状态不对,现在下料请求状态,等待下料任务完成====" + JsonConvert.SerializeObject(req),
  2241. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  2242. responseData.result = "false";
  2243. responseData.resultMsg = "已被下料请求占用,等待下料任务完成";
  2244. return responseData;
  2245. }
  2246. else if (shangliaoqingqiu == "True" && shangliaoyunxu == "False")
  2247. {
  2248. s7.ConnectClose();
  2249. Log.Instance.WriteLogAdd(ActionTypeEnum.CutterRobotAction + "====已经发送上料请求,上料允许状态不满足====" + JsonConvert.SerializeObject(req),
  2250. EnumHelper.GetDescription(ActionTypeEnum.CutterRobotAction));
  2251. responseData.result = "false";
  2252. responseData.resultMsg = "已经发送上料请求,上料允许状态不满";
  2253. return responseData;
  2254. }
  2255. }
  2256. //=========================上下料站请求判断 结束======================
  2257. // 查询需要操作的plc的db块
  2258. CcsActionAddress actionAddressQuery = new CcsActionAddress();
  2259. actionAddressQuery.ActionId = actionInfo.Id;
  2260. List<CcsActionAddress> CcsActionAddresses = _ccsActionAddressService.GetList(actionAddressQuery);
  2261. //查询出需要检查的地址列表
  2262. List<CcsActionAddress> CcsActionAddressChecks = CcsActionAddresses.Where(o => o.Type == ActionAddressTypeEnum.CHECK.ToString()).ToList();
  2263. foreach (CcsActionAddress actionAddress in CcsActionAddressChecks)
  2264. {
  2265. if (!string.IsNullOrEmpty(actionAddress.Address) && !string.IsNullOrEmpty(actionAddress.Value))
  2266. {
  2267. string operateResult = "";
  2268. if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.BOOL.ToString()))
  2269. {
  2270. operateResult = s7.ReadBool(actionAddress.Address).Content.ToString();
  2271. }
  2272. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.SHORT.ToString()))
  2273. {
  2274. operateResult = s7.ReadInt16(actionAddress.Address).Content.ToString();
  2275. }
  2276. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.String.ToString()))
  2277. {
  2278. operateResult = s7.ReadString(actionAddress.Address).Content.ToString();
  2279. }
  2280. else if (actionAddress.AddressType.Equals(TagValueReadTypeEnum.Byte.ToString()))
  2281. {
  2282. operateResult = s7.ReadByte(actionAddress.Address).Content.ToString();
  2283. }
  2284. if (actionAddress.CheckType ? operateResult != actionAddress.Value : operateResult == actionAddress.Value)
  2285. {
  2286. s7.ConnectClose();
  2287. Log.Instance.WriteLogAdd("CutterPut" + req.data.location + "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "====实际为:" + operateResult + JsonConvert.SerializeObject(req),
  2288. "刀具取放状态");
  2289. responseData.result = "false";
  2290. responseData.resultMsg = "异常===>>" + "条件不满足" + actionAddress.Address + "值应为:" + actionAddress.Value + "==实际为:" + operateResult;
  2291. return responseData;
  2292. }
  2293. }
  2294. }
  2295. // 关闭连接
  2296. s7.ConnectClose();
  2297. }
  2298. catch (Exception ex)
  2299. {
  2300. // 关闭连接
  2301. s7.ConnectClose();
  2302. Log.Instance.WriteLogAdd("CutterPut" + req.data.location + "任务下发异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  2303. "刀具取放状态");
  2304. responseData.result = "false";
  2305. responseData.resultMsg = ex.Message;
  2306. return responseData;
  2307. }
  2308. return responseData;
  2309. }
  2310. public async Task<ResponseECSData> setWriteTakeCutter(RequestData<CutterTestData> req)
  2311. {
  2312. Log.Instance.WriteLogAdd("设置刀具取状态===>> " + JsonConvert.SerializeObject(req), "设置刀具取状态");
  2313. // 1、根据url查询设备信息 2、调用httpserveer 发送执行消息
  2314. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "设置刀具取状态");
  2315. try
  2316. {
  2317. // 获取所有在线的设备
  2318. List<Device> devices = _deviceService.GetDeviceList();
  2319. // 比较在线设备是否在其中
  2320. Device device = devices.Where(x => x.Ip == req.url && x.Port == req.port).FirstOrDefault();
  2321. if (device == null)
  2322. {
  2323. Log.Instance.WriteLogAdd("设备已离线===>>" + JsonConvert.SerializeObject(req),
  2324. "设置刀具取状态");
  2325. responseData.result = "false";
  2326. responseData.resultMsg = "设备已离线:" + req.url;
  2327. return responseData;
  2328. }
  2329. // 调用httpserver 设置参数
  2330. if (null != device && device.ProtocolType == "HEIDEHAIN")
  2331. {
  2332. RequestHeidhData hdhReq = new RequestHeidhData();
  2333. hdhReq.ServerUrl = device.ServerUrl;
  2334. hdhReq.MachineName = device.UserName;
  2335. hdhReq.Type = "WriteTakeCutter";
  2336. hdhReq.CutterData = JsonConvert.SerializeObject(req.data);
  2337. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  2338. ResponseHeidhData responseHeidhData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  2339. if (!Result.IsSuccess || !responseHeidhData.result)
  2340. {
  2341. Log.Instance.WriteLogAdd(ActionTypeEnum.WriteDeviationValue + "设置失败===>>" + JsonConvert.SerializeObject(req) + "======结果数据:" + Result, "设置刀具取状态");
  2342. responseData.result = "false";
  2343. responseData.resultMsg = Result.Message;
  2344. return responseData;
  2345. }
  2346. else
  2347. {
  2348. responseData.result = "true";
  2349. responseData.resultMsg = "消费成功";
  2350. }
  2351. }
  2352. }
  2353. catch (Exception ex)
  2354. {
  2355. // 关闭连接
  2356. Log.Instance.WriteLogAdd("任务执行异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  2357. "设置刀具取状态");
  2358. responseData.result = "false";
  2359. responseData.resultMsg = ex.Message;
  2360. }
  2361. return responseData;
  2362. }
  2363. public async Task<ResponseECSData> sendTheBindingInfo(RequestData<BindInfo> req)
  2364. {
  2365. ResponseECSData responseData = new ResponseECSData(req.taskId, req.taskNodeId, "设置成功");
  2366. try
  2367. {
  2368. List<Device> devices = _deviceService.GetDeviceList();
  2369. Device deviceHeidenhain = devices.Where(x => x.Ip.Equals(req.url)
  2370. && x.ProtocolType.Equals(ProtocalTypeEnum.HEIDEHAIN.ToString())).FirstOrDefault();
  2371. if (deviceHeidenhain == null)
  2372. {
  2373. Log.Instance.WriteLogAdd(ActionTypeEnum.BindingInfo + "设备已离线===>>" + JsonConvert.SerializeObject(req),
  2374. EnumHelper.GetDescription(ActionTypeEnum.BindingInfo));
  2375. responseData.result = "false";
  2376. responseData.resultMsg = ActionTypeEnum.BindingInfo + "设备已离线===>>" + JsonConvert.SerializeObject(req);
  2377. return responseData;
  2378. }
  2379. if (deviceHeidenhain != null)
  2380. {
  2381. RequestHeidhData hdhReq = new RequestHeidhData();
  2382. hdhReq.ServerUrl = deviceHeidenhain.ServerUrl;
  2383. hdhReq.MachineName = deviceHeidenhain.UserName;
  2384. hdhReq.Type = OpcUaActionTypeEnum.BindingInfo.ToString();
  2385. hdhReq.BindInfo = JsonConvert.SerializeObject(req.data);
  2386. var Result = await _apiRequestService.RequestAsync(RequsetModeEnum.Post, hdhUrlContext, hdhReq, null);
  2387. ResponseHeidhData responseHeidhData = JsonConvert.DeserializeObject<ResponseHeidhData>(Result.Message);
  2388. if (!Result.IsSuccess || !responseHeidhData.result)
  2389. {
  2390. Log.Instance.WriteLogAdd(ActionTypeEnum.BindingInfo + "绑定数据设置失败===>>" + JsonConvert.SerializeObject(req) + "======结果数据:" + Result, "设备绑定数据设置");
  2391. responseData.result = "false";
  2392. responseData.resultMsg = Result.Message;
  2393. return responseData;
  2394. }
  2395. else
  2396. {
  2397. responseData.result = "true";
  2398. responseData.resultMsg = "消费成功";
  2399. }
  2400. }
  2401. else
  2402. {
  2403. responseData.result = "false";
  2404. responseData.resultMsg = "没找到对应的类型方法";
  2405. return responseData;
  2406. }
  2407. //插入回调
  2408. TaskCallback taskCallbackData = new TaskCallback(req.url, ActionTypeEnum.BindingInfo.ToString(),
  2409. EnumHelper.GetDescription(ActionTypeEnum.BindingInfo), req.taskId, req.taskNodeId);
  2410. await _taskCallbackService.CreateOrUpdateAndCache(taskCallbackData);
  2411. Log.Instance.WriteLogAdd(ActionTypeEnum.BindingInfo + "设置成功===>>" + JsonConvert.SerializeObject(req),
  2412. EnumHelper.GetDescription(ActionTypeEnum.BindingInfo));
  2413. return responseData;
  2414. }
  2415. catch (Exception ex)
  2416. {
  2417. Log.Instance.WriteLogAdd(ActionTypeEnum.BindingInfo + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(req),
  2418. EnumHelper.GetDescription(ActionTypeEnum.BindingInfo));
  2419. responseData.resultMsg = ActionTypeEnum.BindingInfo + "设置异常===>>" + ex.Message + JsonConvert.SerializeObject(req);
  2420. responseData.result = "false";
  2421. return responseData;
  2422. }
  2423. }
  2424. }
  2425. }