2021-07-08 12:15:19 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2021-07-14 18:43:19 +00:00
|
|
|
"context"
|
2021-08-04 10:25:13 +00:00
|
|
|
"log"
|
2021-07-08 12:15:19 +00:00
|
|
|
|
2021-08-04 10:25:13 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/constants"
|
2021-07-28 06:23:37 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/db"
|
2021-07-23 16:27:44 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/handlers"
|
|
|
|
"github.com/authorizerdev/authorizer/server/oauth"
|
2021-07-28 06:23:37 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/session"
|
2021-09-20 05:06:26 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/utils"
|
2021-08-04 10:25:13 +00:00
|
|
|
"github.com/gin-contrib/location"
|
2021-07-14 18:43:19 +00:00
|
|
|
"github.com/gin-gonic/gin"
|
2021-07-08 12:15:19 +00:00
|
|
|
)
|
|
|
|
|
2021-07-14 18:43:19 +00:00
|
|
|
func GinContextToContextMiddleware() gin.HandlerFunc {
|
|
|
|
return func(c *gin.Context) {
|
2021-08-04 10:25:13 +00:00
|
|
|
if constants.AUTHORIZER_URL == "" {
|
|
|
|
url := location.Get(c)
|
2021-08-06 13:47:52 +00:00
|
|
|
constants.AUTHORIZER_URL = url.Scheme + "://" + c.Request.Host
|
2021-12-17 15:55:07 +00:00
|
|
|
log.Println("=> authorizer url:", constants.AUTHORIZER_URL)
|
2021-08-04 10:25:13 +00:00
|
|
|
}
|
2021-07-14 18:43:19 +00:00
|
|
|
ctx := context.WithValue(c.Request.Context(), "GinContextKey", c)
|
|
|
|
c.Request = c.Request.WithContext(ctx)
|
|
|
|
c.Next()
|
|
|
|
}
|
|
|
|
}
|
2021-07-12 18:22:16 +00:00
|
|
|
|
2021-08-04 06:48:57 +00:00
|
|
|
// TODO use allowed origins for cors origin
|
|
|
|
// TODO throw error if url is not allowed
|
2021-07-20 22:04:03 +00:00
|
|
|
func CORSMiddleware() gin.HandlerFunc {
|
|
|
|
return func(c *gin.Context) {
|
|
|
|
origin := c.Request.Header.Get("Origin")
|
2021-12-07 12:20:50 +00:00
|
|
|
constants.APP_URL = origin
|
2021-07-20 22:04:03 +00:00
|
|
|
c.Writer.Header().Set("Access-Control-Allow-Origin", origin)
|
|
|
|
c.Writer.Header().Set("Access-Control-Allow-Credentials", "true")
|
|
|
|
c.Writer.Header().Set("Access-Control-Allow-Headers", "Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization, accept, origin, Cache-Control, X-Requested-With")
|
|
|
|
c.Writer.Header().Set("Access-Control-Allow-Methods", "POST, OPTIONS, GET, PUT")
|
|
|
|
|
|
|
|
if c.Request.Method == "OPTIONS" {
|
|
|
|
c.AbortWithStatus(204)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
c.Next()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-14 18:43:19 +00:00
|
|
|
func main() {
|
2021-07-28 06:23:37 +00:00
|
|
|
InitEnv()
|
|
|
|
db.InitDB()
|
|
|
|
session.InitSession()
|
2021-07-28 11:08:55 +00:00
|
|
|
oauth.InitOAuth()
|
2021-09-20 05:06:26 +00:00
|
|
|
utils.InitServer()
|
2021-07-28 06:23:37 +00:00
|
|
|
|
2021-07-14 18:43:19 +00:00
|
|
|
r := gin.Default()
|
2021-08-04 10:25:13 +00:00
|
|
|
r.Use(location.Default())
|
2021-07-14 18:43:19 +00:00
|
|
|
r.Use(GinContextToContextMiddleware())
|
2021-07-20 22:04:03 +00:00
|
|
|
r.Use(CORSMiddleware())
|
2021-08-04 06:48:57 +00:00
|
|
|
|
2021-07-17 16:29:50 +00:00
|
|
|
r.GET("/", handlers.PlaygroundHandler())
|
|
|
|
r.POST("/graphql", handlers.GraphqlHandler())
|
2021-07-23 08:55:32 +00:00
|
|
|
r.GET("/verify_email", handlers.VerifyEmailHandler())
|
2021-08-04 06:48:57 +00:00
|
|
|
r.GET("/oauth_login/:oauth_provider", handlers.OAuthLoginHandler())
|
|
|
|
r.GET("/oauth_callback/:oauth_provider", handlers.OAuthCallbackHandler())
|
|
|
|
|
|
|
|
// login wall app related routes
|
2021-08-04 10:25:13 +00:00
|
|
|
|
2021-08-04 06:48:57 +00:00
|
|
|
r.LoadHTMLGlob("templates/*")
|
2021-08-04 10:25:13 +00:00
|
|
|
app := r.Group("/app")
|
|
|
|
{
|
|
|
|
app.Static("/build", "app/build")
|
|
|
|
app.GET("/", handlers.AppHandler())
|
|
|
|
app.GET("/reset-password", handlers.AppHandler())
|
|
|
|
}
|
2021-08-04 06:48:57 +00:00
|
|
|
|
2021-07-14 18:43:19 +00:00
|
|
|
r.Run()
|
2021-07-08 12:15:19 +00:00
|
|
|
}
|