udemy-go-microservices/logger-service/cmd/api/main.go

82 lines
1.4 KiB
Go
Raw Normal View History

package main
import (
"context"
2024-08-29 11:24:36 +00:00
"fmt"
"log"
2024-08-29 11:24:36 +00:00
"logger/data"
"net/http"
2024-08-28 21:09:26 +00:00
"time"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
)
const (
webPort = "80"
rpcPort = "5001"
mongoURL = "mongodb://mongo:27017"
gRpcPort = "50001"
)
var client *mongo.Client
2024-08-29 11:24:36 +00:00
type Config struct {
Models data.Models
}
func main() {
// connect to mongo
mongoClient, err := connectToMongo()
if err != nil {
log.Panic(err)
}
2024-08-28 21:09:26 +00:00
// create a context in order to disconnect
ctx, cancel := context.WithTimeout(context.Background(), 15*time.Second)
defer cancel()
// close connection
defer func() {
2024-08-28 21:09:26 +00:00
if err = mongoClient.Disconnect(ctx); err != nil {
panic(err)
}
}()
2024-08-29 11:24:36 +00:00
app := Config{
Models: data.New(client),
}
// start web server
2024-08-29 11:48:47 +00:00
log.Println("Starting service on port", webPort)
app.serve()
2024-08-29 11:24:36 +00:00
}
func (app *Config) serve() {
srv := &http.Server{
Addr: fmt.Sprintf(":%s", webPort),
Handler: app.routes(),
}
err := srv.ListenAndServe()
if err != nil {
log.Panic(err)
}
}
func connectToMongo() (*mongo.Client, error) {
clientOptions := options.Client().ApplyURI(mongoURL)
clientOptions.SetAuth(options.Credential{
Username: "admin",
Password: "password",
})
client, err := mongo.Connect(context.TODO(), clientOptions)
if err != nil {
log.Println("Error connecting:", err)
return nil, err
}
2024-08-29 11:48:47 +00:00
log.Println("Connected to Mongo")
return client, nil
}