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

io.deephaven.proto.flight.util.FlightExportTicketHelper Maven / Gradle / Ivy

//
// Copyright (c) 2016-2024 Deephaven Data Labs and Patent Pending
//
package io.deephaven.proto.flight.util;

import com.google.protobuf.ByteStringAccess;
import com.google.rpc.Code;
import io.deephaven.proto.backplane.grpc.Ticket;
import io.deephaven.proto.util.Exceptions;
import io.deephaven.proto.util.ExportTicketHelper;
import org.apache.arrow.flight.impl.Flight;

import java.nio.ByteOrder;

public class FlightExportTicketHelper {
    /**
     * Convenience method to convert from export id to {@link Flight.Ticket}.
     *
     * @param exportId the export id
     * @return a grpc Ticket wrapping the export id
     */
    public static Flight.Ticket exportIdToFlightTicket(int exportId) {
        final byte[] dest = ExportTicketHelper.exportIdToBytes(exportId);
        return Flight.Ticket.newBuilder().setTicket(ByteStringAccess.wrap(dest)).build();
    }

    /**
     * Convenience method to convert from export id to {@link Flight.FlightDescriptor}.
     *
     * @param exportId the export id
     * @return a grpc Ticket wrapping the export id
     */
    public static Flight.FlightDescriptor exportIdToDescriptor(int exportId) {
        return Flight.FlightDescriptor.newBuilder()
                .setType(Flight.FlightDescriptor.DescriptorType.PATH)
                .addAllPath(ExportTicketHelper.exportIdToPath(exportId))
                .build();
    }

    /**
     * Convenience method to convert from {@link Flight.Ticket} to export id.
     *
     * 

* Ticket's byte[0] must be {@link ExportTicketHelper#TICKET_PREFIX}, bytes[1-4] are a signed int export id in * little-endian. * * @param ticket the grpc Ticket * @param logId an end-user friendly identification of the ticket should an error occur * @return the export id that the Ticket wraps */ public static int ticketToExportId(final Flight.Ticket ticket, final String logId) { return ExportTicketHelper.ticketToExportIdInternal( ticket.getTicket().asReadOnlyByteBuffer().order(ByteOrder.LITTLE_ENDIAN), logId); } /** * Convenience method to convert from {@link Flight.FlightDescriptor} to export id. * *

* Descriptor must be a path. * * @param descriptor the grpc Ticket * @param logId an end-user friendly identification of the ticket should an error occur * @return the export id that the Ticket wraps */ public static int descriptorToExportId(final Flight.FlightDescriptor descriptor, final String logId) { if (descriptor == null) { throw Exceptions.statusRuntimeException(Code.FAILED_PRECONDITION, "Could not resolve descriptor '" + logId + "': is empty"); } if (descriptor.getType() != Flight.FlightDescriptor.DescriptorType.PATH) { throw Exceptions.statusRuntimeException(Code.FAILED_PRECONDITION, "Could not resolve descriptor '" + logId + "': not a path"); } if (descriptor.getPathCount() != 2) { throw Exceptions.statusRuntimeException(Code.FAILED_PRECONDITION, "Could not resolve descriptor '" + logId + "': unexpected path length (found: " + TicketRouterHelper.getLogNameFor(descriptor) + ", expected: 2)"); } try { return Integer.parseInt(descriptor.getPath(1)); } catch (final NumberFormatException nfe) { throw Exceptions.statusRuntimeException(Code.FAILED_PRECONDITION, "Could not resolve descriptor '" + logId + "': export id not numeric (found: " + TicketRouterHelper.getLogNameFor(descriptor) + ")"); } } /** * Convenience method to convert from a Flight.Ticket to a Flight.FlightDescriptor. * * @param ticket the ticket to convert * @param logId an end-user friendly identification of the ticket should an error occur * @return a flight descriptor that represents the ticket */ public static Flight.FlightDescriptor ticketToDescriptor(final Ticket ticket, final String logId) { return exportIdToDescriptor(ExportTicketHelper.ticketToExportId(ticket, logId)); } /** * Convenience method to convert from a Flight.Ticket to a Flight.FlightDescriptor. * * @param ticket the ticket to convert * @param logId an end-user friendly identification of the ticket should an error occur * @return a flight descriptor that represents the ticket */ public static Flight.FlightDescriptor ticketToDescriptor(final Flight.Ticket ticket, final String logId) { return exportIdToDescriptor(ticketToExportId(ticket, logId)); } /** * Convenience method to convert from a Flight.Descriptor to a Flight.Ticket. * * @param descriptor the descriptor to convert * @param logId an end-user friendly identification of the ticket should an error occur * @return a flight ticket that represents the descriptor */ public static Flight.Ticket descriptorToFlightTicket(final Flight.FlightDescriptor descriptor, final String logId) { return exportIdToFlightTicket(descriptorToExportId(descriptor, logId)); } /** * Convenience method to convert from a Flight.Descriptor to a Flight.Ticket. * * @param descriptor the descriptor to convert * @param logId an end-user friendly identification of the ticket should an error occur * @return a flight ticket that represents the descriptor */ public static Ticket descriptorToTicket(final Flight.FlightDescriptor descriptor, final String logId) { return ExportTicketHelper.wrapExportIdInTicket(descriptorToExportId(descriptor, logId)); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy