2023-08-12 19:21:42 +08:00
|
|
|
package routes
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
2023-08-14 04:58:06 +08:00
|
|
|
"github.com/divyam234/teldrive-go/database"
|
2023-08-12 19:21:42 +08:00
|
|
|
"github.com/divyam234/teldrive-go/services"
|
|
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
)
|
|
|
|
|
|
|
|
func addAuthRoutes(rg *gin.RouterGroup) {
|
|
|
|
|
|
|
|
r := rg.Group("/auth")
|
|
|
|
|
2023-08-14 04:58:06 +08:00
|
|
|
authService := services.AuthService{Db: database.DB, SessionMaxAge: 30 * 24 * 60 * 60}
|
2023-08-12 19:21:42 +08:00
|
|
|
|
|
|
|
r.POST("/login", func(c *gin.Context) {
|
|
|
|
|
2023-08-14 04:58:06 +08:00
|
|
|
res, err := authService.LogIn(c)
|
2023-08-12 19:21:42 +08:00
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
c.AbortWithError(err.Code, err.Error)
|
|
|
|
return
|
|
|
|
}
|
2023-08-14 04:58:06 +08:00
|
|
|
c.JSON(http.StatusOK, res)
|
2023-08-12 19:21:42 +08:00
|
|
|
})
|
|
|
|
|
2023-08-13 04:15:19 +08:00
|
|
|
r.GET("/logout", Authmiddleware, func(c *gin.Context) {
|
|
|
|
|
2023-08-14 04:58:06 +08:00
|
|
|
res, err := authService.Logout(c)
|
2023-08-13 04:15:19 +08:00
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
c.AbortWithError(err.Code, err.Error)
|
|
|
|
return
|
|
|
|
}
|
2023-08-14 04:58:06 +08:00
|
|
|
c.JSON(http.StatusOK, res)
|
2023-08-13 04:15:19 +08:00
|
|
|
|
|
|
|
})
|
|
|
|
|
2023-08-15 03:36:24 +08:00
|
|
|
r.GET("/ws", authService.HandleQrCodeLogin)
|
|
|
|
|
2023-08-12 19:21:42 +08:00
|
|
|
r.GET("/session", func(c *gin.Context) {
|
|
|
|
|
|
|
|
session := authService.GetSession(c)
|
|
|
|
|
|
|
|
c.JSON(http.StatusOK, session)
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|