123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 |
- <?php
- namespace app\api\controller;
- use app\common\controller\Api;
- use think\Db;
- use think\Exception;
- class Usersign extends Api
- {
- protected $noNeedLogin = [];
- protected $noNeedRight = ['*'];
-
- public function config()
- {
- $list = Db::name('signin')->order('id asc')->select();
-
- $user_sign = Db::name('user_sign')->where(['uid' => $this->auth->id])->order('id desc')->find();
- $yesterday_time = strtotime('yesterday');
- $today_time = $yesterday_time + 86400;
- if ($user_sign) {
- if ($user_sign['createtime'] >= $yesterday_time) {
- $data['sign_times'] = $user_sign['times'];
- } else {
- $data['sign_times'] = 0;
- }
- if ($user_sign['createtime'] >= $today_time) {
- $data['is_sign'] = 1;
- } else {
- $data['is_sign'] = 0;
- }
- } else {
- $data['sign_times'] = 0;
- $data['is_sign'] = 0;
- }
- $data['sign_round_times'] = $data['sign_times'] % 7;
- $data['list'] = $list;
- $this->success('success',$data);
- }
-
- public function signin(){
- Db::startTrans();
- try {
- $uid = $this->auth->id;
-
- $data = [
- 'uid' => $uid,
- 'type' => 1,
- 'times' => 1,
- 'goldnum' => 0,
- 'createtime' => time(),
- ];
- $yesterday_time = strtotime('yesterday');
- $today_time = $yesterday_time + 86400;
-
- $check = Db::name('user_sign')->where('uid',$uid)->order('id desc')->find();
- if($check){
-
- if($check['createtime'] >= $today_time){
- throw new Exception('今天已经签过了');
- }
- if ($check['createtime'] >= $yesterday_time) {
- $data['times'] = $check['times'] + 1;
- }
- }
-
-
-
-
- $gift = [];
- $sendGift = config('site.sign_gift');
- $userSignGift = model('UserSignGift')->with(['gift'])->find();
- if ($data['times'] == 7 && $sendGift == '1' && !empty($userSignGift)) {
- $giftData = isset($userSignGift['gift']) ? $userSignGift['gift'] : [];
- if (!empty($giftData)) {
- $gift = [
- 'image' => $giftData['image'],
- 'num' => $userSignGift['num'],
- ];
- }
- $giftName = isset($giftData['name']) ? $giftData['name'] : '';
- $data['goldnum'] = $gift['num'];
- $data['type'] = 2;
- $data['remark'] = '签到奖励'.$giftName.$gift['num'];
- } else {
- $signJewel = config('site.sign_jewel');
- $signJewelArr = [];
- if (!empty($signJewel)) {
- $signJewelArr = explode('-', $signJewel);
- }
- $min = isset($signJewelArr[0]) ? $signJewelArr[0] : 1;
- $max = isset($signJewelArr[1]) ? $signJewelArr[1] : 1;
- $gift['num'] = rand($min,$max);
- if ($gift < 1) {
- throw new Exception('签到功能已被关闭');
- }
- $data['goldnum'] = $gift['num'];
- $data['remark'] = '签到钻石'.$gift['num'];
- $user = model('User')->find($uid);
- $userJewel = isset($user['jewel']) ? $user['jewel'] : 0;
- $rs_wallet = model('wallet')->lockChangeAccountRemain($uid,$gift['num'],'+',$userJewel,$data['remark'],16,'jewel');
- if (!$rs_wallet['status']) {
- throw new Exception($rs_wallet['msg']);
- }
- }
-
- $log_id = Db::name('user_sign')->insertGetId($data);
- if(!$log_id){
- throw new Exception('签到失败');
- }
-
- $msg_id = \app\common\model\Message::addMessage($this->auth->id,'签到奖励','签到成功,获得奖励');
- $signImg = config('site.sign_img');
- $result = [
- 'image' => isset($gift['image']) ? $gift['image'] : cdnurl($signImg),
- 'goldnum' => isset($gift['num']) ? $gift['num'] : $data['goldnum'],
- ];
- Db::commit();
- $this->success('签到成功', $result);
- } catch (Exception $e) {
- Db::rollback();
- $this->error($e->getMessage());
- }
- }
-
-
- private function gift_vip($user_sign_gift_vipdays){
- $start = strtotime(date('Y-m-d')) - 518400;
- $map = [
- 'uid' => $this->auth->id,
- 'createtime' => ['gt',$start],
- ];
- $count = Db::name('user_sign')->where($map)->count();
- if($count >= 7){
-
- $add_time = 86400 * $user_sign_gift_vipdays;
-
- $vip_endtime = model('wallet')->getWallet($this->auth->id,'vip_endtime');
- if($vip_endtime <= time()){
- $new_vip_endtime = time() + $add_time;
- }else{
- $new_vip_endtime = $vip_endtime + $add_time;
- }
- $rs = Db::name('user_wallet')->where('user_id',$this->auth->id)->update(['vip_endtime'=>$new_vip_endtime]);
- if($rs === false){
- Db::rollback();
- $this->error('连续签到赠送vip失败');
- }
- return true;
- }
- return false;
- }
- }
|