1
Fork 0
photoview/api/server/server.go

83 lines
2.2 KiB
Go
Raw Normal View History

2020-01-30 14:28:14 +01:00
package main
import (
"log"
"net/http"
2020-02-19 21:33:28 +01:00
"net/url"
2020-01-30 14:28:14 +01:00
"os"
2020-02-19 21:33:28 +01:00
"path"
2020-01-30 14:28:14 +01:00
2020-01-31 23:30:34 +01:00
"github.com/go-chi/chi"
2020-02-19 21:33:28 +01:00
"github.com/go-chi/chi/middleware"
2020-02-05 13:15:01 +01:00
"github.com/go-chi/cors"
2020-02-05 14:51:46 +01:00
"github.com/joho/godotenv"
2020-01-30 14:49:39 +01:00
"github.com/viktorstrate/photoview/api/database"
2020-01-31 23:30:34 +01:00
"github.com/viktorstrate/photoview/api/graphql/auth"
2020-02-09 12:53:21 +01:00
"github.com/viktorstrate/photoview/api/routes"
2020-01-30 14:49:39 +01:00
2020-01-30 14:28:14 +01:00
"github.com/99designs/gqlgen/handler"
photoview_graphql "github.com/viktorstrate/photoview/api/graphql"
2020-02-05 14:51:46 +01:00
"github.com/viktorstrate/photoview/api/graphql/resolvers"
2020-01-30 14:28:14 +01:00
)
2020-01-30 14:49:39 +01:00
const defaultPort = "4001"
2020-01-30 14:28:14 +01:00
func main() {
2020-01-30 14:49:39 +01:00
if err := godotenv.Load(); err != nil {
log.Println("No .env file found")
}
2020-02-19 21:33:28 +01:00
port := os.Getenv("API_LISTEN_PORT")
2020-01-30 14:28:14 +01:00
if port == "" {
port = defaultPort
}
2020-01-31 15:22:58 +01:00
db := database.SetupDatabase()
defer db.Close()
// Migrate database
if err := database.MigrateDatabase(db); err != nil {
log.Fatalf("Could not migrate database: %s\n", err)
}
2020-01-31 23:30:34 +01:00
router := chi.NewRouter()
router.Use(auth.Middleware(db))
2020-02-19 21:33:28 +01:00
router.Use(middleware.Logger)
2020-02-05 13:15:01 +01:00
router.Use(cors.New(cors.Options{
2020-02-15 23:29:03 +01:00
AllowedOrigins: []string{"http://localhost:4001", "http://localhost:1234", "*"},
2020-02-05 13:15:01 +01:00
AllowedMethods: []string{"GET", "POST", "PUT", "DELETE", "OPTIONS"},
AllowedHeaders: []string{"Accept", "Authorization", "Content-Type"},
AllowCredentials: true,
2020-02-05 14:51:46 +01:00
Debug: false,
2020-02-05 13:15:01 +01:00
}).Handler)
2020-02-05 14:51:46 +01:00
graphqlResolver := resolvers.Resolver{Database: db}
2020-01-31 23:30:34 +01:00
graphqlDirective := photoview_graphql.DirectiveRoot{}
graphqlDirective.IsAdmin = photoview_graphql.IsAdmin(db)
graphqlConfig := photoview_graphql.Config{
Resolvers: &graphqlResolver,
Directives: graphqlDirective,
}
2020-01-30 14:49:39 +01:00
2020-02-19 21:33:28 +01:00
endpointURL, err := url.Parse(os.Getenv("API_ENDPOINT"))
if err != nil {
log.Println("WARN: Environment variable API_ENDPOINT not specified")
endpointURL, _ = url.Parse("/")
}
router.Route(endpointURL.Path, func(router chi.Router) {
router.Handle("/", handler.Playground("GraphQL playground", path.Join(endpointURL.Path, "/graphql")))
router.Handle("/graphql", handler.GraphQL(photoview_graphql.NewExecutableSchema(graphqlConfig)))
2020-01-30 14:28:14 +01:00
2020-02-19 21:33:28 +01:00
router.Mount("/photo", routes.PhotoRoutes(db))
})
2020-02-09 12:53:21 +01:00
2020-02-19 21:33:28 +01:00
log.Printf("🚀 Graphql playground ready at %s", endpointURL.String())
2020-01-31 23:30:34 +01:00
log.Fatal(http.ListenAndServe(":"+port, router))
2020-01-30 14:28:14 +01:00
}