Noble.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\Db;
  5. require_once __DIR__.'/../../../vendor/workerman/gatewayclient/Gateway.php';
  6. use GatewayClient\Gateway;
  7. /**
  8. * 贵族接口
  9. */
  10. class Noble extends Api
  11. {
  12. protected $noNeedLogin = ['getNobleLevelList','getNobleLevelPrivilegeInfo','onNoble'];
  13. protected $noNeedRight = ['*'];
  14. /**
  15. * 获取贵族等级列表
  16. */
  17. public function getNobleLevelList() {
  18. $noblelevelModel = new \app\common\model\NobleLevel();
  19. $where = [];
  20. $where["is_show"] = 1;
  21. $noblelevelList = $noblelevelModel->where($where)->select();
  22. return $this->success("获取成功!",$noblelevelList);
  23. }
  24. /**
  25. * 根据贵族等级ID获取贵族等级特权
  26. */
  27. public function getNobleLevelPrivilegeInfo() {
  28. $level_id = $this->request->request("level_id");
  29. if (!$level_id) {
  30. $this->error(__('Invalid parameters'));
  31. }
  32. $nplModel = new \app\common\model\NobleLevelPrivilege();
  33. $where = [];
  34. $where["level_id"] = $level_id;
  35. $where["is_show"] = 1;
  36. $nplInfo = $nplModel->where($where)->select();
  37. if($nplInfo) {
  38. return $this->success("获取成功!",$nplInfo);
  39. } else {
  40. return $this->success("数据为空!",[]);
  41. }
  42. }
  43. /**
  44. * 获取贵族等级以及到期时间
  45. */
  46. public function getNobleDuetime() {
  47. $level_id = $this->request->request("level_id");
  48. if (!$level_id) {
  49. $this->error(__('Invalid parameters'));
  50. }
  51. $userModel = new \app\common\model\User();
  52. $info = $userModel->getUserNobleInfo($level_id,$this->auth->id);
  53. return $this->success("获取成功!",$info);
  54. }
  55. /**
  56. * 获取贵族等级所需金额
  57. */
  58. public function getNobleLogInfo() {
  59. $level_id = $this->request->request("level_id");
  60. if (!$level_id) {
  61. $this->error(__('Invalid parameters'));
  62. }
  63. $nldlModel = new \app\common\model\NobleDredgeLog();
  64. $noblelevelModel = new \app\common\model\NobleLevel();
  65. $noblelevelInfo = $noblelevelModel->where(["id"=>$level_id])->find();
  66. // 获取贵族等级开通信息
  67. $where = [];
  68. $where["user_id"] = $this->auth->id;
  69. $where["level_no"] = $noblelevelInfo["level_no"];
  70. $nldlCount = 0;
  71. $nldlInfo = $nldlModel->where($where)->limit(1)->order("dredge_num","desc")->select();
  72. $nldlInfo && $nldlInfo = $nldlInfo[0];
  73. // 判断是否是首月开通
  74. if($nldlInfo) {
  75. $nldlCount = $nldlInfo["dredge_num"];
  76. }
  77. $money = $nldlCount>0?$noblelevelInfo["renew"]:$noblelevelInfo["first"];
  78. $data["money"] = $money;
  79. return $this->success("获取成功!",$data);
  80. }
  81. /**
  82. * 开通贵族
  83. */
  84. public function beNoble() {
  85. $level_id = $this->request->request("level_id"); // 贵族等级ID
  86. if (!$level_id) {
  87. $this->error(__('Invalid parameters'));
  88. }
  89. if ($this->auth->power->noble == 1) {
  90. $this->error('您已被禁止开通贵族');
  91. }
  92. $time = time();
  93. // 获取贵族信息
  94. $noblelevelModel = new \app\common\model\NobleLevel();
  95. $nldlModel = new \app\common\model\NobleDredgeLog();
  96. $noblelevelInfo = $noblelevelModel->where(["id"=>$level_id])->find();
  97. // 获取贵族等级开通信息
  98. $where = [];
  99. $where["user_id"] = $this->auth->id;
  100. $where["level_no"] = $noblelevelInfo["level_no"];
  101. $nldlCount = 0;
  102. $nldlInfo = $nldlModel->where($where)->limit(1)->order("dredge_num","desc")->select();
  103. $nldlInfo && $nldlInfo = $nldlInfo[0];
  104. // 判断是否是首月开通
  105. if($nldlInfo) {
  106. $nldlCount = $nldlInfo["dredge_num"];
  107. // if(time() - $nldlInfo["createtime"] < 60) { // 同一个人,同一等级,一分钟之内重复开通,鉴定为系统bug
  108. // $this->error("您刚刚开通过此贵族特权");
  109. // }
  110. }
  111. $money = $nldlCount>0?$noblelevelInfo["renew"]:$noblelevelInfo["first"];
  112. if(!$noblelevelInfo || $money <= 0) {
  113. $this->error(__('贵族等级信息有误!'));
  114. }
  115. $userModel = new \app\common\model\User();
  116. $where = [];
  117. $where["id"] = $this->auth->id;
  118. $userInfo = $userModel->where($where)->find();
  119. $userwallet = Db::name('user_wallet')->where('user_id',$this->auth->id)->find();
  120. // 判断用户余额
  121. if($userwallet["jewel"]-$money < 0) {
  122. $this->error("您的钻石余额不足,请先充值");
  123. }
  124. // 获取当前用户贵族等级
  125. if($userInfo["noble"] == $level_id) {
  126. $duetime = $userInfo["noble_duetime"];
  127. if ($duetime < $time) {//过期时间过期验证
  128. $duetime = $time;
  129. }
  130. } else {
  131. $duetime = $time;
  132. }
  133. Db::startTrans();
  134. try{
  135. // 扣除当前用户钻石余额 更新用户贵族信息
  136. $where = [];
  137. $where["id"] = $this->auth->id;
  138. $duetime = strtotime("+1 month",$duetime);
  139. $nextMonth = strtotime("+1 month",$time);
  140. $data = [];
  141. $data["noble"] = $level_id;
  142. $data["noble_duetime"] = $duetime;
  143. // 开通返现
  144. $return = $nldlCount>0?$noblelevelInfo["give"]:$noblelevelInfo["firstgive"];
  145. $res1 = $userModel->update($data,$where);
  146. // 添加当前用户钻石流水记录
  147. $res2 = true;
  148. //扣除用户钻石余额
  149. if($money > 0){
  150. $rs_wallet = model('wallet')->lockChangeAccountRemain($this->auth->id, $money, "-", 0, "开通贵族:'" . $noblelevelInfo["name"] . "',扣除" . $money . "钻石!", 5,'jewel');
  151. if($rs_wallet['status'] == false){
  152. Db::rollback();
  153. $this->error($rs_wallet['msg']);
  154. }
  155. }
  156. // 添加贵族等级开通明细
  157. $data = [];
  158. $data["user_id"] = $this->auth->id;
  159. $data["level_no"] = $noblelevelInfo["level_no"];
  160. $data["dredge_num"] = $nldlCount+1;
  161. $data["createtime"] = $time;
  162. $res3 = $nldlModel->insertGetId($data);
  163. // 添加当前用户钻石流水记录
  164. $res4 = true;
  165. if($return > 0){
  166. $rs_wallet = model('wallet')->lockChangeAccountRemain($this->auth->id, $return, "+", 0, "开通贵族:'" . $noblelevelInfo["name"] . "',赠送" . $return . "钻石!", 15,'jewel');
  167. if($rs_wallet['status'] == false){
  168. Db::rollback();
  169. $this->error($rs_wallet['msg']);
  170. }
  171. }
  172. if($res1 && $res2 && $res3 && $res4) {
  173. Db::commit();
  174. //$this->onNobleEffect($noblelevelInfo,$this->auth->id,$this->auth->nickname);
  175. $this->onNobleAttire($noblelevelInfo,$this->auth->id,$nextMonth,$time);
  176. // +exp
  177. $nobleArr = ['1'=>'entymIFE3J'];
  178. isset($nobleArr[$level_id]) && \app\common\model\TaskLog::tofinish($this->auth->id,$nobleArr[$level_id],1);
  179. // +message
  180. \app\common\model\Message::addMessage($this->auth->id,"贵族开通通知","恭喜,您已成功开通!".$noblelevelInfo["name"]." 贵族特权!");
  181. // 赠送消息尾灯
  182. //\app\common\model\AttireBack::addToMyBack(15,$this->auth->id);
  183. // 赠送聊天气泡
  184. if($noblelevelInfo->tqgq) {
  185. $params_from = $this->request->request("params_from"); // 贵族等级ID
  186. $attireInfo = \app\common\model\Attire::where(["use"=>1,"use_id"=>$level_id])->select();
  187. if (!empty($attireInfo)) {
  188. foreach ($attireInfo as $attireInfoKey => $attireInfoVal) {
  189. \app\common\model\AttireBack::addToMyBack($attireInfoVal->id,$this->auth->id,$params_from);
  190. }
  191. }
  192. }
  193. $this->success("开通成功!");
  194. }
  195. }catch (ValidateException $e) {
  196. Db::rollback();
  197. $this->error($e->getMessage());
  198. } catch (PDOException $e) {
  199. Db::rollback();
  200. $this->error($e->getMessage());
  201. } catch (Exception $e) {
  202. Db::rollback();
  203. $this->error($e->getMessage());
  204. }
  205. }
  206. /**
  207. * 开通贵族后效果
  208. */
  209. private function onNobleEffect($noblelevelInfo,$user_id,$user_nickname) {
  210. $serviceNotice = "";
  211. $serviceSvga = "";
  212. $partyNotice = "";
  213. // 全服通知
  214. if($noblelevelInfo["qftz"] == 1) {
  215. $serviceNotice = "恭喜,玩家:".$user_nickname." 成功开通:".$noblelevelInfo["name"]."贵族特权!";
  216. }
  217. //全服动画
  218. if($noblelevelInfo["qfdh"]) {
  219. $serviceSvga = $noblelevelInfo["qfdh"];
  220. }
  221. // 公屏通知
  222. if($noblelevelInfo["gptz"] == 1) {
  223. $partyNotice = "恭喜,玩家:".$user_nickname." 成功开通:".$noblelevelInfo["name"]."贵族特权!";
  224. }
  225. $tcpArr = [];
  226. $tcpArr['type'] = "userBeNoble";
  227. $tcpArr['data'] = [
  228. 'user_id' => $user_id,
  229. 'nickname' => $user_nickname,
  230. 'serviceNotice' => $serviceNotice,
  231. 'serviceSvga' => $serviceSvga,
  232. 'partyNotice' => $partyNotice,
  233. ];
  234. $tcpJson = json_encode($tcpArr);
  235. $Gateway = new Gateway();
  236. $Gateway::$registerAddress = '127.0.0.1:2345';
  237. $Gateway::sendToAll($tcpJson);//暂时注释
  238. }
  239. /**
  240. * 开通贵族后获得专属座驾
  241. */
  242. private function onNobleAttire($noblelevelInfo,$user_id,$nextMonth,$time) {
  243. // 获取贵族专属座驾信息
  244. $nobleAttireInfo = \app\common\model\NobleAttire::where(["noble_id"=>$noblelevelInfo["id"]])->find();
  245. if($nobleAttireInfo) {
  246. Db::startTrans();
  247. try{
  248. // 更新当前用户背包使用状态
  249. $res1 = \app\common\model\AttireBack::update(["is_using"=>0],["user_id"=>$user_id]);
  250. // 保存用户背包信息
  251. $data = [];
  252. $data["user_id"] = $user_id;
  253. $data["attire_id"] = 0;
  254. $data["type"] = 1;
  255. $data["attire_name"] = $nobleAttireInfo["attire_name"];
  256. $data["price"] = $nobleAttireInfo["price"];
  257. $data["file_image"] = $nobleAttireInfo["file_image"];
  258. $data["gif_image"] = $nobleAttireInfo["gif_image"];
  259. $data["limit_day"] = round(($nextMonth-$time)/86400);
  260. $data["duetime"] = $nextMonth;
  261. $data["is_use"] = 1;
  262. $data["is_using"] = 1;
  263. $data["createtime"] = time();
  264. $res2 = \app\common\model\AttireBack::insert($data);
  265. if($res1 && $res2) {
  266. Db::commit();
  267. }
  268. }catch (ValidateException $e) {
  269. Db::rollback();
  270. $this->error($e->getMessage());
  271. } catch (PDOException $e) {
  272. Db::rollback();
  273. $this->error($e->getMessage());
  274. } catch (Exception $e) {
  275. Db::rollback();
  276. $this->error($e->getMessage());
  277. }
  278. }
  279. }
  280. public function aa() {
  281. Gateway::sendToAll("aaaaaa");
  282. }
  283. }