algoliasearch.analytics.Operator.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of algoliasearch-scala_3 Show documentation
Show all versions of algoliasearch-scala_3 Show documentation
Scala client for Algolia Search API
/** 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` (alias:
* `https://analytics.algolia.com`) - `https://analytics.de.algolia.com` 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 - 2024 Weber Informatics LLC | Privacy Policy