SaveMtrlDefExcutor.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Linq;
  5. using System.Text;
  6. using JLHHJSvr.BLL;
  7. using JLHHJSvr.Com;
  8. using JLHHJSvr.Com.Model;
  9. using JLHHJSvr.Helper;
  10. using JLHHJSvr.LJException;
  11. using JLHHJSvr.Tools;
  12. using LJLib.DAL.SQL;
  13. using LJLib.Net.SPI.Server;
  14. using LJLib.SQLEX;
  15. using static JLHHJSvr.Helper.CacheHelper;
  16. namespace JLHHJSvr.Excutor
  17. {
  18. internal sealed class SaveMtrlDefExcutor : ExcutorBase<SaveMtrlDefRequest, SaveMtrlDefResponse>
  19. {
  20. protected override void ExcuteInternal(SaveMtrlDefRequest request, object state, SaveMtrlDefResponse rslt)
  21. {
  22. var tokendata = BllHelper.GetToken(request.token);
  23. if (tokendata == null)
  24. {
  25. rslt.ErrMsg = "会话已经中断,请重新登录";
  26. return;
  27. }
  28. if (request.mtrl == null)
  29. {
  30. rslt.ErrMsg = "未提交物料类别定义";
  31. return;
  32. }
  33. if (string.IsNullOrEmpty(request.mtrl.name))
  34. {
  35. rslt.ErrMsg = "请输入物料名称";
  36. return;
  37. }
  38. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  39. using (var cmd = con.CreateCommand())
  40. {
  41. con.Open();
  42. var dtNow = DateTime.Now;
  43. AutoInit.AutoInitS(cmd, request.mtrl);
  44. var helper = HelperBase.GetHelper<BasicInfoHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  45. using (cmd.Transaction = con.BeginTransaction())
  46. {
  47. try
  48. {
  49. helper.SaveMtrlDef(request.mtrl);
  50. cmd.Transaction.Commit();
  51. }
  52. catch (Exception e)
  53. {
  54. cmd.Transaction?.Rollback();
  55. rslt.ErrMsg = e.Message;
  56. }
  57. }
  58. }
  59. }
  60. }
  61. }