即时系统
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

541 lines
21 KiB

<?php
namespace app\enterprise\controller;
use app\BaseController;
use app\enterprise\model\{User,Group as GroupModel,GroupUser,Message};
use think\Exception;
use think\facade\Db;
use app\common\controller\Upload;
use GatewayClient\Gateway;
use utils\Str;
class Group extends BaseController
{
protected $setting=['manage' => 0, 'invite' => 1, 'nospeak' => 0];
// 获取联系人列表
public function getAllUser(){
$param=$this->request->param();
$user_ids=isset($param['user_ids'])?$param['user_ids']:[];
$groupId=$param['group_id'] ?? '';
$group_id='';
if($groupId){
$group_id=explode('-',$groupId)[1];
}
$data=User::getAllUser([['status','=',1],['user_id','<>',$this->userInfo['user_id']]],$user_ids,$this->uid,$group_id);
return success('',$data);
}
// 获取群成员
public function groupUserList()
{
$param = $this->request->param();
try {
$group_id = explode('-', $param['group_id'])[1];
$listRows = $this->request->param('limit',0);
$pageSize = $this->request->param('page',1);
$map=['group_id' => $group_id];
if($listRows){
$list=GroupUser::where($map)->order('role asc')->paginate(['list_rows'=>$listRows,'page'=>$pageSize]);
$data=$list->toArray()['data'];
$count=$list->total();
}else{
$data=GroupUser::where($map)->order('role asc')->select();
$count=count($data);
}
$data =User::matchAllUser($data,true,'user_id', 'userInfo', '80', $this->uid);
return success('', $data,$count);
} catch (Exception $e) {
return error($e->getMessage());
}
}
// 获取群基本信息
public function groupInfo()
{
$param = $this->request->param();
try {
$jm='qr';
$groupId=$param['group_id'] ?? '';
$groupInfo = explode('-', $groupId);
$group_id=$groupInfo[1];
$group=GroupModel::find($group_id)->toArray();
$userList=User::matchUser($group,false,'owner_id');
$userCount=GroupUser::where(['group_id'=>$group_id])->count();
$userInfo=$userList[$group['owner_id']];
$expire=time()+7*86400;
$token=urlencode(authcode($this->uid.'-'.$group_id,'ENCODE', $jm,7*86400));
$qrUrl=getMainHost().'/scan/g/'.$token;
$group['id']=$groupId;
$group['qrUrl']=$qrUrl;
//$group['qrExpire']=date('m月d日',$expire);
$group['qrExpire']=date('m-d',$expire);
$group['userInfo']=$userInfo;
$group['ownerName']=$userInfo['realname'];
$group['groupUserCount']=$userCount;
$group['displayName']=$group['name'];
$group['avatar']=avatarUrl($group['avatar'],$group['name'],$group['group_id'],120);
$group['setting']=$group['setting']?json_decode($group['setting'],true):['manage' => 0, 'invite' => 1, 'nospeak' => 0];
$group['isJoin']=GroupUser::where(['group_id'=>$group_id,'user_id'=>$this->uid])->value('role') ?: 0;
return success('', $group);
} catch (Exception $e) {
return error($e->getMessage());
}
}
// 修改团队名称
public function editGroupName()
{
$param = $this->request->param();
$group_id = explode('-', $param['id'])[1];
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$this->userInfo['user_id']])->value('role');
if($role>2){
return warning(lang('group.notAuth'));
}
GroupModel::where(['group_id' => $group_id])->update(['name' => $param['displayName'],'name_py'=>pinyin_sentence($param['displayName'])]);
$param['editUserName'] = $this->userInfo['realname'];
$action='editGroupName';
event('GroupChange', ['action' => $action, 'group_id' => $group_id, 'param' => $param]);
wsSendMsg($group_id, $action, $param, 1);
return success(lang('system.editOk'));
}
// 添加群成员
public function addGroupUser(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
$group_id = explode('-', $param['id'])[1] ?? 0;
if(!$group_id){
return warning(lang('system.exits'));
}
$groupInfo=GroupModel::where(['group_id'=>$group_id])->find();
if(!$groupInfo){
return warning(lang('system.exits'));
}
$user_ids=$param['user_ids'];
$groupUserCount=GroupUser::where(['group_id'=>$group_id,'status'=>1])->count();
if((count($user_ids) + $groupUserCount) > $this->chatSetting['groupUserMax'] && $this->chatSetting['groupUserMax']!=0){
return warning(lang('group.userLimit',['userMax'=>$this->chatSetting['groupUserMax']]));
}
if(count($user_ids)>20){
return warning(lang('group.inviteLimit',['limit'=>20]));
}
try{
foreach($user_ids as $k=>$v){
$item=[
'group_id'=>$group_id,
'user_id'=>$v,
'role'=>3,
'invite_id'=>$uid
];
$hasUser=GroupUser::where(['group_id'=>$group_id,'user_id'=>$v])->find();
// 查询是否有人
if(!$hasUser){
GroupUser::create($item);
}
}
$url=GroupModel::setGroupAvatar($group_id);
// 更新原来群聊的头像和成员列表
wsSendMsg($group_id,"addGroupUser",['group_id'=>$param['id'],'avatar'=>$url],1);
// 给新成员添加新群聊信息
$user=new User();
$data=$user->setContact($group_id,1,'text',lang('group.invite',['username'=>$this->userInfo['realname']]),$groupInfo);
wsSendMsg($user_ids, 'addGroup', $data);
return success(lang('system.addOk'));
}catch(Exception $e){
return error($e->getMessage());
}
}
// 设置管理员
public function setManager(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
$group_id = explode('-', $param['id'])[1];
$user_id=$param['user_id'];
$role=$param['role'];
if(!GroupUser::checkAuth(['group_id'=>$group_id,'user_id'=>$uid])){
return warning(lang('system.notAuth'));
}
$groupUser=GroupUser::where(['group_id'=>$group_id,'user_id'=>$user_id])->find();
if($groupUser){
$groupUser->role=$role;
$groupUser->save();
$avatar=GroupModel::where(['group_id'=>$group_id])->value('avatar');
$url=avatarUrl($avatar);
wsSendMsg($group_id,"setManager",['group_id'=>$param['id'],'user_id'=>$user_id,'avatar'=>$url],1);
return success(lang('system.settingOk'));
}else{
return warning('');
}
}
// 添加群聊
public function add(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
$user_ids=$param['user_ids'] ?? [];
if($this->chatSetting['groupChat']==0){
return warning(lang('system.notAuth'));
}
// 查看是否限制了群聊创建的个数
if($this->userInfo['group_limit']!=0 && $this->userInfo['role']==0){
$myGroup=GroupModel::where(['owner_id'=>$uid])->count();
// 群聊已达上限
if($myGroup>$this->userInfo['group_limit'] || $this->userInfo['group_limit']<0){
return warning(lang('group.limit'));
}
}
if(count($user_ids)>$this->chatSetting['groupUserMax'] && $this->chatSetting['groupUserMax']!=0){
return warning(lang('group.userLimit',['userMax'=>$this->chatSetting['groupUserMax']]));
}
// 管理员可以单独创建一个人的群
if(count($user_ids)<=1 && $this->userInfo['role']>=2){
return warning(lang('group.atLeast'));
}
// 将自己也加入群聊
$user_ids[]=$uid;
Db::startTrans();
$setting=$this->setting;
try{
$create=[
'create_user'=>$uid,
'owner_id'=>$uid,
'name'=>lang('group.name'),
'name_py'=>"qunliao",
'setting'=>json_encode($setting),
];
$name=$param['name'] ?? '';
if($name){
$create['name']=$name;
$create['name_py']=pinyin_sentence($name);
}
$group=new GroupModel();
$group->save($create);
$group_id=$group->group_id;
$data=[];
array_unique($user_ids);
sort($user_ids);
foreach($user_ids as $k=>$v){
$info=[
'user_id'=>$v,
'invite_id'=>$uid,
'status'=>1,
'role'=>3,
'group_id'=>$group_id
];
if($v==$uid){
$info['invite_id']=0;
$info['role']=1;
}
$data[]=$info;
}
$groupUser=new GroupUser();
$groupUser->saveAll($data);
$url=GroupModel::setGroupAvatar($group_id);
$groupInfo=[
'displayName'=>$create['name'],
'owner_id'=>$create['owner_id'],
'role'=>3,
'name_py'=>$create['name_py'],
'id'=>'group-'.$group_id,
'avatar'=>avatarUrl($url,$create['name'],$group_id,120),
'is_group'=>1,
'lastContent'=>lang('group.add',['username'=>$this->userInfo['realname']]),
'lastSendTime'=>time()*1000,
'index'=>"[2]".lang('group.name'),
'is_notice'=>1,
'is_top'=>0,
'setting'=>$setting,
'type'=>'create',
];
Message::create([
'from_user'=>$uid,
'to_user'=>$group_id,
'content'=>str_encipher(lang('group.add',['username'=>''])),
'type'=>'event',
'is_group'=>1,
'is_read'=>1,
'is_last'=>1,
'chat_identify'=>'group-'.$group_id
]);
wsSendMsg($user_ids, 'addGroup', $groupInfo);
Db::commit();
$groupInfo['role']=1;
return success('',$groupInfo);
}catch(Exception $e){
Db::rollback();
return error($e->getMessage());
}
}
// 移除成员
public function removeUser(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
$group_id = explode('-', $param['id'])[1];
$user_id=$param['user_id'];
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->value('role');
if($role>2 && $user_id!=$uid){
return warning(lang('system.notAuth'));
}
$groupUser=GroupUser::where(['group_id'=>$group_id,'user_id'=>$user_id])->find();
if(($groupUser && $groupUser['role']>$role) || $user_id==$uid){
GroupUser::destroy($groupUser->id);
Gateway::$registerAddress = config('gateway.registerAddress');
$clientIds=Gateway::getClientIdByUid($user_id);
// 解绑群组
if($clientIds){
foreach($clientIds as $k=>$v){
Gateway::leaveGroup($v, $group_id);
}
}
}else{
return warning(lang('system.notAuth'));
}
$url=GroupModel::setGroupAvatar($group_id);
wsSendMsg($group_id,"removeUser",['group_id'=>$param['id'],'avatar'=>$url,'user_id'=>$user_id],1);
return success(lang('system.delOk'));
}
// 设置群成员禁言
public function setNoSpeak(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
$group_id = explode('-', $param['id'])[1];
$user_id=$param['user_id'];
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->value('role');
if($role>2 && $user_id!=$uid){
return warning(lang('system.notAuth'));
}
$groupUser=GroupUser::where(['group_id'=>$group_id,'user_id'=>$user_id])->find();
if(!$groupUser){
return warning(lang('system.notAuth'));
}
$noSpeakTimer=$param['noSpeakTimer'] ?? 0;
$noSpeakList=[600,3600,10800,86400];
$noSpeakDay=$param['noSpeakDay'] ?? 1;
$noSpeakTime=$noSpeakDay*86400;
if($noSpeakTimer>0){
$noSpeakTime=$noSpeakList[$noSpeakTimer-1];
}
wsSendMsg($group_id,"setNoSpeak",['group_id'=>$param['id'],'user_id'=>$user_id],1);
GroupUser::where(['group_id'=>$group_id,'user_id'=>$user_id])->update(['no_speak_time'=>time()+$noSpeakTime]);
return success(lang('system.success'));
}
// 解散团队
public function removeGroup(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
$group_id = explode('-', $param['id'])[1];
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->value('role');
if($role>1){
return warning(lang('system.notAuth'));
}
Db::startTrans();
try{
// 删除团队成员
GroupUser::where(['group_id'=>$group_id])->delete();
// 删除团队
GroupModel::destroy($group_id);
wsSendMsg($group_id,"removeGroup",['group_id'=>$param['id']],1);
Db::commit();
return success('');
}catch(Exception $e){
Db::rollback();
return error($e->getMessage());
}
}
// 设置公告
public function setNotice(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
if (!isset($param['notice'])) {
return warning(lang('system.notNull'));
}
// 公告内容检测服务
event('GreenText',['content'=>$param['notice'],'service'=>"comment_detection"]);
$group_id = explode('-', $param['id'])[1];
if($param['notice']==''){
return warning(lang('system.notNull'));
}
$GroupModel = GroupModel::where(['group_id' => $group_id])->find();
if (!$GroupModel) {
return error(lang('system.fail'));
}
$setting = json_decode($GroupModel['setting'], true);
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->value('role');
if($role>2 && $setting['manage'] >= 1){
return warning(lang('system.notAuth'));
}
GroupModel::update(['notice'=>$param['notice']],['group_id'=>$group_id]);
$msg=[
'id'=>\utils\Str::getUuid(),
'user_id'=>$uid,
'content'=>'<b>'.lang('group.notice').':</b>&nbsp;@'.lang('group.all').'<br/>'.$param['notice'].'<br/>',
'toContactId'=>$param['id'],
'sendTime'=>time()*1000,
'type'=>'text',
'is_group'=>1,
'status'=>'succeed',
'fromUser'=>$this->userInfo,
'at'=>[0]
];
$message=new Message();
$data = $message->sendMessage($msg,$this->globalConfig);
if (!$data) {
return warning($message->getError());
}
return success('');
}
// 群聊设置
public function groupSetting(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
$group_id = explode('-', $param['id'])[1];
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->value('role');
if($role!=1){
return warning(lang('system.notAuth'));
}
$setting=json_encode($param['setting']);
GroupModel::update(['setting'=>$setting],['group_id'=>$group_id]);
wsSendMsg($group_id,"groupSetting",['group_id'=>$param['id'],'setting'=>$param['setting']],1);
return success('');
}
//生成群聊头像
protected function setGroupAvatar($group_id){
$userList=GroupUser::where('group_id',$group_id)->limit(9)->column('user_id');
$userList=User::where('user_id','in',$userList)->select()->toArray();
$imgList=[];
$dirPath=app()->getRootPath().'public/temp';
foreach($userList as $k=>$v){
if($v['avatar']){
$imgList[]=avatarUrl($v['avatar'],$v['realname'],$v['user_id']);
}else{
$imgList[]=circleAvatar($v['realname'],80,$v['user_id'],1,$dirPath);
}
}
$groupId='group_'.$group_id;
$path=$dirPath.'/'.$groupId.'.jpg';
$a = getGroupAvatar($imgList,1,$path);
$url='';
if($a){
$upload=new Upload();
$newPath=$upload->uploadLocalAvatar($path,[],$groupId);
if($newPath){
GroupModel::where('group_id',$group_id)->update(['avatar'=>$newPath]);
$url=avatarUrl($newPath);
}
}
// 删除目录下的所有文件
$files = glob($dirPath . '/*'); // 获取目录下所有文件路径
foreach ($files as $file) {
if (is_file($file)) { // 如果是文件则删除
unlink($file);
}
}
return $url;
}
// 加入群
public function joinGroup(){
$param = $this->request->param();
$uid=$this->userInfo['user_id'];
try{
$group_id = explode('-', $param['group_id'])[1];
$inviteUid=$param['inviteUid'] ?? '';
$groupUserCount=GroupUser::where(['group_id'=>$group_id,'status'=>1])->count();
$groupUser=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->find();
$groupInfo=GroupModel::where(['group_id'=>$group_id])->find();
if(!$groupInfo){
return warning(lang('group.exist'));
}
if($groupUser){
return warning(lang('group.alreadyJoin'));
}
if(($groupUserCount+1) > $this->chatSetting['groupUserMax'] && $this->chatSetting['groupUserMax']!=0){
return warning(lang('group.userLimit',['userMax'=>$this->chatSetting['groupUserMax']]));
}
// 加入者的名称
$groupInfo['joinerName']=$this->userInfo['realname'];
GroupUser::joinGroup($uid,$inviteUid,$groupInfo);
return success(lang('system.joinOk'));
}catch(Exception $e){
return error($e->getMessage());
}
}
// 更换群主
public function changeOwner()
{
$user_id = $this->request->param('user_id');
$id = $this->request->param('id');
$group_id = explode('-', $id)[1];
$uid=$this->userInfo['user_id'];
$group=GroupModel::where('group_id',$group_id)->find();
if(!$group){
return warning(lang('group.exist'));
}
$user=User::where('user_id',$user_id)->find();
if(!$user){
return warning(lang('user.exist'));
}
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->value('role');
if($role>1){
return warning(lang('system.notAuth'));
}
Db::startTrans();
try{
GroupUser::where('group_id',$group_id)->where('user_id',$user_id)->update(['role'=>1]);
GroupUser::where('group_id',$group_id)->where('user_id',$group->owner_id)->update(['role'=>3]);
$group->owner_id=$user_id;
$group->save();
wsSendMsg($group_id,"changeOwner",['group_id'=>'group-'.$group_id,'user_id'=>$user_id],1);
Db::commit();
return success('');
}catch (\Exception $e){
Db::rollback();
return warning('');
}
}
// 清理群消息
public function clearMessage()
{
$id = $this->request->param('id');
$group_id = explode('-', $id)[1];
$uid=$this->userInfo['user_id'];
$group=GroupModel::where('group_id',$group_id)->find();
if(!$group){
return warning(lang('group.exist'));
}
$role=GroupUser::where(['group_id'=>$group_id,'user_id'=>$uid])->value('role');
// 如果是群主或者后台管理员才有权限
if($role>1 && $this->userInfo['role']==0){
return warning(lang('system.notAuth'));
}
Db::startTrans();
try{
// 删除所有消息
$res = Message::where(['chat_identify'=>$id])->select();
foreach ($res as $resMes) {
$resMes->delete();
}
// 该群聊的所有未读置为0
GroupUser::where('group_id',$group_id)->update(['unread'=>0]);
wsSendMsg($group_id,"clearMessage",['group_id'=>'group-'.$group_id],1);
Db::commit();
return success('');
}catch (\Exception $e){
Db::rollback();
return warning('');
}
}
}