示例#1
0
        /// <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));
            }
        }
示例#2
0
        /// <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."));
            }
        }
示例#3
0
 /// <summary>
 ///
 /// </summary>
 /// <param name="tradeJournal"></param>
 public virtual BizProcessResult BizProcess(TradeJournal tradeJournal)
 {
     tradeJournal.AssertNotNull("tradeJournal");
     return(BizProcessResult.CreateSuccessResult(tradeJournal.TradeCode));
 }