All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.rocketmq.shaded.io.opentelemetry.exporter.internal.grpc.GrpcStatusUtil Maven / Gradle / Ivy

There is a newer version: 5.0.7
Show newest version
/*
 * Copyright The OpenTelemetry Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package org.apache.rocketmq.shaded.io.opentelemetry.exporter.internal.grpc;

import org.apache.rocketmq.shaded.io.opentelemetry.exporter.internal.marshal.CodedInputStream;
import java.io.IOException;

/**
 * Utilities for working with gRPC status without requiring dependencies on gRPC.
 *
 * 

This class is internal and is hence not for public use. Its APIs are unstable and can change * at any time. */ public final class GrpcStatusUtil { public static final String GRPC_STATUS_CANCELLED = "1"; public static final String GRPC_STATUS_DEADLINE_EXCEEDED = "4"; public static final String GRPC_STATUS_RESOURCE_EXHAUSTED = "8"; public static final String GRPC_STATUS_ABORTED = "10"; public static final String GRPC_STATUS_OUT_OF_RANGE = "11"; public static final String GRPC_STATUS_UNIMPLEMENTED = "12"; public static final String GRPC_STATUS_UNAVAILABLE = "14"; public static final String GRPC_STATUS_DATA_LOSS = "15"; /** Parses the message out of a serialized gRPC Status. */ public static String getStatusMessage(byte[] serializedStatus) throws IOException { CodedInputStream input = CodedInputStream.newInstance(serializedStatus); boolean done = false; while (!done) { int tag = input.readTag(); switch (tag) { case 0: done = true; break; case 18: return input.readStringRequireUtf8(); default: input.skipField(tag); break; } } // Serialized Status proto had no message, proto always defaults to empty string when not found. return ""; } private GrpcStatusUtil() {} }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy