HomeController.cs 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.Globalization;
  5. using System.Linq;
  6. using System.Threading;
  7. using System.Threading.Tasks;
  8. using LotteryWebApp.Common;
  9. using LotteryWebApp.Extensions;
  10. using LotteryWebApp.Languages;
  11. using LotteryWebApp.Models;
  12. using LotteryWebApp.Service;
  13. using Microsoft.AspNetCore.Hosting;
  14. using Microsoft.AspNetCore.Http;
  15. using Microsoft.AspNetCore.Localization;
  16. using Microsoft.AspNetCore.Mvc;
  17. using Microsoft.Extensions.Configuration;
  18. using Microsoft.Extensions.Logging;
  19. using Newtonsoft.Json;
  20. namespace LotteryWebApp.Controllers
  21. {
  22. [AutoValidateAntiforgeryToken]
  23. public class HomeController : BaseController
  24. {
  25. private static readonly log4net.ILog log = log4net.LogManager.GetLogger(typeof(Program));
  26. IConfiguration configuration;
  27. private readonly IWebHostEnvironment webHostEnvironment;
  28. APIFunctions api = new APIFunctions();
  29. bool flashViewEnabled = false;
  30. public HomeController(IConfiguration _configuration, IWebHostEnvironment hostEnvironment)
  31. {
  32. configuration = _configuration;
  33. webHostEnvironment = hostEnvironment;
  34. }
  35. public String GetParameter(String key)
  36. {
  37. return configuration.GetSection(key).Value;
  38. }
  39. public IActionResult FlashView()
  40. {
  41. return View();
  42. }
  43. public JsonResult SetCulture(string lang)
  44. {
  45. try
  46. {
  47. Response.Cookies.Append(
  48. CookieRequestCultureProvider.DefaultCookieName,
  49. CookieRequestCultureProvider.MakeCookieValue(new RequestCulture(lang)),
  50. new CookieOptions { Expires = DateTimeOffset.UtcNow.AddYears(1) }
  51. );
  52. HttpContext.Session.SetComplexData("culture", lang);
  53. }
  54. catch (Exception ex)
  55. {
  56. log.Error("Exp: " + ex);
  57. }
  58. return Json(new { });
  59. }
  60. public async Task<IActionResult> IndexAsync(
  61. string termType,
  62. String uuid,
  63. String mcuid,
  64. String phonenumber,
  65. String token
  66. )
  67. {
  68. //return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Home/Update");
  69. //String param = "transactionId=" + "ABC" + "&requestId=" + "DEF" + "&money=" + "100";
  70. //String url = CreatePrivateURL(configuration, param, "seconds", "0", "0", GetParameter("rsaPolicy"));
  71. HomeIndex_ViewModel model = new HomeIndex_ViewModel();
  72. try
  73. {
  74. HttpContext.Session.SetComplexData("navigator", Constants.HOME_NAVIGATOR);
  75. CultureInfo currentCulture = Thread.CurrentThread.CurrentCulture;
  76. String lang = currentCulture.Name;
  77. log.Info("lang: " + lang);
  78. String msisdnAuto = null;
  79. // check auto login ?uuid=681471d23b83f0a463e2dd5671ea0fc5
  80. // ?uuid=681471d23b83f0a463e2dd5671ea0fc5&mcuid=6c6948a89908d83aec8c05be256970a1&mcapp=mocha
  81. if (!CheckAuthToken())
  82. {
  83. //String uri = HttpContext.Request.QueryString.ToUriComponent().ToString();
  84. log.Info("UUID: " + uuid);
  85. log.Info("token: " + token);
  86. //token = "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJ1c2VySW5mb3IiLCJleHAiOjE3MTAzODE0NTksInV1aWQiOiI1MGEwYjNlNzk5ZjllZDU3YTE1ZjZjNjljODVmYTM3NSJ9.EgR-P_KzsHJ1XCdgeu25Gy_-qAHOfM9uv9RTZSvr0AA";
  87. if (token != null)
  88. {
  89. // nhan dien qua token
  90. AutoLoginRequest autoLoginRequest = new AutoLoginRequest();
  91. autoLoginRequest.token = token;
  92. AutoLoginResponse autoLoginResponse = await api.AutoLoginApiAsync(
  93. configuration,
  94. autoLoginRequest
  95. );
  96. if (autoLoginResponse.code == Code.SUCCESS_CODE)
  97. {
  98. string msisdnReal = validateMsisdn(
  99. autoLoginResponse.data.msisdn.Substring(1)
  100. );
  101. if (msisdnReal == "")
  102. {
  103. return Redirect(
  104. GetParameter(Constants.SUB_DOMAIN) + "/Account/Login"
  105. );
  106. }
  107. // check local system
  108. CheckAccountRequest checkAccountRequest = new CheckAccountRequest
  109. {
  110. msisdn = msisdnReal,
  111. channel = Constants.WEB_CHANNEL,
  112. language = lang == "en" ? "0" : "1"
  113. };
  114. CheckAccountResponse checkAccountResponse = api.CheckAccountApi(
  115. configuration,
  116. checkAccountRequest
  117. );
  118. if (checkAccountResponse.status == Code.SUCCESS)
  119. {
  120. string tokenGetReal = checkAccountResponse.token;
  121. HttpContext.Session.SetComplexData("msisdn", msisdnReal);
  122. // create session
  123. // create new auth
  124. CreateAuthToken();
  125. HttpContext.Session.SetComplexData("token", tokenGetReal);
  126. // load user status
  127. UserGetProfileRequest userGetProfileRequest =
  128. new UserGetProfileRequest
  129. {
  130. users = msisdnReal,
  131. token = tokenGetReal
  132. };
  133. Profile profileGet = api.UserLoadProfileApi(
  134. configuration,
  135. userGetProfileRequest
  136. );
  137. HttpContext.Session.SetComplexData("profile", profileGet);
  138. // load profile
  139. UserStatusRequest userStatusRequest = new UserStatusRequest
  140. {
  141. users = msisdnReal,
  142. token = tokenGetReal
  143. };
  144. UserStatus userStatusGet = api.GetUserStatusApi(
  145. configuration,
  146. userStatusRequest
  147. );
  148. HttpContext.Session.SetComplexData("userStatus", userStatusGet);
  149. }
  150. else
  151. {
  152. return Redirect(
  153. GetParameter(Constants.SUB_DOMAIN) + "/Account/Login"
  154. );
  155. }
  156. }
  157. }
  158. else if (uuid != null)
  159. {
  160. // nhan dien thue bao
  161. //string uuid = HttpContext.Request.QueryString.ToUriComponent().ToString().Substring(6);
  162. //String uuid = data.Substring(data.Length - 5, data.Length);
  163. String res = await CheckAutoLogin(log, uuid);
  164. log.Info("uuid: " + uuid + " res: " + res);
  165. if (res != null)
  166. {
  167. dynamic json = JsonConvert.DeserializeObject(res);
  168. log.Info("res json: " + json);
  169. String code = json["code"];
  170. if (code == "200")
  171. {
  172. String errorCode = json["errorCode"];
  173. if (errorCode == "200")
  174. {
  175. msisdnAuto = json["data"]["msisdn"];
  176. log.Info("msisdnAuto: " + msisdnAuto);
  177. }
  178. }
  179. }
  180. // redirect to OTP screen
  181. String msisdnDetect = validateMsisdn(msisdnAuto.Substring(1));
  182. if (msisdnDetect != "")
  183. {
  184. // get OTP
  185. RegisterRequest request = new RegisterRequest();
  186. request.Msisdn = msisdnDetect;
  187. RegisterResponse reset = api.UserForgotPasswordApi(
  188. configuration,
  189. request
  190. );
  191. if (reset.status == Code.SUCCESS)
  192. {
  193. HttpContext.Session.Remove("regInfos");
  194. HttpContext.Session.SetComplexData("msisdn", msisdnDetect);
  195. // return to login
  196. return Redirect(
  197. GetParameter(Constants.SUB_DOMAIN) + "/Account/Login?step=2"
  198. );
  199. }
  200. }
  201. // return to view to get phone number
  202. model.termType = termType != null ? termType : Constants.GameGroup.Singapore;
  203. //model.uuid = uuid;
  204. //model.subDomain = GetParameter(Constants.SUB_DOMAIN);
  205. return Redirect(
  206. GetParameter(Constants.SUB_DOMAIN)
  207. + "/Account/Login?message="
  208. + Lang.reset_after_1_minute
  209. );
  210. }
  211. else if (phonenumber != null)
  212. {
  213. String channel = GetParameter(Constants.CHANNEL);
  214. if (channel == ApiConstants.WALLET)
  215. {
  216. //giai ma
  217. String msisdnRSA = DecryptRSA(configuration, phonenumber);
  218. // login
  219. HttpContext.Session.SetComplexData("msisdn", msisdnRSA);
  220. // create session
  221. // create new auth
  222. CreateAuthToken();
  223. // login success --> store session
  224. HttpContext.Session.SetComplexData("token", ApiConstants.WALLET_TOKEN);
  225. // load profile
  226. // load user status
  227. UserGetProfileRequest userGetProfileRequest = new UserGetProfileRequest
  228. {
  229. users = msisdnRSA,
  230. token = ApiConstants.WALLET_TOKEN
  231. };
  232. Profile profileGet = api.UserLoadProfileApi(
  233. configuration,
  234. userGetProfileRequest
  235. );
  236. HttpContext.Session.SetComplexData("profile", profileGet);
  237. // load profile
  238. UserStatusRequest userStatusRequest = new UserStatusRequest
  239. {
  240. users = msisdnRSA,
  241. token = ApiConstants.WALLET_TOKEN
  242. };
  243. UserStatus userStatusGet = api.GetUserStatusApi(
  244. configuration,
  245. userStatusRequest
  246. );
  247. HttpContext.Session.SetComplexData("userStatus", userStatusGet);
  248. }
  249. else
  250. {
  251. // after auto detect
  252. String msisdnGet = phonenumber.Substring(1);
  253. String msisdnDetect = validateMsisdn(msisdnGet);
  254. if (msisdnDetect != "")
  255. {
  256. // auto login
  257. // reload user info
  258. HttpContext.Session.Remove("regInfos");
  259. HttpContext.Session.SetComplexData("msisdn", msisdnDetect);
  260. // return to login
  261. return Redirect(
  262. GetParameter(Constants.SUB_DOMAIN) + "/Account/Login?step=2"
  263. );
  264. }
  265. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  266. }
  267. }
  268. else
  269. {
  270. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  271. }
  272. }
  273. Profile profile = HttpContext.Session.GetComplexData<Profile>("profile");
  274. UserStatus userStatus = HttpContext.Session.GetComplexData<UserStatus>(
  275. "userStatus"
  276. );
  277. // login success --> store session
  278. model.termType = termType != null ? termType : Constants.GameGroup.Singapore;
  279. model.userStatus = userStatus;
  280. model.profile = profile;
  281. // get time to nearest term
  282. model.listTerm = new List<Term>();
  283. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  284. String tokenGet = HttpContext.Session.GetComplexData<String>("token");
  285. string fromDate = DateTime.Now.ToString("dd/MM/yyyy");
  286. string toDate = DateTime.Now.AddDays(7).ToString("dd/MM/yyyy");
  287. // get winner
  288. GetTopWinnerRequest getTopWinnerRequest = new GetTopWinnerRequest();
  289. getTopWinnerRequest.type = lang == "en" ? "0" : "1";
  290. getTopWinnerRequest.token = tokenGet;
  291. GetTopWininerResponse getTopWininerResponse = api.GetTopWinnerApi(
  292. configuration,
  293. getTopWinnerRequest
  294. );
  295. if (getTopWininerResponse.responseCode == Code.SUCCESS)
  296. {
  297. model.topWinner = getTopWininerResponse.list;
  298. HttpContext.Session.SetComplexData("topWinner", model.topWinner);
  299. }
  300. ResultOfTermRequest resultOfTermRequest = new ResultOfTermRequest
  301. {
  302. gameId = model.termType,
  303. token = tokenGet,
  304. type = Constants.TERM_HAS_NOT_RESULT_TYPE,
  305. order = Constants.DECS,
  306. fromDate = fromDate,
  307. toDate = toDate,
  308. rowsOnPage = Constants.ROW_ON_PAGE,
  309. seqPage = "1",
  310. id = Constants.ALL_DATA
  311. };
  312. ResultOfTermResponse result = api.GetResultOfTermApi(
  313. configuration,
  314. resultOfTermRequest
  315. );
  316. if (result.responseCode == Code.SESSION_EXPIRED)
  317. {
  318. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  319. }
  320. else if (result.responseCode == Code.SUCCESS)
  321. {
  322. model.listTerm = result.listTerm;
  323. }
  324. }
  325. catch (Exception ex)
  326. {
  327. log.Error(ex);
  328. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  329. }
  330. return View(model);
  331. }
  332. [ValidateAntiForgeryToken]
  333. public IActionResult TermResult(string termType)
  334. {
  335. if (!CheckAuthToken())
  336. {
  337. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  338. }
  339. TermResultModel model = new TermResultModel();
  340. model.listTerm = new List<Term>();
  341. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  342. String token = HttpContext.Session.GetComplexData<String>("token");
  343. String fromDate = DateTime.Now.AddDays(-10).ToString("dd/MM/yyyy");
  344. String toDate = DateTime.Now.ToString("dd/MM/yyyy");
  345. // get result
  346. ResultOfTermRequest resultOfTermRequest = new ResultOfTermRequest
  347. {
  348. gameId = termType,
  349. token = token,
  350. type = Constants.TERM_HAS_RESULT_TYPE,
  351. order = Constants.DECS,
  352. fromDate = fromDate,
  353. toDate = toDate,
  354. rowsOnPage = Constants.ROW_ON_PAGE,
  355. seqPage = "1",
  356. id = Constants.ALL_DATA
  357. };
  358. ResultOfTermResponse result = api.GetResultOfTermApi(
  359. configuration,
  360. resultOfTermRequest
  361. );
  362. if (result.responseCode == Code.SESSION_EXPIRED)
  363. {
  364. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  365. }
  366. else if (result.responseCode == Code.SUCCESS)
  367. {
  368. if (result.listTerm != null)
  369. model.listTerm = result.listTerm;
  370. model.termType = termType;
  371. }
  372. return PartialView("TermResult", model);
  373. }
  374. public IActionResult Transfer(string step, string walletType, string message)
  375. {
  376. if (!CheckAuthToken())
  377. {
  378. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  379. }
  380. HomeTransfer_ViewModel model = new HomeTransfer_ViewModel();
  381. try
  382. {
  383. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  384. String token = HttpContext.Session.GetComplexData<String>("token");
  385. Profile profile = HttpContext.Session.GetComplexData<Profile>("profile");
  386. UserStatus userStatus = HttpContext.Session.GetComplexData<UserStatus>(
  387. "userStatus"
  388. );
  389. TransferMoneyRequest transferData =
  390. HttpContext.Session.GetComplexData<TransferMoneyRequest>("transferData");
  391. model.step = step != null ? step : Constants.TRANSFER_SHOW;
  392. model.walletType =
  393. walletType != null ? walletType : Constants.NATCASH_WALLET_TRANSFER;
  394. model.profile = profile;
  395. model.userStatus = userStatus;
  396. model.transferData = transferData;
  397. model.message = message;
  398. if (step == Constants.TRANSFER_RESULT)
  399. {
  400. // get payment info
  401. String paymentCode = HttpContext.Session.GetComplexData<String>("paymentCode");
  402. TransactionInfoRequest transactionInfoRequest = new TransactionInfoRequest
  403. {
  404. id = paymentCode,
  405. msisdn = msisdn,
  406. token = token
  407. };
  408. TransactionInfoResponse transactionInfoResponse = api.GetTransactionInfoApi(
  409. configuration,
  410. transactionInfoRequest
  411. );
  412. // set code
  413. model.code = transactionInfoResponse.responseCode;
  414. //
  415. if (transactionInfoResponse.responseCode == Code.SESSION_EXPIRED)
  416. {
  417. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  418. }
  419. else if (transactionInfoResponse.responseCode == Code.SUCCESS)
  420. {
  421. TransferMoneyRequest transferMoneyRequest =
  422. HttpContext.Session.GetComplexData<TransferMoneyRequest>(
  423. "transferData"
  424. );
  425. model.walletType = transferMoneyRequest.channelPayment;
  426. if (transactionInfoResponse.list.Count > 0)
  427. {
  428. model.transaction = transactionInfoResponse.list[0];
  429. }
  430. else
  431. {
  432. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Home/Error");
  433. }
  434. }
  435. }
  436. }
  437. catch (Exception ex)
  438. {
  439. log.Error(ex);
  440. }
  441. return View(model);
  442. }
  443. [ValidateAntiForgeryToken]
  444. public IActionResult TransactionConfirm_Action(
  445. string walletType,
  446. string receivernumber,
  447. string moneyon
  448. )
  449. {
  450. try
  451. {
  452. if (!CheckAuthToken())
  453. {
  454. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  455. }
  456. // send otp to user and show otp partial
  457. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  458. String token = HttpContext.Session.GetComplexData<String>("token");
  459. //String receiver = walletType == Constants.NATCASH_WALLET_TRANSFER ? null : msisdn;
  460. String receiver = msisdn;
  461. //if (walletType == Constants.NATCASH_WALLET_TRANSFER)
  462. //{
  463. // receiver = validateMsisdn(receivernumber);
  464. // if (receiver == "")
  465. // {
  466. // return Json(new
  467. // {
  468. // code = Code.FAILURE,
  469. // message = Lang.phone_invalid
  470. // });
  471. // }
  472. //}
  473. // save info to session
  474. TransferMoneyRequest transferMoneyRequest = new TransferMoneyRequest();
  475. transferMoneyRequest.money = moneyon;
  476. transferMoneyRequest.msisdn = msisdn;
  477. transferMoneyRequest.msisdnReceive = receiver;
  478. transferMoneyRequest.channelPayment = walletType;
  479. HttpContext.Session.SetComplexData("transferData", transferMoneyRequest);
  480. return Json(new { code = Code.SUCCESS, });
  481. }
  482. catch (Exception ex)
  483. {
  484. log.Error(ex);
  485. }
  486. return Json(new { code = Code.FAILURE, message = Lang.error_happened });
  487. }
  488. [ValidateAntiForgeryToken]
  489. public JsonResult TransactionSendOTP_Action()
  490. {
  491. try
  492. {
  493. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  494. String token = HttpContext.Session.GetComplexData<String>("token");
  495. TransferMoneyRequest transferData =
  496. HttpContext.Session.GetComplexData<TransferMoneyRequest>("transferData");
  497. String content =
  498. Lang.confirm_transfer_1
  499. + " "
  500. + transferData.money
  501. + Lang.confirm_transfer_2
  502. + " "
  503. + transferData.msisdnReceive
  504. + Lang.confirm_transfer_3;
  505. // send OTP
  506. SendOTPRequest sendOTPRequest = new SendOTPRequest();
  507. sendOTPRequest.msisdn = msisdn;
  508. sendOTPRequest.token = token;
  509. SendOTPResponse sendOTPResponse = api.SendOTPApi(configuration, sendOTPRequest);
  510. return Json(
  511. new
  512. {
  513. code = int.Parse(sendOTPResponse.responseCode),
  514. message = GetLangFromCode(sendOTPResponse.responseCode),
  515. content = content,
  516. }
  517. );
  518. }
  519. catch (Exception ex)
  520. {
  521. log.Error(ex);
  522. }
  523. return Json(new { code = Code.FAILURE, message = Lang.error_happened });
  524. }
  525. [ValidateAntiForgeryToken]
  526. public JsonResult TransactionResentOTP_Action()
  527. {
  528. try
  529. {
  530. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  531. String token = HttpContext.Session.GetComplexData<String>("token");
  532. // send OTP
  533. SendOTPRequest sendOTPRequest = new SendOTPRequest
  534. {
  535. msisdn = msisdn,
  536. token = token
  537. };
  538. SendOTPResponse sendOTPResponse = api.SendOTPApi(configuration, sendOTPRequest);
  539. return Json(
  540. new
  541. {
  542. code = int.Parse(sendOTPResponse.responseCode),
  543. message = GetLangFromCode(sendOTPResponse.responseCode),
  544. }
  545. );
  546. }
  547. catch (Exception ex)
  548. {
  549. log.Error(ex);
  550. }
  551. return Json(new { code = Code.FAILURE, message = Lang.error_happened });
  552. }
  553. [ValidateAntiForgeryToken]
  554. public JsonResult TransactionConfirmOTP_Action(string otp)
  555. {
  556. try
  557. {
  558. String token = HttpContext.Session.GetComplexData<String>("token");
  559. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  560. TransferMoneyRequest transferMoneyRequest =
  561. HttpContext.Session.GetComplexData<TransferMoneyRequest>("transferData");
  562. transferMoneyRequest.otp = otp;
  563. transferMoneyRequest.token = token;
  564. TransferMoneyResponse transferMoneyResponse = api.TransferMoneyApi(
  565. configuration,
  566. transferMoneyRequest
  567. );
  568. if (transferMoneyResponse.responseCode == Code.SUCCESS)
  569. {
  570. // save payment code
  571. //HttpContext.Session.DeleteComplexData("transferData");
  572. HttpContext.Session.SetComplexData(
  573. "paymentCode",
  574. transferMoneyResponse.paymentCode
  575. );
  576. // load user status
  577. UserGetProfileRequest userGetProfileRequest = new UserGetProfileRequest
  578. {
  579. users = msisdn,
  580. token = token
  581. };
  582. Profile profile = api.UserLoadProfileApi(configuration, userGetProfileRequest);
  583. HttpContext.Session.SetComplexData("profile", profile);
  584. // load profile
  585. UserStatusRequest userStatusRequest = new UserStatusRequest
  586. {
  587. users = msisdn,
  588. token = token
  589. };
  590. UserStatus userStatus = api.GetUserStatusApi(configuration, userStatusRequest);
  591. HttpContext.Session.SetComplexData("userStatus", userStatus);
  592. }
  593. return Json(
  594. new
  595. {
  596. code = int.Parse(transferMoneyResponse.responseCode),
  597. message = GetLangFromCode(transferMoneyResponse.responseCode),
  598. }
  599. );
  600. }
  601. catch (Exception ex)
  602. {
  603. log.Error(ex);
  604. }
  605. return Json(new { code = Code.FAILURE, message = Lang.error_happened });
  606. }
  607. public IActionResult Rules(string termType)
  608. {
  609. if (!CheckAuthToken())
  610. {
  611. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  612. }
  613. HomeRules_ViewModel model = new HomeRules_ViewModel();
  614. try
  615. {
  616. model.termType = termType != null ? termType : Constants.GameGroup.Singapore;
  617. }
  618. catch (Exception ex)
  619. {
  620. log.Error(ex);
  621. }
  622. return View(model);
  623. }
  624. public IActionResult Results(string termType, string fromDate, string toDate)
  625. {
  626. if (!CheckAuthToken())
  627. {
  628. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  629. }
  630. HttpContext.Session.SetComplexData("navigator", Constants.RESULT_NAVIGATOR);
  631. HomeResults_ViewModel model = new HomeResults_ViewModel();
  632. try
  633. {
  634. model.termType = termType != null ? termType : Constants.GameGroup.Singapore;
  635. model.fromDate =
  636. fromDate != null ? fromDate : DateTime.Now.AddDays(-2).ToString("dd/MM/yyyy");
  637. model.toDate = toDate != null ? toDate : DateTime.Now.ToString("dd/MM/yyyy");
  638. }
  639. catch (Exception ex)
  640. {
  641. log.Error(ex);
  642. }
  643. return View(model);
  644. }
  645. public IActionResult TermResultHistory(string termType, string fromDate, string toDate)
  646. {
  647. if (!CheckAuthToken())
  648. {
  649. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  650. }
  651. TermResultModel model = new TermResultModel();
  652. model.listTerm = new List<Term>();
  653. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  654. String token = HttpContext.Session.GetComplexData<String>("token");
  655. //String fromDate = DateTime.Now.AddDays(-10).ToString("dd/MM/yyyy");
  656. //String toDate = DateTime.Now.ToString("dd/MM/yyyy");
  657. // get result
  658. ResultOfTermRequest resultOfTermRequest = new ResultOfTermRequest
  659. {
  660. gameId = termType,
  661. token = token,
  662. type = Constants.TERM_HAS_RESULT_TYPE,
  663. order = Constants.DECS,
  664. fromDate = fromDate,
  665. toDate = toDate,
  666. rowsOnPage = Constants.ROW_ON_PAGE,
  667. seqPage = "1",
  668. id = Constants.ALL_DATA
  669. };
  670. ResultOfTermResponse result = api.GetResultOfTermApi(
  671. configuration,
  672. resultOfTermRequest
  673. );
  674. if (result.responseCode == Code.SESSION_EXPIRED)
  675. {
  676. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  677. }
  678. else if (result.responseCode == Code.SUCCESS)
  679. {
  680. if (result.listTerm != null)
  681. model.listTerm = result.listTerm;
  682. model.termType = termType;
  683. }
  684. return PartialView("TermResultHistory", model);
  685. }
  686. public IActionResult Privacy()
  687. {
  688. return View();
  689. }
  690. public IActionResult Update()
  691. {
  692. return View();
  693. }
  694. public IActionResult FAQ()
  695. {
  696. if (!CheckAuthToken())
  697. {
  698. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  699. }
  700. HomeFAQ_ViewModel model = new HomeFAQ_ViewModel();
  701. return View("FAQ", model);
  702. }
  703. [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
  704. public IActionResult Error()
  705. {
  706. return View(
  707. new ErrorViewModel
  708. {
  709. RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier
  710. }
  711. );
  712. }
  713. public IActionResult TransferHistory()
  714. {
  715. return View();
  716. }
  717. [ValidateAntiForgeryToken]
  718. public IActionResult TransferHistoryLoad(string seqpage)
  719. {
  720. if (!CheckAuthToken())
  721. {
  722. return Redirect(GetParameter(Constants.SUB_DOMAIN) + "/Account/Login");
  723. }
  724. HistoryTransfer_ViewModel model = new HistoryTransfer_ViewModel();
  725. model.moneyConverts = new List<MoneyConvert>();
  726. try
  727. {
  728. String msisdn = HttpContext.Session.GetComplexData<String>("msisdn");
  729. String token = HttpContext.Session.GetComplexData<String>("token");
  730. MoneyConvertReq req = new MoneyConvertReq();
  731. req.msisdn = msisdn;
  732. req.token = token;
  733. req.getDetail = "0";
  734. req.id = Constants.ALL_DATA;
  735. req.rowsOnPage = Constants.ROW_ON_PAGE;
  736. req.seqPage = seqpage != null ? seqpage : "1";
  737. req.order = Constants.DECS;
  738. MoneyConvertRes res = api.GetListConvertByUser(configuration, req);
  739. if (res.responseCode == Code.SUCCESS)
  740. {
  741. if (res.list != null)
  742. {
  743. model.moneyConverts = res.list;
  744. // append
  745. List<MoneyConvert> listTransfers = HttpContext.Session.GetComplexData<List<MoneyConvert>>("listTransfers");
  746. if (listTransfers != null && listTransfers.Count > 0)
  747. {
  748. listTransfers.AddRange(res.list);
  749. }
  750. else
  751. {
  752. listTransfers = res.list;
  753. }
  754. HttpContext.Session.SetComplexData("listTransfers", listTransfers);
  755. }
  756. }
  757. }
  758. catch (Exception ex)
  759. {
  760. log.Error(ex);
  761. }
  762. return PartialView("_TransferHis", model);
  763. }
  764. }
  765. }