Merge remote-tracking branch 'origin/develop' into develop
This commit is contained in:
@@ -64,10 +64,7 @@ class Family extends Model
|
||||
*/
|
||||
public function myFamily($user_id)
|
||||
{
|
||||
$myFamily = db::name('vs_family')->where(['user_id' => $user_id,'type' => 1])->find();
|
||||
if($myFamily){
|
||||
$myFamily['group_id'] = 'f'.$myFamily['id'];
|
||||
$myFamily['group_owner_info'] = db::name('user')->where('id',$myFamily['user_id'])->field('nickname,avatar')->find();
|
||||
$myFamily['group_owner_info'] = db::name('user')->where('id',$user_id)->field('nickname,avatar')->find();
|
||||
$myFamily['group_owner_info']['dress'] = model('api/Decorate')->user_decorate_detail($user_id,1);
|
||||
$myFamily['group_owner_info']['user_code'] = model('api/Decorate')->user_decorate_detail($user_id,6);
|
||||
$myFamily['group_owner_info']['icon'][0] = model('api/UserData')->user_wealth_icon($user_id);//财富图标
|
||||
@@ -82,19 +79,17 @@ class Family extends Model
|
||||
$myFamily['group_owner_info']['nobility_image'] = $Nobility['play_image'];
|
||||
$myFamily['group_owner_info']['nickname_color'] = $Nobility['nick_name_color'];
|
||||
|
||||
$myFamily['group_members_num'] = db::name('vs_user_sign')->where(['parent_user_id' => $myFamily['user_id']])->count();
|
||||
$myFamily['group_earnings'] = db::name('vs_user_sign_earnings')->where('user_id',$myFamily['user_id'])->sum('earnings');
|
||||
$myFamily['group_members_num'] = db::name('vs_user_sign')->where(['parent_user_id' => $user_id])->count();
|
||||
$myFamily['group_earnings'] = db::name('vs_user_sign_earnings')->where('user_id',$user_id)->sum('earnings');
|
||||
|
||||
// $lists= db::name('vs_user_sign')->alias('a')
|
||||
// ->join('user b','a.sign_user_id = b.id')
|
||||
// ->field('b.is_online,b.market_value,b.nickname,b.avatar,b.user_code,a.sign_user_id as user_id,a.type,a.end_time,a.sign_user_type')
|
||||
// ->where(['parent_user_id' => $myFamily['user_id'],'end_time' => ['>',time()]])
|
||||
// ->select();
|
||||
$myFamilys = db::name('vs_family')->where(['user_id' => $user_id,'type' => 1])->find();
|
||||
|
||||
if($myFamilys){
|
||||
$lists= db::name('vs_family')->alias('a')
|
||||
->join('user b','a.user_id = b.id')
|
||||
->join('vs_user_sign c','a.user_id = c.sign_user_id')
|
||||
->field('b.is_online,b.market_value,b.nickname,b.avatar,b.user_code,c.type,c.end_time,c.sign_user_type,a.user_id')
|
||||
->where(['a.pid' => $myFamily['user_id'],'a.deletetime' => 0,'a.type' => 0])
|
||||
->where(['a.pid' => $myFamilys['user_id'],'a.deletetime' => 0,'a.type' => 0,'c.end_time' => ['>',time()]])
|
||||
->select();
|
||||
if($lists){
|
||||
foreach ($lists as $k => $v){
|
||||
@@ -105,7 +100,8 @@ class Family extends Model
|
||||
//判断是否是歌手 如果是 返回等级图标
|
||||
$isSinnger = db::name('vs_singer')->where(['user_id' => $v['user_id'],'status' => 1])->value('level');
|
||||
if($isSinnger){
|
||||
$lists[$k]['icon'][2] = db::name('vs_singer_level')->where(['level' => $isSinnger,'deletetime' => 0])->value('image');//等级图标
|
||||
$lists[$k]['icon'][2] = db::name('vs_singer_level')->where(['level' => $isSinnger,'deletetime' => 0])
|
||||
->value('image');//等级图标
|
||||
}
|
||||
$Nobility = model('api/Nobility')->getUserNobilityInfo($v['user_id']);
|
||||
$lists[$k]['mic_cycle'] = model('api/Decorate')->user_decorate_detail($v['user_id'],3);
|
||||
@@ -144,7 +140,13 @@ class Family extends Model
|
||||
}
|
||||
|
||||
$myFamily['group_members_lists'] = $lists ;
|
||||
$myFamily['group_id'] = 'f'.$myFamilys['id'];
|
||||
}else{
|
||||
$myFamily['group_id'] = null;
|
||||
$myFamily['group_members_lists'] = null ;
|
||||
}
|
||||
|
||||
|
||||
return ['code' => 1, 'msg' => '成功', 'data' => $myFamily];
|
||||
}
|
||||
|
||||
|
||||
@@ -1294,6 +1294,9 @@ class Room extends Model
|
||||
}
|
||||
$room_pit = db::name('vs_room_pit')->where(['room_id' => $room_id, 'user_id' => $user_id])->find();
|
||||
if ($room_pit) {
|
||||
if($room_pit['pit_number'] == 2){
|
||||
return ['code' => 0, 'msg' => '师傅麦不能退出', 'data' => null];
|
||||
}
|
||||
model('api/RoomPit')->DownPit($user_id, $room_id, $room_pit['pit_number']);
|
||||
}
|
||||
}elseif ($apply_type == 6){
|
||||
@@ -1930,7 +1933,8 @@ class Room extends Model
|
||||
//开启事务
|
||||
db::startTrans();
|
||||
$data = [];
|
||||
if($type == 1 || $type == 3 || $type == 4 || $type == 8 || $type == 9 || $type == 10){
|
||||
//1-交友,3、4、8-不要了
|
||||
if($type == 1 || $type == 3 || $type == 4 || $type == 8){
|
||||
$data = [
|
||||
'label_id' => 1,
|
||||
'type_id' => $type,
|
||||
@@ -1938,6 +1942,7 @@ class Room extends Model
|
||||
'is_song' => 1
|
||||
];
|
||||
}
|
||||
//拍卖
|
||||
if($type == 2){
|
||||
$data = [
|
||||
'label_id' => 3,
|
||||
@@ -1946,7 +1951,7 @@ class Room extends Model
|
||||
'is_song' => 1
|
||||
];
|
||||
}
|
||||
//交友房(互娱)
|
||||
//(互娱)
|
||||
if($type == 7){
|
||||
$data = [
|
||||
'label_id' => 5,
|
||||
@@ -1954,6 +1959,23 @@ class Room extends Model
|
||||
'room_up_pit_type' => 1,
|
||||
];
|
||||
}
|
||||
|
||||
//点唱房 (让别人唱歌)
|
||||
if($type == 9){
|
||||
$data = [
|
||||
'label_id' => 6,
|
||||
'type_id' => $type,
|
||||
'room_up_pit_type' => 1,
|
||||
];
|
||||
}
|
||||
//签约房
|
||||
if($type == 10){
|
||||
$data = [
|
||||
'label_id' => 7,
|
||||
'type_id' => $type,
|
||||
'room_up_pit_type' => 1,
|
||||
];
|
||||
}
|
||||
$res = db::name('vs_room')->where(['id' => $room_id])->update($data);
|
||||
|
||||
if(!$res){
|
||||
|
||||
@@ -458,6 +458,7 @@ class RoomPit extends Model
|
||||
'a.status' => 0,
|
||||
];
|
||||
|
||||
//常规通道 type: 0普通通道,1优先通道
|
||||
$list['regular'] = db::name('vs_room_pit_apply')->alias('a')->join('user b','a.user_id = b.id')
|
||||
->where($where)->where('a.type',0)->field('a.user_id,a.rank_value,b.nickname,b.avatar')
|
||||
->order('a.rank_value desc')->select();
|
||||
@@ -483,6 +484,7 @@ class RoomPit extends Model
|
||||
//把特殊用户放在最前面
|
||||
array_unshift($list['special'],$special);
|
||||
}
|
||||
if($list['special']){
|
||||
foreach ($list['special'] as $k => $v){
|
||||
//查询用户的爵位
|
||||
$juewei = model('Nobility')->getUserNobilityInfo($v['user_id']);
|
||||
@@ -495,13 +497,13 @@ class RoomPit extends Model
|
||||
}
|
||||
}
|
||||
//先根据$v['jue_wei'] 下面的level 由大到小排序,再根据$v['rank_value'] 由大到小排序level
|
||||
usort($list['regular'], function($a, $b) {
|
||||
usort($list['special'], function($a, $b) {
|
||||
if ($a['jue_wei']['level'] == $b['jue_wei']['level']) {
|
||||
return $b['rank_value'] - $a['rank_value'];
|
||||
}
|
||||
return $b['jue_wei']['level'] - $a['jue_wei']['level'];
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
$list['gift_info'] = db::name('vs_room_pit_apply_help_gift')->where('room_id',$room_id)->find();
|
||||
if($list['gift_info']){
|
||||
|
||||
@@ -449,29 +449,29 @@ class Sign extends Model
|
||||
public function pit_number($room_id,$user_id = 0,$type = 0){
|
||||
if($type == 1){//上麦或者换麦
|
||||
//获取房间2号位上的用户
|
||||
$on_pit_user = db::name('vs_room_pit')
|
||||
$on_pit2_user = db::name('vs_room_pit')
|
||||
->where(['room_id' => $room_id,'pit_number' => 2])->field('before_pit_number,user_id')->find();
|
||||
if($on_pit_user['user_id'] == $user_id){
|
||||
if($on_pit2_user['user_id'] == $user_id){
|
||||
return true;
|
||||
}
|
||||
|
||||
//处理2号位
|
||||
if($on_pit_user && $on_pit_user['user_id']){
|
||||
if($on_pit2_user && $on_pit2_user['user_id']){
|
||||
//2号位有其他用户,需要处理该用户
|
||||
//获取2号位用户之前的位置上是否有用户
|
||||
$before_pit_number = db::name('vs_room_pit')
|
||||
->where(['room_id' => $room_id,'pit_number' => $on_pit_user['before_pit_number']])->value('user_id');
|
||||
->where(['room_id' => $room_id,'pit_number' => $on_pit2_user['before_pit_number']])->value('user_id');
|
||||
|
||||
if($before_pit_number && $on_pit_user['before_pit_number'] != 0){
|
||||
//之前位置有人,直接下麦
|
||||
model('api/RoomPit')->DownPit($on_pit_user['user_id'], $room_id, 2);
|
||||
if($before_pit_number || $on_pit2_user['before_pit_number'] == 0){
|
||||
//之前位置有人或者之前麦位为空,直接下麦
|
||||
model('api/RoomPit')->DownPit($on_pit2_user['user_id'], $room_id, 2);
|
||||
} else {
|
||||
//之前位置无人,换麦
|
||||
db::name('vs_room_pit')->where(['room_id' => $room_id, 'pit_number' => $on_pit_user['before_pit_number']])
|
||||
->update(['user_id' => $on_pit_user['user_id']]);
|
||||
db::name('vs_room_pit')->where(['room_id' => $room_id, 'pit_number' => $on_pit2_user['before_pit_number']])
|
||||
->update(['user_id' => $on_pit2_user['user_id']]);
|
||||
|
||||
//推送换麦消息
|
||||
$this->sendPitChangeMessage($on_pit_user['user_id'], $room_id, 2, $on_pit_user['before_pit_number']);
|
||||
$this->sendPitChangeMessage($on_pit2_user['user_id'], $room_id, 2, $on_pit2_user['before_pit_number']);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -482,12 +482,11 @@ class Sign extends Model
|
||||
->where(['room_id' => $room_id, 'user_id' => $user_id])
|
||||
->field('pit_number')->find();
|
||||
|
||||
if($user_pit_info && $user_pit_info['pit_number']){
|
||||
//用户已在麦上,换到2号位
|
||||
//记录原麦位信息
|
||||
if($user_pit_info && $user_pit_info['pit_number']){//用户已在麦上
|
||||
//移除原麦位上的自己信息
|
||||
db::name('vs_room_pit')->where(['room_id' => $room_id, 'pit_number' => $user_pit_info['pit_number']])
|
||||
->update(['user_id' => 0]);
|
||||
|
||||
//换到2号位,记录原麦位信息
|
||||
db::name('vs_room_pit')->where(['room_id' => $room_id, 'pit_number' => 2])
|
||||
->update(['user_id' => $user_id,'before_pit_number' => $user_pit_info['pit_number']]);
|
||||
//推送换麦消息
|
||||
|
||||
@@ -54,6 +54,10 @@ class PerformPerSecond
|
||||
$this->system_downgrade();
|
||||
echo "\n";
|
||||
|
||||
echo "签约到期处理:\n";
|
||||
$this->sign_room_expire();
|
||||
echo "\n";
|
||||
|
||||
}
|
||||
|
||||
|
||||
@@ -434,4 +438,23 @@ class PerformPerSecond
|
||||
}
|
||||
}
|
||||
|
||||
public function sign_room_expire(){
|
||||
$res = Db::name('vs_room_sign')->where(['end_time' => ['>',time()],'status' => 1])->select();
|
||||
if($res){
|
||||
foreach ($res as $value){
|
||||
db::name('vs_room_sign')->where('id',$value['id'])->update(['status' => 2]);
|
||||
//处理家族
|
||||
$myFamily = db::name('vs_family')
|
||||
->where(['user_id' => $value['sign_user_id'],'type' => 0,'pid' => $value['parent_user_id'],'deletetime' => 0])->find();
|
||||
if($myFamily){
|
||||
$mySignFamily = db::name('vs_family')->where(['user_id' => $value['parent_user_id'],'type' => 1])->find();
|
||||
//删除群成员
|
||||
model('api/Tencent')->delete_group_member('f'.$mySignFamily['id'], $value['sign_user_id']);
|
||||
//退出家族
|
||||
db::name('vs_family')->where('id', $myFamily['id'])->update(['deletetime' => time()]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user