public async Task <IActionResult> RefreshAsync([FromBody] OrderOptionModel query) { Dictionary <string, object> jsonData = new Dictionary <string, object>(); try { var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); var _orders = OrderRepository.GetOrderList(UserData, query); jsonData["query_params"] = JsonConvert.SerializeObject(query); jsonData["content"] = await this.RenderViewAsync <OrderListModel>("OrderList", _orders, true); jsonData["status"] = "OK"; } catch (Exception ex) { jsonData.Clear(); jsonData.Add("status", "FAIL"); jsonData.Add("msg", ex.Message); } return(Json(jsonData)); }
// GET: /<controller>/ public IActionResult Index(ErrorViewModel errorModel) { //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //取挖字 Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE);// RedisHelper.getuiKey(fakeContact.lang); ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); switch (errorModel.ErrorType) { case ErrorType.Invalid_Market: ViewBag.invalid_info = title.common_invalid_market_title; break; case ErrorType.Order_Fail: ViewBag.invalid_info = title.common_invalid_order; break; default: ViewBag.invalid_info = title.common_invalid_info; break; } ViewBag.invalid_title = title.common_invalid_title; ViewBag.common_more_experiences = title.common_more_experiences; ViewBag.error_alert = errorModel.ErrorMessage; return(View()); }
// GET: /<controller>/ public IActionResult Index() { //準備參數 //CALL WMS獲得訂單查詢結果 //計算分頁數 //以MODELS(訂單列表)帶到view try { var aesUserData = User.FindFirst(ClaimTypes.UserData).Value; var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); OrderOptionModel option = new OrderOptionModel() { page_size = Page_Size, current_page = 1 //time_zone = "", //prod_Sdate = "", //prod_Edate = "", //order_Sdate = "", //order_Edate = "", //orders = search.ORDER_NO; }; var orders = OrderRepository.GetOrderList(UserData, option); return(View(orders)); } catch (Exception ex) { throw ex; } }
// API子帳號列表 public IActionResult ApiUser(string query) { var services = HttpContext.RequestServices.GetServices <IB2dAccountRepository>(); var acctRepos = services.First(o => o.GetType() == typeof(B2dApiAccountRepository)); var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dApiAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); QueryParamsModel queryParams = null; if (!string.IsNullOrEmpty(query)) { query = System.Web.HttpUtility.UrlDecode(query).Replace(""", "\""); queryParams = JsonConvert.DeserializeObject <QueryParamsModel>(query); } else { queryParams = acctRepos.GetQueryParamModel(UserData.COMPANY_XID, string.Empty, string.Empty, PAGE_SIZE, 1); } ViewData["QUERY_PARAMS"] = queryParams; ViewData["QUERY_PARAMS_JSON"] = JsonConvert.SerializeObject(queryParams); ViewData["CACHETIME"] = B2dApiAccountRepository.GetCache(UserData.COMPANY_XID); var skip = (queryParams.Paging.current_page - 1) * queryParams.Paging.page_size; var _accounts = acctRepos.GetAccounts(UserData.COMPANY_XID, queryParams.Filter, skip, queryParams.Paging.page_size, queryParams.Sorting); return(View(_accounts)); }
// 單一訂單 public IActionResult OrderDetail(string id) { //先用假訂單 id = "18KK112875437"; Dictionary <string, string> jsonData = new Dictionary <string, string>(); try { var aesUserData = User.FindFirst(ClaimTypes.UserData).Value; var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); var orders = OrderRepository.GetOrderDetail(UserData, id); //JObject jsonObject = JObject.Parse(orders); ViewData["info"] = OrderRepository.GetOrderInfo(orders["order_info"]); ViewData["cus"] = OrderRepository.GetOrderCus(orders["order_cusList"]); ViewData["module"] = OrderRepository.GetOrderModule(orders["order_modules"]); jsonData.Add("status", "OK"); //jsonData["content"] =await this.RenderViewAsync<OrderListModel>("OrderList", orders, true); } catch (Exception ex) { jsonData.Clear(); jsonData.Add("status", "ERROR"); jsonData.Add("content", ex.Message); } return(View()); }
public async Task <IActionResult> SearchOrdersAsync([FromBody] OrderModel search) { Dictionary <string, string> jsonData = new Dictionary <string, string>(); try { var aesUserData = User.FindFirst(ClaimTypes.UserData).Value; var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); OrderOptionModel option = new OrderOptionModel() { page_size = Page_Size, current_page = 1, time_zone = "", prod_Sdate = "", prod_Edate = "", order_Sdate = "", order_Edate = "", orders = new string[] { "18KK12345" } }; var orders = OrderRepository.GetOrderList(UserData, option); jsonData.Add("status", "OK"); jsonData["content"] = await this.RenderViewAsync <OrderListModel>("OrderList", orders, true); } catch (Exception ex) { jsonData.Clear(); jsonData.Add("status", "ERROR"); jsonData.Add("content", ex.Message); } return(Json(jsonData)); }
public async System.Threading.Tasks.Task <IActionResult> ApiRefresh([FromBody] QueryParamsModel queryParams) { Dictionary <string, object> jsonData = new Dictionary <string, object>(); try { var services = HttpContext.RequestServices.GetServices <IB2dAccountRepository>(); var acctRepos = services.First(o => o.GetType() == typeof(B2dApiAccountRepository)); var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //更新分頁資料 queryParams = acctRepos.GetQueryParamModel(UserData.COMPANY_XID, queryParams.Filter, queryParams.Sorting, PAGE_SIZE, queryParams.Paging.current_page); ViewData["QUERY_PARAMS"] = queryParams; var skip = (queryParams.Paging.current_page - 1) * queryParams.Paging.page_size; var _accounts = acctRepos.GetAccounts(UserData.COMPANY_XID, queryParams.Filter, skip, queryParams.Paging.page_size, queryParams.Sorting); jsonData["query_params"] = JsonConvert.SerializeObject(queryParams); jsonData["content"] = await this.RenderViewAsync <List <B2dAccount> >("ApiUserList", _accounts, true); jsonData["status"] = "OK"; } catch (Exception ex) { jsonData.Clear(); jsonData.Add("status", "FAIL"); jsonData.Add("msg", ex.Message); } return(Json(jsonData)); }
public IActionResult UpdateVouchAddon([FromBody] B2dVoucherAddon vouch_addon) { Dictionary <string, object> jsonData = new Dictionary <string, object>(); try { var vouchRepos = HttpContext.RequestServices.GetService <VouchAddonRepository>(); var upd_user = User.FindFirst("Account").Value; var aesUserData = User.FindFirst(ClaimTypes.UserData).Value; var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); vouch_addon.COMPANY_XID = UserData.COMPANY_XID; //更新分銷商公司資料 vouchRepos.UpdateVouchAddon(vouch_addon, upd_user); jsonData["status"] = "OK"; } catch (Exception ex) { jsonData.Clear(); jsonData.Add("status", "FAIL"); jsonData.Add("msg", ex.Message); } return(Json(jsonData)); }
public IActionResult Index() { var userId = User.Identity.Name; var aesUserData = User.FindFirst(ClaimTypes.UserData).Value; var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); ViewData["UserData"] = UserData; return(View()); }
public IActionResult Review() { var aesUserData = User.FindFirst(ClaimTypes.UserData).Value; var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); var xid = UserData.COMPANY_XID; B2dCompany model = CompanyDAL.GetCompany(xid); return(View(model)); }
public IActionResult Index() { var jsonAccount = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); if (jsonAccount != null) { var account = JsonConvert.DeserializeObject <KKdayAccount>(AesCryptHelper.aesDecryptBase64(jsonAccount, Website.Instance.AesCryptKey)); } return(View()); }
// 更改快取時間 public IActionResult Update_CacheTime(Int64 time) { Dictionary <string, string> jsonData = new Dictionary <string, string>(); var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); B2dApiAccountRepository.UpdateCacheTime(time, UserData.COMPANY_XID); jsonData.Add("status", "OK"); return(Json(jsonData)); }
// GET: /<controller>/ public IActionResult Index() { var services = HttpContext.RequestServices.GetServices <IB2dAccountRepository>(); var vouchRepos = HttpContext.RequestServices.GetService <VouchAddonRepository>(); var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); B2dVoucherAddon vouch = vouchRepos.GetVoucherAddon(UserData.COMPANY_XID); return(View(vouch)); }
//付款中途停止導回 //public IActionResult Failure(string id) public IActionResult Failure(string id) { try { BookingShowProdModel prodShow = null; DataModel orderData = null; Boolean chkSuccess = true; Website.Instance.logger.Debug($",bookingFailure_id:{id}"); if (id != null) { string prodShowStr = RedisHelper.getRedis("b2d:ec:order:final:prodShow:" + id); if (prodShowStr != null) { prodShow = JsonConvert.DeserializeObject <BookingShowProdModel>(prodShowStr); } string orderDataStr = RedisHelper.getRedis("b2d:ec:order:final:orderData:" + id); if (orderDataStr != null) { orderData = JsonConvert.DeserializeObject <DataModel>(orderDataStr); } } else { chkSuccess = false; } //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //取挖字 Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE);;//RedisHelper.getuiKey(fakeContact.lang); ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); ViewData["chkSuccess"] = chkSuccess; ViewData["prodShow"] = prodShow; ViewData["orderData"] = orderData; ViewData["prodTitle"] = title; return(View("Success")); } catch (Exception ex) { ViewData["errMsg"] = ex.Message.ToString(); Website.Instance.logger.Debug($"Final_Step3_err:{ex.Message.ToString()}"); //導到錯誤頁 return(RedirectToAction("Index", "Error", new ErrorViewModel { ErrorType = ErrorType.Order_Fail })); } }
[HttpPost]//[AcceptVerbs("Post")] public IActionResult reflashPkg([FromBody] prodQury prodQury) { try { //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //先確認是否有selDate ,如果沒有表示是第一次 //如果有 selDate要依selDate決定可用的套餐 string allCanUseDate = ""; //取挖字 Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE);;// Redishelper.getuiKey(fakeContact.lang); ProdTitleModel title = ProductRepostory.getProdTitle(uikey); ViewData["prodTitle"] = title; ViewData["currency"] = UserData.CURRENCY;//先從這裡取得幣別就不用再抓prod //ProductforEcModel prod = ApiHelper.getProdDtl(fakeContact.companyXid, fakeContact.state, fakeContact.lang, fakeContact.currency, prodQury.prodOid); //prod = prodRep.getProdInfo(prod, prodQury.prodOid, fakeContact.lang, fakeContact.currency, uikey); //prod.guidNo = guid; //ViewData["prodInfo"] = prod; PackageModel pkgs = ProductRepostory.getProdPkg(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, prodQury.prodOid, title); Int64 nowDatetime = Convert.ToInt64(DateTime.Now.ToString("yyyyMMddHHmmss")); pkgs.pkgs = pkgs.pkgs.Where(x => nowDatetime >= Convert.ToInt64(x.online_s_date) && Convert.ToInt64(x.online_e_date) > nowDatetime).ToList(); Website.Instance.logger.Debug($"product_reflashPkg_err:{JsonConvert.SerializeObject(pkgs)}"); List <PkgDateforEcModel> prodPkgDateList = ProductRepostory.getProdPkgDate(pkgs, UserData.LOCALE, UserData.CURRENCY, uikey, out allCanUseDate); //設定每個pkg裡面可以使用的日期有那些 pkgs = ProductRepostory.InitPkg(prodQury, title, pkgs, prodPkgDateList); return(Content(this.RenderPartialViewToString(ViewEngine, "_prodPkg", pkgs))); } catch (Exception ex) { //error Website.Instance.logger.Debug($"product_reflashPkg_err:{ex.ToString()}"); returnStatus status = new returnStatus(); status.status = "Error"; status.msgErr = "資料錯誤,請重新讀取頁";//要改 return(Json(status)); } }
public IActionResult UpdateProfile([FromBody] B2dAccount acc) { try { var services = HttpContext.RequestServices.GetServices <IB2dAccountRepository>(); var accountRepo = services.First(o => o.GetType() == typeof(B2dAccountRepository)); var _strUuid = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == "UUID").Select(c => c.Value)).FirstOrDefault(); var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); var upd_user = UserData.EMAIL; accountRepo.UpdateAccount(acc, upd_user); return(Json("OK")); } catch (Exception ex) { return(Json(ex.ToString())); } }
[HttpPost]//[AcceptVerbs("Post")] public IActionResult GetEventTime([FromBody] prodEvent prodEvent) { try { //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //取挖字 String json = TempData["ProdTitleKeep"] as string; if (string.IsNullOrEmpty(json)) { throw new Exception("資料錯誤,請重新讀取頁面"); } ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(json); TempData.Keep(); PkgEventsModel getEventTime = ProductRepostory.getEvent(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, prodEvent.prodno, prodEvent.pkgno, title); if (getEventTime.result == "0000") { var result = getEventTime.events.Where(x => x.day == prodEvent.DateSelected); //result = new List<Event> { }; getEventTime.events = result.ToList(); return(Json(new { errMsg = "", data = result.ToList() })); } else { return(Json(new { errMsg = "false" })); } } catch (Exception ex) { //error Website.Instance.logger.Debug($"product_eventtime_err:{ex.ToString()}"); returnStatus status = new returnStatus(); status.status = "Error"; status.msgErr = "資料錯誤,請重新讀取頁面";//要改 return(Json(status)); } }
public IActionResult Index() { //假分銷商 //distributorInfo fakeContact = DataSettingRepostory.fakeContact(); //B2d分銷商資料 var aesUserData = User.FindFirst(ClaimTypes.UserData).Value; var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //取得可售商品之國家&城市 string locale = UserData.LOCALE; var countries = CountryRepostory.GetCountries(locale); //取挖字 Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE); //fakeContact.lang, UserData.LOCALE ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); ViewData["prodTitle"] = title; return(View(countries)); }
// 新增API帳號 public IActionResult InsertApiUser([FromBody] B2dApiAccount acc) { try { //var accountRepo = (B2dApiAccountRepository)HttpContext.RequestServices.GetService(typeof(B2dApiAccountRepository)); var services = HttpContext.RequestServices.GetServices <IB2dAccountRepository>(); var accountRepo = (B2dApiAccountRepository)services.First(o => o.GetType() == typeof(B2dApiAccountRepository)); var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dApiAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); var crt_user = UserData.EMAIL; acc.COMPANY_XID = UserData.COMPANY_XID; acc.TEL_AREA = UserData.TEL_AREA; accountRepo.InsertAccount(acc, crt_user); return(Json("OK")); } catch (Exception ex) { return(Json(ex.ToString())); } }
// 關閉API帳號 public IActionResult ApiAccountProfile_close(Int64 xid) { try { var queryArgc = System.Web.HttpUtility.UrlEncode(this.Request.Query["query"].ToString()); var services = HttpContext.RequestServices.GetServices <IB2dAccountRepository>(); var acctRepos = services.First(o => o.GetType() == typeof(B2dApiAccountRepository)); var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); acctRepos.CloseAccount(xid, UserData.EMAIL); ViewData["QueryParams"] = queryArgc; return(Json("OK")); } catch (Exception ex) { Website.Instance.logger.FatalFormat("{0},{1}", ex.Message, ex.StackTrace); throw ex; } }
// GET: /<controller>/ public IActionResult Index(string id) { try { //還沒有做的區塊 //productIntro //product_intruduction_tab 行程表 憑證區塊 //呼叫api 取資料 https://api.sit.kkday.com/api/product/info/fe/v1/17379 //判斷是否有資料,如果沒有要跳 alert 並導頁 //資料取得後要揉資料 //要把挖字存成一個物件並帶到view去 //logs Website.Instance.logger.Info($"[PAY]kkOrderNo:{bookRQ.order.orderMid},priceType:{lst.price_type},jtrTktNo:{payRS.code},jtrErr:{payRS.error_msg}"); //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //fakeContact.state = "CN"; //取挖字 Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE);;// Redishelper.getuiKey(fakeContact.lang); //ProdTitleModel title = ProductRepostory.getProdTitle(uikey); ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); if (id == null) { throw new Exception("商品不存在"); } //從 api取 ProductforEcModel prod = ProductRepostory.getProdDtl(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, id, title); if (prod.result != "0000") { //if (prod.result == "10001" && !prod.prod_mkt.is_ec_sale) if (prod.result == "10001") { int strCut1 = (prod.result_msg.IndexOf("Product ERROR:", StringComparison.CurrentCulture) + "Product ERROR:".Length); int strCut2 = prod.result_msg.IndexOf(", at", StringComparison.CurrentCulture); string errMsg = prod.result_msg.Length > 0 ? prod.result_msg.Substring(strCut1, strCut2 - strCut1) : ""; return(RedirectToAction("Index", "Error", new ErrorViewModel { ErrorType = ErrorType.Invalid_Market, ErrorMessage = errMsg })); } else { throw new Exception(prod.result_msg); //不正確就導錯誤頁,但api還未處理怎麼回傳 } } PackageModel pkgs = ProductRepostory.getProdPkg(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, id, title); if (pkgs.result != "0000") { throw new Exception(prod.result_msg); //不正確就導錯誤頁,但api還未處理怎麼回傳 } Int64 nowDatetime = Convert.ToInt64(DateTime.Now.ToString("yyyyMMddHHmmss")); pkgs.pkgs = pkgs.pkgs.Where(x => nowDatetime >= Convert.ToInt64(x.online_s_date) && Convert.ToInt64(x.online_e_date) > nowDatetime).ToList(); string price1Type = pkgs.pkgs != null && pkgs.pkgs.Any() ? pkgs.pkgs.Select(p => p.is_unit_pirce).FirstOrDefault() : ""; string price1TypeStr = pkgs.pkgs != null && pkgs.pkgs.Any() ? pkgs.pkgs.Select(p => p.unit_txt).FirstOrDefault() : ""; ViewData["priceType"] = price1Type == "NORANK" ? price1TypeStr : title.common_adult; ////判斷是不是可以可以秀可以賣 ,但api 未決定錯誤怎麼給 //if (prod.prod_mkt.is_ec_sale == false) //不能秀就導錯誤頁 //{ // throw new Exception("商品不顯示!"); //} string guid = System.Guid.NewGuid().ToString(); string allCanUseDate = ""; prod = ProductRepostory.getProdOtherInfo(prod, id, UserData.LOCALE, UserData.CURRENCY, uikey); prod.guidNo = pkgs.guid; List <PkgDateforEcModel> prodPkgDateList = ProductRepostory.getProdPkgDate(pkgs, UserData.LOCALE, UserData.CURRENCY, uikey, out allCanUseDate); TempData["ProdTitleKeep"] = JsonConvert.SerializeObject(uikey); //取消政策排序 if (prod.policy_list != null && prod.policy_list.Any()) { prod.policy_list = prod.policy_list.OrderByDescending(o => o.is_over).OrderByDescending(o => o.days).ToList(); } ProductModuleModel module = ProductRepostory.getProdModule(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, id, "", title); if (module != null && module.module_venue_info != null) { if (module.module_venue_info.venue_type == "01") { ViewData["moduleVenue"] = module.module_venue_info; } } ViewData["prodTitle"] = title; ViewData["prod"] = prod; ViewData["pkgs"] = pkgs; ViewData["allCanUseDate"] = allCanUseDate; ViewData["pkgDate"] = prodPkgDateList; ViewData["currency"] = UserData.CURRENCY; return(View()); } catch (Exception ex) { //導到錯誤頁 Website.Instance.logger.Debug($"product_index_err:{ex.ToString()}"); return(RedirectToAction("Index", "Error", new ErrorViewModel { ErrorType = ErrorType.Invalid_Common })); //return View("~/Views/Shared/Error.cshtml", new ErrorViewModel //{ RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier }); } }
public IActionResult bookingStep1([FromBody] DataModel data) { try { //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); string ip = httpContextAccessor.HttpContext.Request.HttpContext.Connection.RemoteIpAddress.ToString().Replace("::1", "127.0.0.1"); data = BookingRepostory.setCardEncrypt(data); //log時把卡號移除 DataModel dataTemp = data.Clone(); dataTemp.card = null; Website.Instance.logger.Debug($"bookingStep1_inputdata:{ JsonConvert.SerializeObject(dataTemp)}"); ApiSetting api = new ApiSetting(); api.apiKey = "kkdayapi"; api.userOid = "1"; api.ver = "1.0.1"; api.locale = UserData.LOCALE; api.currency = UserData.CURRENCY; api.ipaddress = ip; string prodStr = TempData["prod_" + data.guidNo] as string; if (string.IsNullOrEmpty(prodStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } ProductModel prod = JsonConvert.DeserializeObject <ProductModel>(prodStr); string moduleStr = TempData["module_" + data.guidNo] as string; if (string.IsNullOrEmpty(moduleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } ProductModuleModel module = JsonConvert.DeserializeObject <ProductModuleModel>(moduleStr); string pkgStr = TempData["pkg_" + data.guidNo] as string; if (string.IsNullOrEmpty(pkgStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } PkgDetailModel pkg = JsonConvert.DeserializeObject <PkgDetailModel>(pkgStr); string pkgConfirmStr = TempData["confirm_" + data.guidNo] as string; if (string.IsNullOrEmpty(moduleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } confirmPkgInfo confirm = JsonConvert.DeserializeObject <confirmPkgInfo>(pkgConfirmStr); string titleStr = TempData["ProdTitleKeep_" + data.guidNo] as string; if (string.IsNullOrEmpty(moduleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(titleStr); string discRuleStr = TempData["pkgsDiscRule_" + data.guidNo] as string; if (string.IsNullOrEmpty(discRuleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } DiscountRuleModel rule = JsonConvert.DeserializeObject <DiscountRuleModel>(discRuleStr); string pmgwStr = TempData["pmgw_" + data.guidNo] as string; if (string.IsNullOrEmpty(pmgwStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } Pmgw pmgw = JsonConvert.DeserializeObject <Pmgw>(pmgwStr); string showStr = TempData["prodShow_" + data.guidNo] as string; if (string.IsNullOrEmpty(showStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } //BookingShowProdModel show = JsonConvert.DeserializeObject<BookingShowProdModel>(showStr); TempData.Keep(); //排除餐食 data = BookingRepostory.exculdeFood(prod, data, module); string b2bOrder = BookingRepostory.insB2dOrder(title, prod, pkg, confirm, data, UserData, rule); //轉 ordermodel //OrderRepostory res = new OrderRepostory(); //OrderModel ord = res.setOrderModel(data,pmgw,title); //api.json = ord; //string orderModelStr = JsonConvert.SerializeObject(api); //Website.Instance.logger.Debug($"bookingStep1_ordernewdata:{ JsonConvert.SerializeObject(orderModelStr)}"); //KKapiHelper kk = new KKapiHelper(); //JObject order =kk.crtOrder(api); JObject order = ApiHelper.orderNew(data, title); string orderMid = ""; string orderOid = ""; returnStatus status = new returnStatus(); Website.Instance.logger.Debug($"bookingStep1_ordernewresponse:" + JsonConvert.SerializeObject(order));//要改 //要先判斷是不是result='0000' if (order["content"]["result"].ToString() == "0000") { string memUuid = "051794b8-db2a-4fe7-939f-31ab1ee2c719"; orderMid = order["content"]["orderMid"].ToString(); orderOid = order["content"]["orderOid"].ToString(); status.pmchSslRequest = BookingRepostory.setPaymentInfo2(prod, data, orderMid, UserData, pmgw, memUuid); status.status = "OK"; status.url = Website.Instance.Configuration["kkUrl:pmchUrl"].ToString() + pmgw.pmchPayURL; //pmchUrl //要把BookingShowProdModel 帶到訂購final頁 RedisHelper.SetRedis(showStr, "b2d:ec:order:final:prodShow:" + orderMid, 60); RedisHelper.SetRedis(JsonConvert.SerializeObject(data), "b2d:ec:order:final:orderData:" + orderMid, 60); //要存redis 付款主要資訊,最後訂單 upd時要使用,可和下面整合存一個就 BookingRepostory.setPayDtltoRedis(data, orderMid, memUuid, RedisHelper); //要存redis 因為付款後要從這個redis內容再進行payment驗證,可和上面整合存一個就好 //CallJsonPay rdsJson = (CallJsonPay)status.pmchSslRequest.json; CallJsonPay2 rdsJson = (CallJsonPay2)status.pmchSslRequest.json; string callPmchReq = JsonConvert.SerializeObject(status.pmchSslRequest.json); RedisHelper.SetRedis(callPmchReq, "b2d:ec:pmchSslRequest:" + orderMid, 60); } else { status.status = "Error"; status.msgErr = order["content"]["result"].ToString() + order["content"]["msg"].ToString();//要改 } return(Json(status)); //v1/channel/citi/auth //https://pmch.sit.kkday.com/citi/payment/auth //https://payment.kkday.com/v1/channel/adyen/auth } catch (Exception ex) { //error Website.Instance.logger.Debug($"bookingStep1_err_ordernew失敗:{ex.Message.ToString()}"); returnStatus status = new returnStatus(); status.status = "Error"; status.msgErr = ex.Message.ToString(); return(Json(status)); } }
public async Task <IActionResult> AuthenAsync(LoginModel loginModel) { Dictionary <string, string> jsonData = new Dictionary <string, string>(); try { //var accountRepo = (AccountRepository)HttpContext.RequestServices.GetService(typeof(AccountRepository)); var encPassword = WebUtility.UrlEncode(Sha256Helper.Gethash(loginModel.Password)); var account = AccountRepository.GetAccount(loginModel.Email, encPassword); //分流-KKdayUser&UserAdmin var IsKKdayUser = account is KKdayAccount ? true : false; var IsUserAdmin = (account is B2dAccount && ((B2dAccount)account).USER_TYPE.Equals("01")) ? true : false; var strChiperAcct = AesCryptHelper.aesEncryptBase64(JsonConvert.SerializeObject(account), Website.Instance.AesCryptKey); var claims = new List <Claim> { new Claim(ClaimTypes.Name, account.NAME), new Claim("Account", account.EMAIL), new Claim("UUID", account.UUID), new Claim("UserType", IsKKdayUser ? "KKDAY" : (IsUserAdmin ? "ADMIN":"USER")), new Claim("Locale", account.LOCALE), new Claim("Currency", IsKKdayUser ? "" : ((B2dAccount)account).CURRENCY), new Claim(ClaimTypes.UserData, strChiperAcct), // 以AES加密JSON格式把使用者資料保存於Cookie }; //var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); //var UserData = JsonConvert.DeserializeObject<B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); var userIdentity = new ClaimsIdentity(claims, "login"); ClaimsPrincipal principal = new ClaimsPrincipal(userIdentity); await HttpContext.SignInAsync( CookieAuthenticationDefaults.AuthenticationScheme, principal, new AuthenticationProperties() { ExpiresUtc = DateTime.UtcNow.AddDays(10), // 預設 Cookie 有效時間 IsPersistent = false, AllowRefresh = false }); if (!IsKKdayUser) { HttpContext.Session.SetString("B2D_COMPANY_LOCALE", ((B2dAccount)account).LOCALE); HttpContext.Session.SetString("B2D_COMPANY_CURRENCY", ((B2dAccount)account).CURRENCY); } jsonData.Add("status", "OK"); //Just redirect to our index after logging in. jsonData.Add("url", IsKKdayUser ? Url.Content("~/KKday/") : Url.Content("~/")); } catch (Exception ex) { jsonData.Clear(); jsonData.Add("status", "ERROR"); jsonData.Add("msg", ex.Message); } return(Json(jsonData)); }
//付款後導回 public IActionResult Step3(string id, string jsondata) { B2dAccount UserData = null; BookingShowProdModel prodShow = null; DataModel orderData = null; Boolean chkSuccess = true; if (id != null && jsondata != null) { ////回傳的連結有訂編 (記log) ////透過訂編將redis 的資料抓回送出去的資料 ////取b2dredis 內的paymentDtl ////string payDtlStr = RedisHelper.getProdInfotoRedis("b2d:ec:payDtl:" + id); ////PaymentDtl payDtl = JsonConvert.DeserializeObject<PaymentDtl>(payDtlStr); ////從kkday redis 取出 ////組出token res:pmgwTransNo, res:pmgwMethod ,res:pmch_resp ceil res:payAmount order_mid ////md5($pmgw_trans_no.$pmgw_method.$trans_curr_cd.$trans_amt.$pmch_ref_no.$key); ////PmchSslResponse res = JsonConvert.DeserializeObject<PmchSslResponse>(jsondata); //舊版 PmchSslResponse2 res = JsonConvert.DeserializeObject <PmchSslResponse2>(jsondata); //新版 //string transNo = GibberishAES.OpenSSLDecrypt(res.data.pmgw_trans_no, "pmgw@%#@trans*no"); ////CallJsonPay req = JsonConvert.DeserializeObject<CallJsonPay>(RedisHelper.getProdInfotoRedis("b2d:ec:pmchSslRequest:" + id)); //using KKday.Web.B2D.EC.AppCode; //CallJsonPay2 req = JsonConvert.DeserializeObject<CallJsonPay2>(RedisHelper.getProdInfotoRedis("b2d:ec:pmchSslRequest:" + id)); //using KKday.Web.B2D.EC.AppCode; //string token = Website.Instance.Configuration["kkdayKey:pmgwValidToken"].ToString(); //string pmgwMethod = res.data.pmgw_method; //string payCurrency = res.data.pay_currency; //string payAmount = Math.Ceiling(res.data.pay_amount).ToString(); //string pmgwValidToken = MD5Tool.GetMD5(transNo + pmgwMethod + payCurrency + payAmount + id + token); //KKapiHelper helper = new KKapiHelper(); //必須要再呼叫一次要讓FA 知道這個授權是kkday做的!而不是robot //string isSuccess = helper.PaymentValid(transNo, pmgwValidToken); //如果ok就upd //helper.PayUpdSuccessUpdOrder(id, transNo, payDtl, req, res, fakeContact);//舊版 //helper.PayUpdSuccessUpdOrder2(id, transNo, payDtl, req, res, fakeContact); //新版 Website.Instance.logger.Debug($",bookingStep3_id:{id},bookingStep3_jsondata:{jsondata}"); if (res.metadata.status != "0000") //授權失敗,直接跳付款失敗 { chkSuccess = false; } else { Boolean chk = ApiHelper.PaymentValid(id, jsondata); if (chk == false) { chkSuccess = false; } } string prodShowStr = RedisHelper.getRedis("b2d:ec:order:final:prodShow:" + id); if (prodShowStr != null) { prodShow = JsonConvert.DeserializeObject <BookingShowProdModel>(prodShowStr); } string orderDataStr = RedisHelper.getRedis("b2d:ec:order:final:orderData:" + id); if (orderDataStr != null) { orderData = JsonConvert.DeserializeObject <DataModel>(orderDataStr); } } else { chkSuccess = false; } //取挖字 //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE);// RedisHelper.getuiKey(fakeContact.lang); ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); ViewData["chkSuccess"] = chkSuccess; ViewData["prodShow"] = prodShow; ViewData["orderData"] = orderData; ViewData["prodTitle"] = title; return(View("Success")); }
//付款後導回 public IActionResult Step3(string id) { try { BookingShowProdModel prodShow = null; DataModel orderData = null; Boolean chkSuccess = true; //B2d分銷商資料 string jsondata = TempData[id + "forward"] as string; if (string.IsNullOrEmpty(jsondata)) { chkSuccess = false; } B2dAccount UserData = null; if (id != null && jsondata != null && chkSuccess == true) { PmchSslResponse2 res = JsonConvert.DeserializeObject <PmchSslResponse2>(jsondata); //新版 Website.Instance.logger.Debug($",bookingStep3_id:{id},bookingStep3_jsondata:{jsondata}"); if (res.metadata.status != "0000") //授權失敗,直接跳付款失敗 { chkSuccess = false; } else { Boolean chk = ApiHelper.PaymentValid(id, res); if (chk == false) { chkSuccess = false; } } string prodShowStr = RedisHelper.getRedis("b2d:ec:order:final:prodShow:" + id); if (prodShowStr != null) { prodShow = JsonConvert.DeserializeObject <BookingShowProdModel>(prodShowStr); } string orderDataStr = RedisHelper.getRedis("b2d:ec:order:final:orderData:" + id); if (orderDataStr != null) { orderData = JsonConvert.DeserializeObject <DataModel>(orderDataStr); } } else { chkSuccess = false; } //取挖字 //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE);// RedisHelper.getuiKey(fakeContact.lang); ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); ViewData["chkSuccess"] = chkSuccess; ViewData["prodShow"] = prodShow; ViewData["orderData"] = orderData; ViewData["prodTitle"] = title; return(View("Success")); } catch (Exception ex) { ViewData["errMsg"] = ex.Message.ToString(); Website.Instance.logger.Debug($"Final_Step3_err:{ex.Message.ToString()}"); //導到錯誤頁 return(RedirectToAction("Index", "Error", new ErrorViewModel { ErrorType = ErrorType.Order_Fail })); } }
// GET: /<controller>/ public IActionResult ProdList(string pg, string cat_main, string cat_sub, string key1, string citykey, string pricerange, string datefilter, string budget, string[] duration, string[] guidelang) { //紀錄目前頁次 int active_page_idx = Convert.ToInt32(pg ?? "1"); //紀緣分割後的durations if (duration != null) { _durations = duration.Select(s => s.Replace("-", ",")).ToArray(); } //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); //分銷商語系 string locale = UserData.LOCALE; //分銷商幣別 string currency = UserData.CURRENCY; //取得可售商品之國家&城市 var countries = CountryRepostory.GetCountries(locale); Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE); ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); List <ProductBaseModel> prodList = null; //查詢條件不為空值才查 if (!string.IsNullOrEmpty(key1) || !string.IsNullOrEmpty(citykey)) { int offset = (active_page_idx - 1) * 20; //計算從第幾筆開始 int size = 20; //分頁筆數 int total_count = 0; //out 參數 (接收返回的total_count參數) int total_pages = 0; //out 參數 (接收返回的total_pages參數) Facets facets = new Facets(); //out 參數 (接收返回的facets參數) Stats stats = new Stats(); //out 參數 (接收返回的stats參數) //取得資料 prodList = SearchRepostory.GetProduct(locale, currency, key1, citykey, offset, size, datefilter, budget, _durations, guidelang, cat_main, cat_sub, out total_count, out total_pages, out stats, out facets); List <CountryInfo> country = new List <CountryInfo>(); country = CountryRepostory.GetCountries(key1, citykey, locale); //當城市或國家不為空,則清除查詢關鍵字 if (country != null && country.Count() > 0) { //已選城市的判斷 if (!string.IsNullOrEmpty(citykey)) { var cd3 = country.SelectMany(co => co.Cities.Where(ci => ci.IsSelceted == true).ToList()).ToList().First(); string citycd = cd3.CityCode; ViewData["citycode"] = citycd; } else { var city = country.FirstOrDefault().Cities.FirstOrDefault(); city.IsSelceted = true; ViewData["citycode"] = city.CityCode; } key1 = null; } //傳入VIEW的參數 ViewData["total_count"] = total_count; ViewData["active_page_idx"] = active_page_idx; ViewData["total_pages"] = total_pages; ViewData["key"] = key1; ViewData["facets"] = facets; ViewData["duration"] = duration; ViewData["guidelang"] = guidelang; ViewData["stats"] = stats; ViewData["pricerange"] = !string.IsNullOrEmpty(pricerange) ? pricerange : string.Format("{0};{1}", stats.price.min, stats.price.max); ViewData["budget"] = !string.IsNullOrEmpty(budget) ? budget : string.Format("{0};{1}", stats.price.min, stats.price.max); ViewData["country"] = country; ViewData["prodTitle"] = title; } return(View(prodList)); }
// GET: /<controller>/ public IActionResult Index(string guid) { try { //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); string ip = httpContextAccessor.HttpContext.Request.HttpContext.Connection.RemoteIpAddress.ToString().Replace("::1", "127.0.0.1"); //取挖字 Dictionary <string, string> uikey = CommonRepostory.getuiKey(RedisHelper, UserData.LOCALE);// RedisHelper.getuiKey(fakeContact.lang); ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(JsonConvert.SerializeObject(uikey)); if (guid == null) { throw new Exception(title.common_data_error); } confirmPkgInfo confirm = JsonConvert.DeserializeObject <confirmPkgInfo>(RedisHelper.getRedis("bid:ec:confirm:" + guid)); if (confirm == null) { throw new Exception(title.common_data_error); } //從 api取 ProductModuleModel module = ProductRepostory.getProdModule(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, confirm.prodOid, confirm.pkgOid, title); ProductModel prod = ProductRepostory.getProdDtl(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, confirm.prodOid, title); PackageModel pkgs = ProductRepostory.getProdPkg(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, confirm.prodOid, title); if (prod.result != "0000") { Website.Instance.logger.Debug($"booking_index_getProdDtl_err:prodOid->{confirm.prodOid} ,msg-> {prod.result_msg}"); throw new Exception(title.result_code_9990); } if (pkgs.result != "0000") { Website.Instance.logger.Debug($"booking_index_getProdPkg_err:prodOid->{confirm.prodOid},pkgOid ->{confirm.pkgOid} ,msg-> {prod.result_msg}"); throw new Exception(title.result_code_9990); } string flightInfoType = ""; string sendInfoType = ""; PkgDetailModel pkg = null; PkgEventsModel pkgEvent = null; CusAgeRange cusAgeRange = null; string isEvent = "N"; string isHl = "N"; var pkgsTemp = pkgs.pkgs.Where(x => x.pkg_no == confirm.pkgOid).ToList(); if (pkgsTemp.Count() > 0) { foreach (PkgDetailModel p in pkgsTemp) { pkg = p; flightInfoType = p.module_setting.flight_info_type.value; sendInfoType = p.module_setting.send_info_type.value; cusAgeRange = BookingRepostory.getCusAgeRange(confirm, p); isEvent = p.is_event; isHl = p.is_hl; } } else { //丟錯誤頁 Website.Instance.logger.Debug($"booking_index_err:商編->{confirm.prodOid}即有pkgs找不到對應的pkgoid->{ confirm.pkgOid}"); throw new Exception(title.common_data_error); } //如果有event 但沒有傳 event id ,就error if (isEvent == "Y" && string.IsNullOrEmpty(confirm.pkgEvent)) { throw new Exception(title.common_data_error); } if (isEvent == "Y") { pkgEvent = ApiHelper.getPkgEvent(UserData.COMPANY_XID, UserData.COUNRTY_CODE, UserData.LOCALE, UserData.CURRENCY, confirm.prodOid, confirm.pkgOid, title); } //pmgw PmchLstResponse pmchRes = ApiHelper.getPaymentListRes(prod.countries, prod.prod_no.ToString(), DateTime.Now.ToString("yyyy-MM-dd"), DateTime.Now.ToString("yyyy-MM-dd"), DateTimeTool.yyyyMMdd2DateTime(confirm.selDate).ToString("yyyy-MM-dd"), DateTimeTool.yyyyMMdd2DateTime(confirm.selDate).ToString("yyyy-MM-dd"), UserData.COUNRTY_CODE, UserData.LOCALE, prod.prod_type, ip, prod.prod_hander, UserData.CURRENCY, title); Pmgw pmgw = null; if (UserData.CURRENCY == "TWD") { pmgw = pmchRes.pmchlist.Where(x => x.acctdocReceiveMethod == "ONLINE_CITI" && x.pmchCode == "B2D_CITI_TWD").FirstOrDefault(); } else { pmgw = pmchRes.pmchlist.Where(x => x.acctdocReceiveMethod == "ONLINE_HK_ADYEN").FirstOrDefault(); } //必須要設定人數 //var cusData = BookingRepostory.getCusDdate(); int totalCus = 0; if (module.module_cust_data != null) { if (module.module_cust_data.is_require == true) { totalCus = (module.module_cust_data.cus_type == "01") ? 1 : Convert.ToInt32(confirm.price1Qty + confirm.price2Qty + confirm.price3Qty + confirm.price4Qty); } } //滿足國家 List <Country> country = prod.countries; string nationName = ""; if (country.Count > 0) { nationName = country[0].name; } //將dataModel原型 以json str 帶到前台的hidden DataModel dm = DataSettingRepostory.getDefaultDataModel(totalCus, guid); dm.guidNo = guid; String dataModelStr = JsonConvert.SerializeObject(dm); //dm.travelerData[0].meal.mealType ViewData["dataModelStr"] = dataModelStr; VenueInfo venue = module.module_venue_info; if (venue == null) { venue = new VenueInfo(); venue.is_require = false; } RentCar rentCar = module.module_rent_car; if (rentCar == null) { rentCar = new RentCar(); rentCar.is_require = false; } ViewData["confirmPkgInfo"] = confirm; ViewData["contactInfo"] = UserData; ViewData["cusData"] = module.module_cust_data; ViewData["guide"] = module.module_guide_lang_list; ViewData["wifi"] = module.module_sim_wifi; ViewData["exchange"] = module.module_exchange_location_list; ViewData["flightInfo"] = module.module_flight_info; ViewData["venue"] = venue; // module.module_venue_info; ViewData["useDate"] = DateTimeTool.yyyy_mm_dd(confirm.selDate); //DateTimeTool.yyyy_mm_dd(); ViewData["rentCar"] = rentCar; // module.module_rent_car; ViewData["carPsgr"] = module.module_car_pasgr; //車輛資料 ViewData["sendData"] = module.module_send_data; ViewData["contactData"] = module.module_contact_data; ViewData["nationName"] = nationName; ViewData["guid"] = guid; ViewData["prodTitle"] = title; ViewData["totalCus"] = totalCus; ViewData["mainCat"] = prod.prod_type; ViewData["flightInfoType"] = flightInfoType; ViewData["sendInfoType"] = sendInfoType; ViewData["CutOfDay"] = prod.before_order_day; ViewData["cusAgeRange"] = cusAgeRange; BookingShowProdModel show = BookingRepostory.setBookingShowProd(prod, pkg, confirm, UserData.CURRENCY, pkgEvent, title); ViewData["prodShow"] = show; ViewData["isEvent"] = isEvent; // ViewData["isHl"] = isHl; //如果是N就不用做 ViewData["pkgCanUseDate"] = (isHl == "Y" && isEvent == "Y") ? BookingRepostory.getPkgEventDate(pkgEvent, confirm.pkgOid, (confirm.price1Qty + confirm.price2Qty + confirm.price3Qty + confirm.price4Qty)) : ""; //要把這個套餐可以用的日期全抓出來 ViewData["pmgw"] = pmgw; //放到session TempData["prod_" + guid] = JsonConvert.SerializeObject(prod); TempData["pkgEvent_" + guid] = (isHl == "Y" && isEvent == "Y") ? JsonConvert.SerializeObject(pkgEvent) : ""; TempData["module_" + guid] = JsonConvert.SerializeObject(module); TempData["confirm_" + guid] = JsonConvert.SerializeObject(confirm); TempData["ProdTitleKeep_" + guid] = JsonConvert.SerializeObject(title); TempData["pkg_" + guid] = JsonConvert.SerializeObject(pkg); TempData["pkgsDiscRule_" + guid] = JsonConvert.SerializeObject(pkgs.discount_rule); TempData["prodShow_" + guid] = JsonConvert.SerializeObject(show); TempData["pmgw_" + guid] = JsonConvert.SerializeObject(pmgw); return(View()); } catch (Exception ex) { ViewData["errMsg"] = ex.Message.ToString(); Website.Instance.logger.Debug($"booking_index_err:{ex.Message.ToString()}"); //導到錯誤頁 return(RedirectToAction("Index", "Error", new ErrorViewModel { ErrorType = ErrorType.Invalid_Common })); } }
public IActionResult bookingStep1([FromBody] DataModel data) { try { string memUuid = Website.Instance.Configuration["kkdayKey:uuid"]; string userAgent = Request.Headers["User-Agent"].ToString(); UserAgent ua = new UserAgent(userAgent); //B2d分銷商資料 var aesUserData = User.Identities.SelectMany(i => i.Claims.Where(c => c.Type == ClaimTypes.UserData).Select(c => c.Value)).FirstOrDefault(); var UserData = JsonConvert.DeserializeObject <B2dAccount>(AesCryptHelper.aesDecryptBase64(aesUserData, Website.Instance.AesCryptKey)); string ip = httpContextAccessor.HttpContext.Request.HttpContext.Connection.RemoteIpAddress.ToString().Replace("::1", "127.0.0.1"); data = BookingRepostory.setCardEncrypt(data); //log時把卡號移除 DataModel dataTemp = data.Clone(); dataTemp.card = null; Website.Instance.logger.Debug($"bookingStep1_inputdata:{ JsonConvert.SerializeObject(dataTemp)}"); string prodStr = TempData["prod_" + data.guidNo] as string; if (string.IsNullOrEmpty(prodStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } ProductModel prod = JsonConvert.DeserializeObject <ProductModel>(prodStr); string moduleStr = TempData["module_" + data.guidNo] as string; if (string.IsNullOrEmpty(moduleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } ProductModuleModel module = JsonConvert.DeserializeObject <ProductModuleModel>(moduleStr); string pkgStr = TempData["pkg_" + data.guidNo] as string; if (string.IsNullOrEmpty(pkgStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } PkgDetailModel pkg = JsonConvert.DeserializeObject <PkgDetailModel>(pkgStr); string pkgConfirmStr = TempData["confirm_" + data.guidNo] as string; if (string.IsNullOrEmpty(moduleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } confirmPkgInfo confirm = JsonConvert.DeserializeObject <confirmPkgInfo>(pkgConfirmStr); string titleStr = TempData["ProdTitleKeep_" + data.guidNo] as string; if (string.IsNullOrEmpty(moduleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } ProdTitleModel title = JsonConvert.DeserializeObject <ProdTitleModel>(titleStr); string discRuleStr = TempData["pkgsDiscRule_" + data.guidNo] as string; if (string.IsNullOrEmpty(discRuleStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } DiscountRuleModel rule = JsonConvert.DeserializeObject <DiscountRuleModel>(discRuleStr); string pmgwStr = TempData["pmgw_" + data.guidNo] as string; if (string.IsNullOrEmpty(pmgwStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } Pmgw pmgw = JsonConvert.DeserializeObject <Pmgw>(pmgwStr); string showStr = TempData["prodShow_" + data.guidNo] as string; if (string.IsNullOrEmpty(showStr)) { throw new Exception("資料錯誤,請重新讀取頁"); } //BookingShowProdModel show = JsonConvert.DeserializeObject<BookingShowProdModel>(showStr); TempData.Keep(); data = BookingRepostory.setDefaultBookingInfo(memUuid, ua, data, prod, pkg, confirm, UserData, pmgw); //排除餐食 data = BookingRepostory.exculdeFood(prod, data, module); data.company_xid = UserData.COMPANY_XID.ToString(); data.channel_oid = UserData.KKDAY_CHANNEL_OID; data.locale = UserData.LOCALE; data.ip = ip; JObject order = ApiHelper.orderNew(data, title); string orderMid = ""; string orderOid = ""; returnStatus status = new returnStatus(); Website.Instance.logger.Debug($"bookingStep1_ordernewresponse:" + JsonConvert.SerializeObject(order));//要改 //要先判斷是不是result='0000' if (order["result"].ToString() == "0000") { orderMid = order["order_mid"].ToString(); orderOid = order["order_oid"].ToString(); //upd B2bOrder //BookingRepostory.updB2dOrder(UserData.COMPANY_XID, orderOid, orderMid, b2bOrder, title); status.pmchSslRequest = BookingRepostory.setPaymentInfo2(prod, data, orderMid, UserData, pmgw, memUuid, ip); status.status = "OK"; status.url = Website.Instance.Configuration["kkUrl:pmchUrl"].ToString() + pmgw.pmchPayURL; //pmchUrl //要把BookingShowProdModel 帶到訂購final頁 RedisHelper.SetRedis(showStr, "b2d:ec:order:final:prodShow:" + orderMid, 60); RedisHelper.SetRedis(JsonConvert.SerializeObject(data), "b2d:ec:order:final:orderData:" + orderMid, 60); //要存redis 付款主要資訊,最後訂單 upd時要使用,可和下面整合存一個就 BookingRepostory.setPayDtltoRedis(data, orderMid, UserData.UUID, RedisHelper); //要存redis 因為付款後要從這個redis內容再進行payment驗證,可和上面整合存一個就好 //CallJsonPay rdsJson = (CallJsonPay)status.pmchSslRequest.json; CallJsonPay2 rdsJson = (CallJsonPay2)status.pmchSslRequest.json; string callPmchReq = JsonConvert.SerializeObject(status.pmchSslRequest.json); RedisHelper.SetRedis(callPmchReq, "b2d:ec:pmchSslRequest:" + orderMid, 60); } else { status.status = "Error"; status.msgErr = order["content"]["result"].ToString() + order["content"]["msg"].ToString();//要改 } return(Json(status)); //v1/channel/citi/auth //https://pmch.sit.kkday.com/citi/payment/auth //https://payment.kkday.com/v1/channel/adyen/auth } catch (Exception ex) { Website.Instance.logger.Debug($"bookingStep1_err_ordernew失敗:{ex.Message.ToString()}"); ViewData["errMsg"] = ex.Message.ToString(); Website.Instance.logger.Debug($"booking_index_err:{ex.Message.ToString()}"); //導到錯誤頁 return(RedirectToAction("Index", "Error", new ErrorViewModel { ErrorType = ErrorType.Order_Fail, ErrorMessage = ex.Message.ToString() })); } }