void oneTimeLinkLogin() { JToken result = new JObject(); Model.Member.Define memberDefine = new Model.Member.Define(); byte[] decbuff = Convert.FromBase64String(Request["post"]); var o = System.Text.Encoding.UTF8.GetString(decbuff); var json = JsonConvert.DeserializeObject <JObject>(o); int memberId; string ip = glbf.GetClientIP(); int agentId; string memberGuid; string agentId_s = (json["agentId"] ?? "").ToString(); var chkAgentIdFmt = int.TryParse(agentId_s, out agentId); if (chkAgentIdFmt == false) { result["result"] = "fail"; result["msg"] = "代理帳號格式錯誤"; result["errorCode"] = ApiErrorCodes.AgentIdExistFalse; Response.Write(JsonConvert.SerializeObject(result)); return; } var chkAgentIdExit = memberDefine.CheckMemberIdExist(agentId); if (chkAgentIdExit == false) { result["result"] = "fail"; result["msg"] = "代理帳號不存在"; result["errorCode"] = ApiErrorCodes.AgentIdExistFalse; Response.Write(JsonConvert.SerializeObject(result)); return; } string externalId_s = (json["externalId"] ?? "").ToString(); var checkExternalIdExit = memberDefine.CheckMemberExternalIdExist(externalId_s, agentId); if (checkExternalIdExit == false) { result["result"] = "fail"; result["msg"] = "externalId不存在"; result["errorCode"] = ApiErrorCodes.NotFindUsername; Response.Write(JsonConvert.SerializeObject(result)); return; } memberId = memberDefine.GetMemberId(externalId_s, agentId); memberGuid = memberDefine.GetMemberGuid(memberId); string guid_s = (json["guid"] ?? "").ToString(); if (guid_s != memberGuid) { result["result"] = "fail"; result["msg"] = "guid錯誤"; result["errorcode"] = ApiErrorCodes.NotFindUsername; Response.Write(JsonConvert.SerializeObject(result)); return; } Model.Member.Edit memberEdit = new Model.Member.Edit(); Model.Member.Edit.MemberLoginStruct s = new Model.Member.Edit.MemberLoginStruct(); s.MemberId = memberId; s.LoginIP = ip; memberEdit.MemberLoginStructHandle(s); result["result"] = "success"; result["msg"] = "登入成功"; Response.Redirect("./index"); }
void Login() { JToken result = new JObject(); Model.Member.Define memberDefine = new Model.Member.Define(); string clientIP = glbf.GetClientIP(); int agentId; int agentLevelId; string agentStatus; string username = (req["username"] ?? "").ToString(); var chkUsernameExit = memberDefine.CheckMemberUsernameExist(username); if (chkUsernameExit == false) { result["result"] = "fail"; result["msg"] = "無此帳號"; result["column"] = "username"; Response.Write(JsonConvert.SerializeObject(result)); return; } agentId = memberDefine.GetMemberId(username); agentLevelId = memberDefine.GetMemberLevelId(agentId); agentStatus = memberDefine.GetMemberStatus(agentId); if (agentLevelId < 7) { result["result"] = "fail"; result["msg"] = "非代理帳號"; result["column"] = "agentId"; Response.Write(JsonConvert.SerializeObject(result)); return; } if (agentStatus == Model.Member.Define.MemberStauts.Disable) { result["result"] = "fail"; result["msg"] = "帳號鎖定"; result["column"] = "status"; Response.Write(JsonConvert.SerializeObject(result)); return; } else if (agentStatus == Model.Member.Define.MemberStauts.NeedToChangePassword) { result["result"] = "fail"; result["msg"] = "請修改密碼後再次登入"; result["column"] = "status"; Response.Write(JsonConvert.SerializeObject(result)); return; } string password = (req["password"] ?? "").ToString(); if (password != memberDefine.GetMemberPassword(agentId)) { result["result"] = "fail"; result["msg"] = "密碼錯誤"; result["column"] = "password"; Response.Write(JsonConvert.SerializeObject(result)); return; } Model.Member.Edit e = new Model.Member.Edit(); Model.Member.Edit.AgentLoginStruct s = new Model.Member.Edit.AgentLoginStruct(); s.AgentId = agentId; s.LoginIP = clientIP; e.AgentLoginStructHandle(s); result["result"] = "success"; result["msg"] = "登入成功"; result["id"] = agentId.ToString(); Response.Write(JsonConvert.SerializeObject(result)); }
void betFormAdd() { JToken result = new JObject(); if (glbf.GetLoginStatus() != 2) { result["result"] = "fail"; result["msg"] = "未完成登入程序"; result["column"] = "session"; Response.Write(JsonConvert.SerializeObject(result)); return; } Model.Member.Define memberDefine = new Model.Member.Define(); Model.BetForm.Define betFormDefine = new Model.BetForm.Define(); int memberId = (int)Session["id"]; int parentId = (int)Session["parentId"]; string ip = glbf.GetClientIP(); string periodId = betFormDefine.GetLotteryPeriodId(); JObject chooseBallObj; string betType; string betBranch; string betRemark = null; decimal betAmount; int combo; decimal rate; decimal totalBet; decimal walletAmount = memberDefine.GetMemberWalletAmount(memberId); string betType_s = (req["betType"] ?? "").ToString(); var checkBetTypeExit = Model.BetForm.Define.BetTypesLangMap.ContainsKey(betType_s); if (checkBetTypeExit == false) { result["result"] = "fail"; result["msg"] = "找不到此BetType"; result["column"] = "betType"; Response.Write(JsonConvert.SerializeObject(result)); return; } betType = betType_s; string betBranch_s = (req["betBranch"] ?? "").ToString(); int betBranchTemp; var chkBetBranchTempFmt = int.TryParse(betBranch_s, out betBranchTemp); if (chkBetBranchTempFmt == false) { result["result"] = "fail"; result["msg"] = "betBranch格式錯誤"; result["column"] = "betBranch"; Response.Write(JsonConvert.SerializeObject(result)); return; } betBranch = betBranch_s; string betRemark_s = (req["betRemark"] ?? "").ToString(); if (betRemark_s != "") { var checkBetRemark = memberDefine.TitleValidate(betRemark_s); if (checkBetRemark == 2) { result["result"] = "fail"; result["msg"] = "只能輸入中文或英數"; result["column"] = "betRemark"; Response.Write(JsonConvert.SerializeObject(result)); return; } else if (checkBetRemark == 1) { result["result"] = "fail"; result["msg"] = "字串長度錯誤"; result["column"] = "betRemark"; Response.Write(JsonConvert.SerializeObject(result)); return; } } betRemark = betRemark_s; string betAmount_s = (req["betAmount"] ?? "").ToString(); bool chkBetBetAmountFmt = decimal.TryParse(betAmount_s, out betAmount); if (chkBetBetAmountFmt == false) { result["result"] = "fail"; result["msg"] = "BetAmount格式錯誤"; result["column"] = "betAmount"; Response.Write(JsonConvert.SerializeObject(result)); return; } decimal singleBetMinValue = memberDefine.GetMemberSingleBetMinValue(memberId, betType); if (betAmount < singleBetMinValue) { result["result"] = "fail"; result["msg"] = "小於玩法單注限額"; result["column"] = "betAmount"; Response.Write(JsonConvert.SerializeObject(result)); return; } decimal singleBetMaxValue = memberDefine.GetMemberSingleBetMaxValue(memberId, betType); if (betAmount > singleBetMaxValue) { result["result"] = "fail"; result["msg"] = "大於玩法單注限額"; result["column"] = "betAmount"; Response.Write(JsonConvert.SerializeObject(result)); return; } //bool checkBetTime = define.CheckBetTime(); //if (checkBalance == false) //{ // result["result"] = "fail"; // result["msg"] = "超過時間"; // result["errorcode"] = ApiErrorCodes.OverTime; // Response.Write(JsonConvert.SerializeObject(result)); // return; //} string chooseBall_s = (req["chooseBall"] ?? "").ToString().TrimEnd(',').Replace("\r\n", "").Replace(" ", ""); try { chooseBallObj = JsonConvert.DeserializeObject <JObject>(chooseBall_s); } catch (Exception excep) { result["result"] = "fail"; result["msg"] = "chooseBall轉換json失敗"; result["column"] = "chooseBall"; Response.Write(JsonConvert.SerializeObject(result)); return; } var checkChooseBallCntCorrect = betFormDefine.CheckChooseBallCntCorrect(chooseBallObj, betType); if (checkChooseBallCntCorrect == false) { result["result"] = "fail"; result["msg"] = "chooseBall數量錯誤"; result["column"] = "chooseBall"; Response.Write(JsonConvert.SerializeObject(result)); return; } var chkChooseBallItem = betFormDefine.CheckChooseBallItemCorrect(chooseBallObj, betType, parentId); if (chkChooseBallItem == false) { result["result"] = "fail"; result["msg"] = "賠率異常或球號異常"; result["column"] = "chooseBall"; Response.Write(JsonConvert.SerializeObject(result)); return; } string rate_s = (req["rate"] ?? "").ToString(); var chkRateFmt = decimal.TryParse(rate_s, out rate); if (chkRateFmt == false) { result["result"] = "fail"; result["msg"] = "rate格式錯誤"; result["column"] = "rate"; Response.Write(JsonConvert.SerializeObject(result)); return; } if (rate != betFormDefine.CalcBetFormRate(chooseBallObj, betType)) { result["result"] = "fail"; result["msg"] = "rate錯誤"; result["column"] = "rate"; Response.Write(JsonConvert.SerializeObject(result)); return; } string combo_s = (req["combo"] ?? "").ToString(); int comboTemp; var chkComboFmt = int.TryParse(combo_s, out comboTemp); if (chkComboFmt == false) { result["result"] = "fail"; result["msg"] = "combo格式錯誤"; result["column"] = "combo"; Response.Write(JsonConvert.SerializeObject(result)); return; } if (betFormDefine.CalcBetFormCombo(chooseBallObj, betType) != comboTemp) { result["result"] = "fail"; result["msg"] = "combo錯誤"; result["column"] = "combo"; Response.Write(JsonConvert.SerializeObject(result)); return; } combo = comboTemp; string totalBet_s = (req["totalBet"] ?? "").ToString(); var chkTotalBetFmt = decimal.TryParse(totalBet_s, out totalBet); if (chkTotalBetFmt == false) { result["result"] = "fail"; result["msg"] = "totalBet格式錯誤"; result["column"] = "totalBet"; Response.Write(JsonConvert.SerializeObject(result)); return; } if (totalBet != betAmount * combo) { result["result"] = "fail"; result["msg"] = "totalBet錯誤"; result["column"] = "totalBet"; Response.Write(JsonConvert.SerializeObject(result)); return; } decimal betMaxValueByBetType = memberDefine.GetMemberBetMaxValueByBetType(memberId, betType); decimal agentBetMaxValue = memberDefine.GetMemberAgentBetMaxValue(memberId, betType); decimal totalBetByMember = betFormDefine.GetTotalBetByMember(memberId, periodId, betType); decimal totalBetByAgent = betFormDefine.GetTotalBetByAgent(parentId, periodId); if (totalBet + totalBetByMember > betMaxValueByBetType) { result["result"] = "fail"; result["msg"] = "超過單一玩法限制最大總計金額"; result["column"] = "totalBet"; Response.Write(JsonConvert.SerializeObject(result)); return; } if (totalBet + totalBetByAgent > agentBetMaxValue) { result["result"] = "fail"; result["msg"] = "超過代理限制最大總計金額"; result["column"] = ""; Response.Write(JsonConvert.SerializeObject(result)); return; } if (totalBet > walletAmount) { result["result"] = "fail"; result["msg"] = "餘額不足"; result["column"] = ""; Response.Write(JsonConvert.SerializeObject(result)); return; } walletAmount -= totalBet; // 錢包餘額扣掉下注總金額 bool checkBetFormExist = betFormDefine.CheckBetFormExist(memberId, chooseBallObj, betType); if (checkBetFormExist == true) { result["result"] = "fail"; result["msg"] = "重複下注"; result["column"] = ""; Response.Write(JsonConvert.SerializeObject(result)); return; } Model.BetForm.Add betFormAdd = new Model.BetForm.Add(); Model.BetForm.Add.BetFormStruct b = new Model.BetForm.Add.BetFormStruct(); b.memberId = memberId; b.BetType = betType; b.BetBranch = betBranch; // 暫時未使用 b.ChooseBall = JsonConvert.SerializeObject(chooseBallObj); b.Rate = rate; b.Combo = combo; b.BetAmount = betAmount; b.TotalBet = totalBet; b.IP = ip; b.PeriodId = periodId; b.BetRemark = betRemark; betFormAdd.BetFormStructtHandle(b); // add 注單 Model.Member.Edit memberEdit = new Model.Member.Edit(); Model.Member.Edit.BalanceTransferStruct eb = new Model.Member.Edit.BalanceTransferStruct(); eb.MemberId = memberId; eb.WalletAmount = totalBet; memberEdit.BalanceTransferStructHandle(eb); // 修改 walletAmount result["result"] = "success"; result["msg"] = "第" + periodId + "期下注成功,下注金額為:" + totalBet.ToString() + "賠率為:" + rate.ToString() + " ,剩餘金額:" + walletAmount.ToString(); result["column"] = ""; Response.Write(JsonConvert.SerializeObject(result)); }