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

org.apache.pekko.grpc.scaladsl.MetadataBuilder.scala Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * license agreements; and to You under the Apache License, version 2.0:
 *
 *   https://www.apache.org/licenses/LICENSE-2.0
 *
 * This file is part of the Apache Pekko project, which was derived from Akka.
 */

/*
 * Copyright (C) 2018-2021 Lightbend Inc. 
 */

package org.apache.pekko.grpc.scaladsl

import scala.collection.immutable
import org.apache.pekko
import pekko.annotation.{ ApiMayChange, DoNotInherit }
import pekko.http.scaladsl.model.HttpHeader
import pekko.util.ByteString
import pekko.grpc.internal.{ EntryMetadataImpl, HeaderMetadataImpl, MetadataImpl }

/**
 * This class provides an interface for constructing immutable Metadata instances.
 */
@DoNotInherit
@ApiMayChange
class MetadataBuilder {

  /**
   * The list of metadata entries, in reverse order of addition.
   */
  private var entries: List[(String, MetadataEntry)] = Nil

  /**
   * Adds a string entry. The key must not end in the "-bin" binary suffix.
   * @param key The entry key.
   * @param value The entry value.
   * @return The updated builder.
   */
  def addText(key: String, value: String): MetadataBuilder = {
    if (key.endsWith(MetadataImpl.BINARY_SUFFIX))
      throw new IllegalArgumentException(s"String header names must not end with '${MetadataImpl.BINARY_SUFFIX}'")
    addEntry(key, StringEntry(value))
  }

  /**
   * Adds a binary entry. The key must end in the "-bin" binary suffix.
   * @param key The entry key.
   * @param value The entry value.
   * @return The updated builder.
   */
  def addBinary(key: String, value: ByteString): MetadataBuilder = {
    if (!key.endsWith(MetadataImpl.BINARY_SUFFIX))
      throw new IllegalArgumentException(s"Binary header names must end with '${MetadataImpl.BINARY_SUFFIX}'")
    addEntry(key, BytesEntry(value))
  }

  /**
   * Builds the immutable metadata instance.
   * @return The instance.
   */
  def build(): Metadata = {
    // Reverse the entries list to put it back in order of addition.
    new EntryMetadataImpl(entries.reverse)
  }

  /**
   * Helper method that handles adding an entry to the collection.
   */
  private def addEntry(key: String, entry: MetadataEntry): MetadataBuilder = {
    entries = (key, entry) :: entries
    this
  }
}

object MetadataBuilder {

  /**
   * An empty Metadata instance, for use as a default.
   */
  val empty: Metadata = new EntryMetadataImpl(Nil)

  /**
   * Creates a Metadata instance from a sequence of HTTP headers.
   * @param headers The headers.
   * @return The new Metadata instance.
   */
  def fromHeaders(headers: immutable.Seq[HttpHeader]): Metadata =
    new HeaderMetadataImpl(headers)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy