mirror of
https://github.com/MHSanaei/3x-ui.git
synced 2025-10-24 00:54:39 +00:00

* [refactor] api controller * [fix] access log path better to not hardcode the access log path, maybe some ppl dont want to use the default ./access.log * [fix] set select options from logs paths in xray settings * [update] .gitignore * [lint] all .go files * [update] use status code for jsonMsg and 401 to unauthorize * [update] handle response status code via axios * [fix] set correct value if log paths is set to 'none' we also use the default value for the paths if its set to none * [fix] iplimit - only warning access log if f2b is installed
57 lines
910 B
Go
57 lines
910 B
Go
package session
|
|
|
|
import (
|
|
"encoding/gob"
|
|
|
|
"x-ui/database/model"
|
|
|
|
sessions "github.com/Calidity/gin-sessions"
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
const (
|
|
loginUser = "LOGIN_USER"
|
|
)
|
|
|
|
func init() {
|
|
gob.Register(model.User{})
|
|
}
|
|
|
|
func SetLoginUser(c *gin.Context, user *model.User) error {
|
|
s := sessions.Default(c)
|
|
s.Set(loginUser, user)
|
|
return s.Save()
|
|
}
|
|
|
|
func SetMaxAge(c *gin.Context, maxAge int) error {
|
|
s := sessions.Default(c)
|
|
s.Options(sessions.Options{
|
|
Path: "/",
|
|
MaxAge: maxAge,
|
|
})
|
|
return s.Save()
|
|
}
|
|
|
|
func GetLoginUser(c *gin.Context) *model.User {
|
|
s := sessions.Default(c)
|
|
obj := s.Get(loginUser)
|
|
if obj == nil {
|
|
return nil
|
|
}
|
|
user := obj.(model.User)
|
|
return &user
|
|
}
|
|
|
|
func IsLogin(c *gin.Context) bool {
|
|
return GetLoginUser(c) != nil
|
|
}
|
|
|
|
func ClearSession(c *gin.Context) {
|
|
s := sessions.Default(c)
|
|
s.Clear()
|
|
s.Options(sessions.Options{
|
|
Path: "/",
|
|
MaxAge: -1,
|
|
})
|
|
s.Save()
|
|
}
|