mirror of https://github.com/Xhofe/alist
feat: change current user's profile
parent
fb65e98fa3
commit
4f3129ec28
|
@ -32,7 +32,7 @@ func initSettings() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// insert new items
|
// insert new items
|
||||||
for i, _ := range initialSettingItems {
|
for i := range initialSettingItems {
|
||||||
v := initialSettingItems[i]
|
v := initialSettingItems[i]
|
||||||
_, err := db.GetSettingItemByKey(v.Key)
|
_, err := db.GetSettingItemByKey(v.Key)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
|
|
|
@ -17,8 +17,8 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
type LoginReq struct {
|
type LoginReq struct {
|
||||||
Username string `json:"username"`
|
Username string `json:"username" binding:"required"`
|
||||||
Password string `json:"password"`
|
Password string `json:"password" binding:"required"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func Login(c *gin.Context) {
|
func Login(c *gin.Context) {
|
||||||
|
@ -66,3 +66,19 @@ func CurrentUser(c *gin.Context) {
|
||||||
userResp.Password = ""
|
userResp.Password = ""
|
||||||
common.SuccessResp(c, userResp)
|
common.SuccessResp(c, userResp)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func UpdateCurrent(c *gin.Context) {
|
||||||
|
var req LoginReq
|
||||||
|
if err := c.ShouldBind(&req); err != nil {
|
||||||
|
common.ErrorResp(c, err, 400)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
user := c.MustGet("user").(*model.User)
|
||||||
|
user.Username = req.Username
|
||||||
|
user.Password = req.Password
|
||||||
|
if err := db.UpdateUser(user); err != nil {
|
||||||
|
common.ErrorResp(c, err, 500)
|
||||||
|
} else {
|
||||||
|
common.SuccessResp(c)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -18,38 +18,47 @@ func Init(r *gin.Engine) {
|
||||||
r.GET("/d/*path", middlewares.Down, handles.Down)
|
r.GET("/d/*path", middlewares.Down, handles.Down)
|
||||||
r.GET("/p/*path", middlewares.Down, handles.Proxy)
|
r.GET("/p/*path", middlewares.Down, handles.Proxy)
|
||||||
|
|
||||||
r.POST("/api/auth/login", handles.Login)
|
api := r.Group("/api")
|
||||||
|
auth := api.Group("", middlewares.Auth)
|
||||||
|
|
||||||
api := r.Group("/api", middlewares.Auth)
|
api.POST("/auth/login", handles.Login)
|
||||||
api.GET("/auth/current", handles.CurrentUser)
|
auth.GET("/profile", handles.CurrentUser)
|
||||||
|
auth.POST("/profile/update", handles.UpdateCurrent)
|
||||||
|
|
||||||
admin := api.Group("/admin", middlewares.AuthAdmin)
|
// no need auth
|
||||||
|
public := api.Group("/public")
|
||||||
|
public.Any("/settings", handles.PublicSettings)
|
||||||
|
|
||||||
meta := admin.Group("/meta")
|
fs(auth.Group("/fs"))
|
||||||
|
admin(auth.Group("/admin", middlewares.AuthAdmin))
|
||||||
|
}
|
||||||
|
|
||||||
|
func admin(g *gin.RouterGroup) {
|
||||||
|
meta := g.Group("/meta")
|
||||||
meta.GET("/list", handles.ListMetas)
|
meta.GET("/list", handles.ListMetas)
|
||||||
meta.POST("/create", handles.CreateMeta)
|
meta.POST("/create", handles.CreateMeta)
|
||||||
meta.POST("/update", handles.UpdateMeta)
|
meta.POST("/update", handles.UpdateMeta)
|
||||||
meta.POST("/delete", handles.DeleteMeta)
|
meta.POST("/delete", handles.DeleteMeta)
|
||||||
|
|
||||||
user := admin.Group("/user")
|
user := g.Group("/user")
|
||||||
user.GET("/list", handles.ListUsers)
|
user.GET("/list", handles.ListUsers)
|
||||||
user.POST("/create", handles.CreateUser)
|
user.POST("/create", handles.CreateUser)
|
||||||
user.POST("/update", handles.UpdateUser)
|
user.POST("/update", handles.UpdateUser)
|
||||||
user.POST("/delete", handles.DeleteUser)
|
user.POST("/delete", handles.DeleteUser)
|
||||||
|
|
||||||
storage := admin.Group("/storage")
|
storage := g.Group("/storage")
|
||||||
storage.GET("/list", handles.ListStorages)
|
storage.GET("/list", handles.ListStorages)
|
||||||
storage.GET("/get", handles.GetStorage)
|
storage.GET("/get", handles.GetStorage)
|
||||||
storage.POST("/create", handles.CreateStorage)
|
storage.POST("/create", handles.CreateStorage)
|
||||||
storage.POST("/update", handles.UpdateStorage)
|
storage.POST("/update", handles.UpdateStorage)
|
||||||
storage.POST("/delete", handles.DeleteStorage)
|
storage.POST("/delete", handles.DeleteStorage)
|
||||||
|
|
||||||
driver := admin.Group("/driver")
|
driver := g.Group("/driver")
|
||||||
driver.GET("/list", handles.ListDriverItems)
|
driver.GET("/list", handles.ListDriverItems)
|
||||||
driver.GET("/names", handles.ListDriverNames)
|
driver.GET("/names", handles.ListDriverNames)
|
||||||
driver.GET("/items", handles.GetDriverItems)
|
driver.GET("/items", handles.GetDriverItems)
|
||||||
|
|
||||||
setting := admin.Group("/setting")
|
setting := g.Group("/setting")
|
||||||
setting.GET("/get", handles.GetSetting)
|
setting.GET("/get", handles.GetSetting)
|
||||||
setting.GET("/list", handles.ListSettings)
|
setting.GET("/list", handles.ListSettings)
|
||||||
setting.POST("/save", handles.SaveSettings)
|
setting.POST("/save", handles.SaveSettings)
|
||||||
|
@ -57,7 +66,7 @@ func Init(r *gin.Engine) {
|
||||||
setting.POST("/reset_token", handles.ResetToken)
|
setting.POST("/reset_token", handles.ResetToken)
|
||||||
setting.POST("/set_aria2", handles.SetAria2)
|
setting.POST("/set_aria2", handles.SetAria2)
|
||||||
|
|
||||||
task := admin.Group("/task")
|
task := g.Group("/task")
|
||||||
task.GET("/down/undone", handles.UndoneDownTask)
|
task.GET("/down/undone", handles.UndoneDownTask)
|
||||||
task.GET("/down/done", handles.DoneDownTask)
|
task.GET("/down/done", handles.DoneDownTask)
|
||||||
task.POST("/down/cancel", handles.CancelDownTask)
|
task.POST("/down/cancel", handles.CancelDownTask)
|
||||||
|
@ -71,28 +80,23 @@ func Init(r *gin.Engine) {
|
||||||
task.GET("/copy/done", handles.DoneCopyTask)
|
task.GET("/copy/done", handles.DoneCopyTask)
|
||||||
task.POST("/copy/cancel", handles.CancelCopyTask)
|
task.POST("/copy/cancel", handles.CancelCopyTask)
|
||||||
|
|
||||||
ms := admin.Group("/message")
|
ms := g.Group("/message")
|
||||||
ms.GET("/get", message.PostInstance.GetHandle)
|
ms.GET("/get", message.PostInstance.GetHandle)
|
||||||
ms.POST("/send", message.PostInstance.SendHandle)
|
ms.POST("/send", message.PostInstance.SendHandle)
|
||||||
|
}
|
||||||
|
|
||||||
// guest can
|
func fs(g *gin.RouterGroup) {
|
||||||
public := api.Group("/public")
|
g.Any("/list", handles.FsList)
|
||||||
r.Any("/api/public/settings", handles.PublicSettings)
|
g.Any("/get", handles.FsGet)
|
||||||
//public.GET("/settings", controllers.PublicSettings)
|
g.Any("/dirs", handles.FsDirs)
|
||||||
public.Any("/list", handles.FsList)
|
g.POST("/mkdir", handles.FsMkdir)
|
||||||
public.Any("/get", handles.FsGet)
|
g.POST("/rename", handles.FsRename)
|
||||||
public.Any("/dirs", handles.FsDirs)
|
g.POST("/move", handles.FsMove)
|
||||||
|
g.POST("/copy", handles.FsCopy)
|
||||||
// gust can't
|
g.POST("/remove", handles.FsRemove)
|
||||||
fs := api.Group("/fs")
|
g.POST("/put", handles.FsPut)
|
||||||
fs.POST("/mkdir", handles.FsMkdir)
|
g.POST("/link", middlewares.AuthAdmin, handles.Link)
|
||||||
fs.POST("/rename", handles.FsRename)
|
g.POST("/add_aria2", handles.AddAria2)
|
||||||
fs.POST("/move", handles.FsMove)
|
|
||||||
fs.POST("/copy", handles.FsCopy)
|
|
||||||
fs.POST("/remove", handles.FsRemove)
|
|
||||||
fs.POST("/put", handles.FsPut)
|
|
||||||
fs.POST("/link", middlewares.AuthAdmin, handles.Link)
|
|
||||||
fs.POST("/add_aria2", handles.AddAria2)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func Cors(r *gin.Engine) {
|
func Cors(r *gin.Engine) {
|
||||||
|
|
Loading…
Reference in New Issue