mirror of
https://github.com/pocket-id/pocket-id.git
synced 2025-12-08 09:13:13 +03:00
128 lines
2.6 KiB
Go
128 lines
2.6 KiB
Go
//go:build e2etest
|
|
|
|
package controller
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"github.com/pocket-id/pocket-id/backend/internal/service"
|
|
)
|
|
|
|
func NewTestController(group *gin.RouterGroup, testService *service.TestService) {
|
|
testController := &TestController{TestService: testService}
|
|
|
|
group.POST("/test/reset", testController.resetAndSeedHandler)
|
|
group.POST("/test/refreshtoken", testController.signRefreshToken)
|
|
|
|
group.GET("/externalidp/jwks.json", testController.externalIdPJWKS)
|
|
group.POST("/externalidp/sign", testController.externalIdPSignToken)
|
|
}
|
|
|
|
type TestController struct {
|
|
TestService *service.TestService
|
|
}
|
|
|
|
func (tc *TestController) resetAndSeedHandler(c *gin.Context) {
|
|
var baseURL string
|
|
if c.Request.TLS != nil {
|
|
baseURL = "https://" + c.Request.Host
|
|
} else {
|
|
baseURL = "http://" + c.Request.Host
|
|
}
|
|
|
|
skipLdap := c.Query("skip-ldap") == "true"
|
|
skipSeed := c.Query("skip-seed") == "true"
|
|
|
|
if err := tc.TestService.ResetDatabase(); err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
if err := tc.TestService.ResetApplicationImages(); err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
if !skipSeed {
|
|
if err := tc.TestService.SeedDatabase(baseURL); err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
}
|
|
|
|
if err := tc.TestService.ResetAppConfig(c.Request.Context()); err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
if !skipLdap {
|
|
if err := tc.TestService.SetLdapTestConfig(c.Request.Context()); err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
if err := tc.TestService.SyncLdap(c.Request.Context()); err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
}
|
|
|
|
tc.TestService.SetJWTKeys()
|
|
|
|
c.Status(http.StatusNoContent)
|
|
}
|
|
|
|
func (tc *TestController) externalIdPJWKS(c *gin.Context) {
|
|
jwks, err := tc.TestService.GetExternalIdPJWKS()
|
|
if err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
c.JSON(http.StatusOK, jwks)
|
|
}
|
|
|
|
func (tc *TestController) externalIdPSignToken(c *gin.Context) {
|
|
var input struct {
|
|
Aud string `json:"aud"`
|
|
Iss string `json:"iss"`
|
|
Sub string `json:"sub"`
|
|
}
|
|
err := c.ShouldBindJSON(&input)
|
|
if err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
token, err := tc.TestService.SignExternalIdPToken(input.Iss, input.Sub, input.Aud)
|
|
if err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
c.Writer.WriteString(token)
|
|
}
|
|
|
|
func (tc *TestController) signRefreshToken(c *gin.Context) {
|
|
var input struct {
|
|
UserID string `json:"user"`
|
|
ClientID string `json:"client"`
|
|
RefreshToken string `json:"rt"`
|
|
}
|
|
err := c.ShouldBindJSON(&input)
|
|
if err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
token, err := tc.TestService.SignRefreshToken(input.UserID, input.ClientID, input.RefreshToken)
|
|
if err != nil {
|
|
_ = c.Error(err)
|
|
return
|
|
}
|
|
|
|
c.Writer.WriteString(token)
|
|
}
|