SaveMattressExcutor.cs 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Diagnostics;
  5. using System.Linq;
  6. using System.Text;
  7. using DirectService.Tools;
  8. using JLHHJSvr.BLL;
  9. using JLHHJSvr.Com;
  10. using JLHHJSvr.Com.Model;
  11. using JLHHJSvr.Helper;
  12. using JLHHJSvr.LJException;
  13. using JLHHJSvr.Tools;
  14. using LJLib.DAL.SQL;
  15. using LJLib.Net.SPI.Server;
  16. namespace JLHHJSvr.Excutor
  17. {
  18. internal sealed class SaveMattressExcutor : ExcutorBase<SaveMattressRequest, SaveMattressResponse>
  19. {
  20. protected override void ExcuteInternal(SaveMattressRequest request, object state, SaveMattressResponse rslt)
  21. {
  22. var tokendata = BllHelper.GetToken(request.token);
  23. if (tokendata == null)
  24. {
  25. rslt.ErrMsg = "会话已经中断,请重新登录";
  26. return;
  27. }
  28. if (request.mattress == null)
  29. {
  30. rslt.ErrMsg = "缺少主表信息";
  31. return;
  32. }
  33. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  34. using (var cmd = con.CreateCommand())
  35. {
  36. con.Open();
  37. // 初始化属性
  38. AutoInit.AutoInitS(cmd, request.mattress);
  39. if(request.mattress.copy_id != null && request.mattress.copy_id > 0)
  40. {
  41. request.mattress.mattressid = 0;
  42. request.mattress.mattresscode = string.Empty;
  43. request.mattress.yw_flag = 0;
  44. request.mattress.yw_auditingrep = "";
  45. request.mattress.yw_auditingdate = null;
  46. request.mattress.js1_flag = 0;
  47. request.mattress.js1_auditingrep = "";
  48. request.mattress.js1_auditingdate = null;
  49. request.mattress.js2_flag = 0;
  50. request.mattress.js2_auditingrep = "";
  51. request.mattress.js2_auditingdate = null;
  52. request.mattress.xd_flag = 0;
  53. request.mattress.xd_auditingrep = "";
  54. request.mattress.xd_auditingdate = null;
  55. request.mattress.flag = 0;
  56. request.mattress.auditingrep = "";
  57. request.mattress.auditingdate = null;
  58. request.mattress.qr_auditingrep = "";
  59. request.mattress.qr_auditingdate = null;
  60. request.mattress.erp_mtrlid = 0;
  61. request.mattress.erp_mtrlcode = "";
  62. request.mattress.erp_piccode = "";
  63. request.mattress.erp_mtrlname = "";
  64. foreach (var mx in request.mattressMx)
  65. {
  66. mx.mattressid = 0;
  67. mx.mattressmxid = 0;
  68. }
  69. }
  70. else
  71. {
  72. #region 状态判断
  73. if (request.mattress.mattressid > 0) {
  74. var mattressInfo = new u_mattress() { mattressid = request.mattress.mattressid };
  75. if (DbSqlHelper.SelectOne(cmd, mattressInfo, "flag, xd_flag, yw_flag, mattresscode, parentid") == 1)
  76. {
  77. if (mattressInfo.xd_flag == 1)
  78. {
  79. rslt.ErrMsg = "床垫报价单【" + mattressInfo.mattresscode + "】已业务下单,不能修改";
  80. return;
  81. }
  82. }
  83. }
  84. if (request.subspecs != null && request.subspecs.Count > 0)
  85. {
  86. foreach (var submx in request.subspecs)
  87. {
  88. var itemid = Convert.ToInt32(submx["mattressid"]);
  89. if (itemid == 0) continue;
  90. var mattressInfo = new u_mattress() { mattressid = itemid };
  91. if (DbSqlHelper.SelectOne(cmd, mattressInfo, "flag, xd_flag, yw_flag, mattresscode, parentid") == 1)
  92. {
  93. if (mattressInfo.xd_flag == 1)
  94. {
  95. rslt.ErrMsg = "副规格-床垫报价单【" + mattressInfo.mattresscode + "】已业务下单,不能修改";
  96. return;
  97. }
  98. }
  99. }
  100. }
  101. #endregion
  102. }
  103. foreach (var mx in request.mattressMx)
  104. {
  105. AutoInit.AutoInitS(cmd, mx);
  106. }
  107. using (cmd.Transaction = con.BeginTransaction())
  108. {
  109. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  110. var helperBednet = HelperBase.GetHelper<BedNetHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  111. try
  112. {
  113. rslt.mxmessage = new List<string>();
  114. rslt.mxmessage = toSaveMattress(cmd, request.mattress, request.mattressMx, request.extraProcesses, request.extraCosts, tokendata);
  115. rslt.mattressid = request.mattress.mattressid;
  116. rslt.mattresscode = request.mattress.mattresscode;
  117. var subspecsList = helper.GetMattressSubspecs(request.mattress.mattressid);
  118. //if (subspecsList.Count > 0)
  119. //{
  120. // foreach (var submx in subspecsList)
  121. // {
  122. // // 删除副规格特殊工艺表
  123. // cmd.CommandText = @"DELETE u_mattress_mx_extra WHERE mattressid = @mattressid";
  124. // cmd.Parameters.Clear();
  125. // cmd.Parameters.AddWithValue("@mattressid", submx.mattressid);
  126. // cmd.ExecuteNonQuery();
  127. // // 删除副规格明细
  128. // cmd.CommandText = @"DELETE u_mattress_mx_mtrl WHERE mattressid = @mattressid";
  129. // cmd.Parameters.Clear();
  130. // cmd.Parameters.AddWithValue("@mattressid", submx.mattressid);
  131. // cmd.ExecuteNonQuery();
  132. // // 删除副规格
  133. // cmd.CommandText = @"DELETE u_mattress WHERE mattressid = @mattressid";
  134. // cmd.Parameters.Clear();
  135. // cmd.Parameters.AddWithValue("@mattressid", submx.mattressid);
  136. // cmd.ExecuteNonQuery();
  137. // }
  138. //}
  139. if (request.subspecs != null && request.subspecs.Count > 0)
  140. {
  141. // 排序:宽、长,从小到大
  142. var _subspecs = request.subspecs.OrderBy(o => o["mattress_width"]).ThenBy(o => o["mattress_length"]).ToList();
  143. // 副规格
  144. foreach (var submx in _subspecs)
  145. {
  146. var _mattressid = 0;
  147. var _mattresscode = "";
  148. if (submx.Value<int>("mattressid") > 0)
  149. {
  150. _mattressid = Convert.ToInt32(submx["mattressid"]);
  151. }
  152. if (!string.IsNullOrEmpty(submx.Value<string>("mattresscode")))
  153. {
  154. _mattresscode = Convert.ToString(submx["mattresscode"]);
  155. }
  156. var _mattress = ObjectHelper.DeepCopy(request.mattress);
  157. _mattress.parentid = request.mattress.mattressid;
  158. _mattress.createby = request.mattress.createby;
  159. _mattress.mattressid = _mattressid;
  160. _mattress.mattresscode = _mattresscode;
  161. _mattress.mattress_width = Convert.ToInt32(submx["mattress_width"]);
  162. _mattress.mattress_length = Convert.ToInt32(submx["mattress_length"]);
  163. _mattress.mattress_height = Convert.ToInt32(submx["mattress_height"]);
  164. _mattress.mattressrelcode = Convert.ToString(submx["mattressrelcode"]);
  165. _mattress.mattressname = Convert.ToString(submx["mattressname"]);
  166. if (submx.Value<int>("erp_mtrlid") > 0)
  167. {
  168. _mattress.erp_mtrlid = Convert.ToInt32(submx["erp_mtrlid"]);
  169. }
  170. if (!string.IsNullOrEmpty(submx.Value<string>("erp_mtrlcode")))
  171. {
  172. _mattress.erp_mtrlcode = Convert.ToString(submx["erp_mtrlcode"]);
  173. }
  174. if (submx.Value<int>("erp_configcodetype") > 0)
  175. {
  176. _mattress.erp_configcodetype = Convert.ToInt32(submx["erp_configcodetype"]);
  177. }
  178. if (!string.IsNullOrEmpty(submx.Value<string>("erp_mtrlengname")))
  179. {
  180. _mattress.erp_mtrlengname = Convert.ToString(submx["erp_mtrlengname"]);
  181. }
  182. if (!string.IsNullOrEmpty(submx.Value<string>("erp_mtrlmode")))
  183. {
  184. _mattress.erp_mtrlmode = Convert.ToString(submx["erp_mtrlmode"]);
  185. }
  186. if (!string.IsNullOrEmpty(submx.Value<string>("erp_mtrlname")))
  187. {
  188. _mattress.erp_mtrlname = Convert.ToString(submx["erp_mtrlname"]);
  189. }
  190. if (!string.IsNullOrEmpty(submx.Value<string>("erp_mtrltype")))
  191. {
  192. _mattress.erp_mtrltype = Convert.ToString(submx["erp_mtrltype"]);
  193. }
  194. if (submx.Value<int>("erp_mtrltypeid") > 0)
  195. {
  196. _mattress.erp_mtrltypeid = Convert.ToInt32(submx["erp_mtrltypeid"]);
  197. }
  198. if (!string.IsNullOrEmpty(submx.Value<string>("erp_mtrlunit")))
  199. {
  200. _mattress.erp_mtrlunit = Convert.ToString(submx["erp_mtrlunit"]);
  201. }
  202. if (!string.IsNullOrEmpty(submx.Value<string>("erp_piccode")))
  203. {
  204. _mattress.erp_piccode = Convert.ToString(submx["erp_piccode"]);
  205. }
  206. var _mattressMx = new List<u_mattress_mx_mtrl>();
  207. if (request.mattressMx != null && request.mattressMx.Any())
  208. {
  209. var bednetIndex = 0; // 床网索引
  210. var ifSubspecsIndex = 0; // 垫层主副规格物料索引
  211. foreach (var itemMx in request.mattressMx)
  212. {
  213. var item = ObjectHelper.DeepCopy(itemMx);
  214. item.mattressid = _mattress.mattressid;
  215. item.mattressmxid = 0;
  216. item.message = "";
  217. #region 副规格床网自动匹配/新增逻辑
  218. if (item.formulatype == 99 && item.mtrlid > 0)
  219. {
  220. bednetIndex++;
  221. var oBednet = new u_bednet();
  222. var _bednet = helperBednet.GetBedNet(item.mtrlid.Value);
  223. var _bednetMx = helperBednet.GetBedNetMxList(item.mtrlid.Value);
  224. var _bednetSpring = helperBednet.GetBedNetSpringList(item.mtrlid.Value);
  225. //_bednet.mattress_width = Convert.ToInt32(submx["mattress_width"]) - (request.mattress.mattress_width - _bednet.mattress_width);
  226. //_bednet.mattress_length = Convert.ToInt32(submx["mattress_length"]) - (request.mattress.mattress_length - _bednet.mattress_length);
  227. _bednet.mattress_width = Convert.ToInt32(submx["mattress_width"]);
  228. _bednet.mattress_length = Convert.ToInt32(submx["mattress_length"]);
  229. var _spring_qty_width = Convert.ToInt32(submx["spring_qty_width_" + bednetIndex]);
  230. var _spring_qty_length = Convert.ToInt32(submx["spring_qty_length_" + bednetIndex]);
  231. var _bednet_fork_qty = _bednet.fork_qty;
  232. if (!string.IsNullOrEmpty(submx.Value<string>("bednet_fork_qty_" + bednetIndex)))
  233. {
  234. _bednet_fork_qty = Convert.ToInt32(submx["bednet_fork_qty_" + bednetIndex]);
  235. }
  236. if (_bednetMx.Count > 0)
  237. {
  238. cmd.CommandText = @"SELECT TOP 1 u_bednet.bednetid
  239. ,u_bednet_type.typename
  240. ,bednetcode
  241. ,mattress_width
  242. ,mattress_length
  243. ,mattress_height
  244. ,nottax_factory_cost
  245. FROM u_bednetmx
  246. INNER JOIN u_bednet on u_bednet.bednetid = u_bednetmx.bednetid
  247. INNER JOIN u_bednet_type on u_bednet_type.bednettypeid = u_bednet.bednettypeid
  248. WHERE u_bednet.bednettypeid = @bednettypeid
  249. AND u_bednet.mattress_width = @mattress_width
  250. AND u_bednet.mattress_length = @mattress_length
  251. AND u_bednet.if_doublenet = @if_doublenet
  252. AND u_bednet.if_doublespring = @if_doublespring
  253. AND u_bednet.snake_wire_diameter = @snake_wire_diameter
  254. AND u_bednet.if_rsorwa = @if_rsorwa
  255. AND u_bednet.if_sponge_drilling = @if_sponge_drilling
  256. AND u_bednet.ifsaleout = 0
  257. AND u_bednet.sponge_mtrlid = @sponge_mtrlid
  258. AND u_bednet.sponge_thickness = @sponge_thickness
  259. AND u_bednet.sponge_height = @sponge_height
  260. AND u_bednet.sponge_tc_mtrlid = @sponge_tc_mtrlid
  261. AND u_bednet.sponge_tc_thickness = @sponge_tc_thickness
  262. AND u_bednet.sponge_tc_height = @sponge_tc_height
  263. AND u_bednet.edge_mtrlid = @edge_mtrlid
  264. AND u_bednet.edge_height = @edge_height
  265. AND u_bednet.felt_mtrlid = @felt_mtrlid
  266. AND u_bednet.felt_qty = @felt_qty
  267. AND u_bednet.felt_x_mtrlid = @felt_x_mtrlid
  268. AND u_bednet.felt_x_qty = @felt_x_qty
  269. AND u_bednet.fork_qty = @fork_qty
  270. AND u_bednet.felt_dscrp = @felt_dscrp
  271. AND u_bednet.duo_qv_str = @duo_qv_str
  272. AND u_bednetmx.bednet_height = @bednet_height
  273. AND u_bednetmx.springid = @springid
  274. AND u_bednetmx.spring_qty_width = @spring_qty_width
  275. AND u_bednetmx.spring_qty_length = @spring_qty_length
  276. AND u_bednetmx.if_side_iron = @if_side_iron
  277. AND u_bednetmx.side_iron_qty = @side_iron_qty
  278. AND u_bednetmx.fabrics2_mtrlid = @fabrics2_mtrlid
  279. AND u_bednetmx.fabrics1_mtrlid = @fabrics1_mtrlid
  280. AND u_bednetmx.if_hard_around = @if_hard_around
  281. AND u_bednetmx.hard_around_springid = @hard_around_springid
  282. AND u_bednetmx.hard_around_row = @hard_around_row
  283. AND u_bednetmx.if_15strip = @if_15strip
  284. ";
  285. cmd.Parameters.Clear();
  286. cmd.Parameters.AddWithValue("@bednettypeid", _bednet.bednettypeid);
  287. cmd.Parameters.AddWithValue("@mattress_width", _bednet.mattress_width);
  288. cmd.Parameters.AddWithValue("@mattress_length", _bednet.mattress_length);
  289. cmd.Parameters.AddWithValue("@if_doublenet", _bednet.if_doublenet);
  290. cmd.Parameters.AddWithValue("@if_doublespring", _bednet.if_doublespring);
  291. cmd.Parameters.AddWithValue("@snake_wire_diameter", _bednet.snake_wire_diameter);
  292. cmd.Parameters.AddWithValue("@if_rsorwa", _bednet.if_rsorwa);
  293. cmd.Parameters.AddWithValue("@if_sponge_drilling", _bednet.if_sponge_drilling);
  294. cmd.Parameters.AddWithValue("@sponge_mtrlid", _bednet.sponge_mtrlid);
  295. cmd.Parameters.AddWithValue("@sponge_thickness", _bednet.sponge_thickness);
  296. cmd.Parameters.AddWithValue("@sponge_height", _bednet.sponge_height);
  297. cmd.Parameters.AddWithValue("@sponge_tc_mtrlid", _bednet.sponge_tc_mtrlid);
  298. cmd.Parameters.AddWithValue("@sponge_tc_thickness", _bednet.sponge_tc_thickness);
  299. cmd.Parameters.AddWithValue("@sponge_tc_height", _bednet.sponge_tc_height);
  300. cmd.Parameters.AddWithValue("@edge_mtrlid", _bednet.edge_mtrlid);
  301. cmd.Parameters.AddWithValue("@edge_height", _bednet.edge_height);
  302. cmd.Parameters.AddWithValue("@felt_mtrlid", _bednet.felt_mtrlid);
  303. cmd.Parameters.AddWithValue("@felt_qty", _bednet.felt_qty);
  304. cmd.Parameters.AddWithValue("@felt_x_mtrlid", _bednet.felt_x_mtrlid);
  305. cmd.Parameters.AddWithValue("@felt_x_qty", _bednet.felt_x_qty);
  306. cmd.Parameters.AddWithValue("@felt_dscrp", _bednet.felt_dscrp);
  307. cmd.Parameters.AddWithValue("@duo_qv_str", _bednet.duo_qv_str);
  308. cmd.Parameters.AddWithValue("@fork_qty", _bednet.iffork == 1 ? _bednet_fork_qty : 0);
  309. cmd.Parameters.AddWithValue("@bednet_height", _bednetMx[0].bednet_height);
  310. cmd.Parameters.AddWithValue("@springid", _bednetMx[0].springid);
  311. cmd.Parameters.AddWithValue("@spring_qty_width", _spring_qty_width);
  312. cmd.Parameters.AddWithValue("@spring_qty_length", _spring_qty_length);
  313. cmd.Parameters.AddWithValue("@if_side_iron", _bednetMx[0].if_side_iron);
  314. cmd.Parameters.AddWithValue("@side_iron_qty", _bednetMx[0].side_iron_qty);
  315. cmd.Parameters.AddWithValue("@fabrics2_mtrlid", _bednetMx[0].fabrics2_mtrlid);
  316. cmd.Parameters.AddWithValue("@fabrics1_mtrlid", _bednetMx[0].fabrics1_mtrlid);
  317. cmd.Parameters.AddWithValue("@if_hard_around", _bednetMx[0].if_hard_around);
  318. cmd.Parameters.AddWithValue("@hard_around_springid", _bednetMx[0].hard_around_springid);
  319. cmd.Parameters.AddWithValue("@hard_around_row", _bednetMx[0].hard_around_row);
  320. cmd.Parameters.AddWithValue("@if_15strip", _bednetMx[0].if_15strip);
  321. using (var reader = cmd.ExecuteReader())
  322. {
  323. if (reader.Read())
  324. {
  325. oBednet = new u_bednet() {
  326. bednetid = Convert.ToInt32(reader["bednetid"]),
  327. typename = Convert.ToString(reader["typename"]),
  328. bednetcode = Convert.ToString(reader["bednetcode"]),
  329. mattress_width = Convert.ToInt32(reader["mattress_width"]),
  330. mattress_length = Convert.ToInt32(reader["mattress_length"]),
  331. mattress_height = Convert.ToInt32(reader["mattress_height"]),
  332. nottax_factory_cost = Convert.ToDecimal(reader["nottax_factory_cost"])
  333. };
  334. }
  335. }
  336. }
  337. // 匹配失败,自动新建
  338. if (oBednet.bednetid == null)
  339. {
  340. oBednet = _bednet;
  341. _bednetMx[0].spring_qty_width = _spring_qty_width;
  342. _bednetMx[0].spring_qty_length = _spring_qty_length;
  343. oBednet.fork_qty = _bednet_fork_qty;
  344. oBednet.bednetid = 0;
  345. // 袋装网,多个分区时,重新分配弹簧
  346. helperBednet.GetSpringListQty(oBednet, _bednetMx[0], ref _bednetSpring);
  347. helperBednet.SaveBedNet(oBednet, _bednetMx, _bednetSpring);
  348. }
  349. var _mtrlname = oBednet.typename +
  350. " " +
  351. oBednet.bednetcode +
  352. " " +
  353. oBednet.mattress_width +
  354. "*" +
  355. oBednet.mattress_length +
  356. "*" +
  357. oBednet.mattress_height;
  358. item.mtrlid = oBednet.bednetid;
  359. item.mtrlname = _mtrlname;
  360. item.price = oBednet.nottax_factory_cost;
  361. item.qty = 1;
  362. }
  363. #endregion
  364. #region 垫层改动逻辑
  365. if (item.formulatype == 1 && item.mtrlid > 0 )
  366. {
  367. // 规格长/宽,按比例缩放
  368. if (item.mattress_width > 0)
  369. {
  370. item.mattress_width = (int)Math.Floor((decimal)item.mattress_width * (Convert.ToDecimal(submx["mattress_width"]) / (decimal)request.mattress.mattress_width));
  371. }
  372. if (item.mattress_length > 0)
  373. {
  374. item.mattress_length = (int)Math.Floor((decimal)item.mattress_length * (Convert.ToDecimal(submx["mattress_length"]) / (decimal)request.mattress.mattress_length));
  375. }
  376. // 副规格-垫层物料替换
  377. if (item.if_subspecs == 1)
  378. {
  379. ifSubspecsIndex++;
  380. item.mtrlid = Convert.ToInt32(submx["cushions_subspecs_" + ifSubspecsIndex]);
  381. }
  382. }
  383. #endregion
  384. _mattressMx.Add(item);
  385. }
  386. #region FEAT:内布套/顶部裥棉逻辑
  387. var butaoList = _mattressMx.Where(t => (t.formulatype == 101 || t.formulatype == 102 || t.formulatype == 103) && t.mtrlid > 0 && (t.mattress_width > 0 || t.mattress_length > 0));
  388. foreach(var itemMx in butaoList)
  389. {
  390. itemMx.mattress_width += _mattress.mattress_width - request.mattress.mattress_width;
  391. itemMx.mattress_length += _mattress.mattress_length - request.mattress.mattress_length;
  392. }
  393. #endregion
  394. }
  395. toSaveMattress(cmd, _mattress, _mattressMx, request.extraProcesses, request.extraCosts, tokendata);
  396. }
  397. }
  398. cmd.Transaction.Commit();
  399. }
  400. catch (Exception e)
  401. {
  402. cmd.Transaction.Rollback();
  403. rslt.ErrMsg = e.ToString();
  404. Trace.Write(e);
  405. }
  406. }
  407. }
  408. }
  409. public List<string> toSaveMattress(SqlCommand cmd, u_mattress mattress, List<u_mattress_mx_mtrl> mattressMx, List<u_mattress_mx_extra> extraProcesses, List<u_mattress_mx_extra> extraCosts, TokenData tokendata)
  410. {
  411. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  412. List<string> message = new List<string>();
  413. helper.MattressCalculateCost(mattress, mattressMx, extraProcesses, extraCosts);
  414. var mxmessageList = mattressMx.Where(item => !string.IsNullOrEmpty(item.message)).ToList();
  415. if (mxmessageList.Any())
  416. {
  417. foreach (var mx in mxmessageList)
  418. {
  419. message.Add(mx.message);
  420. }
  421. }
  422. try
  423. {
  424. helper.SaveMattress(mattress, mattressMx, extraProcesses, extraCosts, true);
  425. if (mattress.copy_id != null && mattress.copy_id > 0)
  426. {
  427. helper.CopyMattressInterface(mattress.copy_id.Value, mattress.mattressid);
  428. }
  429. }
  430. catch (Exception e)
  431. {
  432. throw new LJCommonException(e.Message);
  433. }
  434. return message;
  435. }
  436. }
  437. }