tech.ydb.core.grpc.GrpcStatuses Maven / Gradle / Ivy
package tech.ydb.core.grpc;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import tech.ydb.core.Issue;
import tech.ydb.core.Result;
import tech.ydb.core.Status;
import tech.ydb.core.StatusCode;
/**
* @author Sergey Polovko
*/
public final class GrpcStatuses {
private static final Logger logger = LoggerFactory.getLogger(GrpcStatuses.class);
private GrpcStatuses() { }
public static Result toResult(io.grpc.Status status) {
assert !status.isOk();
return Result.fail(toStatus(status));
}
public static tech.ydb.core.Status toStatus(io.grpc.Status status) {
if (status.isOk()) {
return Status.SUCCESS;
}
Issue message = Issue.of(getMessage(status), Issue.Severity.ERROR);
StatusCode code = getStatusCode(status.getCode());
Throwable cause = status.getCause();
if (cause == null) {
return Status.of(code, cause, message);
}
return Status.of(code, cause, message, Issue.of(cause.toString(), Issue.Severity.ERROR));
}
private static String getMessage(io.grpc.Status status) {
if (status.getCode() == io.grpc.Status.Code.CANCELLED) {
logger.debug("gRPC cancellation: {}, {}", status.getCode(), status.getDescription());
} else {
logger.warn("gRPC issue: {}, {}", status.getCode(), status.getDescription());
}
String message = "gRPC error: (" + status.getCode() + ')';
return status.getDescription() == null
? message
: message + ' ' + status.getDescription();
}
private static StatusCode getStatusCode(io.grpc.Status.Code code) {
switch (code) {
case UNAVAILABLE: return StatusCode.TRANSPORT_UNAVAILABLE;
case UNAUTHENTICATED: return StatusCode.CLIENT_UNAUTHENTICATED;
case CANCELLED: return StatusCode.CLIENT_CANCELLED;
case UNIMPLEMENTED: return StatusCode.CLIENT_CALL_UNIMPLEMENTED;
case DEADLINE_EXCEEDED: return StatusCode.CLIENT_DEADLINE_EXCEEDED;
case RESOURCE_EXHAUSTED: return StatusCode.CLIENT_RESOURCE_EXHAUSTED;
default:
return StatusCode.CLIENT_GRPC_ERROR;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy