Noble.php 15 KB

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