2021-05-10 00:51:15 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/joho/godotenv"
|
|
|
|
_ "github.com/lib/pq"
|
2021-06-24 02:19:43 +00:00
|
|
|
|
2021-07-05 23:22:24 +00:00
|
|
|
"github.com/christianselig/apollo-backend/internal/data"
|
|
|
|
"github.com/christianselig/apollo-backend/internal/reddit"
|
2021-05-10 00:51:15 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type config struct {
|
|
|
|
port int
|
|
|
|
}
|
|
|
|
|
|
|
|
type application struct {
|
2021-06-24 02:19:43 +00:00
|
|
|
cfg config
|
|
|
|
logger *log.Logger
|
|
|
|
db *sql.DB
|
|
|
|
models *data.Models
|
|
|
|
client *reddit.Client
|
2021-05-10 00:51:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
err := godotenv.Load()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal("Error loading .env file")
|
|
|
|
}
|
|
|
|
|
|
|
|
var cfg config
|
|
|
|
flag.IntVar(&cfg.port, "port", 4000, "API server port")
|
|
|
|
flag.Parse()
|
|
|
|
|
|
|
|
logger := log.New(os.Stdout, "", log.Ldate|log.Ltime)
|
|
|
|
|
|
|
|
db, err := sql.Open("postgres", os.Getenv("DATABASE_URL"))
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
defer db.Close()
|
|
|
|
|
|
|
|
rc := reddit.NewClient(os.Getenv("REDDIT_CLIENT_ID"), os.Getenv("REDDIT_CLIENT_SECRET"))
|
|
|
|
|
|
|
|
app := &application{
|
|
|
|
cfg,
|
|
|
|
logger,
|
|
|
|
db,
|
|
|
|
data.NewModels(db),
|
|
|
|
rc,
|
|
|
|
}
|
|
|
|
|
|
|
|
srv := &http.Server{
|
|
|
|
Addr: fmt.Sprintf(":%d", cfg.port),
|
|
|
|
Handler: app.routes(),
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.Printf("starting server on %s", srv.Addr)
|
|
|
|
err = srv.ListenAndServe()
|
|
|
|
logger.Fatal(err)
|
|
|
|
}
|