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

57 lines
1.3 KiB
Go
Raw Normal View History

2020-01-30 14:28:14 +01:00
package main
import (
"log"
"net/http"
"os"
2020-01-31 23:30:34 +01:00
"github.com/go-chi/chi"
2020-01-30 14:49:39 +01:00
"github.com/joho/godotenv"
"github.com/viktorstrate/photoview/api/database"
2020-01-31 23:30:34 +01:00
"github.com/viktorstrate/photoview/api/graphql/auth"
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-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")
}
port := os.Getenv("API_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-01-31 15:22:58 +01:00
graphqlResolver := photoview_graphql.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-01-31 23:30:34 +01:00
router.Handle("/", handler.Playground("GraphQL playground", "/query"))
router.Handle("/query", handler.GraphQL(photoview_graphql.NewExecutableSchema(graphqlConfig)))
2020-01-30 14:28:14 +01:00
log.Printf("connect to http://localhost:%s/ for GraphQL playground", port)
2020-01-31 23:30:34 +01:00
log.Fatal(http.ListenAndServe(":"+port, router))
2020-01-30 14:28:14 +01:00
}