Skip to content

Commit

Permalink
cmd: avoid panic when starting with a bad config (#598)
Browse files Browse the repository at this point in the history
Previously, if you ran opa-envoy-plugin wiht a bad config like this:

    plugins:
      envoy_ext_authz_grpc:
        addr: "127.0.0.1:9090:"

You'd run into a panic:

```
{"err":"listen tcp: address 127.0.0.1:9090:: too many colons in address","level":"error","msg":"Unable to create listener.","time":"2024-09-25T10:48:55+02:00"}
{"addr":"127.0.0.1:9090:","dry-run":false,"enable-reflection":false,"level":"info","msg":"Starting gRPC server.","path":"envoy/authz/allow","query":"","time":"2024-09-25T10:48:55+02:00"}
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x20 pc=0xbc569ea]

goroutine 14 [running]:
google.golang.org/grpc.(*Server).Serve(0xc000544c00, {0x0, 0x0})
	/Users/stephan/Sources/open-policy-agent/opa-envoy-plugin/vendor/google.golang.org/grpc/server.go:863 +0x16a
github.com/open-policy-agent/opa-envoy-plugin/internal.(*envoyExtAuthzGrpcServer).listen(0xc0004fe690)
	/Users/stephan/Sources/open-policy-agent/opa-envoy-plugin/internal/internal.go:348 +0x630
created by github.com/open-policy-agent/opa-envoy-plugin/internal.(*envoyExtAuthzGrpcServer).Start in goroutine 1
	/Users/stephan/Sources/open-policy-agent/opa-envoy-plugin/internal/internal.go:284 +0xba
```

With this change, the behaviour is the same as for a bad url: the error is
logged, and the plugin fails to become ready.

I think it would be better to error out, but that would require some deeper
refactoring. At least now, we'll avoid the panic.

Signed-off-by: Stephan Renatus <stephan@styra.com>
  • Loading branch information
srenatus authored Sep 25, 2024
1 parent 35d872f commit df3f81c
Showing 1 changed file with 1 addition and 0 deletions.
1 change: 1 addition & 0 deletions internal/internal.go
Original file line number Diff line number Diff line change
Expand Up @@ -333,6 +333,7 @@ func (p *envoyExtAuthzGrpcServer) listen() {

if err != nil {
logger.WithFields(map[string]interface{}{"err": err}).Error("Unable to create listener.")
return
}

logger.WithFields(map[string]interface{}{
Expand Down

0 comments on commit df3f81c

Please sign in to comment.