mirror of
https://github.com/yangjian102621/geekai.git
synced 2025-09-17 16:56:38 +08:00
Merge branch 'ui' of 172.28.1.6:yangjian/chatgpt-plus into ui
This commit is contained in:
commit
072c96e1ec
@ -16,7 +16,6 @@ func NewDefaultConfig() *types.AppConfig {
|
|||||||
return &types.AppConfig{
|
return &types.AppConfig{
|
||||||
Listen: "0.0.0.0:5678",
|
Listen: "0.0.0.0:5678",
|
||||||
ProxyURL: "",
|
ProxyURL: "",
|
||||||
Manager: types.Manager{Username: "admin", Password: "admin123"},
|
|
||||||
StaticDir: "./static",
|
StaticDir: "./static",
|
||||||
StaticUrl: "http://localhost/5678/static",
|
StaticUrl: "http://localhost/5678/static",
|
||||||
Redis: types.RedisConfig{Host: "localhost", Port: 6379, Password: ""},
|
Redis: types.RedisConfig{Host: "localhost", Port: 6379, Password: ""},
|
||||||
|
@ -10,7 +10,6 @@ type AppConfig struct {
|
|||||||
Session Session
|
Session Session
|
||||||
ProxyURL string
|
ProxyURL string
|
||||||
MysqlDns string // mysql 连接地址
|
MysqlDns string // mysql 连接地址
|
||||||
Manager Manager // 后台管理员账户信息
|
|
||||||
StaticDir string // 静态资源目录
|
StaticDir string // 静态资源目录
|
||||||
StaticUrl string // 静态资源 URL
|
StaticUrl string // 静态资源 URL
|
||||||
Redis RedisConfig // redis 连接信息
|
Redis RedisConfig // redis 连接信息
|
||||||
@ -122,14 +121,6 @@ func (c RedisConfig) Url() string {
|
|||||||
return fmt.Sprintf("%s:%d", c.Host, c.Port)
|
return fmt.Sprintf("%s:%d", c.Host, c.Port)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Manager 管理员
|
|
||||||
type Manager struct {
|
|
||||||
Username string `json:"username"`
|
|
||||||
Password string `json:"password"`
|
|
||||||
Captcha string `json:"captcha"` // 验证码
|
|
||||||
CaptchaId string `json:"captcha_id"` // 验证码id
|
|
||||||
}
|
|
||||||
|
|
||||||
// ChatConfig 系统默认的聊天配置
|
// ChatConfig 系统默认的聊天配置
|
||||||
type ChatConfig struct {
|
type ChatConfig struct {
|
||||||
OpenAI ModelAPIConfig `json:"open_ai"`
|
OpenAI ModelAPIConfig `json:"open_ai"`
|
||||||
|
@ -5,6 +5,8 @@ import (
|
|||||||
"chatplus/core/types"
|
"chatplus/core/types"
|
||||||
"chatplus/handler"
|
"chatplus/handler"
|
||||||
logger2 "chatplus/logger"
|
logger2 "chatplus/logger"
|
||||||
|
"chatplus/store/model"
|
||||||
|
"chatplus/utils"
|
||||||
"chatplus/utils/resp"
|
"chatplus/utils/resp"
|
||||||
"context"
|
"context"
|
||||||
"github.com/go-redis/redis/v8"
|
"github.com/go-redis/redis/v8"
|
||||||
@ -18,6 +20,14 @@ import (
|
|||||||
|
|
||||||
var logger = logger2.GetLogger()
|
var logger = logger2.GetLogger()
|
||||||
|
|
||||||
|
// Manager 管理员
|
||||||
|
type Manager struct {
|
||||||
|
Username string `json:"username"`
|
||||||
|
Password string `json:"password"`
|
||||||
|
Captcha string `json:"captcha"` // 验证码
|
||||||
|
CaptchaId string `json:"captcha_id"` // 验证码id
|
||||||
|
}
|
||||||
|
|
||||||
type ManagerHandler struct {
|
type ManagerHandler struct {
|
||||||
handler.BaseHandler
|
handler.BaseHandler
|
||||||
db *gorm.DB
|
db *gorm.DB
|
||||||
@ -32,7 +42,8 @@ func NewAdminHandler(app *core.AppServer, db *gorm.DB, client *redis.Client) *Ma
|
|||||||
|
|
||||||
// Login 登录
|
// Login 登录
|
||||||
func (h *ManagerHandler) Login(c *gin.Context) {
|
func (h *ManagerHandler) Login(c *gin.Context) {
|
||||||
var data types.Manager
|
|
||||||
|
var data Manager
|
||||||
if err := c.ShouldBindJSON(&data); err != nil {
|
if err := c.ShouldBindJSON(&data); err != nil {
|
||||||
resp.ERROR(c, types.InvalidArgs)
|
resp.ERROR(c, types.InvalidArgs)
|
||||||
return
|
return
|
||||||
@ -40,32 +51,51 @@ func (h *ManagerHandler) Login(c *gin.Context) {
|
|||||||
|
|
||||||
// add captcha
|
// add captcha
|
||||||
if !base64Captcha.DefaultMemStore.Verify(data.CaptchaId, data.Captcha, true) {
|
if !base64Captcha.DefaultMemStore.Verify(data.CaptchaId, data.Captcha, true) {
|
||||||
resp.ERROR(c, "验证码错误,请重新输入!")
|
resp.ERROR(c, "验证码错误!")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
manager := h.App.Config.Manager
|
var manager model.AdminUser
|
||||||
if data.Username == manager.Username && data.Password == manager.Password {
|
res := h.db.Model(&model.AdminUser{}).Where("username = ?", data.Username).First(&manager)
|
||||||
// 创建 token
|
if res.Error != nil {
|
||||||
token := jwt.NewWithClaims(jwt.SigningMethodHS256, jwt.MapClaims{
|
resp.ERROR(c, "请检查用户名或者密码是否填写正确")
|
||||||
"user_id": manager.Username,
|
return
|
||||||
"expired": time.Now().Add(time.Second * time.Duration(h.App.Config.Session.MaxAge)).Unix(),
|
|
||||||
})
|
|
||||||
tokenString, err := token.SignedString([]byte(h.App.Config.Session.SecretKey))
|
|
||||||
if err != nil {
|
|
||||||
resp.ERROR(c, "Failed to generate token, "+err.Error())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
// 保存到 redis
|
|
||||||
key := "users/" + manager.Username
|
|
||||||
if _, err := h.redis.Set(context.Background(), key, tokenString, 0).Result(); err != nil {
|
|
||||||
resp.ERROR(c, "error with save token: "+err.Error())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
resp.SUCCESS(c, tokenString)
|
|
||||||
} else {
|
|
||||||
resp.ERROR(c, "用户名或者密码错误")
|
|
||||||
}
|
}
|
||||||
|
password := utils.GenPassword(data.Password, manager.Salt)
|
||||||
|
if password != manager.Password {
|
||||||
|
resp.ERROR(c, "用户名或密码错误")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// 超级管理员默认是ID:1
|
||||||
|
if manager.Id != 1 && manager.Status == false {
|
||||||
|
resp.ERROR(c, "该用户已被禁止登录,请联系超级管理员")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// 创建 token
|
||||||
|
token := jwt.NewWithClaims(jwt.SigningMethodHS256, jwt.MapClaims{
|
||||||
|
"user_id": manager.Username,
|
||||||
|
"expired": time.Now().Add(time.Second * time.Duration(h.App.Config.Session.MaxAge)).Unix(),
|
||||||
|
})
|
||||||
|
tokenString, err := token.SignedString([]byte(h.App.Config.Session.SecretKey))
|
||||||
|
if err != nil {
|
||||||
|
resp.ERROR(c, "Failed to generate token, "+err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// 保存到 redis
|
||||||
|
key := "users/" + manager.Username
|
||||||
|
if _, err := h.redis.Set(context.Background(), key, tokenString, 0).Result(); err != nil {
|
||||||
|
resp.ERROR(c, "error with save token: "+err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// 更新最后登录时间和IP
|
||||||
|
manager.LastLoginIp = c.ClientIP()
|
||||||
|
manager.LastLoginAt = time.Now().Unix()
|
||||||
|
h.db.Model(&manager).Updates(manager)
|
||||||
|
|
||||||
|
resp.SUCCESS(c, tokenString)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Logout 注销
|
// Logout 注销
|
||||||
|
18
api/main.go
18
api/main.go
@ -383,15 +383,15 @@ func main() {
|
|||||||
s.Engine.GET("/api/admin/upload/remove", h.Remove)
|
s.Engine.GET("/api/admin/upload/remove", h.Remove)
|
||||||
}),
|
}),
|
||||||
|
|
||||||
//// 系统管理员
|
// 系统管理员
|
||||||
//fx.Provide(admin.NewSysUserHandler),
|
fx.Provide(admin.NewSysUserHandler),
|
||||||
//fx.Invoke(func(s *core.AppServer, h *admin.SysUserHandler) {
|
fx.Invoke(func(s *core.AppServer, h *admin.SysUserHandler) {
|
||||||
// group := s.Engine.Group("/api/admin/sysUser/")
|
group := s.Engine.Group("/api/admin/sysUser/")
|
||||||
// group.POST("save", h.Save)
|
group.POST("save", h.Save)
|
||||||
// group.GET("list", h.List)
|
group.GET("list", h.List)
|
||||||
// group.POST("remove", h.Remove)
|
group.POST("remove", h.Remove)
|
||||||
// group.POST("resetPass", h.ResetPass)
|
group.POST("resetPass", h.ResetPass)
|
||||||
//}),
|
}),
|
||||||
|
|
||||||
fx.Provide(handler.NewFunctionHandler),
|
fx.Provide(handler.NewFunctionHandler),
|
||||||
fx.Invoke(func(s *core.AppServer, h *handler.FunctionHandler) {
|
fx.Invoke(func(s *core.AppServer, h *handler.FunctionHandler) {
|
||||||
|
@ -3,7 +3,6 @@ package vo
|
|||||||
type AdminUser struct {
|
type AdminUser struct {
|
||||||
BaseVo
|
BaseVo
|
||||||
Username string `json:"username"`
|
Username string `json:"username"`
|
||||||
Salt string `json:"salt"` // 密码盐
|
|
||||||
Status bool `json:"status"` // 当前状态
|
Status bool `json:"status"` // 当前状态
|
||||||
LastLoginAt int64 `json:"last_login_at"` // 最后登录时间
|
LastLoginAt int64 `json:"last_login_at"` // 最后登录时间
|
||||||
LastLoginIp string `json:"last_login_ip"` // 最后登录 IP
|
LastLoginIp string `json:"last_login_ip"` // 最后登录 IP
|
||||||
|
Loading…
Reference in New Issue
Block a user