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

algoliasearch.monitoring.Metric.scala Maven / Gradle / Ivy

There is a newer version: 2.9.2
Show newest version
/** Algolia Monitoring API The Monitoring API lets you check the status of your Algolia infrastructure. ## Base URLs The
  * base URL for requests to the Monitoring API is: - `https://status.algolia.com` **All requests must use HTTPS.** ##
  * Availability and authentication Access to the [Infrastructure](#tag/infrastructure) endpoints is available as part
  * of the [Premium or Elevate plans](https://www.algolia.com/pricing). To authenticate requests to the Infrastructure
  * endpoints, add these headers: - `x-algolia-application-id`. Your Algolia application ID. - `x-algolia-api-key`. Your
  * Monitoring API key. You can find your application ID and API key in the [Algolia
  * dashboard](https://dashboard.algolia.com/account). Other endpoints don't require authentication. ## Response status
  * and errors The Monitoring API returns JSON responses. Since JSON doesn't guarantee any specific ordering, don't rely
  * on the order of attributes in the API response. Successful responses return a `2xx` status. Client errors return a
  * `4xx` status. Server errors are indicated by a `5xx` status. Error responses have a `message` property with more
  * information. ## Version The current version of the Monitoring API is version 1, as indicated by the `/1/` in each
  * endpoint's URL.
  *
  * The version of the OpenAPI document: 1.0.0
  *
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
  * https://openapi-generator.tech Do not edit the class manually.
  */
package algoliasearch.monitoring

import org.json4s._

sealed trait Metric

/** Metric enumeration
  */
object Metric {
  case object AvgBuildTime extends Metric {
    override def toString = "avg_build_time"
  }
  case object SsdUsage extends Metric {
    override def toString = "ssd_usage"
  }
  case object RamSearchUsage extends Metric {
    override def toString = "ram_search_usage"
  }
  case object RamIndexingUsage extends Metric {
    override def toString = "ram_indexing_usage"
  }
  case object CpuUsage extends Metric {
    override def toString = "cpu_usage"
  }
  case object Star extends Metric {
    override def toString = "*"
  }
  val values: Seq[Metric] = Seq(AvgBuildTime, SsdUsage, RamSearchUsage, RamIndexingUsage, CpuUsage, Star)

  def withName(name: String): Metric = Metric.values
    .find(_.toString == name)
    .getOrElse(throw new MappingException(s"Unknown Metric value: $name"))
}

class MetricSerializer
    extends CustomSerializer[Metric](_ =>
      (
        {
          case JString(value) => Metric.withName(value)
          case JNull          => null
        },
        { case value: Metric =>
          JString(value.toString)
        }
      )
    )




© 2015 - 2024 Weber Informatics LLC | Privacy Policy