其余文件
This commit is contained in:
29
app/kefuapi/validate/ChatValidate.php
Normal file
29
app/kefuapi/validate/ChatValidate.php
Normal file
@ -0,0 +1,29 @@
|
||||
<?php
|
||||
|
||||
namespace app\kefuapi\validate;
|
||||
|
||||
use app\common\basics\Validate;
|
||||
use app\common\model\user\User;
|
||||
|
||||
|
||||
class ChatValidate extends Validate
|
||||
{
|
||||
protected $rule = [
|
||||
'user_id' => 'require|checkUser',
|
||||
];
|
||||
|
||||
protected $message = [
|
||||
'user_id.require' => '参数缺失',
|
||||
];
|
||||
|
||||
protected function checkUser($value, $rule, $data=[])
|
||||
{
|
||||
$user = User::where(['id' => $value])->findOrEmpty();
|
||||
|
||||
if ($user->isEmpty() || $user['del']) {
|
||||
return '用户不存在';
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
122
app/kefuapi/validate/LoginValidate.php
Normal file
122
app/kefuapi/validate/LoginValidate.php
Normal file
@ -0,0 +1,122 @@
|
||||
<?php
|
||||
|
||||
namespace app\kefuapi\validate;
|
||||
|
||||
use app\common\basics\Validate;
|
||||
use app\common\enum\KefuEnum;
|
||||
use app\common\logic\ChatLogic;
|
||||
use app\common\model\Admin;
|
||||
use app\common\model\shop\ShopAdmin;
|
||||
use think\facade\Cache;
|
||||
|
||||
/**
|
||||
* 客服登录验证
|
||||
* Class LoginValidate
|
||||
* @package app\shopapi\validate
|
||||
*/
|
||||
class LoginValidate extends Validate
|
||||
{
|
||||
protected $rule = [
|
||||
'type' => 'require',
|
||||
'client' => 'require',
|
||||
'account' => 'require',
|
||||
'password' => 'require|checkPassword',
|
||||
];
|
||||
|
||||
protected $message = [
|
||||
'type.require' => '参数缺失',
|
||||
'account.require' => '请输入账号',
|
||||
'password.require' => '请输入密码',
|
||||
'password.checkPassword' => '账号或密码错误',
|
||||
'client.require' => '请输入客户端'
|
||||
];
|
||||
|
||||
|
||||
/**
|
||||
* @notes 校验密码
|
||||
* @param $password
|
||||
* @param $other
|
||||
* @param $data
|
||||
* @return bool|string
|
||||
* @author 段誉
|
||||
* @date 2021/11/9 16:02
|
||||
*/
|
||||
protected function checkPassword($password, $other, $data)
|
||||
{
|
||||
$field = 'k.id, k.shop_id, a.account, a.salt, a.password,
|
||||
k.disable as kefu_disable, a.disable as admin_disable';
|
||||
|
||||
$condition = ['a.account' => $data['account'], 'k.del' => 0, 'a.del' => 0];
|
||||
|
||||
if (KefuEnum::TYPE_SHOP == $data['type']) {
|
||||
$isPlatform = false;
|
||||
$chat = (new ShopAdmin())->alias('a')
|
||||
->field($field)
|
||||
->join('kefu k', 'a.id = k.admin_id and a.shop_id = k.shop_id')
|
||||
->where($condition)
|
||||
->findOrEmpty();
|
||||
} else {
|
||||
$isPlatform = true;
|
||||
$chat = (new Admin())->alias('a')
|
||||
->field($field)
|
||||
->join('kefu k', 'k.admin_id = a.id')
|
||||
->where(['k.shop_id' => 0])
|
||||
->where($condition)
|
||||
->findOrEmpty();
|
||||
}
|
||||
|
||||
if (false === $this->safe(false, $isPlatform)) {
|
||||
$this->message['password.password'] .= ':多次输入错误';
|
||||
return false;
|
||||
}
|
||||
|
||||
if ($chat->isEmpty()) {
|
||||
$this->safe(true, $isPlatform);
|
||||
return '账号不存在';
|
||||
}
|
||||
|
||||
if ($chat['kefu_disable'] || $chat['admin_disable']) {
|
||||
return '账号被禁用';
|
||||
}
|
||||
|
||||
$password = generatePassword($password, $chat['salt']);
|
||||
if ($password != $chat['password']) {
|
||||
$this->safe(true, $isPlatform);
|
||||
return false;
|
||||
}
|
||||
|
||||
// 检查后台配置是否开启,当前缓存驱动是否redis
|
||||
if (false === ChatLogic::checkConfig($chat['shop_id'])) {
|
||||
return ChatLogic::getError() ?: '请联系管理员设置后台配置';
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 连续30分钟内15次输错密码,无法登录
|
||||
* @param bool $add
|
||||
* @return bool
|
||||
*/
|
||||
protected function safe($status = false, $isPlatform = false)
|
||||
{
|
||||
if ($isPlatform) {
|
||||
$errorCount = 'platform_kefu_error_count' . request()->ip();
|
||||
} else {
|
||||
$errorCount = 'shop_kefu_error_count' . request()->ip();
|
||||
}
|
||||
|
||||
if ($status) {
|
||||
$loginErrorCount = Cache::get($errorCount);
|
||||
$loginErrorCount++;
|
||||
Cache::tag('kefu_login_error_count')->set($errorCount, $loginErrorCount, 1800);
|
||||
}
|
||||
|
||||
$count = Cache::get($errorCount);
|
||||
|
||||
if (!empty($count) && $count >= 15) {
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
106
app/kefuapi/validate/TokenValidate.php
Normal file
106
app/kefuapi/validate/TokenValidate.php
Normal file
@ -0,0 +1,106 @@
|
||||
<?php
|
||||
// +----------------------------------------------------------------------
|
||||
// | likeshop开源商城系统
|
||||
// +----------------------------------------------------------------------
|
||||
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
||||
// | gitee下载:https://gitee.com/likeshop_gitee
|
||||
// | github下载:https://github.com/likeshop-github
|
||||
// | 访问官网:https://www.likeshop.cn
|
||||
// | 访问社区:https://home.likeshop.cn
|
||||
// | 访问手册:http://doc.likeshop.cn
|
||||
// | 微信公众号:likeshop技术社区
|
||||
// | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
|
||||
// | likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
|
||||
// | 禁止对系统程序代码以任何目的,任何形式的再发布
|
||||
// | likeshop团队版权所有并拥有最终解释权
|
||||
// +----------------------------------------------------------------------
|
||||
// | author: likeshop.cn.team
|
||||
// +----------------------------------------------------------------------
|
||||
|
||||
namespace app\kefuapi\validate;
|
||||
|
||||
|
||||
use app\common\basics\Validate;
|
||||
use app\common\model\Admin;
|
||||
use app\common\model\kefu\Kefu;
|
||||
use app\common\model\kefu\KefuSession;
|
||||
use app\common\model\shop\ShopAdmin;
|
||||
|
||||
/**
|
||||
* 客服登录验证
|
||||
* Class TokenValidate
|
||||
* @package app\kefu\validate
|
||||
*/
|
||||
class TokenValidate extends Validate
|
||||
{
|
||||
protected $rule = [
|
||||
'token' => 'require|valid|chat',
|
||||
];
|
||||
|
||||
/**
|
||||
* @notes token验证
|
||||
* @param $token
|
||||
* @param $other
|
||||
* @param $data
|
||||
* @return bool|string
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @author 段誉
|
||||
* @date 2021/11/23 10:55
|
||||
*/
|
||||
protected function valid($token, $other, $data)
|
||||
{
|
||||
$session = KefuSession::where(['token' => $token])->find();
|
||||
if (empty($session)) {
|
||||
return '会话失效,请重新登录';
|
||||
}
|
||||
if ($session['expire_time'] <= time()) {
|
||||
return '登录超时,请重新登录';
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @notes 用户验证
|
||||
* @param $token
|
||||
* @param $other
|
||||
* @param $data
|
||||
* @return bool|string
|
||||
* @author 段誉
|
||||
* @date 2021/11/23 17:29
|
||||
*/
|
||||
protected function chat($token, $other, $data)
|
||||
{
|
||||
$kefu = (new Kefu())->alias('k')
|
||||
->join('kefu_session ks', 'k.id = ks.kefu_id')
|
||||
->where(['ks.token' => $token, 'k.del' => 0])
|
||||
->field('k.*,ks.token,ks.client')
|
||||
->hidden(['password'])
|
||||
->findOrEmpty();
|
||||
|
||||
if ($kefu->isEmpty()) {
|
||||
return '用户不存在';
|
||||
}
|
||||
|
||||
// 获取客服对应的管理员信息
|
||||
if ($kefu['shop_id'] > 0) {
|
||||
$kefu_admin = (new ShopAdmin())->where(['id' => $kefu['admin_id']])->findOrEmpty();
|
||||
} else {
|
||||
$kefu_admin = (new Admin())->where(['id' => $kefu['admin_id']])->findOrEmpty();
|
||||
}
|
||||
|
||||
if ($kefu_admin->isEmpty()) {
|
||||
return '关联管理员不存在';
|
||||
}
|
||||
|
||||
if ($kefu['disable'] == 1 || $kefu_admin['disable'] == 1) {
|
||||
return '用户被禁用';
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user