algoliasearch.api.MonitoringClient.scala Maven / Gradle / Ivy
/** Code generated by OpenAPI Generator (https://openapi-generator.tech), manual changes will be lost - read more on
* https://github.com/algolia/api-clients-automation. DO NOT EDIT.
*/
package algoliasearch.api
import algoliasearch.monitoring.BadRequest
import algoliasearch.monitoring.ErrorBase
import algoliasearch.monitoring.Forbidden
import algoliasearch.monitoring.IncidentsResponse
import algoliasearch.monitoring.IndexingTimeResponse
import algoliasearch.monitoring.InfrastructureResponse
import algoliasearch.monitoring.InventoryResponse
import algoliasearch.monitoring.LatencyResponse
import algoliasearch.monitoring.Metric._
import algoliasearch.monitoring.Period._
import algoliasearch.monitoring.StatusResponse
import algoliasearch.monitoring.Unauthorized
import algoliasearch.monitoring._
import algoliasearch.ApiClient
import algoliasearch.api.MonitoringClient.hosts
import algoliasearch.api.MonitoringClient.readTimeout
import algoliasearch.api.MonitoringClient.writeTimeout
import algoliasearch.api.MonitoringClient.connectTimeout
import algoliasearch.config._
import algoliasearch.internal.util._
import java.util.concurrent.TimeUnit
import scala.concurrent.duration.Duration
import scala.concurrent.{ExecutionContext, Future}
import scala.util.Random
object MonitoringClient {
/** Creates a new MonitoringClient instance using default hosts.
*
* @param appId
* application ID
* @param apiKey
* api key
*
* @param clientOptions
* client options
*/
def apply(
appId: String,
apiKey: String,
clientOptions: ClientOptions = ClientOptions()
) = new MonitoringClient(
appId = appId,
apiKey = apiKey,
clientOptions = clientOptions
)
private def readTimeout(): Duration = {
Duration(5, TimeUnit.SECONDS)
}
private def connectTimeout(): Duration = {
Duration(2, TimeUnit.SECONDS)
}
private def writeTimeout(): Duration = {
Duration(30, TimeUnit.SECONDS)
}
private def hosts(): Seq[Host] = {
List(
Host("status.algolia.com", Set(CallType.Read, CallType.Write))
)
}
}
class MonitoringClient(
appId: String,
apiKey: String,
clientOptions: ClientOptions = ClientOptions()
) extends ApiClient(
appId = appId,
apiKey = apiKey,
clientName = "Monitoring",
defaultHosts = hosts(),
defaultReadTimeout = readTimeout(),
defaultWriteTimeout = writeTimeout(),
defaultConnectTimeout = connectTimeout(),
formats = JsonSupport.format,
options = clientOptions
) {
/** This method allow you to send requests to the Algolia REST API.
*
* @param path
* Path of the endpoint, anything after \"/1\" must be specified.
* @param parameters
* Query parameters to apply to the current query.
*/
def customDelete[T: Manifest](
path: String,
parameters: Option[Map[String, Any]] = None,
requestOptions: Option[RequestOptions] = None
)(implicit ec: ExecutionContext): Future[T] = Future {
requireNotNull(path, "Parameter `path` is required when calling `customDelete`.")
val request = HttpRequest
.builder()
.withMethod("DELETE")
.withPath(s"/${path}")
.withQueryParameters(parameters)
.build()
execute[T](request, requestOptions)
}
/** This method allow you to send requests to the Algolia REST API.
*
* @param path
* Path of the endpoint, anything after \"/1\" must be specified.
* @param parameters
* Query parameters to apply to the current query.
*/
def customGet[T: Manifest](
path: String,
parameters: Option[Map[String, Any]] = None,
requestOptions: Option[RequestOptions] = None
)(implicit ec: ExecutionContext): Future[T] = Future {
requireNotNull(path, "Parameter `path` is required when calling `customGet`.")
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/${path}")
.withQueryParameters(parameters)
.build()
execute[T](request, requestOptions)
}
/** This method allow you to send requests to the Algolia REST API.
*
* @param path
* Path of the endpoint, anything after \"/1\" must be specified.
* @param parameters
* Query parameters to apply to the current query.
* @param body
* Parameters to send with the custom request.
*/
def customPost[T: Manifest](
path: String,
parameters: Option[Map[String, Any]] = None,
body: Option[Any] = None,
requestOptions: Option[RequestOptions] = None
)(implicit ec: ExecutionContext): Future[T] = Future {
requireNotNull(path, "Parameter `path` is required when calling `customPost`.")
val request = HttpRequest
.builder()
.withMethod("POST")
.withPath(s"/${path}")
.withBody(body)
.withQueryParameters(parameters)
.build()
execute[T](request, requestOptions)
}
/** This method allow you to send requests to the Algolia REST API.
*
* @param path
* Path of the endpoint, anything after \"/1\" must be specified.
* @param parameters
* Query parameters to apply to the current query.
* @param body
* Parameters to send with the custom request.
*/
def customPut[T: Manifest](
path: String,
parameters: Option[Map[String, Any]] = None,
body: Option[Any] = None,
requestOptions: Option[RequestOptions] = None
)(implicit ec: ExecutionContext): Future[T] = Future {
requireNotNull(path, "Parameter `path` is required when calling `customPut`.")
val request = HttpRequest
.builder()
.withMethod("PUT")
.withPath(s"/${path}")
.withBody(body)
.withQueryParameters(parameters)
.build()
execute[T](request, requestOptions)
}
/** Retrieves known incidents for the selected clusters.
*
* @param clusters
* Subset of clusters, separated by commas.
*/
def getClusterIncidents(clusters: String, requestOptions: Option[RequestOptions] = None)(implicit
ec: ExecutionContext
): Future[IncidentsResponse] = Future {
requireNotNull(clusters, "Parameter `clusters` is required when calling `getClusterIncidents`.")
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/incidents/${escape(clusters)}")
.build()
execute[IncidentsResponse](request, requestOptions)
}
/** Retrieves the status of selected clusters.
*
* @param clusters
* Subset of clusters, separated by commas.
*/
def getClusterStatus(clusters: String, requestOptions: Option[RequestOptions] = None)(implicit
ec: ExecutionContext
): Future[StatusResponse] = Future {
requireNotNull(clusters, "Parameter `clusters` is required when calling `getClusterStatus`.")
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/status/${escape(clusters)}")
.build()
execute[StatusResponse](request, requestOptions)
}
/** Retrieves known incidents for all clusters.
*/
def getIncidents(
requestOptions: Option[RequestOptions] = None
)(implicit ec: ExecutionContext): Future[IncidentsResponse] = Future {
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/incidents")
.build()
execute[IncidentsResponse](request, requestOptions)
}
/** Retrieves average times for indexing operations for selected clusters.
*
* @param clusters
* Subset of clusters, separated by commas.
*/
def getIndexingTime(clusters: String, requestOptions: Option[RequestOptions] = None)(implicit
ec: ExecutionContext
): Future[IndexingTimeResponse] = Future {
requireNotNull(clusters, "Parameter `clusters` is required when calling `getIndexingTime`.")
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/indexing/${escape(clusters)}")
.build()
execute[IndexingTimeResponse](request, requestOptions)
}
/** Retrieves the average latency for search requests for selected clusters.
*
* @param clusters
* Subset of clusters, separated by commas.
*/
def getLatency(clusters: String, requestOptions: Option[RequestOptions] = None)(implicit
ec: ExecutionContext
): Future[LatencyResponse] = Future {
requireNotNull(clusters, "Parameter `clusters` is required when calling `getLatency`.")
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/latency/${escape(clusters)}")
.build()
execute[LatencyResponse](request, requestOptions)
}
/** Retrieves metrics related to your Algolia infrastructure, aggregated over a selected time window. Access to this
* API is available as part of the [Premium or Elevate plans](https://www.algolia.com/pricing). You must authenticate
* requests with the `x-algolia-application-id` and `x-algolia-api-key` headers (using the Monitoring API key).
*
* @param metric
* Metric to report. For more information about the individual metrics, see the description of the API response. To
* include all metrics, use `*`.
* @param period
* Period over which to aggregate the metrics: - `minute`. Aggregate the last minute. 1 data point per 10 seconds.
* \- `hour`. Aggregate the last hour. 1 data point per minute. - `day`. Aggregate the last day. 1 data point per
* 10 minutes. - `week`. Aggregate the last week. 1 data point per hour. - `month`. Aggregate the last month. 1
* data point per day.
*/
def getMetrics(metric: Metric, period: Period, requestOptions: Option[RequestOptions] = None)(implicit
ec: ExecutionContext
): Future[InfrastructureResponse] = Future {
requireNotNull(metric, "Parameter `metric` is required when calling `getMetrics`.")
requireNotNull(period, "Parameter `period` is required when calling `getMetrics`.")
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/infrastructure/${escape(metric)}/period/${escape(period)}")
.build()
execute[InfrastructureResponse](request, requestOptions)
}
/** Test whether clusters are reachable or not.
*
* @param clusters
* Subset of clusters, separated by commas.
*/
def getReachability(clusters: String, requestOptions: Option[RequestOptions] = None)(implicit
ec: ExecutionContext
): Future[Map[String, Map[String, Boolean]]] = Future {
requireNotNull(clusters, "Parameter `clusters` is required when calling `getReachability`.")
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/reachability/${escape(clusters)}/probes")
.build()
execute[Map[String, Map[String, Boolean]]](request, requestOptions)
}
/** Retrieves the servers that belong to clusters. The response depends on whether you authenticate your API request:
* \- With authentication, the response lists the servers assigned to your Algolia application's cluster. - Without
* authentication, the response lists the servers for all Algolia clusters.
*/
def getServers(
requestOptions: Option[RequestOptions] = None
)(implicit ec: ExecutionContext): Future[InventoryResponse] = Future {
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/inventory/servers")
.build()
execute[InventoryResponse](request, requestOptions)
}
/** Retrieves the status of all Algolia clusters and instances.
*/
def getStatus(requestOptions: Option[RequestOptions] = None)(implicit ec: ExecutionContext): Future[StatusResponse] =
Future {
val request = HttpRequest
.builder()
.withMethod("GET")
.withPath(s"/1/status")
.build()
execute[StatusResponse](request, requestOptions)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy