при запросах с клиента:
ctx = metadata.NewOutgoingContext(ctx, metadata.Pairs("Authorization", c.jwtTokenStr))
c.jwtTokenStr точно является валидным токеном
ctx точно используется для запроса со стороны клиента
на серврее обратаывает interceptor и всегда выдает одну и ту же ошибку:
rpc error: code = Unauthenticated desc = missing token
код обработки в interceptor:
md, ok := metadata.FromIncomingContext(ctx)
if !ok {
return nil, status.Error(codes.Unauthenticated, "missing metadata")
}
tokenMeta, ok := md["Authorization"]
if !ok || len(tokenMeta) == 0 {
return nil, status.Error(codes.Unauthenticated, "missing token")
}
в чем может быть проблема?
WithPerRPCCredentials ? upd: плюс посмотреть дебаггером на тему регистра в заголовках
не использовал, это что?
Это одна из опций в grpc запросе. Метод клиента имеет третий параметр типа ...opts и плюс апдейт в исходном сообщении на тему регистра в метаданных.
я так понял это нужно обновлять сам клиент, а не просто добавлять в контекст метаданные? а с контекстом все же что у меня может быть не так?
регистр ключа метаданных
ааа, точно, помню были проблемы из-за того что не кастумный тип используется в ключе хранилища у контекста
Обсуждают сегодня