123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- <?php
- namespace app\api\controller;
- use app\common\controller\Api;
- use think\Db;
- class Usersign extends Api
- {
- protected $noNeedLogin = ['config'];
- 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(){
- $uid = $this->auth->id;
-
- $data = [
- 'uid' => $uid,
- '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){
- $this->error('今天已经签过了');
- }
- if ($check['createtime'] >= $yesterday_time) {
- $data['times'] = $check['times'] + 1;
- }else{
-
- }
- }
- if($data['times'] > 7){
- $data['times'] = 1;
- }
-
- $list = Db::name('signin')->order('id asc')->column('id,goldnum');
- $data['goldnum'] = isset($list[$data['times']]) ? $list[$data['times']] : 0 ;
- Db::startTrans();
-
- $log_id = Db::name('user_sign')->insertGetId($data);
- if(!$log_id){
- Db::rollback();
- $this->error('签到失败');
- }
-
- $rs = model('wallet')->lockChangeAccountRemain($this->auth->id,0,'gold',$data['goldnum'],41,'签到','user_sign',$log_id);
- if($rs['status'] === false){
- Db::rollback();
- $this->error($rs['msg']);
- }
-
-
- $msg_id = \app\common\model\Message::addMessage($this->auth->id,'签到奖励','签到成功,获得金币奖励');
- Db::commit();
- $remark = '获得金币'.$data['goldnum'];
-
- $this->success('签到成功',$remark);
- }
-
-
-
- }
|