116 lines
4.3 KiB
PHP
116 lines
4.3 KiB
PHP
<?php
|
|
declare (strict_types = 1);
|
|
|
|
namespace app\admin\validate\v1;
|
|
|
|
use app\admin\model\v1\ArticleCategoryModel;
|
|
use think\facade\Db;
|
|
use think\Validate;
|
|
|
|
class ArticleCategoryValidate extends Validate
|
|
{
|
|
/**
|
|
* 定义验证规则
|
|
* 格式:'字段名' => ['规则1','规则2'...]
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $rule = [
|
|
'id' => 'require|integer',
|
|
'language_id' => 'require|integer',
|
|
'name' => 'require|unique:article_category,name^language_id|max:64',
|
|
'icon' => 'max:125',
|
|
'pid' => 'integer|different:id|checkPidNotBeChildren', // 验证pid
|
|
'unique_label' => 'require|max:64',
|
|
'sort' => 'require|integer',
|
|
'is_show' => 'require|in:0,1',
|
|
'seo_title' => 'max:255',
|
|
'seo_keywords' => 'max:255',
|
|
'seo_desc' => 'max:255',
|
|
];
|
|
|
|
/**
|
|
* 定义错误信息
|
|
* 格式:'字段名.规则名' => '错误信息'
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $message = [
|
|
'id.require' => '分类ID不能为空',
|
|
'id.integer' => '分类ID必须为整数',
|
|
'language_id.require' => '语言ID不能为空',
|
|
'language_id.integer' => '语言ID必须为整数',
|
|
'name.require' => '分类名称不能为空',
|
|
'name.unique' => '分类名称已存在',
|
|
'name.max' => '分类名称最多64个字符',
|
|
'icon.max' => '分类图片最多125个字符',
|
|
'pid.integer' => '父级分类ID必须为整数',
|
|
'pid.different' => '父级分类ID不能为自身',
|
|
'pid.checkPidNotBeChildren' => '父级分类不能为自身或自身的子分类',
|
|
'unique_label.require' => '分类唯一标识不能为空',
|
|
'unique_label.max' => '分类唯一标识最多64个字符',
|
|
'sort.require' => '排序不能为空',
|
|
'sort.integer' => '排序必须为整数',
|
|
'is_show.require' => '是否显示不能为空',
|
|
'is_show.in' => '是否显示值必须为0或1',
|
|
'seo_title.max' => 'SEO标题最多255个字符',
|
|
'seo_keywords.max' => 'SEO关键词最多255个字符',
|
|
'seo_desc.max' => 'SEO描述最多255个字符',
|
|
];
|
|
|
|
// 验证pid
|
|
protected function checkPidNotBeChildren($value, $rule, $data = [])
|
|
{
|
|
if ($value == 0) {
|
|
return true;
|
|
}
|
|
|
|
$children = [];
|
|
$table_name = (new ArticleCategoryModel)->getTable();
|
|
if (env('DB_VERSION', '5') == '8') {
|
|
$children = Db::query(
|
|
preg_replace(
|
|
'/\s+/u',
|
|
' ',
|
|
"WITH RECURSIVE article_tree_by AS (
|
|
SELECT a.id, a.pid FROM $table_name a WHERE a.id = {$data['id']}
|
|
UNION ALL
|
|
SELECT k.id, k.pid FROM $table_name k INNER JOIN article_tree_by t ON t.id = k.pid
|
|
)
|
|
SELECT id FROM article_tree_by WHERE id <> {$data['id']};"
|
|
)
|
|
);
|
|
} else {
|
|
$children = \think\facade\Db::query("
|
|
SELECT t2.id
|
|
FROM (
|
|
SELECT
|
|
@r AS _id, (SELECT @r := GROUP_CONCAT(id) FROM $table_name WHERE FIND_IN_SET(pid, _id)) AS parent_id
|
|
FROM
|
|
(SELECT @r := {$data['id']}) vars, $table_name h
|
|
WHERE @r <> 0) t1
|
|
JOIN $table_name t2
|
|
ON FIND_IN_SET(t2.pid, t1._id)
|
|
ORDER BY t2.id;
|
|
");
|
|
}
|
|
if (!empty($children) && in_array($data['pid'], array_column($children, 'id'))) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
// 新增分类验证场景
|
|
protected function sceneAdd()
|
|
{
|
|
$this->remove('id', 'require|integer')->remove('pid', 'different|checkPidNotBeChildren');
|
|
}
|
|
|
|
// 更新分类验证场景
|
|
protected function sceneEdit()
|
|
{
|
|
$this->remove('unique_label', 'require|max:64');
|
|
}
|
|
}
|