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

algoliasearch.analytics.Operator.scala Maven / Gradle / Ivy

/** Analytics API The Analytics API gives you access to metrics related to your Algolia search experience. ## Base URLs
  * The base URLs for requests to the Analytics API are: - `https://analytics.us.algolia.com` -
  * `https://analytics.de.algolia.com` - `https://analytics.algolia.com` (routes requests to the closest of the above
  * servers, based on your geographical location) Use the URL that matches your [analytics
  * region](https://dashboard.algolia.com/account/infrastructure/analytics). **All requests must use HTTPS.** ##
  * Availability and authentication Access to the Analytics API is available as part of the [Premium or Elevate
  * plans](https://www.algolia.com/pricing). To authenticate your API requests, add these headers: -
  * `x-algolia-application-id`. Your Algolia application ID. - `x-algolia-api-key`. An API key with the necessary
  * permissions to make the request. The required access control list (ACL) to make a request is listed in each
  * endpoint's reference. You can find your application ID and API key in the [Algolia
  * dashboard](https://dashboard.algolia.com/account). ## Rate limits You can make up to **100 requests per minute per
  * app** to the Analytics API. The response includes headers with information about the limits. ## Parameters Query
  * parameters must be [URL-encoded](https://developer.mozilla.org/en-US/docs/Glossary/Percent-encoding). Non-ASCII
  * characters must be UTF-8 encoded. Plus characters (`+`) are interpreted as spaces. ## Response status and errors The
  * Analytics 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 Analytics API is version 2, as indicated by the `/2/` in each endpoint's URL.
  *
  * The version of the OpenAPI document: 2.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.analytics

import org.json4s._

sealed trait Operator

/** Character that characterizes how the filter is applied. For example, for a facet filter `facet:value`, `:` is the
  * operator. For a numeric filter `count>50`, `>` is the operator.
  */
object Operator {
  case object Colon extends Operator {
    override def toString = ":"
  }
  case object LessThan extends Operator {
    override def toString = "<"
  }
  case object LessThanOrEqualTo extends Operator {
    override def toString = "<="
  }
  case object Equal extends Operator {
    override def toString = "="
  }
  case object NotEqual extends Operator {
    override def toString = "!="
  }
  case object GreaterThan extends Operator {
    override def toString = ">"
  }
  case object GreaterThanOrEqualTo extends Operator {
    override def toString = ">="
  }
  val values: Seq[Operator] =
    Seq(Colon, LessThan, LessThanOrEqualTo, Equal, NotEqual, GreaterThan, GreaterThanOrEqualTo)

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

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




© 2015 - 2025 Weber Informatics LLC | Privacy Policy