|
@@ -0,0 +1,787 @@
|
|
|
+<?php
|
|
|
+
|
|
|
+namespace app\api\controller;
|
|
|
+
|
|
|
+use app\common\controller\Api;
|
|
|
+use think\Db;
|
|
|
+
|
|
|
+ * 匹配 与 匹配的收费
|
|
|
+ */
|
|
|
+class Match extends Api
|
|
|
+{
|
|
|
+ protected $noNeedLogin = ['*'];
|
|
|
+ protected $noNeedRight = ['*'];
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ public function video_audio_moneycheck(){
|
|
|
+
|
|
|
+ $to_user_id = input_post('from_user_id');
|
|
|
+ $to_user_info = Db::name('user')->field('id,real_status,gender')->where('id',$to_user_id)->find();
|
|
|
+ if(!$to_user_info){
|
|
|
+ $this->error('不存在的用户');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ $type = input_post('type','video');
|
|
|
+ $price = $type == 'video' ? config('site.video_min_price') : config('site.audio_min_price');
|
|
|
+
|
|
|
+
|
|
|
+ $auth_level = 0;
|
|
|
+ $tous_level = 0;
|
|
|
+
|
|
|
+
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status == 1){
|
|
|
+ $auth_level = 30;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status != 1){
|
|
|
+ $auth_level = 20;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 1){
|
|
|
+ $auth_level = 10;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] == 1){
|
|
|
+ $tous_level = 30;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] != 1){
|
|
|
+ $tous_level = 20;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 1){
|
|
|
+ $tous_level = 10;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level == $tous_level){
|
|
|
+ $price = 0;
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level < $tous_level){
|
|
|
+ $kou_user = $this->auth->id;
|
|
|
+ }else{
|
|
|
+ $kou_user = $to_user_info['id'];
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($price > 0 && $kou_user == $this->auth->id){
|
|
|
+ Db::startTrans();
|
|
|
+ $gold = model('wallet')->getWallet($kou_user,'gold');
|
|
|
+ if(bccomp($price,$gold) == 1){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error('金币不足');
|
|
|
+ }
|
|
|
+ Db::commit();
|
|
|
+ }
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public function video_onemin(){
|
|
|
+
|
|
|
+ $to_user_id = input_post('to_user_id');
|
|
|
+ $to_user_info = Db::name('user')->field('id,real_status,gender,free_video,free_audio,free_typing')->where('id',$to_user_id)->find();
|
|
|
+ if(!$to_user_info){
|
|
|
+ $this->error('不存在的用户');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ $price = config('site.video_min_price');
|
|
|
+ $bili = config('site.money_to_gold');
|
|
|
+ $gift_plat_scale = config('site.gift_plat_scale');
|
|
|
+ $money = bcdiv($price,$bili,2);
|
|
|
+ $money = bcdiv(bcmul($money,100 - $gift_plat_scale,2),100,2);
|
|
|
+
|
|
|
+
|
|
|
+ $auth_level = 0;
|
|
|
+ $tous_level = 0;
|
|
|
+
|
|
|
+
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status == 1){
|
|
|
+ $auth_level = 30;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status != 1){
|
|
|
+ $auth_level = 20;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 1){
|
|
|
+ $auth_level = 10;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] == 1){
|
|
|
+ $tous_level = 30;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] != 1){
|
|
|
+ $tous_level = 20;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 1){
|
|
|
+ $tous_level = 10;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level == $tous_level){
|
|
|
+ $price = 0;$money = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::startTrans();
|
|
|
+
|
|
|
+ $data = [
|
|
|
+ 'user_id' => $this->auth->id,
|
|
|
+ 'price' => $price,
|
|
|
+ 'createtime' => time(),
|
|
|
+ 'to_user_id' => $to_user_id,
|
|
|
+ 'money' => $money,
|
|
|
+ ];
|
|
|
+
|
|
|
+ $log_id = Db::name('user_match_video_log')->insertGetId($data);
|
|
|
+ if(!$log_id){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error('扣费失败');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level == $tous_level){
|
|
|
+ Db::commit();
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level < $tous_level){
|
|
|
+ $kou_user = $this->auth->id;
|
|
|
+ $get_user = $to_user_info['id'];
|
|
|
+ $get_user_free = $to_user_info['free_video'];
|
|
|
+ }else{
|
|
|
+ $kou_user = $to_user_info['id'];
|
|
|
+ $get_user = $this->auth->id;
|
|
|
+ $get_user_free = $this->auth->free_video;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($price > 0 && $kou_user != $this->auth->id){
|
|
|
+ $gold = model('wallet')->getWallet($kou_user,'gold');
|
|
|
+ if(bccomp($price,$gold) == 1){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error('对方金币不足');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($price > 0){
|
|
|
+ $rs = model('wallet')->lockChangeAccountRemain($kou_user, $get_user,'gold',-$price,11,'','user_match_video_log',$log_id);
|
|
|
+ if($rs['status'] === false){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error($rs['msg']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if($money > 0 && $get_user_free == 0){
|
|
|
+ $rs = model('wallet')->lockChangeAccountRemain($get_user,$kou_user,'money',$money,21,'','user_match_video_log',$log_id);
|
|
|
+ if($rs['status'] === false){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error($rs['msg']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::commit();
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+ public function audio_onemin(){
|
|
|
+
|
|
|
+ $to_user_id = input_post('to_user_id');
|
|
|
+ $to_user_info = Db::name('user')->field('id,real_status,gender,free_video,free_audio,free_typing')->where('id',$to_user_id)->find();
|
|
|
+ if(!$to_user_info){
|
|
|
+ $this->error('不存在的用户');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ $price = config('site.audio_min_price');
|
|
|
+ $bili = config('site.money_to_gold');
|
|
|
+ $gift_plat_scale = config('site.gift_plat_scale');
|
|
|
+ $money = bcdiv($price,$bili,2);
|
|
|
+ $money = bcdiv(bcmul($money,100 - $gift_plat_scale,2),100,2);
|
|
|
+
|
|
|
+
|
|
|
+ $auth_level = 0;
|
|
|
+ $tous_level = 0;
|
|
|
+
|
|
|
+
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status == 1){
|
|
|
+ $auth_level = 30;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status != 1){
|
|
|
+ $auth_level = 20;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 1){
|
|
|
+ $auth_level = 10;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] == 1){
|
|
|
+ $tous_level = 30;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] != 1){
|
|
|
+ $tous_level = 20;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 1){
|
|
|
+ $tous_level = 10;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level == $tous_level){
|
|
|
+ $price = 0;$money = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::startTrans();
|
|
|
+
|
|
|
+ $data = [
|
|
|
+ 'user_id' => $this->auth->id,
|
|
|
+ 'price' => $price,
|
|
|
+ 'createtime' => time(),
|
|
|
+ 'to_user_id' => $to_user_id,
|
|
|
+ 'money' => $money,
|
|
|
+ ];
|
|
|
+
|
|
|
+ $log_id = Db::name('user_match_audio_log')->insertGetId($data);
|
|
|
+ if(!$log_id){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error('扣费失败');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level == $tous_level){
|
|
|
+ Db::commit();
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level < $tous_level){
|
|
|
+ $kou_user = $this->auth->id;
|
|
|
+ $get_user = $to_user_info['id'];
|
|
|
+ $get_user_free = $to_user_info['free_audio'];
|
|
|
+ }else{
|
|
|
+ $kou_user = $to_user_info['id'];
|
|
|
+ $get_user = $this->auth->id;
|
|
|
+ $get_user_free = $this->auth->free_audio;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($price > 0 && $kou_user != $this->auth->id){
|
|
|
+ $gold = model('wallet')->getWallet($kou_user,'gold');
|
|
|
+ if(bccomp($price,$gold) == 1){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error('对方金币不足');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($price > 0){
|
|
|
+ $rs = model('wallet')->lockChangeAccountRemain($kou_user,$get_user,'gold',-$price,12,'','user_match_audio_log',$log_id);
|
|
|
+ if($rs['status'] === false){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error($rs['msg']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if($money > 0 && $get_user_free == 0){
|
|
|
+ $rs = model('wallet')->lockChangeAccountRemain($get_user, $kou_user,'money',$money,22,'','user_match_audio_log',$log_id);
|
|
|
+ if($rs['status'] === false){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error($rs['msg']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::commit();
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+ public function typing_once(){
|
|
|
+
|
|
|
+ $to_user_id = input_post('to_user_id');
|
|
|
+ $to_user_info = Db::name('user')->field('id,real_status,gender,free_video,free_audio,free_typing')->where('id',$to_user_id)->find();
|
|
|
+ if(!$to_user_info){
|
|
|
+ $this->error('不存在的用户');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ $price = config('site.typing_min_price');
|
|
|
+ $bili = config('site.money_to_gold');
|
|
|
+ $gift_plat_scale = config('site.gift_plat_scale');
|
|
|
+ $money = bcdiv($price,$bili,2);
|
|
|
+ $money = bcdiv(bcmul($money,100 - $gift_plat_scale,2),100,2);
|
|
|
+
|
|
|
+
|
|
|
+ $auth_level = 0;
|
|
|
+ $tous_level = 0;
|
|
|
+
|
|
|
+
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status == 1){
|
|
|
+ $auth_level = 30;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 0 && $this->auth->real_status != 1){
|
|
|
+ $auth_level = 20;
|
|
|
+ }
|
|
|
+ if($this->auth->gender == 1){
|
|
|
+ $auth_level = 10;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] == 1){
|
|
|
+ $tous_level = 30;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 0 && $to_user_info['real_status'] != 1){
|
|
|
+ $tous_level = 20;
|
|
|
+ }
|
|
|
+ if($to_user_info['gender'] == 1){
|
|
|
+ $tous_level = 10;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level == $tous_level){
|
|
|
+ $price = 0;$money = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ if($auth_level > $tous_level){
|
|
|
+ $price = 0;$money = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::startTrans();
|
|
|
+
|
|
|
+ $data = [
|
|
|
+ 'user_id' => $this->auth->id,
|
|
|
+ 'price' => $price,
|
|
|
+ 'createtime' => time(),
|
|
|
+ 'to_user_id' => $to_user_id,
|
|
|
+ 'money' => $money,
|
|
|
+ ];
|
|
|
+
|
|
|
+ $log_id = Db::name('user_match_typing_log')->insertGetId($data);
|
|
|
+ if(!$log_id){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error('扣费失败');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level == $tous_level){
|
|
|
+ Db::commit();
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+ if($price == 0 && $money == 0){
|
|
|
+ Db::commit();
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if($auth_level < $tous_level){
|
|
|
+ $kou_user = $this->auth->id;
|
|
|
+ $get_user = $to_user_info['id'];
|
|
|
+ $get_user_free = $to_user_info['free_typing'];
|
|
|
+ }else{
|
|
|
+
|
|
|
+ $kou_user = $to_user_info['id'];
|
|
|
+ $get_user = $this->auth->id;
|
|
|
+ $get_user_free = $this->auth->free_typing;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if($price > 0){
|
|
|
+ $rs = model('wallet')->lockChangeAccountRemain($kou_user,$get_user,'gold',-$price,13,'','user_match_typing_log',$log_id);
|
|
|
+ if($rs['status'] === false){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error($rs['msg']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if($money > 0 && $get_user_free == 0){
|
|
|
+ $rs = model('wallet')->lockChangeAccountRemain($get_user,$kou_user,'money',$money,23,'','user_match_typing_log',$log_id);
|
|
|
+ if($rs['status'] === false){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error($rs['msg']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $task_rs = \app\common\model\TaskLog::tofinish($this->auth->id,15);
|
|
|
+ if($task_rs === false){
|
|
|
+ Db::rollback();
|
|
|
+ $this->error('完成任务赠送奖励失败');
|
|
|
+ }
|
|
|
+
|
|
|
+ Db::commit();
|
|
|
+ $this->success('success');
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public function getaudiouser(){
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $end = $start + 86399;
|
|
|
+
|
|
|
+ $map = [
|
|
|
+ 'user_id' => $this->auth->id,
|
|
|
+ 'createtime' => ['between',[$start,$end]],
|
|
|
+ 'price' => 0,
|
|
|
+ ];
|
|
|
+
|
|
|
+ $check = Db::name('user_match_audio_log')->where($map)->find();*/
|
|
|
+ $check = true;
|
|
|
+
|
|
|
+
|
|
|
+ if($check){
|
|
|
+ $price = config('site.audio_min_price');
|
|
|
+ $gold = model('wallet')->getWallet($this->auth->id,'gold');
|
|
|
+
|
|
|
+ if($gold < $price){
|
|
|
+ $this->error('您的金币已经不足,请充值');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $map = [
|
|
|
+ 'status' =>1,
|
|
|
+ 'gender' => $this->auth->gender == 1 ? 0 : 1,
|
|
|
+ 'is_online' => 0,
|
|
|
+ 'is_livebc' => 0,
|
|
|
+ 'is_active' => 1,
|
|
|
+
|
|
|
+
|
|
|
+ 'open_match_audio' => 1,
|
|
|
+
|
|
|
+ ];
|
|
|
+
|
|
|
+ $lists = Db::name('user')->field('id,cityname,status,gender,real_status,tag_ids')->where($map)->order('logintime desc')->page($this->page,100)->select();
|
|
|
+ $lists = $this->fliter_user($lists,10);
|
|
|
+
|
|
|
+ $result = [];
|
|
|
+ if(!empty($lists)){
|
|
|
+ foreach($lists as $key => $val){
|
|
|
+ $result[] = ['id'=>$val];
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if(!empty($result)){
|
|
|
+ $task_rs = \app\common\model\TaskLog::tofinish($this->auth->id,11);
|
|
|
+ if($task_rs === false){
|
|
|
+ $this->error('完成任务赠送奖励失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ $this->success('success',$result);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public function getvideouser(){
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $end = $start + 86399;
|
|
|
+
|
|
|
+ $map = [
|
|
|
+ 'user_id' => $this->auth->id,
|
|
|
+ 'createtime' => ['between',[$start,$end]],
|
|
|
+ 'price' => 0,
|
|
|
+ ];
|
|
|
+
|
|
|
+ $check = Db::name('user_match_video_log')->where($map)->find();*/
|
|
|
+ $check = true;
|
|
|
+
|
|
|
+
|
|
|
+ if($check){
|
|
|
+ $price = config('site.video_min_price');
|
|
|
+ $gold = model('wallet')->getWallet($this->auth->id,'gold');
|
|
|
+
|
|
|
+ if($gold < $price){
|
|
|
+ $this->error('您的金币已经不足,请充值');
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $map = [
|
|
|
+ 'status' =>1,
|
|
|
+ 'gender' => $this->auth->gender == 1 ? 0 : 1,
|
|
|
+ 'is_online' => 0,
|
|
|
+ 'is_livebc' => 0,
|
|
|
+ 'is_active' => 1,
|
|
|
+
|
|
|
+
|
|
|
+ 'open_match_video' => 1,
|
|
|
+
|
|
|
+ ];
|
|
|
+
|
|
|
+ $lists = Db::name('user')->field('id,cityname,status,gender,real_status,tag_ids')->where($map)->order('logintime desc')->page($this->page,100)->select();
|
|
|
+ $lists = $this->fliter_user($lists,10);
|
|
|
+
|
|
|
+ $result = [];
|
|
|
+ if(!empty($lists)){
|
|
|
+ foreach($lists as $key => $val){
|
|
|
+ $result[] = ['id'=>$val];
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if(!empty($result)){
|
|
|
+ $task_rs = \app\common\model\TaskLog::tofinish($this->auth->id,12);
|
|
|
+ if($task_rs === false){
|
|
|
+ $this->error('完成任务赠送奖励失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
+ $this->success('success',$result);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public function gettypinguser(){
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $map = [
|
|
|
+ 'status' =>1,
|
|
|
+ 'gender' => $this->auth->gender == 1 ? 0 : 1,
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ 'open_match_typing' => 1,
|
|
|
+
|
|
|
+ ];
|
|
|
+
|
|
|
+ $lists = Db::name('user')->field('id,cityname,status,gender,real_status,tag_ids')->where($map)->order('logintime desc')->page($this->page,100)->select();
|
|
|
+
|
|
|
+ $lists = array_column($lists,'id');
|
|
|
+
|
|
|
+ $result = [];
|
|
|
+ if(!empty($lists)){
|
|
|
+
|
|
|
+ $result[] = ['id'=>$val];
|
|
|
+ }*/
|
|
|
+ $result = Db::name('user')->field('id,nickname,username,avatar,audio_bio')->where(['id'=>['IN',$lists]])->select();
|
|
|
+ $result = list_domain_image($result,['avatar,audio_bio']);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if(!empty($result)){
|
|
|
+ $task_rs = \app\common\model\TaskLog::tofinish($this->auth->id,10);
|
|
|
+ if($task_rs === false){
|
|
|
+ $this->error('完成任务赠送奖励失败');
|
|
|
+ }
|
|
|
+ }
|
|
|
+ $this->success('success',$result);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private function fliter_user($lists,$number = 1){
|
|
|
+
|
|
|
+ if(empty($lists)){
|
|
|
+ return $lists;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ foreach($lists as $key => $val){
|
|
|
+ if(redis_matching_get($val['id']) == 1){
|
|
|
+ unset($lists[$key]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ $all_result = array_column($lists,'id');
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $citydata = [];
|
|
|
+ foreach($lists as $key => $val){
|
|
|
+ if( !empty($this->auth->cityname) && $this->auth->cityname == $val['cityname'] ){
|
|
|
+ $citydata[] = $val['id'];
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $tagdata = [];
|
|
|
+ foreach($lists as $key => $val){
|
|
|
+ if( !empty($this->auth->tag_ids) && !empty($val['tag_ids']) ){
|
|
|
+
|
|
|
+ $auth_tag_ids = explode(',',$this->auth->tag_ids);
|
|
|
+ $val_tag_ids = explode(',',$val['tag_ids']);
|
|
|
+ if(count(array_intersect($auth_tag_ids,$val_tag_ids)) > 0){
|
|
|
+ $tagdata[] = $val['id'];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ $double_data = [];
|
|
|
+ if(!empty($citydata) && !empty($tagdata)){
|
|
|
+ $double_data = array_intersect($citydata,$tagdata);
|
|
|
+ }
|
|
|
+
|
|
|
+ if(count($double_data) >= $number){
|
|
|
+ return $double_data;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ $merge_data = array_merge($citydata,$tagdata);
|
|
|
+ $merge_data = array_flip(array_flip($merge_data));
|
|
|
+
|
|
|
+ if(count($merge_data) >= $number){
|
|
|
+ return $merge_data;
|
|
|
+ }
|
|
|
+
|
|
|
+ return $all_result;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public function intimacylevel() {
|
|
|
+ $user_id = input('user_id', 0, 'intval');
|
|
|
+ if (!$user_id) {
|
|
|
+ $this->error('参数缺失');
|
|
|
+ }
|
|
|
+ if ($this->auth->gender == 0) {
|
|
|
+ $where['uid'] = $user_id;
|
|
|
+ $where['other_uid'] = $this->auth->id;
|
|
|
+ } else {
|
|
|
+ $where['uid'] = $this->auth->id;
|
|
|
+ $where['other_uid'] = $user_id;
|
|
|
+ }
|
|
|
+
|
|
|
+ $level = 0;
|
|
|
+ $level_name = '';
|
|
|
+
|
|
|
+ $qinmi_sum = 0;
|
|
|
+ $next_level_diff = 0;
|
|
|
+
|
|
|
+ $next_level_name = 0;
|
|
|
+ $next_level_value = 0;
|
|
|
+
|
|
|
+
|
|
|
+ $list = Db::name('intimacy_level')->field('name,level,value')->order('value')->select();
|
|
|
+
|
|
|
+
|
|
|
+ $user_intimacy_info = Db::name('user_intimacy')->where($where)->find();
|
|
|
+ if ($user_intimacy_info) {
|
|
|
+
|
|
|
+ $qinmi_sum = $user_intimacy_info['value'];
|
|
|
+ if ($list) {
|
|
|
+
|
|
|
+ $level_info = Db::name('intimacy_level')->where(['value' => ['elt', $user_intimacy_info['value']]])->order('level desc')->find();
|
|
|
+ if ($level_info) {
|
|
|
+ $level = $level_info['level'];
|
|
|
+ $level_name = $level_info['name'];
|
|
|
+ }
|
|
|
+
|
|
|
+ $next_level_info = Db::name('intimacy_level')->where(['value' => ['gt', $user_intimacy_info['value']]])->order('value')->find();
|
|
|
+ if ($next_level_info) {
|
|
|
+ $next_level_name = $next_level_info['name'];
|
|
|
+ $next_level_value = $next_level_info['value'];
|
|
|
+ $next_level_diff = $next_level_info['value'] - $user_intimacy_info['value'];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ $next_level = Db::name('intimacy_level')->order('value')->find();
|
|
|
+ $next_level_diff = $next_level['value'];
|
|
|
+ $next_level_name = $next_level['name'];
|
|
|
+ $next_level_value = $next_level['value'];
|
|
|
+ }
|
|
|
+
|
|
|
+ if ($list) {
|
|
|
+ foreach ($list as &$v) {
|
|
|
+ if ($v['level'] < $level) {
|
|
|
+ $v['is_unlock'] = 1;
|
|
|
+ } elseif ($v['level'] == $level) {
|
|
|
+ $v['is_unlock'] = 2;
|
|
|
+ } else {
|
|
|
+ $v['is_unlock'] = 3;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ $data['level'] = $level;
|
|
|
+ $data['level_name'] = $level_name;
|
|
|
+ $data['qinmi_sum'] = $qinmi_sum;
|
|
|
+ $data['next_level_diff'] = $next_level_diff;
|
|
|
+ $data['next_level_name'] = $next_level_name;
|
|
|
+ $data['next_level_value'] = $next_level_value;
|
|
|
+ $data['level_list'] = $list;
|
|
|
+
|
|
|
+ $this->success('亲密度等级信息', $data);
|
|
|
+ }
|
|
|
+
|
|
|
+ public function test(){
|
|
|
+ $this->addintimacy(1,3,20);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public function addintimacy($uid = 0, $other_uid = 0, $value = 0) {
|
|
|
+
|
|
|
+ $level_remark = '';
|
|
|
+ $user_intimacy_info = Db::name('user_intimacy')->where(['uid' => $uid, 'other_uid' => $other_uid])->find();
|
|
|
+ if ($user_intimacy_info) {
|
|
|
+ $user_intimacy_data['value'] = $user_intimacy_info['value'] + $value;
|
|
|
+
|
|
|
+ $level = Db::name('intimacy_level')->where(['value' => ['elt', $user_intimacy_data['value']]])->order('level desc')->find();
|
|
|
+ if ($level) {
|
|
|
+ $user_intimacy_data['level'] = $level['level'];
|
|
|
+ if ($level['level'] != $user_intimacy_info['level']) {
|
|
|
+ $level_remark = "恭喜你们亲密度达到".$level['level']."级,获得称号'".$level['name']."'";
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ $user_intimacy_rs = Db::name('user_intimacy')->where(['uid' => $uid, 'other_uid' => $other_uid])->setField($user_intimacy_data);
|
|
|
+ } else {
|
|
|
+ $user_intimacy_data['uid'] = $uid;
|
|
|
+ $user_intimacy_data['other_uid'] = $other_uid;
|
|
|
+ $user_intimacy_data['value'] = $value;
|
|
|
+
|
|
|
+
|
|
|
+ $level = Db::name('intimacy_level')->where(['value' => ['elt', $value]])->order('level desc')->find();
|
|
|
+ if ($level) {
|
|
|
+ $user_intimacy_data['level'] = $level['level'];
|
|
|
+ $level_remark = "恭喜你们亲密度达到".$level['level']."级,获得称号'".$level['name']."'";
|
|
|
+ }
|
|
|
+
|
|
|
+ $user_intimacy_rs = Db::name('user_intimacy')->insertGetId($user_intimacy_data);
|
|
|
+ }
|
|
|
+
|
|
|
+ return ['status' => $user_intimacy_rs, 'level_remark' => $level_remark];
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+}
|