123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275 |
- using PhihongEv.Lib;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- namespace MesAdaptor
- {
- public class SajectConnectSajet : ISajetConnect
- {
- private enum CMD
- {
- Signin = 1,
- SnCheck = 2,
- WoCheck = -1,
- Report = 3,
- Log = 4,
- HeaderRegister = 8,
- ValueReport = 5,
- StringValueReport = 6,
- }
- public bool SajetTransStart() => SajetConnectAdapter.SajetTransStart();
- public bool SajetTransClose() => SajetConnectAdapter.SajetTransClose();
- private string userId = "";
- public bool SajetTransSignIn(ref string data)
- {
- var attemptId = data;
- if (SajetTransData(CMD.Signin, ref data))
- {
- if (string.IsNullOrEmpty(data) || data.StartsWith("NG"))
- {
- userId = "";
- return false;
- }
- else
- {
- userId = attemptId;
- return true;
- }
- }
- userId = "";
- return false;
- }
- private string WorkOrder = "";
- public bool SajetTransWoCheck(ref string workOrder)
- {
- return true;
- }
- private string SN;
- public bool SajetTransSnCheck(ref string serialNumber)
- {
- var attemptSN = serialNumber;
- var msg = serialNumber;
- if (SajetTransData(CMD.SnCheck, ref msg))
- {
- if (string.IsNullOrEmpty(msg) || msg.StartsWith("NG"))
- {
- SN = "";
- return false;
- }
- else
- {
- SN = attemptSN;
- return true;
- }
- }
- SN = "";
- return false;
- }
- public bool SajetTranFinishSuccess()
- {
- if (string.IsNullOrEmpty(userId))
- return false;
- if (string.IsNullOrEmpty(SN))
- return false;
- string msg = userId + ";" + SN + ";";
- if (string.IsNullOrEmpty(msg))
- return false;
- msg += "OK";
- #if DEBUG
- return true;
- #endif
- return SajetTransData(CMD.Report, ref msg);
- }
- public bool SajetTranFinishFail(MesErrorCode errorCode)
- {
- if (string.IsNullOrEmpty(userId))
- return false;
- if (string.IsNullOrEmpty(SN))
- return false;
- string msg = userId + ";" + SN + ";";
- if (string.IsNullOrEmpty(msg))
- return false;
- msg += $"NG;{errorCode};"; //E114
- #if DEBUG
- return true;
- #endif
- return SajetTransData(CMD.Report, ref msg);
- }
- public string SajetTransRegisterHeader(string model, string header)
- {
- if (string.IsNullOrEmpty(userId))
- return "";
- var msg = userId + ";";
- msg += model + ";" + header;
- if (SajetTransData(CMD.HeaderRegister, ref msg))
- {
- if (msg.StartsWith("OK"))
- {
- //get codename
- msg = msg.Substring(3);
- var spaceIndex = msg.IndexOf(";");
- if (spaceIndex > 0)
- {
- msg = msg.Substring(0, spaceIndex);
- }
- return msg;
- }
- return null;
- }
- return null;
- }
- public bool SajetTransReport(ValueReportDatas reportPair)
- {
- //build header
- Dictionary<string, int> valuePairs = new Dictionary<string, int>();
- foreach (var data in reportPair)
- {
- if (int.TryParse(data.Val, out int val))
- {
- valuePairs.Add(data.Key, val);
- }
- else if (data.Val.ToLower().Contains("fail"))
- {
- valuePairs.Add(data.Key, 0);
- }
- else if (data.Val.ToLower().Contains("success"))
- {
- valuePairs.Add(data.Key, 1);
- }
- else
- {
- valuePairs.Add(string.Format("{0}:{1}", data.Key, data.Val), 1);
- }
- }
- //register Header
- var codePair = new Dictionary<string, string>();
- string model = "";
- if (SystemID.TryParse(SN,out var systemID))
- {
- model = systemID.ModelName.ToString();
- }
- foreach (var key in valuePairs.Keys)
- {
- var code = SajetTransRegisterHeader(model, key);
- if (string.IsNullOrEmpty(code))
- continue;
- codePair.Add(key, code);
- }
- //report value
- var reportResult = SajetTransReport(valuePairs, codePair);
- return reportResult;
- }
- public bool SajetTransReport(Dictionary<string, int> resultPair, Dictionary<string, string> codePair)
- {
- if (string.IsNullOrEmpty(userId))
- return false;
- if (string.IsNullOrEmpty(SN))
- return false;
- string msgHeader = userId + ";" + SN;
- string msg = "";
- foreach (var result in resultPair)
- {
- if (codePair.Keys.Contains(result.Key))
- {
- msg = string.Format("{0};{1}:{2};",msgHeader, codePair[result.Key], string.Format("{0}.00", result.Value));
- //msg += string.Format(";{0}:{1}", codePair[result.Key], string.Format("{0}.00", result.Value));
- }
- //msg += ";";
- SajetTransData(CMD.ValueReport, ref msg);
- //msg = userId + ";" + SN;
- }
- //msg += ";";
- return true;
- }
- public bool SajetTransReport(Dictionary<string, string> resultPair, Dictionary<string, string> codePair)
- {
- if (string.IsNullOrEmpty(userId))
- return false;
- if (string.IsNullOrEmpty(SN))
- return false;
- string msg = userId + ";" + SN;
- foreach (var result in resultPair)
- {
- if (codePair.Keys.Contains(result.Key))
- {
- msg += string.Format(";{0}:{1}", codePair[result.Key], string.Format("{0}.00", result.Value));
- }
- msg += ";";
- SajetTransData(CMD.StringValueReport, ref msg);
- msg = userId + ";" + SN;
- }
- msg += ";";
- return true;
- }
- public bool SajetTransLog(string data)
- {
- return true;
- if (string.IsNullOrEmpty(userId))
- return false;
- if (string.IsNullOrEmpty(SN))
- return false;
- string prefix = userId + ";" + SN + ";";
- while (data.Length > 0)
- {
- var msg = prefix;
- int sendLength = Math.Min(250 - msg.Length, data.Length);
- var sendString = data.Substring(0, sendLength);
- msg += sendString;
- if (!SajetTransData(CMD.Log, ref msg))
- {
- break;
- }
- data = data.Substring(sendLength);
- }
- return data.Length == 0;
- }
- private bool SajetTransData(CMD command, ref string data)
- {
- return SajetConnectAdapter.SajetTransData((int)command, ref data);
- }
- private string GetSendPrefix()
- {
- string msg = "";
- if (string.IsNullOrEmpty(userId))
- {
- return null;
- }
- msg = userId + ";";
- if (string.IsNullOrEmpty(WorkOrder))
- {
- return null;
- }
- msg += WorkOrder + ";";
- return msg;
- }
- }
- }
|