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

45 lines
1011 B
Go
Raw Normal View History

2020-01-30 14:28:14 +01:00
package main
import (
"log"
"net/http"
"os"
2020-01-30 14:49:39 +01:00
"github.com/joho/godotenv"
"github.com/viktorstrate/photoview/api/database"
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)
}
graphqlResolver := photoview_graphql.Resolver{Database: db}
2020-01-30 14:49:39 +01:00
2020-01-30 14:28:14 +01:00
http.Handle("/", handler.Playground("GraphQL playground", "/query"))
2020-01-31 15:22:58 +01:00
http.Handle("/query", handler.GraphQL(photoview_graphql.NewExecutableSchema(photoview_graphql.Config{Resolvers: &graphqlResolver})))
2020-01-30 14:28:14 +01:00
log.Printf("connect to http://localhost:%s/ for GraphQL playground", port)
log.Fatal(http.ListenAndServe(":"+port, nil))
}