using CRM.Core.BLL.EventBus.Events; using CRM.Core.Common.EventBus; using CRM.Core.DTO; using System; using System.Text; using WX.CRM.Common; namespace CRM.Core.BLL.EventBus.EventHandlers { public class SignContractEventHandler : IEventHandler { public void Handle(SignContractEvent @event) { try { LogHelper.Info("签约事件推送执行:" + @event.ToJson()); try { //http://post.hc.dn8188.com/Rights/orderback.html var noticeUrl = Utility.GetSettingByKey("noticeUrl"); if (!string.IsNullOrEmpty(noticeUrl)) { Utility.GetData(noticeUrl, "orderid=" + @event.OrderId.ToString() + "&type=2&values=1", Encoding.UTF8); } } catch (Exception exx) { LogHelper.Error("通知前端错误:" + exx.ToString()); } var host = Utility.GetSettingOrNullByKey("DataSyncApiUrl"); var url = host + "/api/DataSync"; var para = new SYNC_PUSH_DTO() { bidatatype = "Client_SignContract", deptcode = @event.DeptCode, jsontext = new { @event.OrderId, @event.HtId }.ToJson() }; var rep = Utility.PostAjaxData(url, para.ToJson(), Encoding.UTF8); var ret = Utility.JSONToObject(rep); if (!ret.result) LogHelper.Error("接口 SignContractEventHandler 写入失败!"); } catch (Exception ex) { LogHelper.Error("签约事件推送错误:" + ex.ToString()); } } } }