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

org.flyte.jflyte.utils.ProtoWriter Maven / Gradle / Ivy

Go to download

Primarily used by jflyte, but can also be used to extend or build a jflyte alternative

There is a newer version: 0.4.60
Show newest version
/*
 * Copyright 2021-2023 Flyte Authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.flyte.jflyte.utils;

import flyteidl.core.DynamicJob;
import flyteidl.core.Errors;
import flyteidl.core.Literals;
import java.io.IOException;
import java.io.OutputStream;
import java.io.UncheckedIOException;
import java.nio.channels.Channels;
import java.nio.channels.WritableByteChannel;
import java.util.Map;
import org.flyte.api.v1.DynamicJobSpec;
import org.flyte.api.v1.Literal;
import org.flyte.jflyte.api.FileSystem;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/** ProtocolBuffer file writer helper. */
public class ProtoWriter {
  private static final String OUTPUTS_PB = "outputs.pb";
  private static final String FUTURES_PB = "futures.pb";
  private static final String ERROR_PB = "error.pb";
  private static final Logger LOG = LoggerFactory.getLogger(ProtoWriter.class);

  private final String outputPrefix;
  private final FileSystem outputFs;

  public ProtoWriter(String outputPrefix, FileSystem outputFs) {
    this.outputPrefix = outputPrefix;
    this.outputFs = outputFs;
  }

  interface Writer {
    void write(OutputStream os) throws IOException;
  }

  public void writeFutures(DynamicJobSpec dynamicJobSpec) {
    String outputUri = normalizeUri(outputPrefix, FUTURES_PB);

    writeTo(
        outputFs,
        outputUri,
        outputStream -> {
          DynamicJob.DynamicJobSpec proto = ProtoUtil.serialize(dynamicJobSpec);

          LOG.debug("writeFutures {}", proto);

          proto.writeTo(outputStream);
        });
  }

  public void writeOutputs(Map outputs) {
    String outputUri = normalizeUri(outputPrefix, OUTPUTS_PB);

    writeTo(
        outputFs,
        outputUri,
        outputStream -> {
          Literals.LiteralMap proto = ProtoUtil.serialize(outputs);

          LOG.debug("writeOutputs {}", proto);

          proto.writeTo(outputStream);
        });
  }

  public void writeError(Errors.ContainerError containerError) {
    String outputUri = normalizeUri(outputPrefix, ERROR_PB);

    writeTo(
        outputFs,
        outputUri,
        outputStream -> {
          Errors.ErrorDocument proto =
              Errors.ErrorDocument.newBuilder().setError(containerError).build();

          LOG.debug("writeError {}", proto);

          proto.writeTo(outputStream);
        });
  }

  private static void writeTo(FileSystem fs, String uri, Writer writer) {
    try (WritableByteChannel channel = fs.writer(uri);
        OutputStream os = Channels.newOutputStream(channel)) {
      writer.write(os);
    } catch (IOException e) {
      throw new UncheckedIOException(e);
    }
  }

  private static String normalizeUri(String prefix, String fileName) {
    String uri;
    if (prefix.endsWith("/")) {
      uri = prefix + fileName;
    } else {
      uri = prefix + "/" + fileName;
    }
    return uri;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy