Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

microservices added #45

Merged
merged 41 commits into from
Nov 25, 2024
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
4d58183
added grpc to delivery for trips
mevain Nov 17, 2024
631b890
microservices added
timurIsaevIY Nov 21, 2024
bc14748
changed main
mevain Nov 21, 2024
b9aeab2
added trips grpc
mevain Nov 21, 2024
d9bab01
attractions service fixed
timurIsaevIY Nov 22, 2024
fbcdfee
userService
AnnHarvard Nov 21, 2024
fb666d0
gRPC for users
AnnHarvard Nov 22, 2024
bb09bd4
fixing
AnnHarvard Nov 22, 2024
72eb9d9
added auth routes
AnnHarvard Nov 22, 2024
d17c765
services fixed
timurIsaevIY Nov 22, 2024
e5d363b
returned token in cookie
AnnHarvard Nov 22, 2024
87bc563
fixed login and search
mevain Nov 23, 2024
e3a29c8
scheme changed
timurIsaevIY Nov 23, 2024
b00809d
made structure for survey's microservice
AnnHarvard Nov 23, 2024
6414574
fixed names
AnnHarvard Nov 23, 2024
7e7470f
added image path to searh response
mevain Nov 23, 2024
c24a329
fix
AnnHarvard Nov 23, 2024
132e421
fixed getPlace
mevain Nov 23, 2024
1e92184
proto added
timurIsaevIY Nov 23, 2024
38f4472
Merge remote-tracking branch 'origin/gRPC_places' into gRPC_places
timurIsaevIY Nov 23, 2024
1d5087e
http handler for surveys
AnnHarvard Nov 23, 2024
aad18ca
made http handlers for surveys
AnnHarvard Nov 23, 2024
a2de459
grpc server added
timurIsaevIY Nov 23, 2024
e2426ae
started repo
mevain Nov 23, 2024
076fbb6
started usecase for surveys
AnnHarvard Nov 23, 2024
755403e
finished repo
mevain Nov 23, 2024
99c07c0
made usecase for surveys
AnnHarvard Nov 23, 2024
6e0349e
grpc server added
timurIsaevIY Nov 23, 2024
dc98722
SCHEME BD CHANGE
timurIsaevIY Nov 23, 2024
b799ac4
SCHEME BD CHANGE
timurIsaevIY Nov 23, 2024
58d7b39
SCHEME BD CHANGE
timurIsaevIY Nov 23, 2024
19b6ebd
fixed mistakes with error handling
AnnHarvard Nov 23, 2024
5bb15b3
ne znay
timurIsaevIY Nov 23, 2024
2db430f
ne znay
timurIsaevIY Nov 23, 2024
6c09e5d
ne znay
timurIsaevIY Nov 23, 2024
58704d5
ne znay
timurIsaevIY Nov 23, 2024
300f54d
fixed authorization
mevain Nov 24, 2024
b3d2e89
fixed trip queries
mevain Nov 24, 2024
d30eaf8
added field description to db
AnnHarvard Nov 23, 2024
0481bc5
added global search to microservices
AnnHarvard Nov 24, 2024
f819b4b
fixed deleting review
AnnHarvard Nov 25, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions cmd/attractions/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
FROM golang:1.23.1-alpine AS builder
COPY . /github.com/go-park-mail-ru/2024_2_ThereWillBeName/attractions
WORKDIR /github.com/go-park-mail-ru/2024_2_ThereWillBeName/attractions
RUN go mod download
RUN go clean --modcache
RUN CGO_ENABLED=0 GOOS=linux go build -mod=readonly -o ./.bin ./cmd/attractions/main.go
FROM scratch AS runner
WORKDIR /build
COPY --from=builder /github.com/go-park-mail-ru/2024_2_ThereWillBeName/attractions/.bin .
EXPOSE 50051
ENTRYPOINT ["./.bin"]
71 changes: 71 additions & 0 deletions cmd/attractions/main.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
package main

import (
"2024_2_ThereWillBeName/internal/models"
grpcAttractions "2024_2_ThereWillBeName/internal/pkg/attractions/delivery/grpc"
"2024_2_ThereWillBeName/internal/pkg/attractions/delivery/grpc/gen"
placeRepo "2024_2_ThereWillBeName/internal/pkg/attractions/repo"
placeUsecase "2024_2_ThereWillBeName/internal/pkg/attractions/usecase"
categoriesRepo "2024_2_ThereWillBeName/internal/pkg/categories/repo"
categoriesUsecase "2024_2_ThereWillBeName/internal/pkg/categories/usecase"
citiesRepo "2024_2_ThereWillBeName/internal/pkg/cities/repo"
citiesUsecase "2024_2_ThereWillBeName/internal/pkg/cities/usecase"
reviewRepo "2024_2_ThereWillBeName/internal/pkg/reviews/repo"
reviewUsecase "2024_2_ThereWillBeName/internal/pkg/reviews/usecase"
"database/sql"
"flag"
"fmt"
"google.golang.org/grpc"
"google.golang.org/grpc/reflection"
"log"
"net"
"os"
"os/signal"
"syscall"
)

func main() {
var cfg models.ConfigGrpc
flag.IntVar(&cfg.Port, "grpc-port", 50051, "gRPC server port")
flag.StringVar(&cfg.ConnStr, "connStr", "host=tripdb port=5432 user=service password=test dbname=trip sslmode=disable", "PostgreSQL connection string")
flag.Parse()

db, err := sql.Open("postgres", cfg.ConnStr)
if err != nil {
log.Fatalf("failed to connect to database: %v", err)
}
defer db.Close()

reviewsRepo := reviewRepo.NewReviewRepository(db)
reviewUsecase := reviewUsecase.NewReviewsUsecase(reviewsRepo)
placeRepo := placeRepo.NewPLaceRepository(db)
placeUsecase := placeUsecase.NewPlaceUsecase(placeRepo)
citiesRepo := citiesRepo.NewCitiesRepository(db)
citiesUsecase := citiesUsecase.NewCitiesUsecase(citiesRepo)
categoriesRepo := categoriesRepo.NewCategoriesRepo(db)
categoriesUsecase := categoriesUsecase.NewCategoriesUsecase(categoriesRepo)

grpcAttractionsServer := grpc.NewServer()
attractionsHandler := grpcAttractions.NewGrpcAttractionsHandler(placeUsecase, citiesUsecase, reviewUsecase, categoriesUsecase)
gen.RegisterAttractionsServer(grpcAttractionsServer, attractionsHandler)
reflection.Register(grpcAttractionsServer)

go func() {
listener, err := net.Listen("tcp", fmt.Sprintf(":%d", cfg.Port))
if err != nil {
log.Fatalf("failed to listen: %v", err)
}
log.Printf("gRPC server listening on :%d", cfg.Port)
if err := grpcAttractionsServer.Serve(listener); err != nil {
log.Fatalf("failed to serve gRPC: %v", err)
}
}()

stop := make(chan os.Signal, 1)
signal.Notify(stop, os.Interrupt, syscall.SIGINT, syscall.SIGTERM)
<-stop

log.Println("Shutting down gRPC server...")
grpcAttractionsServer.GracefulStop()
log.Println("gRPC server gracefully stopped")
}
11 changes: 11 additions & 0 deletions cmd/gateway/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
FROM golang:1.23.1-alpine AS builder
COPY . /github.com/go-park-mail-ru/2024_2_ThereWillBeName/gateway
WORKDIR /github.com/go-park-mail-ru/2024_2_ThereWillBeName/gateway
RUN go mod download
RUN go clean --modcache
RUN CGO_ENABLED=0 GOOS=linux go build -mod=readonly -o ./.bin ./cmd/gateway/main.go
FROM scratch AS runner
WORKDIR /build
COPY --from=builder /github.com/go-park-mail-ru/2024_2_ThereWillBeName/gateway/.bin .
EXPOSE 8080
ENTRYPOINT ["./.bin"]
173 changes: 173 additions & 0 deletions cmd/gateway/main.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,173 @@
package main

import (
"2024_2_ThereWillBeName/internal/models"
genAttractions "2024_2_ThereWillBeName/internal/pkg/attractions/delivery/grpc/gen"
httpPlaces "2024_2_ThereWillBeName/internal/pkg/attractions/delivery/http"
httpCategories "2024_2_ThereWillBeName/internal/pkg/categories/delivery/http"
httpCities "2024_2_ThereWillBeName/internal/pkg/cities/delivery/http"
"2024_2_ThereWillBeName/internal/pkg/httpresponses"
httpresponse "2024_2_ThereWillBeName/internal/pkg/httpresponses"
"2024_2_ThereWillBeName/internal/pkg/jwt"
"2024_2_ThereWillBeName/internal/pkg/logger"
"2024_2_ThereWillBeName/internal/pkg/middleware"
httpReviews "2024_2_ThereWillBeName/internal/pkg/reviews/delivery/http"
genTrips "2024_2_ThereWillBeName/internal/pkg/trips/delivery/grpc/gen"
httpTrips "2024_2_ThereWillBeName/internal/pkg/trips/delivery/http"
httpUsers "2024_2_ThereWillBeName/internal/pkg/user/delivery/http"
"context"
"errors"
"flag"
"fmt"
"github.com/gorilla/mux"
"google.golang.org/grpc"
"google.golang.org/grpc/credentials/insecure"
"log"
"log/slog"
"net/http"
"os"
"os/signal"
"strconv"
"syscall"
)

func main() {
var cfg models.Config
flag.IntVar(&cfg.Port, "port", 8080, "API server port")
flag.StringVar(&cfg.Env, "env", "production", "Environment")
flag.StringVar(&cfg.AllowedOrigin, "allowed-origin", "*", "Allowed origin")
flag.Parse()

logger := setupLogger()

jwtSecret := os.Getenv("JWT_SECRET")
jwtHandler := jwt.NewJWT(jwtSecret, logger)

attractionsConn, err := grpc.NewClient("localhost:50051", grpc.WithTransportCredentials(insecure.NewCredentials()))
if err != nil {
log.Fatalf("did not connect to attractions service: %v", err)
}
defer attractionsConn.Close()
attractionsClient := genAttractions.NewAttractionsClient(attractionsConn)

usersConn, err := grpc.NewClient("localhost:50052", grpc.WithTransportCredentials(insecure.NewCredentials()))
if err != nil {
log.Fatalf("did not connect to users service: %v", err)
}
defer usersConn.Close()
usersClient := gen.NewUsersClient(usersConn)

Check failure on line 58 in cmd/gateway/main.go

View workflow job for this annotation

GitHub Actions / linters

undefined: gen

tripsConn, err := grpc.NewClient("localhost:50053", grpc.WithTransportCredentials(insecure.NewCredentials()))
if err != nil {
log.Fatalf("did not connect to trips service: %v", err)
}
defer tripsConn.Close()
tripsClient := genTrips.NewTripsClient(tripsConn)

// Инициализация HTTP сервера
corsMiddleware := middleware.NewCORSMiddleware([]string{cfg.AllowedOrigin})
r := mux.NewRouter().PathPrefix("/api/v1").Subrouter()
r.Use(corsMiddleware.CorsMiddleware)

// Обработка ненайденных маршрутов
r.NotFoundHandler = http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
response := httpresponses.ErrorResponse{
Message: "Not found",
}
httpresponses.SendJSONResponse(w, response, http.StatusNotFound, logger)
})

// Маршрут для healthcheck
r.HandleFunc("/healthcheck", healthcheckHandler).Methods(http.MethodGet)

// Маршруты для attractions
placesHandler := httpPlaces.NewPlacesHandler(attractionsClient, logger)
places := r.PathPrefix("/places").Subrouter()
places.HandleFunc("", placesHandler.GetPlacesHandler).Methods(http.MethodGet)
places.HandleFunc("/search/{placeName}", placesHandler.SearchPlacesHandler).Methods(http.MethodGet)
places.HandleFunc("/{id}", placesHandler.GetPlaceHandler).Methods(http.MethodGet)
places.HandleFunc("/category/{categoryName}", placesHandler.GetPlacesByCategoryHandler).Methods(http.MethodGet)

categoriesHandler := httpCategories.NewCategoriesHandler(attractionsClient, logger)
categories := r.PathPrefix("/categories").Subrouter()
categories.HandleFunc("", categoriesHandler.GetCategoriesHandler).Methods(http.MethodGet)

reviewsHandler := httpReviews.NewReviewHandler(attractionsClient, logger)
reviews := places.PathPrefix("/{placeID}/reviews").Subrouter()
reviews.Handle("", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(reviewsHandler.CreateReviewHandler), logger)).Methods(http.MethodPost)
reviews.Handle("/reviewID", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(reviewsHandler.UpdateReviewHandler), logger)).Methods(http.MethodPut)
reviews.Handle("/reviewID", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(reviewsHandler.DeleteReviewHandler), logger)).Methods(http.MethodDelete)
reviews.HandleFunc("/{reviewID}", reviewsHandler.GetReviewHandler).Methods(http.MethodGet)
reviews.HandleFunc("", reviewsHandler.GetReviewsByPlaceIDHandler).Methods(http.MethodGet)

citiesHandler := httpCities.NewCitiesHandler(attractionsClient, logger)
cities := r.PathPrefix("/cities").Subrouter()
cities.HandleFunc("/search", citiesHandler.SearchCitiesByNameHandler).Methods(http.MethodGet)
cities.HandleFunc("/{id}", citiesHandler.SearchCityByIDHandler).Methods(http.MethodGet)

usersHandler := httpUsers.NewUsersHandler(usersClient, logger)

Check failure on line 108 in cmd/gateway/main.go

View workflow job for this annotation

GitHub Actions / linters

undefined: httpUsers.NewUsersHandler
users := r.PathPrefix("/users").Subrouter()
users.HandleFunc("", usersHandler.GetUsersHandler).Methods(http.MethodGet)
users.HandleFunc("/{id}", usersHandler.GetUserHandler).Methods(http.MethodGet)

tripsHandler := httpTrips.NewTripHandler(tripsClient, logger)
trips := r.PathPrefix("/trips").Subrouter()
trips.HandleFunc("/{id}", tripsHandler.GetTripHandler).Methods(http.MethodGet)
trips.Handle("", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(tripsHandler.CreateTripHandler), logger)).Methods(http.MethodPost)
trips.Handle("/{id}", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(tripsHandler.UpdateTripHandler), logger)).Methods(http.MethodPut)
trips.Handle("/{id}", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(tripsHandler.DeleteTripHandler), logger)).Methods(http.MethodDelete)
trips.Handle("/{id}", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(tripsHandler.AddPlaceToTripHandler), logger)).Methods(http.MethodPost)
user.Handle("/trips", middleware.MiddlewareAuth(jwtHandler, http.HandlerFunc(tripsHandler.GetTripsByUserIDHandler), logger)).Methods(http.MethodGet)

Check failure on line 120 in cmd/gateway/main.go

View workflow job for this annotation

GitHub Actions / linters

undefined: user (typecheck)

httpSrv := &http.Server{Handler: r, Addr: fmt.Sprintf(":%d", cfg.Port)}
go func() {
logger.Info("HTTP server listening on :%d", cfg.Port)
if err := httpSrv.ListenAndServe(); err != nil && !errors.Is(err, http.ErrServerClosed) {
logger.Error("failed to serve HTTP: %v", err)
os.Exit(1)
}
}()

stop := make(chan os.Signal, 1)
signal.Notify(stop, os.Interrupt, syscall.SIGINT, syscall.SIGTERM)
<-stop

logger.Info("Shutting down HTTP server...")
if err := httpSrv.Shutdown(context.Background()); err != nil {
logger.Error("HTTP server shutdown failed: %v", err)
os.Exit(1)
}
logger.Info("HTTP server gracefully stopped")
}

func healthcheckHandler(w http.ResponseWriter, r *http.Request) {
logger := setupLogger()

_, err := fmt.Fprintf(w, "STATUS: OK")
if err != nil {
logger.Error("Failed to write healthcheck response", slog.Any("error", err))
response := httpresponse.ErrorResponse{
Message: "Invalid request",
}
httpresponse.SendJSONResponse(w, response, http.StatusBadRequest, logger)
}
}

func setupLogger() *slog.Logger {

levelEnv := os.Getenv("LOG_LEVEL")
logLevel := slog.LevelDebug
if level, err := strconv.Atoi(levelEnv); err == nil {
logLevel = slog.Level(level)
}

opts := logger.PrettyHandlerOptions{
SlogOpts: slog.HandlerOptions{
Level: logLevel,
},
}

handler := logger.NewPrettyHandler(os.Stdout, opts)

return slog.New(handler)
}
Loading
Loading