228 lines
7.7 KiB
PHP
Executable File
228 lines
7.7 KiB
PHP
Executable File
<?php
|
||
// +----------------------------------------------------------------------
|
||
// | likeadmin快速开发前后端分离管理后台(PHP版)
|
||
// +----------------------------------------------------------------------
|
||
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
||
// | 开源版本可自由商用,可去除界面版权logo
|
||
// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
|
||
// | github下载:https://github.com/likeshop-github/likeadmin
|
||
// | 访问官网:https://www.likeadmin.cn
|
||
// | likeadmin团队 版权所有 拥有最终解释权
|
||
// +----------------------------------------------------------------------
|
||
// | author: likeadminTeam
|
||
// +----------------------------------------------------------------------
|
||
|
||
namespace app\adminapi\logic\channel;
|
||
|
||
use app\common\enum\OfficialAccountEnum;
|
||
use app\common\enum\YesNoEnum;
|
||
use app\common\logic\BaseLogic;
|
||
use app\common\model\channel\OfficialAccountReply;
|
||
use app\common\service\wechat\WeChatConfigService;
|
||
use app\common\service\wechat\WeChatOaService;
|
||
|
||
|
||
|
||
/**
|
||
* 微信公众号回复逻辑层
|
||
* Class OfficialAccountReplyLogic
|
||
* @package app\adminapi\logic\channel
|
||
*/
|
||
class OfficialAccountReplyLogic extends BaseLogic
|
||
{
|
||
/**
|
||
* @notes 添加回复(关注/关键词/默认)
|
||
* @param $params
|
||
* @return bool
|
||
* @author 段誉
|
||
* @date 2022/3/29 10:57
|
||
*/
|
||
public static function add($params)
|
||
{
|
||
try {
|
||
// 关键字回复排序值须大于0
|
||
if ($params['reply_type'] == OfficialAccountEnum::REPLY_TYPE_KEYWORD && $params['sort'] <= 0) {
|
||
throw new \Exception('排序值须大于0');
|
||
}
|
||
if ($params['reply_type'] != OfficialAccountEnum::REPLY_TYPE_KEYWORD && $params['status']) {
|
||
// 非关键词回复只能有一条记录处于启用状态,所以将该回复类型下的已有记录置为禁用状态
|
||
OfficialAccountReply::where(['reply_type' => $params['reply_type']])->update(['status' => YesNoEnum::NO]);
|
||
}
|
||
OfficialAccountReply::create($params);
|
||
return true;
|
||
} catch (\Exception $e) {
|
||
self::setError($e->getMessage());
|
||
return false;
|
||
}
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 查看回复详情
|
||
* @param $params
|
||
* @return array
|
||
* @author 段誉
|
||
* @date 2022/3/29 11:00
|
||
*/
|
||
public static function detail($params)
|
||
{
|
||
$field = 'id,name,keyword,reply_type,matching_type,content_type,content,status,sort';
|
||
$field .= ',reply_type as reply_type_desc, matching_type as matching_type_desc, content_type as content_type_desc, status as status_desc';
|
||
return OfficialAccountReply::field($field)->findOrEmpty($params['id'])->toArray();
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 编辑回复(关注/关键词/默认)
|
||
* @param $params
|
||
* @return bool
|
||
* @author 段誉
|
||
* @date 2022/3/29 11:01
|
||
*/
|
||
public static function edit($params)
|
||
{
|
||
try {
|
||
// 关键字回复排序值须大于0
|
||
if ($params['reply_type'] == OfficialAccountEnum::REPLY_TYPE_KEYWORD && $params['sort'] <= 0) {
|
||
throw new \Exception('排序值须大于0');
|
||
}
|
||
if ($params['reply_type'] != OfficialAccountEnum::REPLY_TYPE_KEYWORD && $params['status']) {
|
||
// 非关键词回复只能有一条记录处于启用状态,所以将该回复类型下的已有记录置为禁用状态
|
||
OfficialAccountReply::where(['reply_type' => $params['reply_type']])->update(['status' => YesNoEnum::NO]);
|
||
}
|
||
OfficialAccountReply::update($params);
|
||
return true;
|
||
} catch (\Exception $e) {
|
||
self::setError($e->getMessage());
|
||
return false;
|
||
}
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 删除回复(关注/关键词/默认)
|
||
* @param $params
|
||
* @author 段誉
|
||
* @date 2022/3/29 11:01
|
||
*/
|
||
public static function delete($params)
|
||
{
|
||
OfficialAccountReply::destroy($params['id']);
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 更新排序
|
||
* @param $params
|
||
* @author 段誉
|
||
* @date 2022/3/29 11:01
|
||
*/
|
||
public static function sort($params)
|
||
{
|
||
$params['sort'] = $params['new_sort'];
|
||
OfficialAccountReply::update($params);
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 更新状态
|
||
* @param $params
|
||
* @author 段誉
|
||
* @date 2022/3/29 11:01
|
||
*/
|
||
public static function status($params)
|
||
{
|
||
$reply = OfficialAccountReply::findOrEmpty($params['id']);
|
||
$reply->status = !$reply->status;
|
||
$reply->save();
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 微信公众号回调
|
||
* @return \Psr\Http\Message\ResponseInterface|void
|
||
* @throws \EasyWeChat\Kernel\Exceptions\BadRequestException
|
||
* @throws \EasyWeChat\Kernel\Exceptions\InvalidArgumentException
|
||
* @throws \EasyWeChat\Kernel\Exceptions\RuntimeException
|
||
* @throws \ReflectionException
|
||
* @throws \Throwable
|
||
* @author 段誉
|
||
* @date 2023/2/27 14:38\
|
||
*/
|
||
public static function index()
|
||
{
|
||
$server = (new WeChatOaService())->getServer();
|
||
// 事件
|
||
$server->addMessageListener(OfficialAccountEnum::MSG_TYPE_EVENT, function ($message, \Closure $next) {
|
||
switch ($message['Event']) {
|
||
case OfficialAccountEnum::EVENT_SUBSCRIBE: // 关注事件
|
||
$replyContent = OfficialAccountReply::where([
|
||
'reply_type' => OfficialAccountEnum::REPLY_TYPE_FOLLOW,
|
||
'status' => YesNoEnum::YES
|
||
])
|
||
->value('content');
|
||
|
||
if (empty($replyContent)) {
|
||
// 未启用关注回复 或 关注回复内容为空
|
||
$replyContent = static::getDefaultReply();
|
||
}
|
||
if ($replyContent) {
|
||
return $replyContent;
|
||
}
|
||
break;
|
||
}
|
||
return $next($message);
|
||
});
|
||
|
||
// 文本
|
||
$server->addMessageListener(OfficialAccountEnum::MSG_TYPE_TEXT, function ($message, \Closure $next) {
|
||
$replyList = OfficialAccountReply::where([
|
||
'reply_type' => OfficialAccountEnum::REPLY_TYPE_KEYWORD,
|
||
'status' => YesNoEnum::YES
|
||
])
|
||
->order('sort asc')
|
||
->select();
|
||
|
||
$replyContent = '';
|
||
foreach ($replyList as $reply) {
|
||
switch ($reply['matching_type']) {
|
||
case OfficialAccountEnum::MATCHING_TYPE_FULL:
|
||
$reply['keyword'] === $message['Content'] && $replyContent = $reply['content'];
|
||
break;
|
||
case OfficialAccountEnum::MATCHING_TYPE_FUZZY:
|
||
stripos($message['Content'], $reply['keyword']) !== false && $replyContent = $reply['content'];
|
||
break;
|
||
}
|
||
if ($replyContent) {
|
||
break; // 得到回复文本,中止循环
|
||
}
|
||
}
|
||
//消息回复为空的话,找默认回复
|
||
if (empty($replyContent)) {
|
||
$replyContent = static::getDefaultReply();
|
||
}
|
||
if ($replyContent) {
|
||
return $replyContent;
|
||
}
|
||
return $next($message);
|
||
});
|
||
|
||
return $server->serve();
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 默认回复信息
|
||
* @return mixed
|
||
* @author 段誉
|
||
* @date 2023/2/27 14:36
|
||
*/
|
||
public static function getDefaultReply()
|
||
{
|
||
return OfficialAccountReply::where([
|
||
'reply_type' => OfficialAccountEnum::REPLY_TYPE_DEFAULT,
|
||
'status' => YesNoEnum::YES
|
||
])
|
||
->value('content');
|
||
}
|
||
} |