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

caliban.reporting.SchemaReportingRef.scala Maven / Gradle / Ivy

package caliban.reporting

import caliban._
import zio._

import java.util.UUID

/**
 * @param bootId A randomly generated UUID that's unique for each instance of your edge server. Set this value on server startup (a given value should not persist across restarts).
 * @param graphRef Indicates which Apollo Studio graph and variant the server is reporting its schema to (e.g., my-graph-id@my-variant)
 * @param coreSchema The schema SDL of the graph to be reported.
 * @param renderSchema Render the schema for reporting.
 * @param platform The infrastructure environment that your edge server is running in (localhost, kubernetes/deployment, aws lambda, google cloud run, google cloud function, AWS ECS, etc.)
 * @param serverId An ID that's unique for each instance of your edge server. Unlike bootId, this value should persist across an instance's restarts. In a Kubernetes cluster, this might be the pod name, whereas the container can restart.
 * @param userVersion An arbitrary string you can set to distinguish data sent by different versions of your edge server. For example, this can be the SHA of the Git commit for your deployed server code. We plan to make this value visible in Apollo Studio.
 * @param runtimeVersion The runtime that your edge server is running, such as node 12.03.
 * @param libraryVersion The name and version of the server and/or reporting agent your edge server is using, such as apollo-server-2.8 or graphql-java-3.1.
 */
case class SchemaReportingRef[A](
  bootId: UUID,
  graphRef: String,
  coreSchema: Ref[A],
  renderSchema: A => String,
  platform: Option[String] = None,
  serverId: Option[String] = None,
  userVersion: Option[String] = None,
  runtimeVersion: Option[String] = None,
  libraryVersion: Option[String] = None
) {
  def setSchema(a: A)(implicit trace: Trace): UIO[Unit] =
    coreSchema.set(a)
}

object SchemaReportingRef {
  def fromRef[A](
    schema: Ref[A],
    graphRef: String,
    platform: Option[String] = None,
    serverId: Option[String] = None,
    userVersion: Option[String] = None,
    runtimeVersion: Option[String] = None,
    libraryVersion: Option[String] = None
  )(f: A => String): UIO[SchemaReportingRef[A]] = for {
    bootId <- Random.nextUUID
  } yield SchemaReportingRef[A](
    bootId,
    graphRef = graphRef,
    coreSchema = schema,
    renderSchema = f,
    platform = platform,
    serverId = serverId,
    userVersion = userVersion,
    runtimeVersion = runtimeVersion,
    libraryVersion = libraryVersion
  )

  def make(
    schema: GraphQL[Any],
    graphRef: String,
    platform: Option[String] = None,
    serverId: Option[String] = None,
    userVersion: Option[String] = None,
    runtimeVersion: Option[String] = None,
    libraryVersion: Option[String] = None
  ): UIO[SchemaReportingRef[GraphQL[Any]]] =
    Ref
      .make(schema)
      .flatMap(fromRef(_, graphRef, platform, serverId, userVersion, runtimeVersion, libraryVersion)(_.render))

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy