ether-pms/sql/init.sql

175 lines
6.3 KiB
SQL

-- Ether PMS Database Initialization Script
-- Database: ether_pms
-- ============================================
-- Auth Module Tables
-- ============================================
-- User Table
CREATE TABLE IF NOT EXISTS auth_user (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
username VARCHAR(50) UNIQUE NOT NULL,
password VARCHAR(100) NOT NULL,
salt VARCHAR(32),
real_name VARCHAR(50),
phone VARCHAR(20),
email VARCHAR(100),
avatar VARCHAR(200),
status VARCHAR(20) DEFAULT 'ACTIVE',
last_login_time TIMESTAMP,
last_login_ip VARCHAR(50),
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
created_by UUID
);
CREATE INDEX idx_auth_user_username ON auth_user(username);
CREATE INDEX idx_auth_user_phone ON auth_user(phone);
CREATE INDEX idx_auth_user_status ON auth_user(status);
-- Role Table
CREATE TABLE IF NOT EXISTS auth_role (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
code VARCHAR(50) UNIQUE NOT NULL,
name VARCHAR(50) NOT NULL,
description VARCHAR(200),
type VARCHAR(20),
data_scope VARCHAR(20) DEFAULT 'SELF',
project_id VARCHAR(50),
status VARCHAR(20) DEFAULT 'ENABLED',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE INDEX idx_auth_role_code ON auth_role(code);
CREATE INDEX idx_auth_role_project ON auth_role(project_id);
-- Permission Table
CREATE TABLE IF NOT EXISTS auth_permission (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
code VARCHAR(100) UNIQUE NOT NULL,
name VARCHAR(100) NOT NULL,
type VARCHAR(20),
resource VARCHAR(50),
method VARCHAR(50),
description VARCHAR(200),
parent_code VARCHAR(50),
sort_order INTEGER DEFAULT 0,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE INDEX idx_auth_permission_code ON auth_permission(code);
CREATE INDEX idx_auth_permission_type ON auth_permission(type);
CREATE INDEX idx_auth_permission_parent ON auth_permission(parent_code);
-- User-Role Relation Table
CREATE TABLE IF NOT EXISTS auth_user_role (
user_id UUID REFERENCES auth_user(id) ON DELETE CASCADE,
role_id UUID REFERENCES auth_role(id) ON DELETE CASCADE,
PRIMARY KEY (user_id, role_id)
);
-- Role-Permission Relation Table
CREATE TABLE IF NOT EXISTS auth_role_permission (
role_id UUID REFERENCES auth_role(id) ON DELETE CASCADE,
permission_id UUID REFERENCES auth_permission(id) ON DELETE CASCADE,
PRIMARY KEY (role_id, permission_id)
);
-- ============================================
-- MDM Module Tables
-- ============================================
-- Project Table
CREATE TABLE IF NOT EXISTS mdm_project (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
code VARCHAR(50) UNIQUE NOT NULL,
name VARCHAR(100) NOT NULL,
description VARCHAR(500),
address VARCHAR(200),
project_type VARCHAR(20),
province VARCHAR(50),
city VARCHAR(50),
district VARCHAR(50),
longitude DOUBLE PRECISION,
latitude DOUBLE PRECISION,
status VARCHAR(20) DEFAULT 'ACTIVE',
building_count INTEGER,
unit_count INTEGER,
room_count INTEGER,
floor_count INTEGER,
logo VARCHAR(200),
contact VARCHAR(200),
contact_phone VARCHAR(20),
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE INDEX idx_mdm_project_code ON mdm_project(code);
CREATE INDEX idx_mdm_project_status ON mdm_project(status);
-- Space Node Table
CREATE TABLE IF NOT EXISTS mdm_space_node (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
code VARCHAR(50) NOT NULL,
name VARCHAR(100) NOT NULL,
node_type VARCHAR(50) NOT NULL,
parent_code VARCHAR(50),
project_code VARCHAR(50) NOT NULL,
sort_order INTEGER DEFAULT 0,
building VARCHAR(50),
unit VARCHAR(50),
floor VARCHAR(50),
room_number VARCHAR(50),
area INTEGER,
status VARCHAR(20) DEFAULT 'ACTIVE',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
UNIQUE(code, project_code)
);
CREATE INDEX idx_mdm_space_node_project ON mdm_space_node(project_code);
CREATE INDEX idx_mdm_space_node_type ON mdm_space_node(node_type);
CREATE INDEX idx_mdm_space_node_parent ON mdm_space_node(parent_code);
-- ============================================
-- Initial Data
-- ============================================
-- Insert default admin user
-- Password: Admin123! (BCrypt encrypted)
-- Password requirements: 8-20 chars, uppercase, lowercase, digit, special char
INSERT INTO auth_user (username, password, real_name, status)
VALUES ('admin', '$2a$10$N9qo8uLOickgx2ZMRZoMye/U.N4.5F.HQW5R.HGmh3R1VJfF5WQa', '系统管理员', 'ACTIVE');
-- Insert default roles
INSERT INTO auth_role (code, name, description, type, data_scope, status)
VALUES
('SYSTEM_ADMIN', '系统管理员', '系统超级管理员', 'SYSTEM', 'ALL', 'ENABLED'),
('PROJECT_ADMIN', '项目管理员', '项目管理员', 'PROJECT', 'PROJECT', 'ENABLED'),
('EMPLOYEE', '普通员工', '普通员工', 'DEPARTMENT', 'SELF', 'ENABLED');
-- Insert default permissions
INSERT INTO auth_permission (code, name, type, resource, method, sort_order)
VALUES
('dashboard', '仪表盘', 'MENU', '/dashboard', 'GET', 1),
('user:list', '用户列表', 'BUTTON', '/api/users', 'GET', 10),
('user:create', '创建用户', 'BUTTON', '/api/users', 'POST', 11),
('user:update', '更新用户', 'BUTTON', '/api/users', 'PUT', 12),
('user:delete', '删除用户', 'BUTTON', '/api/users', 'DELETE', 13),
('role:list', '角色列表', 'BUTTON', '/api/roles', 'GET', 20),
('role:create', '创建角色', 'BUTTON', '/api/roles', 'POST', 21),
('role:update', '更新角色', 'BUTTON', '/api/roles', 'PUT', 22),
('role:delete', '删除角色', 'BUTTON', '/api/roles', 'DELETE', 23),
('project:list', '项目列表', 'BUTTON', '/api/projects', 'GET', 30),
('project:create', '创建项目', 'BUTTON', '/api/projects', 'POST', 31),
('project:update', '更新项目', 'BUTTON', '/api/projects', 'PUT', 32),
('project:delete', '删除项目', 'BUTTON', '/api/projects', 'DELETE', 33);
-- Assign all permissions to SYSTEM_ADMIN role
INSERT INTO auth_role_permission (role_id, permission_id)
SELECT r.id, p.id
FROM auth_role r, auth_permission p
WHERE r.code = 'SYSTEM_ADMIN';