Gift.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\Db;
  5. /**
  6. * 礼物接口
  7. */
  8. class Gift extends Api
  9. {
  10. protected $noNeedLogin = ['getGiftList','getGiftType'];
  11. protected $noNeedRight = '*';
  12. public function _initialize()
  13. {
  14. parent::_initialize();
  15. $this->giftModel = new \app\common\model\Gift();
  16. $this->gifttypeModel = new \app\common\model\GiftType();
  17. }
  18. //gift_id必须是爆币礼物才可以
  19. public function test($user_id,$gift_id = 0,$pay_total = 10000){
  20. //奖项参数
  21. $conf_arr = Db::name('gift_baobi_config')->where('gift_id',$gift_id)->select();
  22. if(empty($conf_arr)){
  23. return true;
  24. }
  25. //用户今天的爆币情况,与消费情况,不用区分具体哪个爆币礼物
  26. $today_start = strtotime(date('Y-m-d'));
  27. $today_end = $today_start + 86399;
  28. $map = [
  29. 'user_id' => $user_id,
  30. 'createtime' => ['BETWEEN',[$today_start,$today_end]],
  31. ];
  32. $today_data = Db::name('gift_baobi_log')->field('sum(pay_total) as today_pay_total,sum(baobi_total) as today_baobi_total')->where($map)->find('pay_total');
  33. if($today_data['today_baobi_total'] > $today_data['today_pay_total']){
  34. //爆币比消费还高了,不用抽奖了,记录个日志,返回。这里的日志仅用来记录今日消费 sum(pay_total)
  35. $data = [];
  36. $data['user_id'] = $user_id;
  37. $data['gift_id'] = $gift_id;
  38. $data['baobi_id'] = 0;
  39. $data['beilv'] = 0;
  40. $data['rate'] = 0;
  41. $data['pay_total'] = $pay_total;
  42. $data['baobi_total'] = 0;
  43. $data['createtime'] = time();
  44. $log_id = Db::name('gift_baobi_log')->insertGetId($data);
  45. if(!$log_id){
  46. return false;
  47. }
  48. return true;
  49. }
  50. //概率新数组
  51. $gailv = [];
  52. $bei = 100; //小数变整数
  53. foreach ($conf_arr as $key=>$value)
  54. {
  55. $gailv[$value['id']] = $value['rate']*$bei;
  56. }
  57. //dump($gailv);
  58. //奖项新数组
  59. $conf_column = [];
  60. foreach ($conf_arr as $key=>$value)
  61. {
  62. $conf_column[$value['id']] = $value;
  63. }
  64. //dump($conf_column);
  65. //抽
  66. $rid = $this->getRand($gailv); //根据概率获取奖项id
  67. //dump($rid);
  68. //返回中奖结果
  69. $result = $conf_column[$rid];
  70. //爆币金额
  71. $baobi_total = bcdiv(bcmul($pay_total,$result['beilv'],0),100,0);
  72. //写入爆币记录,不论有没有钱。全都写入其实是为了方便查日志,比在money_log里找范围更小,而且可删除
  73. $data = [];
  74. $data['user_id'] = $user_id;
  75. $data['gift_id'] = $gift_id;
  76. $data['baobi_id'] = $result['id'];
  77. $data['beilv'] = $result['beilv'];
  78. $data['rate'] = $result['rate'];
  79. $data['pay_total'] = $pay_total;
  80. $data['baobi_total'] = $baobi_total;
  81. $data['createtime'] = time();
  82. $log_id = Db::name('gift_baobi_log')->insertGetId($data);
  83. if(!$log_id){
  84. return false;
  85. }
  86. //直接给用户钱
  87. if($baobi_total > 0){
  88. $rs_wallet = model('wallet')->lockChangeAccountRemain($user_id,$baobi_total,'+',0,'送礼物爆币'.$result['beilv'].'%',21,'jewel');
  89. if($rs_wallet['status'] === false){
  90. return false;
  91. }
  92. }
  93. //默认成功
  94. return true;
  95. }
  96. //概率获得算法
  97. private function getRand($proArr) {
  98. //概率数组的总概率精度
  99. $proSum = array_sum($proArr);
  100. $key = rand(1, $proSum);
  101. // echo $key;
  102. $result = 0;
  103. $now = 0;
  104. foreach ($proArr as $k=>$v)
  105. {
  106. $now = $now + $v;
  107. if($key<=$now)
  108. {
  109. $result = $k;
  110. break;
  111. }
  112. }
  113. unset ($proArr);
  114. return $result;
  115. }
  116. /**
  117. * 获取礼物列表
  118. */
  119. public function getGiftList() {
  120. $type = input('type',0);
  121. // 获取基本信息
  122. $where = ['is_show'=>1];
  123. if($type){
  124. $where['type'] = $type;
  125. }
  126. $giftList = Db::name('gift')->field('id,name,price,image,special')->where($where)->order("sort","asc")->select();
  127. $giftList = list_domain_image($giftList,['image','special']);
  128. $this->success("获取成功!",$giftList);
  129. }
  130. /**
  131. * 获取礼物类型
  132. */
  133. public function getGiftType() {
  134. // 获取基本信息
  135. $where = [];
  136. $where["is_show"] = 1;
  137. $giftList = $this->gifttypeModel->field("id,name")->where($where)->order("weight","desc")->select();
  138. $this->success("获取成功!",$giftList);
  139. }
  140. /**
  141. * 获取我的背包礼物
  142. */
  143. public function getMyBackGift() {
  144. $userid = input("user_id", $this->auth->id);
  145. // 分页搜索构建
  146. $list = \app\common\model\GiftBack::field("id,name,image,gif_image,value,sum(number) as number")
  147. ->where(["user_id"=>$userid,"is_use"=>0])
  148. ->group("name")
  149. ->select();
  150. $this->success("获取成功!",$list);
  151. }
  152. /**
  153. * 获取我的礼物墙
  154. */
  155. public function getMyGiftWall() {
  156. $user_id = input("user_id", 0);
  157. $userid = $user_id ? $user_id : $this->auth->id;
  158. $list = \app\common\model\GiftUserParty::alias('a')->join("hx_gift g", "g.id = a.gift_id", "inner")->field("gift_id,g.name,g.image,sum(number) as number")
  159. ->where(["user_to_id" => $userid,])
  160. ->group("gift_id")
  161. ->order('g.value desc')
  162. ->select();
  163. $this->success("获取成功!", $list);
  164. }
  165. /**
  166. * 获取我的礼物墙
  167. */
  168. public function getMyGiftWall_typing() {
  169. $user_id = input("user_id", 0);
  170. $userid = $user_id ? $user_id : $this->auth->id;
  171. $list = Db::name('gift_user_typing')->alias('log')
  172. ->join('gift', 'gift.id = log.gift_id', 'LEFT')->field('log.*,sum(number) as number,gift.name,gift.image,gift.special')
  173. ->where(['log.user_to_id' => $userid])
  174. ->group('log.gift_id')
  175. ->order('gift.price desc')
  176. ->select();
  177. $list = list_domain_image($list,['image','special']);
  178. $this->success("获取成功!", $list);
  179. }
  180. /**
  181. * 获取我的收送礼明细
  182. */
  183. public function my_gift_log(){
  184. $user_id = $this->auth->id;
  185. $type = input('type',1);
  186. $where = [];
  187. if($type == 1){
  188. $where['user_id'] = $user_id;//我送出
  189. $joinstr = 'gup.user_to_id = user.id';
  190. }else{
  191. $where['user_to_id'] = $user_id;//我收到
  192. $joinstr = 'gup.user_id = user.id';
  193. }
  194. $list = Db::name('gift_user_party')->alias('gup')
  195. ->join('user',$joinstr,'LEFT')->field('gup.*,user.nickname')
  196. ->where($where)->order('id desc')->autopage()->select();
  197. $list = list_domain_image($list,['gift_gif_image']);
  198. $rs = [];
  199. if(empty($list)){
  200. $this->success(1,$rs);
  201. }
  202. foreach($list as $key => $val){
  203. if($type == 1){
  204. $remark = '赠送'.$val['nickname'].','.$val['gift_name'].'*'.$val['number'].',价值'.$val['value'].'钻石';
  205. }else{
  206. $remark = $val['nickname'].'赠送,'.$val['gift_name'].'*'.$val['number'].',价值'.$val['value'].'钻石';
  207. }
  208. $rs[] = [
  209. 'id' => $val['id'],
  210. 'gift_image' => $val['gift_gif_image'],
  211. 'createtime' => $val['createtime'],
  212. 'remark' => $remark
  213. ];
  214. }
  215. $this->success(1,$rs);
  216. }
  217. //聊天送礼物
  218. public function givegift_typing() {
  219. // 接口防并发
  220. if (!$this->apiLimit(1, 1000)) {
  221. $this->error(__('Operation frequently'));
  222. }
  223. $user_id = input('user_id');// 赠送对象
  224. $gift_id = input('gift_id');// 礼物ID
  225. $number = input('number',1,'intval');//数量
  226. if (!$user_id || !$gift_id || $number < 1)
  227. {
  228. $this->error();
  229. }
  230. // 不可以赠送给自己
  231. if($this->auth->id == $user_id)
  232. {
  233. $this->error("不可以赠送给自己");
  234. }
  235. // 获取礼物信息
  236. $giftinfo = Db::name('gift')->where('id',$gift_id)->find();
  237. if (!$giftinfo)
  238. {
  239. $this->error("请选择礼物");
  240. }
  241. $giftvalue = bcmul($giftinfo['price'],$number);
  242. //被赠送人信息
  243. $touserinfo = Db::name('user')->where('id',$user_id)->find();
  244. if (!$touserinfo)
  245. {
  246. $this->error("不存在的用户");
  247. }
  248. // 判断当前用户余额
  249. $user_gold = model('wallet')->getWallet($this->auth->id,'gold');
  250. if($user_gold < $giftvalue)
  251. {
  252. $this->error("您的金币余额不足");
  253. }
  254. Db::startTrans();
  255. // 添加礼物赠送记录表
  256. $data = [
  257. 'user_id' => $this->auth->id,
  258. 'user_to_id' => $user_id,
  259. 'gift_id' => $giftinfo['id'],
  260. 'gift_name' => $giftinfo['name'],
  261. 'number' => $number,
  262. 'price' => $giftinfo['price'],
  263. 'total_price' => $giftvalue,
  264. 'createtime' => time(),
  265. ];
  266. $log_id = Db::name('gift_user_typing')->insertGetId($data);
  267. if(!$log_id){
  268. Db::rollback();
  269. $this->error('赠送失败');
  270. }
  271. if($giftvalue > 0){
  272. // 扣除当前用户余额
  273. $wallet_rs = model('wallet')->lockChangeAccountRemain($this->auth->id,'gold',-$giftvalue,53,'赠送礼物:'.$giftinfo["name"],'gift_user_typing',$log_id);
  274. if($wallet_rs['status'] === false){
  275. Db::rollback();
  276. $this->error($wallet_rs['msg']);
  277. }
  278. // 添加赠送用户余额
  279. $money_to_gold = config('site.money_to_gold');
  280. $gift_plat_scale = config('site.gift_plat_scale');
  281. $giftmoney = bcdiv($giftvalue,$money_to_gold,2);
  282. $money = bcdiv(bcmul($giftmoney,100 - $gift_plat_scale,2),100,2);
  283. $wallet_rs = model('wallet')->lockChangeAccountRemain($user_id,'money',$money,54,'获得礼物:'.$giftinfo["name"],'gift_user_typing',$log_id);
  284. if($wallet_rs['status'] === false){
  285. Db::rollback();
  286. $this->error($wallet_rs['msg']);
  287. }
  288. }
  289. Db::commit();
  290. $this->success('赠送成功');
  291. }
  292. }