Mjolnir is Namely's common Go packages. It contains packages for things like health checks, database utils, logging, etc.
The Logger returns an interceptor that will set a *logrus.Entry on the context.
The logger makes calls to your gRPC endpoints assuming they return a protobuf response or an error.
out, err := handler(ctx, req)
When building gRPC Services, sometimes you may want return user friendly protobuf error responses, and other times you may want to return generic internal errors (e.g. when your DB write fails).
If your proto Error is set up like:
message Error {
string key = 1;
string message = 2;
}
Then included in this repo is the ability to customize error responses to fit both conditions. Both KeyedErr and FieldErr can be passed around like standard errors because they implement the error interface.
For example, say you have a standard Get User endpoint. In an error condition you decide to return a friendly "user not found" message if the user doesn't exist, or otherwise a generic internal server error (your client doesn't need to know about internal errors!).
Then you can build your proto error response with something like:
var ErrUserNotFound = &KeyedErr{
ErrorKey: "not_found",
Message: "user not found",
}
&proto.Error{
Key: ErrUserNotFound.Key(),
Message: ErrUserNotFound.Error(),
},
And otherwise a generic response like:
var grpcError = data.NewFieldErr(
&logrus.Fields{
"error": err,
},
)