/// <summary> /// /// </summary> /// <param name="tradeJournal"></param> public virtual BizProcessResult BizProcess(TradeJournal tradeJournal) { this.BizProcessApi.AssertNotNull("BizProcess"); tradeJournal.AssertNotNull("tradeJournal"); var data = tradeJournal.ToJson(); try { var sw = System.Diagnostics.Stopwatch.StartNew(); var response = new HttpDecorator().HttpPostJson(this.BizProcessApi, data, null); sw.Stop(); LogManager.GetLogger().Info("BizProcess [{0}-{1}] {2}", response.StatusCode, sw.Elapsed, this.BizProcessApi); if (response.StatusCode == System.Net.HttpStatusCode.OK) { if (null != response.Content) { LogManager.GetLogger().Info("BizProcess [{0}] <<===== {1}", response.Content, tradeJournal.ToJson()); var result = response.Content.ConvertEntity <BizProcessResult>(); return(result); } } var errorInfo = new Dictionary <string, object>(); errorInfo.Add("tradeJournal", tradeJournal.ToJson()); errorInfo.Add("BizProcessApi", this.BizProcessApi); errorInfo.Add("HttpStatusCode", response.StatusCode); if (response.StatusCode == System.Net.HttpStatusCode.OK) { errorInfo.Add("HttpResult", response.Content); } LogManager.GetLogger().Error(errorInfo); return(BizProcessResult.CreateErrorResult(this.GetType().Name, string.Format("the request failed[{0}].", response.StatusCode))); } catch (Exception ex) { var info = new Dictionary <string, object>(); info.Add("tradeJournal", tradeJournal.ToJson()); ex.HandleException(info); return(BizProcessResult.CreateErrorResult(this.GetType().Name, ex.Message)); } }
/// <summary> /// /// </summary> /// <param name="tradeJournal"></param> public BizProcessResult BizProcess(TradeJournal tradeJournal) { tradeJournal.AssertNotNull("tradeJournal"); var walletType = WalletType.Privateness; if (tradeJournal.TradeType == TradeType.PersonalToOrganization || tradeJournal.TradeType == TradeType.OrganizationToOrganization) { walletType = WalletType.Organization; } var paymentResult = Wallet.AddBalance(walletType, tradeJournal.OwnerId, tradeJournal.TradeCode); if (null != paymentResult && paymentResult.Success) { return(BizProcessResult.CreateSuccessResult("")); } else { return(BizProcessResult.CreateErrorResult(this.GetType().Name, "[Wallet.AddBalance] fail.")); } }