mirror of
https://gitee.com/wonderful-code/buildadmin
synced 2024-11-23 07:40:18 +00:00
69 lines
2.0 KiB
PHP
69 lines
2.0 KiB
PHP
<?php
|
|
|
|
use think\facade\Db;
|
|
use think\migration\Migrator;
|
|
|
|
class Version202 extends Migrator
|
|
{
|
|
/**
|
|
* 规范菜单规则
|
|
* @throws Throwable
|
|
*/
|
|
public function up(): void
|
|
{
|
|
Db::startTrans();
|
|
try {
|
|
$dashboardId = Db::name('admin_rule')
|
|
->where('name', 'dashboard/dashboard')
|
|
->lock(true)
|
|
->value('id');
|
|
if ($dashboardId) {
|
|
// 修改name
|
|
Db::name('admin_rule')
|
|
->where('name', 'dashboard/dashboard')
|
|
->update([
|
|
'name' => 'dashboard',
|
|
]);
|
|
|
|
// 增加一个查看的权限节点
|
|
$dashboardIndexId = Db::name('admin_rule')->insertGetId([
|
|
'pid' => $dashboardId,
|
|
'type' => 'button',
|
|
'title' => '查看',
|
|
'name' => 'dashboard/index',
|
|
'update_time' => time(),
|
|
'create_time' => time(),
|
|
]);
|
|
|
|
// 原本有控制台权限的管理员,给予新增的查看权限
|
|
$group = Db::name('admin_group')
|
|
->where('rules', 'find in set', $dashboardId)
|
|
->select();
|
|
foreach ($group as $item) {
|
|
|
|
$newRules = trim($item['rules'], ',');
|
|
$newRules = $newRules . ',' . $dashboardIndexId;
|
|
|
|
Db::name('admin_group')
|
|
->where('id', $item['id'])
|
|
->update([
|
|
'rules' => $newRules
|
|
]);
|
|
}
|
|
}
|
|
|
|
// 修改name
|
|
Db::name('admin_rule')
|
|
->where('name', 'buildadmin/buildadmin')
|
|
->update([
|
|
'name' => 'buildadmin',
|
|
]);
|
|
|
|
Db::commit();
|
|
} catch (Throwable $e) {
|
|
Db::rollback();
|
|
throw $e;
|
|
}
|
|
}
|
|
}
|