-
Notifications
You must be signed in to change notification settings - Fork 572
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
Global request interceptor #2769
Comments
Ended up with the following code: suspend fun <S : Any, R : Any> GrpcCall<S, R>.executeAuthenticated(authTokenHolder: AuthTokenHolder, request: S): R {
val token = authTokenHolder.getAuthToken() ?: return execute(request)
requestMetadata += AUTH_HEADER to token
return try {
execute(request)
} catch (e: GrpcException) {
if (e.grpcStatus == GrpcStatus.UNAUTHENTICATED) {
authTokenHolder.invalidate(token)
}
throw e
}
}
There are two drawbacks with this solution:
|
+1, would be great to have ClientInterceptor API for things like logging. |
That feels sad to do that if OkHttp already does it (very well) |
However, it's done in a different level/layer which causes some inconvenience. For example, if you would want to log every request or response in OkHttp's interceptor the data would be decoded twice - once in the interceptor and once in the Wire's code. As mentioned above, you need to know gRPC protocol implementation details in order to handle the status codes while intercepting HTTP requests. |
Would it be possible to expose some internal methods to facilitate response parsing in OkHttp interceptor? I'm primarily interested in |
A more concrete issue with using OkHttp's interceptor is that the trailers might not be available at the point when an interceptor is invoked. |
Would opening |
Yes. It would be good to mention in the documentation that the response has to be consumed prior to calling This is how I handle gRPC status codes now:
|
I couldn't find a way in Wire to intercept all the requests and handle their responses. Without that implementing things like authentication is much harder.
The way it works in
io.grpc
is that you implement and add aio.grpc.ClientInterceptor
when creating aio.grpc.Channel
. For example, the code authenticating requests might look like this (note that the existing auth token is invalidated on receivingStatus.UNAUTHENTICATED
from the server):However, it's hard to do the same in Wire as there is no single point of request handling.
Here it was suggested to add an
OkHttpClient
interceptor and set the HTTP headers instead which IMO is not correct as it's a wrong application layer (HTTP vs gRPC). Moreover, it's hard to detect authentication errors as gRPC has its own status codes and always returns HTTP status code200
(even if the request couldn't be authenticated according to gRPC, for example). This of course could be worked around by checking thegrpc-status
header but it doesn't look clean to me.Am I missing something? Or how are you supposed to implement authentication (or any other generic request handling) in Wire?
The text was updated successfully, but these errors were encountered: