hyperf-chat/app/Service/TalkMessageService.php

240 lines
7.5 KiB
PHP
Raw Normal View History

2021-07-05 21:52:44 +08:00
<?php
namespace App\Service;
2021-07-13 22:53:13 +08:00
use App\Cache\LastMessage;
use App\Constants\TalkMessageEvent;
2021-07-08 23:44:43 +08:00
use App\Constants\TalkMessageType;
2021-07-17 00:07:24 +08:00
use App\Model\Group\GroupMember;
2021-07-09 22:57:19 +08:00
use App\Model\Talk\TalkRecordsCode;
2021-07-12 23:19:58 +08:00
use App\Model\Talk\TalkRecordsVote;
2021-07-17 00:07:24 +08:00
use App\Model\Talk\TalkRecordsVoteAnswer;
2021-07-13 22:53:13 +08:00
use App\Support\MessageProducer;
2021-07-17 00:07:24 +08:00
use App\Support\UserRelation;
2021-07-08 23:44:43 +08:00
use Exception;
use App\Constants\MediaFileType;
2021-07-09 22:57:19 +08:00
use App\Model\Talk\TalkRecords;
use App\Model\Talk\TalkRecordsFile;
2021-07-08 23:44:43 +08:00
use Hyperf\DbConnection\Db;
2021-07-05 21:52:44 +08:00
class TalkMessageService
{
2021-07-08 23:44:43 +08:00
/**
* 创建代码块消息
*
* @param array $message
* @param array $code
2021-07-13 22:53:13 +08:00
* @return bool
2021-07-08 23:44:43 +08:00
*/
public function insertCodeMessage(array $message, array $code)
{
Db::beginTransaction();
try {
$message['msg_type'] = TalkMessageType::CODE_MESSAGE;
$message['created_at'] = date('Y-m-d H:i:s');
$message['updated_at'] = date('Y-m-d H:i:s');
2021-07-05 21:52:44 +08:00
2021-07-08 23:44:43 +08:00
$insert = TalkRecords::create($message);
if (!$insert) {
throw new Exception('插入聊天记录失败...');
}
$code['record_id'] = $insert->id;
$code['created_at'] = date('Y-m-d H:i:s');
if (!TalkRecordsCode::create($code)) {
throw new Exception('插入聊天记录(代码消息)失败...');
}
Db::commit();
} catch (Exception $e) {
Db::rollBack();
return false;
}
2021-07-13 22:53:13 +08:00
MessageProducer::publish(MessageProducer::create(TalkMessageEvent::EVENT_TALK, [
'sender_id' => $insert->user_id,
'receiver_id' => $insert->receiver_id,
'talk_type' => $insert->talk_type,
'record_id' => $insert->id
]));
LastMessage::getInstance()->save($insert->talk_type, $insert->user_id, $insert->receiver_id, [
'text' => '[代码消息]',
'created_at' => date('Y-m-d H:i:s')
]);
return true;
2021-07-08 23:44:43 +08:00
}
/**
* 创建文件类消息
*
* @param array $message
* @param array $file
2021-07-13 22:53:13 +08:00
* @return bool
2021-07-08 23:44:43 +08:00
*/
public function insertFileMessage(array $message, array $file)
{
Db::beginTransaction();
try {
$message['msg_type'] = TalkMessageType::FILE_MESSAGE;
$message['created_at'] = date('Y-m-d H:i:s');
$message['updated_at'] = date('Y-m-d H:i:s');
$insert = TalkRecords::create($message);
if (!$insert) {
throw new Exception('插入聊天记录失败...');
}
$file['record_id'] = $insert->id;
$file['file_type'] = MediaFileType::getMediaType($file['file_suffix']);
$file['created_at'] = date('Y-m-d H:i:s');
if (!TalkRecordsFile::create($file)) {
throw new Exception('插入聊天记录(代码消息)失败...');
}
Db::commit();
} catch (Exception $e) {
Db::rollBack();
return false;
}
2021-07-13 22:53:13 +08:00
MessageProducer::publish(MessageProducer::create(TalkMessageEvent::EVENT_TALK, [
'sender_id' => $insert->user_id,
'receiver_id' => $insert->receiver_id,
'talk_type' => $insert->talk_type,
'record_id' => $insert->id
]));
LastMessage::getInstance()->save($insert->talk_type, $insert->user_id, $insert->receiver_id, [
'text' => '[图片消息]',
'created_at' => date('Y-m-d H:i:s')
]);
return true;
2021-07-08 23:44:43 +08:00
}
2021-07-12 23:19:58 +08:00
/**
2021-07-17 00:07:24 +08:00
* 添加投票消息
*
2021-07-12 23:19:58 +08:00
* @param array $message
* @param array $vote
2021-07-17 00:07:24 +08:00
* @return bool
2021-07-12 23:19:58 +08:00
*/
public function insertVoteMessage(array $message, array $vote)
{
2021-07-17 00:07:24 +08:00
$answer_num = GroupMember::where('group_id', $message['receiver_id'])->where('is_quit', 0)->count();
2021-07-12 23:19:58 +08:00
Db::beginTransaction();
try {
2021-07-17 21:27:48 +08:00
$message['msg_type'] = TalkMessageType::VOTE_MESSAGE;
2021-07-12 23:19:58 +08:00
$message['created_at'] = date('Y-m-d H:i:s');
$message['updated_at'] = date('Y-m-d H:i:s');
2021-07-17 21:27:48 +08:00
$insert = TalkRecords::create($message);
2021-07-17 00:07:24 +08:00
$options = [];
2021-07-17 21:27:48 +08:00
foreach ($vote['answer_option'] as $k => $option) {
2021-07-17 00:07:24 +08:00
$options[chr(65 + $k)] = $option;
2021-07-12 23:19:58 +08:00
}
2021-07-17 21:27:48 +08:00
$vote['record_id'] = $insert->id;
$vote['answer_option'] = $options;
$vote['answer_num'] = $answer_num;
$vote['created_at'] = date('Y-m-d H:i:s');
$vote['updated_at'] = $vote['created_at'];
2021-07-12 23:19:58 +08:00
if (!TalkRecordsVote::create($vote)) {
throw new Exception('插入聊天记录(投票消息)失败...');
}
Db::commit();
} catch (Exception $e) {
Db::rollBack();
return false;
}
2021-07-17 00:07:24 +08:00
// 推送消息通知
2021-07-13 22:53:13 +08:00
MessageProducer::publish(MessageProducer::create(TalkMessageEvent::EVENT_TALK, [
'sender_id' => $insert->user_id,
'receiver_id' => $insert->receiver_id,
'talk_type' => $insert->talk_type,
'record_id' => $insert->id
]));
LastMessage::getInstance()->save($insert->talk_type, $insert->user_id, $insert->receiver_id, [
'text' => '[投票消息]',
'created_at' => date('Y-m-d H:i:s')
]);
return true;
2021-07-12 23:19:58 +08:00
}
2021-07-17 00:07:24 +08:00
/**
* 群投票处理方法
*
* @param int $user_id
* @param array $params
* @return bool
*/
public function handleVote(int $user_id, array $params): bool
{
$record = TalkRecords::join('talk_records_vote as vote', 'vote.record_id', '=', 'talk_records.id')
->where('talk_records.id', $params['record_id'])
2021-07-17 21:27:48 +08:00
->withCasts([
'answer_option' => 'array'
])
2021-07-17 00:07:24 +08:00
->first([
2021-07-17 21:27:48 +08:00
'talk_records.id', 'talk_records.receiver_id', 'talk_records.talk_type', 'talk_records.msg_type',
2021-07-17 00:07:24 +08:00
'vote.id as vote_id', 'vote.answer_mode', 'vote.answer_option', 'vote.answer_num', 'vote.status as vote_status'
]);
if (!$record) return false;
if ($record->msg_type != TalkMessageType::VOTE_MESSAGE) {
return false;
}
if (!UserRelation::isFriendOrGroupMember($user_id, $record->receiver_id, $record->talk_type)) {
return false;
}
$options = explode(',', $params['options']);
if (!$options) {
return false;
}
sort($options);
foreach ($options as $value) {
2021-07-17 21:27:48 +08:00
if (!isset($record->answer_option[$value])) return false;
2021-07-17 00:07:24 +08:00
}
// 单选模式取第一个
if ($record->answer_mode == 1) {
$options = [$options[0]];
}
try {
Db::transaction(function () use ($options, $record, $user_id) {
TalkRecordsVote::where('id', $record->vote_id)->update([
'answered_num' => Db::raw('answered_num + 1'),
'status' => Db::raw('if(answered_num >= answer_num, 1, 0)'),
'updated_at' => date('Y-m-d H:i:s'),
]);
foreach ($options as $option) {
TalkRecordsVoteAnswer::create([
'vote_id' => $record->vote_id,
'user_id' => $user_id,
'option' => $option,
'created_at' => date('Y-m-d H:i:s'),
]);
}
});
} catch (\Exception $e) {
return false;
}
return true;
}
2021-07-05 21:52:44 +08:00
}