技术栈:Go (Gin + GORM) + PHP + MySQL 5.7 + Redis 主要功能: - 多班级完全隔离(class_id 贯穿全系统) - 后端从 Python FastAPI 重写为 Go Gin(端口 56789) - 超级管理员独立登录(env 配置路径,默认账密 admin/Admin123) - 科任老师/课代表新角色 - 课代表作业管理页面 - 排行榜分项排行(操行分/考勤/作业) - 角色加减分上下限由班主任配置 - 家长改密功能(可开关) - 班级角色按需开关 - 宿舍号格式:南0-000 - 周度/月度重置功能 - MySQL 5.7 兼容 - Nginx 反向代理部署 开发者: Canglan 版权归属: Sea Network Technology Studio 许可证: Apache License 2.0
37 lines
1.5 KiB
Go
37 lines
1.5 KiB
Go
// ===========================================
|
||
// 多班级版班级管理系统 - Go 后端
|
||
//
|
||
// 开发者: Canglan
|
||
// 联系方式: admin@sea-studio.top
|
||
// 版权归属: Sea Network Technology Studio
|
||
// 许可证: Apache License 2.0
|
||
//
|
||
// 版权所有 © Sea Network Technology Studio
|
||
// ===========================================
|
||
|
||
package model
|
||
|
||
import "time"
|
||
|
||
// AdminRole 管理员角色模型,对应 admin_roles 表
|
||
type AdminRole struct {
|
||
AdminRoleID int `gorm:"column:admin_role_id;primaryKey;autoIncrement" json:"admin_role_id"`
|
||
UserID int `gorm:"column:user_id;not null;uniqueIndex:uk_user_class" json:"user_id"`
|
||
ClassID int `gorm:"column:class_id;not null;uniqueIndex:uk_user_class;index:idx_admin_role_class" json:"class_id"`
|
||
RoleType string `gorm:"column:role_type;type:enum('班主任','班长','学习委员','考勤委员','劳动委员','志愿委员','科任老师','课代表');not null" json:"role_type"`
|
||
SubjectID *int `gorm:"column:subject_id" json:"subject_id"`
|
||
CreatedAt time.Time `gorm:"column:created_at;autoCreateTime" json:"created_at"`
|
||
|
||
// 虚拟字段(JOIN 查询时使用)
|
||
RealName *string `gorm:"-" json:"real_name,omitempty"`
|
||
Username *string `gorm:"-" json:"username,omitempty"`
|
||
UserStatus *int8 `gorm:"-" json:"user_status,omitempty"`
|
||
SubjectName *string `gorm:"-" json:"subject_name,omitempty"`
|
||
ClassName *string `gorm:"-" json:"class_name,omitempty"`
|
||
}
|
||
|
||
// TableName 指定表名
|
||
func (AdminRole) TableName() string {
|
||
return "admin_roles"
|
||
}
|