This repo is archived. You can view files and clone it, but cannot push or open issues or pull requests.
SXS20240115/SRC/wsSXS/wsENT_21684/wsENT_21684.cs
2024-01-17 16:05:54 +08:00

1083 lines
48 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System;
using System.Data;
using System.Web.Services;
using Microsoft.VisualBasic;
using Microsoft.VisualBasic.CompilerServices;
using static iMESCore.Base.iMESComXML;
using static iMESCore.Base.iMESConst;
using static iMESCore.Base.iMESComSubroutine;
namespace wsSXS
{
public class wsENT_21684
{
private MEStc_SXS.clsENT21684 objENT = new MEStc_SXS.clsENT21684();
private kcSYS.clsSYSUserLog objSYS = new kcSYS.clsSYSUserLog(); // 宣告Sys的物件
//private kcBasis_UPD.clsBasis_UPD objBasis = new kcBasis_UPD.clsBasis_UPD(); //主檔優化
//private kcBasis_Query.clsBasis_Query objQuery = new kcBasis_Query.clsBasis_Query(); //主檔優化
private System.Xml.XmlDocument xmlDoc = new System.Xml.XmlDocument(); // 用以讀取Xml字串
private DateTime ArriveTime; // 送達時間
private string strIdentity; // Identity XML字串
private string strReturnValue; // ReturnValue XML字串
private string strException; // Exception XML字串
private string strResult; // Result XML字串
private string strMessage; // Message XML字串
private iMESCore.Settings.AppSettings objSetting = new iMESCore.Settings.AppSettings();
private string strResourceDir = "Resources";
public wsENT_21684()
{
try
{
strResourceDir = System.IO.Path.Combine("wsUpdateResource", objSetting["ResourceDir"].ToString());
}
catch (Exception)
{ }
}
#region --- Student ---
[WebMethod(Description = "Load Student Data")]
public string LoadStudent(string InXml)
{
string LoadStudentRet = default(string);
// 先給預設值,以判斷是否有傳入該參數
string StudentNo = defString;
int IssueState = 2;
ArriveTime = DateTime.Now;
string AdditionalXml = "";
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 判斷是否有傳入Student,若有,表示要依Student查詢
if (xmlDoc.DocumentElement.GetElementsByTagName("Studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("Studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("Studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// 判斷是否有傳入IssueState,若有,表示要依IssueState查詢
if (xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Count > 0)
{
if (xmlDoc.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Count > 0)
{
IssueState = Conversions.ToInteger(xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Item(0).InnerText);
}
}
// 呼叫副程式處理查詢條件與Additional格式
AdditionalXml = CombineXMLQueryAdditional(xmlDoc);
// 呼叫Dll執行
strReturnValue = objENT.LoadStudent(StudentNo, IssueState, AdditionalXml);
strException = "";
strResult = "success";
}
catch (iMESException.MESException ex)
{
strReturnValue = "";
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Show Student Failed!!", ex.StackTrace);
strResult = "fail";
}
catch (Exception ex)
{
strReturnValue = "";
strException = CombineXMLException(defWSErrCode, ex.Message, "Show Student Failed!!", ex.StackTrace);
strResult = "fail";
}
finally
{
// 將各部份之XML字串組起來並傳出
LoadStudentRet = CombineXMLResponse(strIdentity, strReturnValue, strException, strResult, "");
}
return LoadStudentRet;
}
[WebMethod(Description = "Add Student data")]
public string AddStudent(string InXml)
{
string AddStudentRet = default(string);
// 先給預設值,以判斷是否有傳入該參數
var StudentNo = default(string);
string StudentName;
string Score = defString;
string Creator = defString;
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 開始解譯InXml字串
// Student一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
if (xmlDoc.DocumentElement.GetElementsByTagName("studentname").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentname").Item(0).SelectNodes("value").Count > 0)
{
StudentName = xmlDoc.DocumentElement.GetElementsByTagName("studentname").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentName Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentName Not Found!");
}
// Score
if (xmlDoc.DocumentElement.GetElementsByTagName("score").Count > 0)
{
if (xmlDoc.GetElementsByTagName("score").Item(0).SelectNodes("value").Count > 0)
{
Score = xmlDoc.DocumentElement.GetElementsByTagName("score").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// Creator
if (xmlDoc.DocumentElement.GetElementsByTagName("creator").Count > 0)
{
if (xmlDoc.GetElementsByTagName("creator").Item(0).SelectNodes("value").Count > 0)
{
Creator = xmlDoc.DocumentElement.GetElementsByTagName("creator").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// 呼叫Dll執行新增資料
objENT.AddStudent(StudentNo, StudentName, Score, Creator);
strException = "";
strResult = "success";
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "AddStudent");
}
catch (iMESException.MESException ex)
{
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Add Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: Conversions.ToString(ex.ErrorCode));
}
catch (Exception ex)
{
strException = CombineXMLException(defWSErrCode, ex.Message, "Add Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: defWSErrCode);
}
finally
{
// 將各部份之XML字串組起來並傳出
AddStudentRet = CombineXMLResponse(strIdentity, "", strException, strResult, "");
}
return AddStudentRet;
}
[WebMethod(Description = "Edit Specified Student Data")]
public string EditStudent(string InXml)
{
string EditStudentRet = default(string);
// 參數先給預設值,以判斷是否有傳入該參數
var StudentNo = default(string);
int IssueState = defInteger;
string StudentName = defString;
string Score = defString;
int DataStamp = defInteger;
string AdditionalXml = "";
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 開始解譯InXml字串
// Student一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
// IssueState一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Count > 0)
{
if (xmlDoc.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Count > 0)
{
IssueState = Conversions.ToInteger(xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Item(0).InnerText);
}
else
{
throw new iMESException.MESException("0000-200002", "[%IssueState%]");
}
}
else
{
throw new iMESException.MESException("0000-200002", "[%IssueState%]");
}
// StudentName不可空白
if (xmlDoc.DocumentElement.GetElementsByTagName("studentname").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentname").Item(0).SelectNodes("value").Count > 0)
{
StudentName = xmlDoc.DocumentElement.GetElementsByTagName("studentname").Item(0).SelectNodes("value").Item(0).InnerText;
if (string.IsNullOrEmpty(StudentName))
{
throw new iMESException.MESException("0000-200001", "StudentName is empty!");
}
}
}
// Description
if (xmlDoc.DocumentElement.GetElementsByTagName("score").Count > 0)
{
if (xmlDoc.GetElementsByTagName("score").Item(0).SelectNodes("value").Count > 0)
{
Score = xmlDoc.DocumentElement.GetElementsByTagName("score").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// AdditionalXml
GetXMLTagValue(ref AdditionalXml, xmlDoc, "additionalxml");
// DataStamp
GetXMLTagValue(ref DataStamp, xmlDoc, "datastamp", true);
if (IssueState == 0) // Unfrozen時才可修改
{
// 有修改欄位值時
if ((StudentName ?? "") != defString | (Score ?? "") != defString)
{
// 呼叫Dll執行修改
objENT.EditStudent(StudentNo, StudentName, Score, AdditionalXml, DataStamp: DataStamp, Reviser: GetXMLCurUserNo(xmlDoc), ReviseDate: ArriveTime);
}
}
strException = "";
strResult = "success";
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "EditStudent");
}
catch (iMESException.MESException ex)
{
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Edit Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: Conversions.ToString(ex.ErrorCode));
}
catch (Exception ex)
{
strException = CombineXMLException(defWSErrCode, ex.Message, "Edit Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: defWSErrCode);
}
finally
{
// 將各部份之XML字串組起來並傳出
EditStudentRet = CombineXMLResponse(strIdentity, "", strException, strResult, "");
}
return EditStudentRet;
}
[WebMethod(Description = "Delete Student By Specified Student")]
public string DelStudent(string InXml)
{
string DelStudentRet = default(string);
var StudentNo = default(string);
int IssueState;
string strDelState; // 寫入tblSysEventLog中的訊息,0:未簽核刪除,2:已簽核刪除,-1:不使用刪除
int DataStamp = defInteger;
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 開始解譯InXml字串
// Student一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
// IssueState一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Count > 0)
{
if (xmlDoc.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Count > 0)
{
IssueState = Conversions.ToInteger(xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Item(0).InnerText);
}
else
{
throw new iMESException.MESException("0000-200002", "[%IssueState%]");
}
}
else
{
throw new iMESException.MESException("0000-200002", "[%IssueState%]");
}
// DataStamp
GetXMLTagValue(ref DataStamp, xmlDoc, "datastamp", true);
switch (IssueState)
{
case 0:
{
objENT.DelStudent(StudentNo);
strDelState = "未簽核刪除";
break;
}
case 2:
{
objENT.SetStudentIssueState(StudentNo, -1, DataStamp: DataStamp, Reviser: GetXMLCurUserNo(xmlDoc), ReviseDate: ArriveTime);
strDelState = "已簽核刪除";
break;
}
case -1:
{
objENT.DelStudent(StudentNo);
strDelState = "不使用刪除";
break;
}
default:
{
throw new iMESException.MESException("0000-200021", "[%IssueState%]");
}
}
strException = "";
strResult = "success";
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "DelStudent:" + strDelState);
}
catch (iMESException.MESException ex)
{
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Delete Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: Conversions.ToString(ex.ErrorCode));
}
catch (Exception ex)
{
strException = CombineXMLException(defWSErrCode, ex.Message, "Delete Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: defWSErrCode);
}
finally
{
DelStudentRet = CombineXMLResponse(strIdentity, "", strException, strResult, "");
}
return DelStudentRet;
}
[WebMethod(Description = "Approve Specified Student Data")]
public string ApproveStudent(string InXml)
{
string ApproveStudentRet = default(string);
string IssueNo = "Student BASIS"; // 簽核編號:Student BASIS.若找不到,表示直接將狀態改為Active.
var StudentNo = default(string);
int IssueState;
var objIssue = new kcISSUE.clsIssue();
DataRow IssueDR;
int DataStamp = defInteger;
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 開始解譯InXml字串
// Student一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
// IssueState一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Count > 0)
{
if (xmlDoc.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Count > 0)
{
IssueState = Conversions.ToInteger(xmlDoc.DocumentElement.GetElementsByTagName("issuestate").Item(0).SelectNodes("value").Item(0).InnerText);
}
else
{
throw new iMESException.MESException("0000-200002", "[%IssueState%]");
}
}
else
{
throw new iMESException.MESException("0000-200002", "[%IssueState%]");
}
// DataStamp
GetXMLTagValue(ref DataStamp, xmlDoc, "datastamp", true);
if (IssueState == 0) // 當狀態為Unfrozen時才作
{
// 去IssueManagement中找核准的方式
IssueDR = objIssue.GetIssueJobMap(IssueNo);
// 找不到表示bypass直接核准
if (IssueDR["JobNo"] is DBNull)
{
// 直接核准
objENT.SetStudentIssueState(StudentNo, 2, DataStamp: DataStamp, Reviser: GetXMLCurUserNo(xmlDoc), ReviseDate: ArriveTime);
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "ApproveStudent");
}
else
{
// 檢查JobNo是否有定義Detail檔,沒有Detail檔則直接核准
DataRow tmpDR;
tmpDR = objIssue.GetIssueJobDetail(Conversions.ToString(IssueDR["JobNo"]));
if (tmpDR["JobNo"] is DBNull)
{
objENT.SetStudentIssueState(StudentNo, 2, DataStamp: DataStamp, Reviser: GetXMLCurUserNo(xmlDoc), ReviseDate: ArriveTime);
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "ApproveStudent");
}
else
{
// 將狀態改為Pending,且應以找到的JobNo來進入簽核
// 填入簽核現況檔之Initial
var ApproveSQL = new Collection();
var RejectSQL = new Collection();
string tmpSQL;
string IssueSubject;
string IssueMasterNo;
// 核准後應將狀態改為Active
tmpSQL = "Update tblENTStudent Set IssueState = 2 Where StudentNo = '" + StudentNo + "'";
ApproveSQL.Add(tmpSQL);
// 退回則應將狀態回復到Unfrozen
tmpSQL = "Update tblENTStudent Set IssueState = 0 Where StudentNo = '" + StudentNo + "'";
RejectSQL.Add(tmpSQL);
// Creator未傳入表示以目前的User
string Creator;
if (xmlDoc.DocumentElement.GetElementsByTagName("creator").Count > 0)
{
if (xmlDoc.GetElementsByTagName("creator").Item(0).SelectNodes("value").Count > 0)
{
Creator = xmlDoc.DocumentElement.GetElementsByTagName("creator").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
Creator = GetXMLCurUserNo(xmlDoc);
}
}
else
{
Creator = GetXMLCurUserNo(xmlDoc);
}
IssueSubject = "StudentNo: " + StudentNo;
IssueMasterNo = objIssue.InitIssueMasterNo();
// 此筆資料進入Issue流程
objIssue.StartIssueProcess(IssueMasterNo, ApproveSQL, RejectSQL, IssueNo, IssueDR["JobNo"].ToString(), IssueSubject, Creator);
// 將狀態改為Pending
objENT.SetStudentIssueState(StudentNo, 1, DataStamp: DataStamp, Reviser: GetXMLCurUserNo(xmlDoc), ReviseDate: ArriveTime);
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "ApproveStudent");
// 發Email給JobSerialNo=1之負責群組
objIssue.SendEmailToFirstGroup(IssueMasterNo, IssueSubject);
}
}
}
strException = "";
strResult = "success";
}
catch (iMESException.MESException ex)
{
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Approve Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: Conversions.ToString(ex.ErrorCode));
}
catch (Exception ex)
{
strException = CombineXMLException(defWSErrCode, ex.Message, "Approve Student failed!", ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: defWSErrCode);
}
finally
{
// 將各部份之XML字串組起來並傳出
ApproveStudentRet = CombineXMLResponse(strIdentity, "", strException, strResult, "");
}
return ApproveStudentRet;
}
// Student parent
[WebMethod(Description = "Load Student parent Data")]
public string LoadStudentCont(string InXml)
{
string LoadStudentContRet = default(string);
// 先給預設值,以判斷是否有傳入該參數
string StudentNo = defString;
string parentName = defString;
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 判斷是否有傳入StudentNo,若有,表示要依StudentNo查詢
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
if (xmlDoc.DocumentElement.GetElementsByTagName("parentname").Count > 0)
{
if (xmlDoc.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Count > 0)
{
parentName = xmlDoc.DocumentElement.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// 呼叫Dll執行
strReturnValue = objENT.LoadStudentCont(StudentNo, parentName);
strException = "";
strResult = "success";
}
catch (iMESException.MESException ex)
{
strReturnValue = "";
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Show Student parent Failed!!", ex.StackTrace);
strResult = "fail";
}
catch (Exception ex)
{
strReturnValue = "";
strException = CombineXMLException(defWSErrCode, ex.Message, "Show Student parent Failed!!", ex.StackTrace);
strResult = "fail";
}
finally
{
// 將各部份之XML字串組起來並傳出
LoadStudentContRet = CombineXMLResponse(strIdentity, strReturnValue, strException, strResult, "");
}
return LoadStudentContRet;
}
[WebMethod(Description = "Add Student parent data")]
public string AddStudentCont(string InXml)
{
string AddStudentContRet = default(string);
// 先給預設值,以判斷是否有傳入該參數
var StudentNo = default(string);
var parentName = default(string);
string TelNo = defString;
string FaxNo = defString;
string Title = defString;
string Address = defString;
string EMail = defString;
string Description = defString;
string AdditionalXml = "";
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 開始解譯InXml字串
// StudentNo一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
// parentName一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("parentname").Count > 0)
{
if (xmlDoc.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Count > 0)
{
parentName = xmlDoc.DocumentElement.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "parentName Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "parentName Not Found!");
}
// TelNo
if (xmlDoc.DocumentElement.GetElementsByTagName("telno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("telno").Item(0).SelectNodes("value").Count > 0)
{
TelNo = xmlDoc.DocumentElement.GetElementsByTagName("telno").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// FaxNo
if (xmlDoc.DocumentElement.GetElementsByTagName("faxno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("faxno").Item(0).SelectNodes("value").Count > 0)
{
FaxNo = xmlDoc.DocumentElement.GetElementsByTagName("faxno").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// Title
if (xmlDoc.DocumentElement.GetElementsByTagName("title").Count > 0)
{
if (xmlDoc.GetElementsByTagName("title").Item(0).SelectNodes("value").Count > 0)
{
Title = xmlDoc.DocumentElement.GetElementsByTagName("title").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// Address
if (xmlDoc.DocumentElement.GetElementsByTagName("address").Count > 0)
{
if (xmlDoc.GetElementsByTagName("address").Item(0).SelectNodes("value").Count > 0)
{
Address = xmlDoc.DocumentElement.GetElementsByTagName("address").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// EMail
if (xmlDoc.DocumentElement.GetElementsByTagName("email").Count > 0)
{
if (xmlDoc.GetElementsByTagName("email").Item(0).SelectNodes("value").Count > 0)
{
EMail = xmlDoc.DocumentElement.GetElementsByTagName("email").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// Description
//if (xmlDoc.DocumentElement.GetElementsByTagName("description").Count > 0)
//{
// if (xmlDoc.GetElementsByTagName("description").Item(0).SelectNodes("value").Count > 0)
// {
// Description = xmlDoc.DocumentElement.GetElementsByTagName("description").Item(0).SelectNodes("value").Item(0).InnerText;
// }
//
//}
// AdditionalXml
GetXMLTagValue(ref AdditionalXml, xmlDoc, "additionalxml");
// 呼叫Dll執行新增資料
objENT.AddStudentCont(StudentNo, parentName, TelNo, FaxNo, Title, Address, EMail, Description, AdditionalXml, GetXMLCurUserNo(xmlDoc), ArriveTime);
strException = "";
strResult = "success";
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "AddStudentparent parentName:" + parentName);
}
catch (iMESException.MESException ex)
{
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Add Studentparent Data failed, parentName:" + parentName, ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: Conversions.ToString(ex.ErrorCode));
}
catch (Exception ex)
{
strException = CombineXMLException(defWSErrCode, ex.Message, "Add Studentparent Data failed, parentName:" + parentName, ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: defWSErrCode);
}
finally
{
// 將各部份之XML字串組起來並傳出
AddStudentContRet = CombineXMLResponse(strIdentity, "", strException, strResult, "");
}
return AddStudentContRet;
}
[WebMethod(Description = "Edit Specified Student parent Data")]
public string EditStudentCont(string InXml)
{
string EditStudentContRet = default(string);
// 先給預設值,以判斷是否有傳入該參數
var StudentNo = default(string);
var parentName = default(string);
string TelNo = defString;
string FaxNo = defString;
string Title = defString;
string Address = defString;
string EMail = defString;
//string Description = defString;
int DataStamp = defInteger;
string AdditionalXml = "";
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 開始解譯InXml字串
// StudentNo一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
// parentName一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("parentname").Count > 0)
{
if (xmlDoc.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Count > 0)
{
parentName = xmlDoc.DocumentElement.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "parentName Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "parentName Not Found!");
}
// TelNo
if (xmlDoc.DocumentElement.GetElementsByTagName("telno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("telno").Item(0).SelectNodes("value").Count > 0)
{
TelNo = xmlDoc.DocumentElement.GetElementsByTagName("telno").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// FaxNo
if (xmlDoc.DocumentElement.GetElementsByTagName("faxno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("faxno").Item(0).SelectNodes("value").Count > 0)
{
FaxNo = xmlDoc.DocumentElement.GetElementsByTagName("faxno").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// Title
if (xmlDoc.DocumentElement.GetElementsByTagName("title").Count > 0)
{
if (xmlDoc.GetElementsByTagName("title").Item(0).SelectNodes("value").Count > 0)
{
Title = xmlDoc.DocumentElement.GetElementsByTagName("title").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// Address
if (xmlDoc.DocumentElement.GetElementsByTagName("address").Count > 0)
{
if (xmlDoc.GetElementsByTagName("address").Item(0).SelectNodes("value").Count > 0)
{
Address = xmlDoc.DocumentElement.GetElementsByTagName("address").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// EMail
if (xmlDoc.DocumentElement.GetElementsByTagName("email").Count > 0)
{
if (xmlDoc.GetElementsByTagName("email").Item(0).SelectNodes("value").Count > 0)
{
EMail = xmlDoc.DocumentElement.GetElementsByTagName("email").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
// Description
//if (xmlDoc.DocumentElement.GetElementsByTagName("description").Count > 0)
//{
// if (xmlDoc.GetElementsByTagName("description").Item(0).SelectNodes("value").Count > 0)
// {
// Description = xmlDoc.DocumentElement.GetElementsByTagName("description").Item(0).SelectNodes("value").Item(0).InnerText;
// }
//}
// AdditionalXml
GetXMLTagValue(ref AdditionalXml, xmlDoc, "additionalxml");
// DataStamp
GetXMLTagValue(ref DataStamp, xmlDoc, "datastamp", true);
// If IssueState = 0 Then 'Unfrozen時才可修改
// 有修改欄位值時
if ((TelNo ?? "") != defString | (FaxNo ?? "") != defString | (Title ?? "") != defString | (Address ?? "") != defString | (EMail ?? "") != defString)
{
// 呼叫Dll執行修改
objENT.EditStudentCont(StudentNo, parentName, TelNo, FaxNo, Title, Address, EMail, AdditionalXml, DataStamp: DataStamp, Reviser: GetXMLCurUserNo(xmlDoc), ReviseDate: ArriveTime);
}
// End If
strException = "";
strResult = "success";
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "EditStudentparent parentName:" + parentName);
}
catch (iMESException.MESException ex)
{
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Edit Studentparent Data failed, parentName:" + parentName, ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: Conversions.ToString(ex.ErrorCode));
}
catch (Exception ex)
{
strException = CombineXMLException(defWSErrCode, ex.Message, "Edit Studentparent Data failed, parentName:" + parentName, ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: defWSErrCode);
}
finally
{
// 將各部份之XML字串組起來並傳出
EditStudentContRet = CombineXMLResponse(strIdentity, "", strException, strResult, "");
}
return EditStudentContRet;
}
[WebMethod(Description = "Delete Student parent By Specified StudentNo and parentName")]
public string DelStudentCont(string InXml)
{
string DelStudentContRet = default(string);
var StudentNo = default(string);
string parentName = defString; // 沒有傳入表示要刪除指定Student的所有parent
ArriveTime = DateTime.Now;
try
{
// 讀取InXml字串
xmlDoc.LoadXml(InXml);
// 組Identity字串
strIdentity = CombineXMLIdentity(Environment.MachineName, GetXMLCurUserNo(xmlDoc), Conversions.ToString(ArriveTime));
// 開始解譯InXml字串
// StudentNo一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("studentno").Count > 0)
{
if (xmlDoc.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Count > 0)
{
StudentNo = xmlDoc.DocumentElement.GetElementsByTagName("studentno").Item(0).SelectNodes("value").Item(0).InnerText;
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
}
else
{
throw new iMESException.MESException("0000-200002", "StudentNo Not Found!");
}
// parentName一定要傳入
if (xmlDoc.DocumentElement.GetElementsByTagName("parentname").Count > 0)
{
if (xmlDoc.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Count > 0)
{
parentName = xmlDoc.DocumentElement.GetElementsByTagName("parentname").Item(0).SelectNodes("value").Item(0).InnerText;
}
}
objENT.DelStudentCont(StudentNo, parentName);
strException = "";
strResult = "success";
objSYS.AddEventLog("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, "DelStudentparent parentName:" + parentName);
}
catch (iMESException.MESException ex)
{
strException = CombineXMLException(Conversions.ToString(ex.ErrorCode), TranslateMsg(ex.Message, GetXMLLanguageMode(xmlDoc), strResourceDir), "Del Studentparent Data failed, parentName:" + parentName, ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: Conversions.ToString(ex.ErrorCode));
}
catch (Exception ex)
{
strException = CombineXMLException(defWSErrCode, ex.Message, "Del Studentparent Data failed, parentName:" + parentName, ex.StackTrace);
strResult = "fail";
objSYS.AddErrorLog_ErrorCode("wsENT_21684", GetXMLCurUserNo(xmlDoc), "StudentNo", StudentNo, DateTime.Now, strException, ComputerName: GetXMLCurComputer(xmlDoc), ErrorCode: defWSErrCode);
}
finally
{
DelStudentContRet = CombineXMLResponse(strIdentity, "", strException, strResult, "");
}
return DelStudentContRet;
}
#endregion
}
}