|
@@ -74,7 +74,7 @@ class MessageService extends BaseService
|
|
|
$where['a.to_uid'] = $userId;
|
|
$where['a.to_uid'] = $userId;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- $field = ['a.id','a.title','a.type','a.description','a.content','a.from_uid','a.to_uid','a.create_time','a.is_read','a.pages','a.status','b.nickname as from_nickname','c.nickname as to_nickname'];
|
|
|
|
|
|
|
+ $field = ['a.id','a.title','a.type','a.msg_type','a.chat_type','a.description','a.content','a.from_user_name','a.from_user_avatar','a.from_uid','a.to_user_name','a.to_user_avatar','a.to_uid','a.create_time','a.is_read','a.pages','a.status'];
|
|
|
$datas = $this->model->from('message as a')
|
|
$datas = $this->model->from('message as a')
|
|
|
->leftJoin('member as b','b.id','=','a.from_uid')
|
|
->leftJoin('member as b','b.id','=','a.from_uid')
|
|
|
->leftJoin('member as c','c.id','=','a.to_uid')
|
|
->leftJoin('member as c','c.id','=','a.to_uid')
|
|
@@ -90,6 +90,11 @@ class MessageService extends BaseService
|
|
|
$query->where('a.type', $type);
|
|
$query->where('a.type', $type);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ $chatType = isset($params['chat_type'])? intval($params['chat_type']) : 0;
|
|
|
|
|
+ if($chatType){
|
|
|
|
|
+ $query->where('a.chat_type', $chatType);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
$status = isset($params['status'])? intval($params['status']) : 0;
|
|
$status = isset($params['status'])? intval($params['status']) : 0;
|
|
|
if($status){
|
|
if($status){
|
|
|
$query->where('a.status', $status);
|
|
$query->where('a.status', $status);
|
|
@@ -108,6 +113,7 @@ class MessageService extends BaseService
|
|
|
$item['content'] = $item['content']? json_decode($item['content'], true) : [];
|
|
$item['content'] = $item['content']? json_decode($item['content'], true) : [];
|
|
|
}
|
|
}
|
|
|
unset($item);
|
|
unset($item);
|
|
|
|
|
+
|
|
|
// 更新已读
|
|
// 更新已读
|
|
|
if($ids){
|
|
if($ids){
|
|
|
$this->model->whereIn('id', $ids)->update(['is_read'=> 1,'update_time'=>time()]);
|
|
$this->model->whereIn('id', $ids)->update(['is_read'=> 1,'update_time'=>time()]);
|
|
@@ -134,7 +140,7 @@ class MessageService extends BaseService
|
|
|
return $datas;
|
|
return $datas;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- $types = [1];
|
|
|
|
|
|
|
+ $types = [1,4,5];
|
|
|
$setting = MemberSettingService::make()->getSetting($userId);
|
|
$setting = MemberSettingService::make()->getSetting($userId);
|
|
|
if($setting){
|
|
if($setting){
|
|
|
foreach ($setting as $k => $v){
|
|
foreach ($setting as $k => $v){
|
|
@@ -144,8 +150,9 @@ class MessageService extends BaseService
|
|
|
$types[] = 3;
|
|
$types[] = 3;
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
+ asort($types);
|
|
|
}else{
|
|
}else{
|
|
|
- $types = [1,2,3];
|
|
|
|
|
|
|
+ $types = [1,2,3,4,5];
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
$field = ['title','type','to_uid','description','is_read','create_time'];
|
|
$field = ['title','type','to_uid','description','is_read','create_time'];
|
|
@@ -160,16 +167,15 @@ class MessageService extends BaseService
|
|
|
$datas = $datas? $datas->toArray() : [];
|
|
$datas = $datas? $datas->toArray() : [];
|
|
|
$total = 0;
|
|
$total = 0;
|
|
|
if($datas){
|
|
if($datas){
|
|
|
- $titles = [1=>'消息通知',2=>'订单通知',3=>'账户通知'];
|
|
|
|
|
|
|
+ $titles = [1=>'公告通知',2=>'订单通知',3=>'账户通知',4=>'客服通知',5=>'互动消息'];
|
|
|
foreach($datas as &$item){
|
|
foreach($datas as &$item){
|
|
|
- $item['time_text'] = isset($item['create_time']) && $item['create_time']? dateFormat($item['create_time']) : '';
|
|
|
|
|
$item['title'] = isset($titles[$item['type']])? $titles[$item['type']] : '消息通知';
|
|
$item['title'] = isset($titles[$item['type']])? $titles[$item['type']] : '消息通知';
|
|
|
- $data = $this->getNewMessage($item['type'],$userId);
|
|
|
|
|
- $item['description'] = isset($data['description']) && $data['description']? $data['description'] : (isset($data['message'])? mb_substr($data['message'],0,20,'utf-8'):'有新消息');
|
|
|
|
|
|
|
+ $data = $this->getNewMessage($item['type'],0, $userId);
|
|
|
|
|
+ $item['description'] = isset($data['description']) && $data['description']? $data['description'] : (isset($data['message'])? mb_substr($data['message'],0,20,'utf-8'): lang('有新消息'));
|
|
|
$item['create_time'] = isset($data['create_time']) && $data['create_time']? $data['create_time'] : '';
|
|
$item['create_time'] = isset($data['create_time']) && $data['create_time']? $data['create_time'] : '';
|
|
|
$item['time_text'] = isset($item['create_time']) && $item['create_time'] ? dateFormat($item['create_time']) : '';
|
|
$item['time_text'] = isset($item['create_time']) && $item['create_time'] ? dateFormat($item['create_time']) : '';
|
|
|
$item['create_time'] = isset($item['create_time']) ? datetime($item['create_time'], 'Y-m-d H.i.s') : '';
|
|
$item['create_time'] = isset($item['create_time']) ? datetime($item['create_time'], 'Y-m-d H.i.s') : '';
|
|
|
- $unread = $this->getUnreadCount($userId, $item['type']);
|
|
|
|
|
|
|
+ $unread = $this->getUnreadCount($userId,0, $item['type']);
|
|
|
$item['unread'] = intval($unread);
|
|
$item['unread'] = intval($unread);
|
|
|
$total += intval($unread);
|
|
$total += intval($unread);
|
|
|
}
|
|
}
|
|
@@ -180,24 +186,108 @@ class MessageService extends BaseService
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
|
|
|
+ * 聊天分组消息
|
|
|
|
|
+ * @param $userId
|
|
|
|
|
+ * @param $params
|
|
|
|
|
+ * @param int $pageSize
|
|
|
|
|
+ * @return array
|
|
|
|
|
+ */
|
|
|
|
|
+ public function getDataListFromatKey($userId, $params, $pageSize=0)
|
|
|
|
|
+ {
|
|
|
|
|
+ $page = request()->post('page', 1);
|
|
|
|
|
+ $cacheKey = "caches:message:chat_{$page}_".md5($userId.json_encode($params).$pageSize);
|
|
|
|
|
+ $datas = RedisService::get($cacheKey);
|
|
|
|
|
+ $data = isset($datas['data'])? $datas['data'] : [];
|
|
|
|
|
+ if($datas && $data) {
|
|
|
|
|
+ return [
|
|
|
|
|
+ 'unread'=> isset($datas['unReadCount'])? $datas['unReadCount'] : 0,
|
|
|
|
|
+ 'total'=> isset($datas['total'])? $datas['total'] : 0,
|
|
|
|
|
+ 'list'=> $data,
|
|
|
|
|
+ 'pageSize'=> $pageSize,
|
|
|
|
|
+ 'cache'=> true,
|
|
|
|
|
+ ];
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ $where = ['a.type'=>9,'a.status'=> 1,'a.mark'=>1];
|
|
|
|
|
+ $expire = ConfigService::make()->getConfigByCode('chat_log_expire');
|
|
|
|
|
+ $expire = $expire? $expire*86400 : 60*86400;
|
|
|
|
|
+ $field = ['a.id','a.chat_key','a.from_user_id','a.to_user_id','a.msg_type','a.create_time','a.video_time','a.is_connect','a.is_read','a.from_is_show','a.to_is_show','a.status','b.avatar as from_avatar','b.nickname as from_nickname','c.avatar as to_avatar','c.nickname as to_nickname'];
|
|
|
|
|
+ $datas = $this->model->from('imchat as a')
|
|
|
|
|
+ ->where($where)
|
|
|
|
|
+ ->where('a.chat_key','>', 0)
|
|
|
|
|
+ ->where('a.create_time','>=', time() - $expire)
|
|
|
|
|
+ ->where(function($query) use($params){
|
|
|
|
|
+ $chatKey = isset($params['chat_key'])? trim($params['chat_key']) : '';
|
|
|
|
|
+ if($chatKey){
|
|
|
|
|
+ $query->where('a.chat_key', $chatKey);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ $isRead = isset($params['is_read'])? intval($params['is_read']) : 0;
|
|
|
|
|
+ if($isRead){
|
|
|
|
|
+ $query->where('a.is_read', $isRead);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ $chatType = isset($params['chat_type'])? intval($params['chat_type']) : 0;
|
|
|
|
|
+ if($chatType){
|
|
|
|
|
+ $query->where('a.chat_type', $chatType);
|
|
|
|
|
+ }
|
|
|
|
|
+ })
|
|
|
|
|
+ ->select($field)
|
|
|
|
|
+ ->groupBy('chat_key')
|
|
|
|
|
+ ->orderBy('a.create_time','desc')
|
|
|
|
|
+ ->orderBy('a.id','desc')
|
|
|
|
|
+ ->paginate($pageSize > 0 ? $pageSize : 9999999);
|
|
|
|
|
+ $datas = $datas ? $datas->toArray() : [];
|
|
|
|
|
+ $unReadCount = 0;
|
|
|
|
|
+ if ($datas) {
|
|
|
|
|
+ foreach ($datas['data'] as &$item) {
|
|
|
|
|
+ $item['from_user_avatar'] = isset($item['from_user_avatar']) && $item['from_user_avatar'] ? get_image_url($item['from_user_avatar']) : get_image_url('/images/member/logo.png');
|
|
|
|
|
+ $item['to_user_avatar'] = isset($item['to_user_avatar']) && $item['to_user_avatar'] ? get_image_url($item['to_user_avatar']) : get_image_url('/images/member/logo.png');
|
|
|
|
|
+ $data = $this->getNewMessage(0,$item['chat_key']);
|
|
|
|
|
+ $item['description'] = isset($data['description']) && $data['description']? $data['description'] : (isset($data['message'])? mb_substr($data['message'],0,20,'utf-8'):lang('有新消息'));
|
|
|
|
|
+ $item['create_time'] = isset($data['create_time']) && $data['create_time']? $data['create_time'] : '';
|
|
|
|
|
+ $item['time_text'] = isset($item['create_time']) && $item['create_time'] ? dateFormat($item['create_time']) : '';
|
|
|
|
|
+ $item['create_time'] = isset($item['create_time']) ? datetime($item['create_time'], 'Y-m-d H.i.s') : '';
|
|
|
|
|
+ $item['unread'] = $this->getUnreadCount($userId, $item['chat_key'], 0);
|
|
|
|
|
+ $unReadCount += intval($item['unread']);
|
|
|
|
|
+ }
|
|
|
|
|
+ unset($item);
|
|
|
|
|
+ $datas['unReadCount'] = $unReadCount;
|
|
|
|
|
+ RedisService::set($cacheKey, $datas, rand(3, 5));
|
|
|
|
|
+ }
|
|
|
|
|
+ return [
|
|
|
|
|
+ 'unread'=> $unReadCount,
|
|
|
|
|
+ 'total'=> isset($datas['total'])? $datas['total'] : 0,
|
|
|
|
|
+ 'list'=> isset($datas['data'])? $datas['data'] : [],
|
|
|
|
|
+ 'pageSize'=> $pageSize,
|
|
|
|
|
+ 'cache'=> false,
|
|
|
|
|
+ ];
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
* 获取最新消息
|
|
* 获取最新消息
|
|
|
* @param $chatKey
|
|
* @param $chatKey
|
|
|
* @return mixed
|
|
* @return mixed
|
|
|
*/
|
|
*/
|
|
|
- public function getNewMessage($type,$userId=0)
|
|
|
|
|
|
|
+ public function getNewMessage($type=0, $chatKey=0, $userId=0)
|
|
|
{
|
|
{
|
|
|
- $cacheKey = "caches:messages:new_{$type}_{$userId}";
|
|
|
|
|
|
|
+ $cacheKey = "caches:messages:new_{$type}_{$chatKey}_{$userId}";
|
|
|
$data = RedisService::get($cacheKey);
|
|
$data = RedisService::get($cacheKey);
|
|
|
if($data){
|
|
if($data){
|
|
|
return $data;
|
|
return $data;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- $where = ['type'=>$type,'status'=>1,'mark'=>1];
|
|
|
|
|
|
|
+ $where = ['status'=>1,'mark'=>1];
|
|
|
|
|
+ if($type){
|
|
|
|
|
+ $where['type'] = $type;
|
|
|
|
|
+ }
|
|
|
|
|
+ if($chatKey){
|
|
|
|
|
+ $where['chat_key'] = $chatKey;
|
|
|
|
|
+ }
|
|
|
if($userId){
|
|
if($userId){
|
|
|
$where['to_uid'] = $userId;
|
|
$where['to_uid'] = $userId;
|
|
|
}
|
|
}
|
|
|
$data = $this->model->where($where)->select('id','description','content','create_time')
|
|
$data = $this->model->where($where)->select('id','description','content','create_time')
|
|
|
- //->orderBy('is_read','desc')
|
|
|
|
|
->orderBy('create_time','desc')
|
|
->orderBy('create_time','desc')
|
|
|
->orderBy('id','desc')
|
|
->orderBy('id','desc')
|
|
|
->first();
|
|
->first();
|
|
@@ -233,9 +323,9 @@ class MessageService extends BaseService
|
|
|
* @param $userId
|
|
* @param $userId
|
|
|
* @return array|mixed
|
|
* @return array|mixed
|
|
|
*/
|
|
*/
|
|
|
- public function getUnreadCount($userId, $type=0)
|
|
|
|
|
|
|
+ public function getUnreadCount($userId, $chatKey=0, $type=0)
|
|
|
{
|
|
{
|
|
|
- $cacheKey = "caches:messages:unReadCount:{$userId}_{$type}";
|
|
|
|
|
|
|
+ $cacheKey = "caches:messages:unReadCount:{$userId}_{$chatKey}_{$type}";
|
|
|
$data = RedisService::get($cacheKey);
|
|
$data = RedisService::get($cacheKey);
|
|
|
if(RedisService::exists($cacheKey)){
|
|
if(RedisService::exists($cacheKey)){
|
|
|
return $data;
|
|
return $data;
|
|
@@ -244,6 +334,9 @@ class MessageService extends BaseService
|
|
|
if($type>0){
|
|
if($type>0){
|
|
|
$where['type'] = $type;
|
|
$where['type'] = $type;
|
|
|
}
|
|
}
|
|
|
|
|
+ if($chatKey){
|
|
|
|
|
+ $where['chat_key'] = $chatKey;
|
|
|
|
|
+ }
|
|
|
$data = $this->model->where($where)->count('id');
|
|
$data = $this->model->where($where)->count('id');
|
|
|
RedisService::set($cacheKey, $data, rand(3, 5));
|
|
RedisService::set($cacheKey, $data, rand(3, 5));
|
|
|
return $data;
|
|
return $data;
|
|
@@ -294,10 +387,16 @@ class MessageService extends BaseService
|
|
|
* @param $chatKey 聊天窗口ID
|
|
* @param $chatKey 聊天窗口ID
|
|
|
* @return bool
|
|
* @return bool
|
|
|
*/
|
|
*/
|
|
|
- public function setRead($userId, $type)
|
|
|
|
|
|
|
+ public function setRead($userId, $type=0, $chatKey='')
|
|
|
{
|
|
{
|
|
|
- $this->model->where(['to_uid'=> $userId,'type'=> $type])
|
|
|
|
|
- ->update(['is_read'=>1,'update_time'=>time()]);
|
|
|
|
|
|
|
+ $where = ['to_uid'=> $userId];
|
|
|
|
|
+ if($type){
|
|
|
|
|
+ $where['type'] = $type;
|
|
|
|
|
+ }
|
|
|
|
|
+ if($chatKey){
|
|
|
|
|
+ $where['chat_key'] = $chatKey;
|
|
|
|
|
+ }
|
|
|
|
|
+ $this->model->where($where)->update(['is_read'=>1,'update_time'=>time()]);
|
|
|
|
|
|
|
|
// 清除缓存
|
|
// 清除缓存
|
|
|
RedisService::keyDel("caches:messages:bar*");
|
|
RedisService::keyDel("caches:messages:bar*");
|