From 298593b9810da7462d93cdf45c5332bc255e72fb Mon Sep 17 00:00:00 2001 From: leofvo Date: Thu, 24 Oct 2024 14:37:22 +0200 Subject: [PATCH] refactor(server.go): improve code lisibility factorize repetitive blocks verify http method on openapi request --- internal/servers/server.go | 29 ++++++++++++++++------------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/internal/servers/server.go b/internal/servers/server.go index 7f99f6a53..199b7d597 100644 --- a/internal/servers/server.go +++ b/internal/servers/server.go @@ -308,20 +308,18 @@ func (s *Container) Run( // Create the gRPC gateway mux grpcMux := runtime.NewServeMux(muxOpts...) - if err = grpcV1.RegisterPermissionHandler(ctx, grpcMux, conn); err != nil { - return err - } - if err = grpcV1.RegisterSchemaHandler(ctx, grpcMux, conn); err != nil { - return err - } - if err = grpcV1.RegisterDataHandler(ctx, grpcMux, conn); err != nil { - return err + handlers := []func(context.Context, *runtime.ServeMux, *grpc.ClientConn) error{ + grpcV1.RegisterPermissionHandler, + grpcV1.RegisterSchemaHandler, + grpcV1.RegisterDataHandler, + grpcV1.RegisterBundleHandler, + grpcV1.RegisterTenancyHandler, } - if err = grpcV1.RegisterBundleHandler(ctx, grpcMux, conn); err != nil { - return err - } - if err = grpcV1.RegisterTenancyHandler(ctx, grpcMux, conn); err != nil { - return err + + for _, handler := range handlers { + if err = handler(ctx, grpcMux, conn); err != nil { + return fmt.Errorf("failed to register handler: %w", err) + } } // Create a new http.ServeMux for serving your OpenAPI file and gRPC gateway @@ -329,6 +327,11 @@ func (s *Container) Run( if srv.HTTP.ExposeOpenAPI { httpMux.HandleFunc("/openapi.json", func(w http.ResponseWriter, r *http.Request) { + if r.Method != http.MethodGet { + http.Error(w, "Method not allowed", http.StatusMethodNotAllowed) + return + } + w.Header().Set("Content-Type", "application/json") http.ServeFile(w, r, "./docs/api-reference/openapi.json") }) }