mirror of
https://devops.lemonos.cn/lawson/FendxPHP.git
synced 2026-06-15 15:02:49 +08:00
- 创建用户表(users)包含基本信息和认证字段 - 创建角色表(roles)用于权限控制 - 创建权限表(permissions)定义系统权限 - 创建用户角色关联表(user_roles)建立用户与角色关系 - 创建角色权限关联表(role_permissions)建立角色与权限关系 - 创建迁移记录表(migrations)追踪数据库变更 - 添加AdminController提供管理员面板功能 - 实现系统监控、配置管理、缓存清理等功能 - 添加AOP切面编程支持的各种通知类型 - 实现告警管理AlertManager支持多渠道告警 - 添加文档注解接口规范
88 lines
2.7 KiB
PHP
88 lines
2.7 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
|
|
use Fendx\Database\Seeder\Seeder;
|
|
use Fendx\Database\Connection\DB;
|
|
|
|
/**
|
|
* 用户角色关联种子数据
|
|
*/
|
|
class UserRoleSeeder extends Seeder
|
|
{
|
|
public function run(): void
|
|
{
|
|
// 获取用户和角色ID
|
|
$users = DB::table('users')->pluck('id', 'username')->toArray();
|
|
$roles = DB::table('roles')->pluck('id', 'name')->toArray();
|
|
|
|
$userRoles = [];
|
|
|
|
// admin 用户 -> 超级管理员
|
|
if (isset($users['admin']) && isset($roles['super_admin'])) {
|
|
$userRoles[] = [
|
|
'user_id' => $users['admin'],
|
|
'role_id' => $roles['super_admin'],
|
|
'guard_name' => 'web',
|
|
'created_at' => date('Y-m-d H:i:s'),
|
|
];
|
|
}
|
|
|
|
// test_user 用户 -> 普通用户
|
|
if (isset($users['test_user']) && isset($roles['user'])) {
|
|
$userRoles[] = [
|
|
'user_id' => $users['test_user'],
|
|
'role_id' => $roles['user'],
|
|
'guard_name' => 'web',
|
|
'created_at' => date('Y-m-d H:i:s'),
|
|
];
|
|
}
|
|
|
|
// developer 用户 -> 管理员
|
|
if (isset($users['developer']) && isset($roles['admin'])) {
|
|
$userRoles[] = [
|
|
'user_id' => $users['developer'],
|
|
'role_id' => $roles['admin'],
|
|
'guard_name' => 'web',
|
|
'created_at' => date('Y-m-d H:i:s'),
|
|
];
|
|
}
|
|
|
|
// moderator 用户 -> 版主
|
|
if (isset($users['moderator']) && isset($roles['moderator'])) {
|
|
$userRoles[] = [
|
|
'user_id' => $users['moderator'],
|
|
'role_id' => $roles['moderator'],
|
|
'guard_name' => 'web',
|
|
'created_at' => date('Y-m-d H:i:s'),
|
|
];
|
|
}
|
|
|
|
// user001 用户 -> 普通用户
|
|
if (isset($users['user001']) && isset($roles['user'])) {
|
|
$userRoles[] = [
|
|
'user_id' => $users['user001'],
|
|
'role_id' => $roles['user'],
|
|
'guard_name' => 'web',
|
|
'created_at' => date('Y-m-d H:i:s'),
|
|
];
|
|
}
|
|
|
|
// user002 用户 -> 普通用户
|
|
if (isset($users['user002']) && isset($roles['user'])) {
|
|
$userRoles[] = [
|
|
'user_id' => $users['user002'],
|
|
'role_id' => $roles['user'],
|
|
'guard_name' => 'web',
|
|
'created_at' => date('Y-m-d H:i:s'),
|
|
];
|
|
}
|
|
|
|
// 批量插入用户角色关联
|
|
if (!empty($userRoles)) {
|
|
DB::table('user_roles')->insert($userRoles);
|
|
}
|
|
|
|
$this->command->info('用户角色关联种子数据插入完成');
|
|
}
|
|
}
|