2025-04-09 09:11:20 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace app\job;
|
|
|
|
|
|
|
|
|
|
use think\queue\Job;
|
|
|
|
|
use think\facade\Log;
|
|
|
|
|
use think\Queue;
|
|
|
|
|
use think\facade\Config;
|
|
|
|
|
use app\api\controller\MessageController;
|
|
|
|
|
|
|
|
|
|
class MessageChatroomListJob
|
|
|
|
|
{
|
2026-01-08 11:50:32 +08:00
|
|
|
/**
|
|
|
|
|
* 最大同步页数
|
|
|
|
|
*/
|
2026-01-17 17:03:48 +08:00
|
|
|
const MAX_SYNC_PAGES = 1;
|
2026-01-08 11:50:32 +08:00
|
|
|
|
2025-04-09 09:11:20 +08:00
|
|
|
/**
|
|
|
|
|
* 队列任务处理
|
|
|
|
|
* @param Job $job 队列任务
|
|
|
|
|
* @param array $data 任务数据
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public function fire(Job $job, $data)
|
|
|
|
|
{
|
|
|
|
|
try {
|
|
|
|
|
// 如果任务执行成功后删除任务
|
|
|
|
|
if ($this->processMessageChatroomList($data, $job->attempts())) {
|
|
|
|
|
$job->delete();
|
|
|
|
|
Log::info('微信群聊消息列表任务执行成功,页码:' . $data['pageIndex']);
|
|
|
|
|
} else {
|
|
|
|
|
if ($job->attempts() > 3) {
|
|
|
|
|
// 超过重试次数,删除任务
|
|
|
|
|
Log::error('微信群聊消息列表任务执行失败,已超过重试次数,页码:' . $data['pageIndex']);
|
|
|
|
|
$job->delete();
|
|
|
|
|
} else {
|
|
|
|
|
// 任务失败,重新放回队列
|
|
|
|
|
Log::warning('微信群聊消息列表任务执行失败,重试次数:' . $job->attempts() . ',页码:' . $data['pageIndex']);
|
|
|
|
|
$job->release(Config::get('queue.failed_delay', 10));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
|
// 出现异常,记录日志
|
|
|
|
|
Log::error('微信群聊消息列表任务异常:' . $e->getMessage());
|
|
|
|
|
if ($job->attempts() > 3) {
|
|
|
|
|
$job->delete();
|
|
|
|
|
} else {
|
|
|
|
|
$job->release(Config::get('queue.failed_delay', 10));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 处理微信群聊消息列表获取
|
|
|
|
|
* @param array $data 任务数据
|
|
|
|
|
* @param int $attempts 重试次数
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
protected function processMessageChatroomList($data, $attempts)
|
|
|
|
|
{
|
|
|
|
|
// 获取参数
|
|
|
|
|
$pageIndex = isset($data['pageIndex']) ? $data['pageIndex'] : 0;
|
|
|
|
|
$pageSize = isset($data['pageSize']) ? $data['pageSize'] : 100;
|
|
|
|
|
|
|
|
|
|
Log::info('开始获取微信群聊消息列表,页码:' . $pageIndex . ',页大小:' . $pageSize);
|
|
|
|
|
|
|
|
|
|
// 实例化控制器
|
|
|
|
|
$messageController = new MessageController();
|
|
|
|
|
|
|
|
|
|
// 构建请求参数
|
|
|
|
|
$params = [
|
|
|
|
|
'pageIndex' => $pageIndex,
|
|
|
|
|
'pageSize' => $pageSize
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
// 设置请求信息
|
|
|
|
|
$request = request();
|
|
|
|
|
$request->withGet($params);
|
|
|
|
|
|
|
|
|
|
// 调用添加好友任务获取方法
|
2025-04-09 14:45:27 +08:00
|
|
|
$result = $messageController->getChatroomList($pageIndex,$pageSize,true);
|
2025-04-09 09:11:20 +08:00
|
|
|
$response = json_decode($result,true);
|
2026-01-19 10:30:09 +08:00
|
|
|
|
|
|
|
|
// 确保 response 是数组格式
|
|
|
|
|
if (!is_array($response)) {
|
|
|
|
|
$response = [];
|
|
|
|
|
}
|
2025-04-09 09:11:20 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
// 判断是否成功
|
2026-01-19 10:30:09 +08:00
|
|
|
if (isset($response['code']) && $response['code'] == 200) {
|
|
|
|
|
$data = isset($response['data']) ? $response['data'] : [];
|
|
|
|
|
|
|
|
|
|
// 确保 data 是数组格式
|
|
|
|
|
if (!is_array($data)) {
|
|
|
|
|
$data = [];
|
|
|
|
|
}
|
2025-04-09 09:11:20 +08:00
|
|
|
|
2026-01-08 11:50:32 +08:00
|
|
|
// 判断是否有下一页,且未超过最大同步页数
|
2026-01-19 10:30:09 +08:00
|
|
|
if (!empty($data) && is_array($data) && count($data) > 0) {
|
2025-04-09 09:11:20 +08:00
|
|
|
$nextPageIndex = $pageIndex + 1;
|
2026-01-08 11:50:32 +08:00
|
|
|
// 检查是否超过最大同步页数
|
|
|
|
|
if ($nextPageIndex < self::MAX_SYNC_PAGES) {
|
|
|
|
|
// 有下一页且未超过最大页数,将下一页任务添加到队列
|
|
|
|
|
$this->addNextPageToQueue($nextPageIndex, $pageSize);
|
|
|
|
|
Log::info('添加下一页任务到队列,页码:' . $nextPageIndex);
|
|
|
|
|
} else {
|
|
|
|
|
Log::info('已达到最大同步页数(' . self::MAX_SYNC_PAGES . '),停止添加下一页任务');
|
|
|
|
|
}
|
2025-04-09 09:11:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
} else {
|
|
|
|
|
$errorMsg = isset($response['msg']) ? $response['msg'] : '未知错误';
|
|
|
|
|
Log::error('获取微信群聊消息列表失败:' . $errorMsg);
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 添加下一页任务到队列
|
|
|
|
|
* @param int $pageIndex 页码
|
|
|
|
|
* @param int $pageSize 每页大小
|
|
|
|
|
*/
|
|
|
|
|
protected function addNextPageToQueue($pageIndex, $pageSize)
|
|
|
|
|
{
|
|
|
|
|
$data = [
|
|
|
|
|
'pageIndex' => $pageIndex,
|
|
|
|
|
'pageSize' => $pageSize
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
// 添加到队列,设置任务名为 message_chatroom_list
|
|
|
|
|
Queue::push(self::class, $data, 'message_chatroom_list');
|
|
|
|
|
}
|
|
|
|
|
}
|