Skip to content

Commit

Permalink
[OGE-5650] Return not found status code when db returns not found
Browse files Browse the repository at this point in the history
  • Loading branch information
goncalo-rodrigues committed Nov 2, 2023
1 parent 2a68324 commit f933db8
Showing 1 changed file with 20 additions and 1 deletion.
21 changes: 20 additions & 1 deletion app.go
Original file line number Diff line number Diff line change
Expand Up @@ -610,7 +610,15 @@ func (h *Headscale) Serve() error {
}

// Start the local gRPC server without TLS and without authentication
grpcSocket := grpc.NewServer(zerolog.UnaryInterceptor())
grpcOptions := []grpc.ServerOption{
grpc.UnaryInterceptor(
grpcMiddleware.ChainUnaryServer(
serverErrorInterceptor,
zerolog.NewUnaryServerInterceptor(),
),
),
}
grpcSocket := grpc.NewServer(grpcOptions...)

v1.RegisterHeadscaleServiceServer(grpcSocket, newHeadscaleV1APIServer(h))
reflection.Register(grpcSocket)
Expand Down Expand Up @@ -650,6 +658,7 @@ func (h *Headscale) Serve() error {
grpc.UnaryInterceptor(
grpcMiddleware.ChainUnaryServer(
h.grpcAuthenticationInterceptor,
serverErrorInterceptor,
zerolog.NewUnaryServerInterceptor(),
),
),
Expand Down Expand Up @@ -991,3 +1000,13 @@ func readOrCreatePrivateKey(path string) (*key.MachinePrivate, error) {

return &machineKey, nil
}

func serverErrorInterceptor(ctx context.Context, req any, _ *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (any, error) {
resp, err := handler(ctx, req)

if errors.Is(err, gorm.ErrRecordNotFound) {
return resp, status.Error(codes.NotFound, err.Error())
}

return resp, err
}

0 comments on commit f933db8

Please sign in to comment.