casdoor.go 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. package user
  2. import (
  3. "fmt"
  4. "github.com/0xJacky/Nginx-UI/api"
  5. "github.com/0xJacky/Nginx-UI/internal/user"
  6. "github.com/0xJacky/Nginx-UI/settings"
  7. "github.com/casdoor/casdoor-go-sdk/casdoorsdk"
  8. "github.com/gin-gonic/gin"
  9. "github.com/pkg/errors"
  10. "gorm.io/gorm"
  11. "net/http"
  12. "net/url"
  13. )
  14. type CasdoorLoginUser struct {
  15. Code string `json:"code" binding:"required,max=255"`
  16. State string `json:"state" binding:"required,max=255"`
  17. }
  18. func CasdoorCallback(c *gin.Context) {
  19. var loginUser CasdoorLoginUser
  20. ok := api.BindAndValid(c, &loginUser)
  21. if !ok {
  22. return
  23. }
  24. endpoint := settings.CasdoorSettings.Endpoint
  25. clientId := settings.CasdoorSettings.ClientId
  26. clientSecret := settings.CasdoorSettings.ClientSecret
  27. certificate := settings.CasdoorSettings.Certificate
  28. organization := settings.CasdoorSettings.Organization
  29. application := settings.CasdoorSettings.Application
  30. if endpoint == "" || clientId == "" || clientSecret == "" || certificate == "" || organization == "" || application == "" {
  31. c.JSON(http.StatusInternalServerError, gin.H{
  32. "message": "Casdoor is not configured",
  33. })
  34. return
  35. }
  36. casdoorsdk.InitConfig(endpoint, clientId, clientSecret, certificate, organization, application)
  37. token, err := casdoorsdk.GetOAuthToken(loginUser.Code, loginUser.State)
  38. if err != nil {
  39. api.ErrHandler(c, err)
  40. return
  41. }
  42. claims, err := casdoorsdk.ParseJwtToken(token.AccessToken)
  43. if err != nil {
  44. api.ErrHandler(c, err)
  45. return
  46. }
  47. u, err := user.GetUser(claims.Name)
  48. if err != nil {
  49. if errors.Is(err, gorm.ErrRecordNotFound) {
  50. c.JSON(http.StatusForbidden, gin.H{
  51. "message": "User not exist",
  52. })
  53. } else {
  54. api.ErrHandler(c, err)
  55. }
  56. return
  57. }
  58. userToken, err := user.GenerateJWT(u.Name)
  59. if err != nil {
  60. api.ErrHandler(c, err)
  61. return
  62. }
  63. c.JSON(http.StatusOK, LoginResponse{
  64. Message: "ok",
  65. Token: userToken,
  66. })
  67. }
  68. func GetCasdoorUri(c *gin.Context) {
  69. endpoint := settings.CasdoorSettings.Endpoint
  70. clientId := settings.CasdoorSettings.ClientId
  71. redirectUri := settings.CasdoorSettings.RedirectUri
  72. state := settings.CasdoorSettings.Application
  73. if endpoint == "" || clientId == "" || redirectUri == "" || state == "" {
  74. c.JSON(http.StatusOK, gin.H{
  75. "uri": "",
  76. })
  77. return
  78. }
  79. encodedRedirectUri := url.QueryEscape(redirectUri)
  80. c.JSON(http.StatusOK, gin.H{
  81. "uri": fmt.Sprintf("%s/login/oauth/authorize?client_id=%s&response_type=code&redirect_uri=%s&state=%s&scope=read", endpoint, clientId, encodedRedirectUri, state),
  82. })
  83. }