def post(self, account, apply_sorder, **kwargs): # 获取申请帮助子订单信息 apply_help_pay = ApplyHelpPayMgr().get_data_by_sorder(apply_sorder) if not apply_help_pay: logger.info("accept_help_confirm ERROR_LOGIC, not apply_help!!!, apply_sorder:%s" % apply_sorder) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} accept_order = apply_help_pay['accept_order'] apply_order = apply_help_pay['apply_order'] accept_help = AcceptHelpMgr().get_data_by_order(accept_order) if not accept_help: logger.info("accept_help_confirm ERROR_LOGIC, not accept_help!!!, accept_order:%s" % accept_order) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} if accept_help['accept_uid'] != account.id: logger.info("accept_help_confirm ERROR_LOGIC, apply_sorder's accept uid not the account!!!, uid:%s, account:%s" % (accept_help['accept_uid'], account.id)) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} # 申请帮助支付订单确认 ApplyHelpPayMgr().do_confirm(apply_sorder) # 申请帮助订单确认 ApplyHelpMgr().do_confirm(apply_order) # 接受帮助订单确认 AcceptHelpMgr().do_confirm(accept_order) return {"result": error_code.ERROR_SUCCESS}
def init_cron_job(): """ 初始化系统cron job :return: """ apply_req = ArgumentParser().args.apply_req match = ArgumentParser().args.match apply_pay = ArgumentParser().args.apply_pay accept_req = ArgumentParser().args.accept_req apply_wait = ArgumentParser().args.apply_wait # init AcceptApplyMatcher().init(AcceptHelpMgr().match_ls, ApplyHelpMgr().match_ls, AcceptHelpMgr().do_accept, ApplyHelpMgr().do_apply, ServerInfoMgr().make_unique_id) Jobs().add_cron_job(ApplyReqFilter().filter, **{apply_req.split('_')[0]: int(apply_req.split('_')[1])}) Jobs().add_cron_job(AcceptApplyMatcher().match, **{match.split('_')[0]: int(match.split('_')[1])}) if ArgumentParser().args.enable_pay_check: Jobs().add_cron_job(ApplyPayFilter().filter, **{apply_pay.split('_')[0]: int(apply_pay.split('_')[1])}) Jobs().add_cron_job(AcceptReqFilter().filter, **{accept_req.split('_')[0]: int(accept_req.split('_')[1])}) Jobs().add_cron_job(ApplyWaitFilter().filter, **{apply_wait.split('_')[0]: int(apply_wait.split('_')[1])}) [logger.warn("cron job:%s" % {"cron": cron_job.cron, "func": cron_job.func}) for cron_job in Jobs().cron_job]
def get(self, account, apply_uid, accept_uid, apply_money, **kwargs): apply_money = int(apply_money) if not AccountMgr().is_id_exist(apply_uid): logger.info( "AutoMatchHandler ERROR_UID_NOT_EXIST, apply_uid not existed, %s" % apply_uid) self.set_status(error_code.ERROR_UID_NOT_EXIST, 'Parameter Error') return error_code.ERROR_UID_NOT_EXIST if not AccountMgr().is_id_exist(accept_uid): logger.info( "AutoMatchHandler ERROR_UID_NOT_EXIST, id not existed, %s" % accept_uid) self.set_status(error_code.ERROR_UID_NOT_EXIST, 'Parameter Error') return error_code.ERROR_UID_NOT_EXIST # 获取申请帮助信息 apply_help_dic = ApplyHelpMgr().get_unfinish(apply_uid) if not apply_help_dic: # 判断是否有申请帮助请求在排队,如果有,直接进入匹配模式 apply_help_req = ApplyHelpReqMgr().get_unfinish(apply_uid) if not apply_help_req: logger.info( "AutoMatchHandler ERROR_LOGIC, not apply_help_dic, apply_uid:%s" % apply_uid) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return error_code.ERROR_LOGIC ApplyHelpReqMgr().do_match(apply_help_req['id']) apply_help_dic = ApplyHelpMgr().get_unfinish(apply_uid) assert apply_help_dic # 获取接受帮助信息 accept_help_dic = AcceptHelpMgr().get_unfinish(accept_uid) if not accept_help_dic: accept_help_req = AcceptHelpReqMgr().get_unfinish(accept_uid) if not accept_help_req: logger.info( "AutoMatchHandler ERROR_LOGIC, not accept_help_dic, accept_uid:%s" % accept_uid) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return error_code.ERROR_LOGIC AcceptHelpReqMgr().do_match(accept_help_req['id']) accept_help_dic = AcceptHelpMgr().get_unfinish(accept_uid) assert accept_help_dic # 接受帮助金额判定 apply_money = min(apply_money, apply_help_dic['apply_lmoney'], accept_help_dic['accept_lmoney']) # 手动匹配 accept_matched_ls = [{ "accept_order": accept_help_dic['accept_order'], "apply_money": apply_money }] AcceptApplyMatcher().matched_proc(apply_help_dic, accept_matched_ls) return error_code.ERROR_SUCCESS
def do_deny_pay(self, apply_sorder): """ 拒绝支付处理 :param apply_sorder: 申请帮助子订单id :return: """ from mmm_da.lib.help.control import ApplyHelpMgr, AcceptHelpMgr apply_help_pay_dic = self.get_data_by_sorder(apply_sorder) assert apply_help_pay_dic apply_help_dic = ApplyHelpMgr().get_data_by_order( apply_help_pay_dic['apply_order']) # 封号 account = AccountMgr().get_data_by_id(apply_help_dic['apply_uid']) account.attr_stat = SEALED # 接受帮助/申请帮助恢复 AcceptHelpMgr().do_recover(apply_help_pay_dic['accept_order'], apply_help_pay_dic['apply_pmoney']) ApplyHelpMgr().do_recover(apply_help_pay_dic['apply_order'], apply_help_pay_dic['apply_pmoney']) # 未支付奖金处理 BonusMgr().on_apply_cancel(apply_help_dic['apply_uid'], apply_help_pay_dic['apply_pmoney']) upd_dic = { "apply_sorder": apply_sorder, "apply_pstat": APYS_PAY_REFUSE } self.update_dic(apply_sorder, upd_dic)
def post(self, account, **kwargs): apply_helps = ApplyHelpMgr().get_datas_by_uid(account.id) if not apply_helps: # 将申请帮助请求信息转化成申请帮助信息 apply_help_req = ApplyHelpReqMgr().get_unfinish(account.id) apply_help = apply_help_req_2_apply_help(apply_help_req) logger.info("cur_apply_help Success!!, not apply_helps:%s, apply_help_req:%s" % (apply_helps, apply_help_req)) return {"result": error_code.ERROR_SUCCESS, "apply_help_ls": [], "apply_help": apply_help} assert len(apply_helps) == 1 cur_apply_help = apply_helps[0] cur_apply_help_pay_ls = ApplyHelpPayMgr().get_datas_by_apply_order(cur_apply_help['apply_order']) apply_help_ls = [] for apply_help_pay_dic in cur_apply_help_pay_ls: # 获取申请帮助信息 apply_res_dic = sub_dict(cur_apply_help, ['apply_order', 'apply_uid', 'apply_stime',]) apply_res_dic.update(sub_dict(apply_help_pay_dic, ['apply_sorder', 'apply_pmoney', 'apply_mtime', 'apply_pstat', 'apply_piture', 'apply_message'])) # 获取接受帮助信息 accept_info = AcceptHelpMgr().get_data_by_order(apply_help_pay_dic['accept_order']) apply_res_dic['accept_uid'] = accept_info['accept_uid'] # 获取接受帮助账号信息 account_obj = AccountMgr().get_data_by_id(accept_info['accept_uid']) apply_res_dic['bank_name'] = account_obj.bank_name apply_help_ls.append(apply_res_dic) return {"result": error_code.ERROR_SUCCESS, "apply_help": cur_apply_help, "apply_help_ls": apply_help_ls}
def post(self, account, **kwargs): accept_help = AcceptHelpMgr().get_unfinish(account.id) if not accept_help: accept_help_req = AcceptHelpReqMgr().get_unfinish(account.id) return {"result": error_code.ERROR_SUCCESS, "accept_help": accept_help_req_2_accept_help(accept_help_req), "apply_help_ls": []} apply_help_ls =[] # 获取申请帮助子订单信息 apply_help_pays = ApplyHelpPayMgr().get_datas_by_accept_order(accept_help['accept_order']) for apply_help_pay_dic in apply_help_pays: apply_help_dic = ApplyHelpMgr().get_data_by_order(apply_help_pay_dic['apply_order']) # 申请帮助信息 apply_info = sub_dict(apply_help_dic, ['apply_order','apply_uid','apply_stime',]) apply_info.update(sub_dict(apply_help_pay_dic, ['apply_sorder', 'apply_pmoney', 'apply_mtime', 'apply_pstat', 'apply_piture', 'apply_message'])) # 申请帮助账号信息 account_obj = AccountMgr().get_data_by_id(apply_help_dic['apply_uid']) apply_info['bank_name'] = account_obj.bank_name apply_help_ls.append(apply_info) return {"result": error_code.ERROR_SUCCESS, "accept_help": accept_help, "apply_help_ls": apply_help_ls}
def do_match(self, id): """ 进入匹配队列 :param id: 进入匹配的id :return: """ accept_dic = self.get_data_by_id(id) # upd data upd_dic = {"id": id, "accept_req_stat": ACPRS_FINISH} self.__update_dic(id, upd_dic) # 接受帮助请求完成的时候可以删除内存 self.__del_data_2_mem(accept_dic) # 减少接受帮助总次数 ServerInfoMgr().attr_total_accept_cnt -= 1 # 加入接受帮助管理器 AcceptHelpMgr().add_accept_help(accept_dic['id'], accept_dic['accept_req_uid'], accept_dic['accept_req_money'])
def post(self, account, mafuluo, **kwargs): """ 接受帮助的时候,如果有一单申请帮助未完成,则不能接受帮助 :param account: 账号 :param mafuluo: 提取的马夫罗,整形 :param kwargs: :return: """ mafuluo = int(mafuluo) # 提取的马夫罗总数必须大于0 if mafuluo <= 0 : logger.info("accept_help ERROR_LOGIC, mafuluo:%s<=0!!!, id:%s" % (mafuluo, account.id)) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} # 提取的马夫罗必须小于账号拥有的马夫罗 if mafuluo > account.attr_mafuluo: logger.info("accept_help ERROR_LOGIC, mafuluo:%s>=acount.attr_mafuluo:%s!!!, id:%s" % (mafuluo, account.attr_mafuluo, account.id)) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} # 申请帮助还在请求处理, if ApplyHelpReqMgr().get_unfinish(account.id): logger.info("accept_help ERROR_LOGIC, has ApplyHelpReqMgr!!!, id:%s" % account.id) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} # 申请帮助还在匹配处理 if ApplyHelpMgr().get_unfinish(account.id): logger.info("accept_help ERROR_LOGIC, has ApplyHelpMgr!!!, id:%s" % account.id) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} # 接受帮助还在请求处理, if AcceptHelpReqMgr().get_unfinish(account.id): logger.info("apply_help ERROR_LOGIC, has AcceptHelpReqMgr!!!, id:%s" % account.id) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} # 接受帮助还在匹配处理 if AcceptHelpMgr().get_unfinish(account.id): logger.info("apply_help ERROR_LOGIC, has AcceptHelpMgr!!!, id:%s" % account.id) self.set_status(error_code.ERROR_LOGIC, 'Parameter Error') return {"result": error_code.ERROR_LOGIC} # 资金平衡判断 if ArgumentParser().args.use_system_balance: if ServerInfoMgr().attr_total_accept_money + mafuluo + ServerInfoMgr().attr_system_balance\ > ServerInfoMgr().attr_total_apply_money: logger.info("accept_help ERROR_LOGIC, has reach the system balance!!!, " "total_accept_money:%s, total_apply_money:%s, system_balance:%s, mafuluo:%s" %(ServerInfoMgr().attr_total_accept_money, ServerInfoMgr().attr_total_apply_money, ServerInfoMgr().attr_system_balance, mafuluo)) self.set_status(error_code.EEROR_ACCEPT_BALANCE, 'Parameter Error') return # 扣除mafuluo account.attr_mafuluo -= mafuluo # 请求接受帮助 AcceptHelpReqMgr().add_req(account.id, mafuluo) accept_help_req = AcceptHelpReqMgr().get_unfinish(account.id) return {"result": error_code.ERROR_SUCCESS, "accept_help": accept_help_req_2_accept_help(accept_help_req)}
def post(self, account, **kwargs): return { "result": error_code.ERROR_SUCCESS, "accept_help_list": AcceptHelpMgr().all_match_ls() }