commonMain.com.algolia.client.api.QuerySuggestionsClient.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of algoliasearch-client-kotlin Show documentation
Show all versions of algoliasearch-client-kotlin Show documentation
"Algolia is a powerful search-as-a-service solution, made easy to use with API clients, UI libraries, and pre-built integrations. Algolia API Client for Kotlin lets you easily use the Algolia Search REST API from your JVM project, such as Android or backend implementations."
/** 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 com.algolia.client.api
import com.algolia.client.configuration.*
import com.algolia.client.exception.*
import com.algolia.client.extensions.internal.*
import com.algolia.client.model.querysuggestions.*
import com.algolia.client.transport.*
import com.algolia.client.transport.internal.*
import kotlinx.serialization.json.*
public class QuerySuggestionsClient(
override val appId: String,
override val apiKey: String,
public val region: String,
override val options: ClientOptions = ClientOptions(),
) : ApiClient {
init {
require(appId.isNotBlank()) { "`appId` is missing." }
require(apiKey.isNotBlank()) { "`apiKey` is missing." }
}
override val requester: Requester = requesterOf(clientName = "QuerySuggestions", appId = appId, apiKey = apiKey, options = options) {
val allowedRegions = listOf("eu", "us")
require(region in allowedRegions) { "`region` is required and must be one of the following: ${allowedRegions.joinToString()}" }
val url = "query-suggestions.$region.algolia.com"
listOf(Host(url))
}
/**
* Create a configuration.
* Create a new Query Suggestions configuration. You can have up to 100 configurations per Algolia application.
* @param querySuggestionsConfigurationWithIndex
* @param requestOptions additional request configuration.
*/
public suspend fun createConfig(querySuggestionsConfigurationWithIndex: QuerySuggestionsConfigurationWithIndex, requestOptions: RequestOptions? = null): BaseResponse {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "configs"),
body = querySuggestionsConfigurationWithIndex,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Send requests to the Algolia REST API.
* 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 requestOptions additional request configuration.
*/
public suspend fun del(path: String, parameters: Map? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `del`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = "/1{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Delete a configuration.
* Delete a Query Suggestions configuration. Deleting only removes the configuration and stops updates to the Query Suggestions index. The Query Suggestions index itself is not deleted.
* @param indexName Query Suggestions index name.
* @param requestOptions additional request configuration.
*/
public suspend fun deleteConfig(indexName: String, requestOptions: RequestOptions? = null): BaseResponse {
require(indexName.isNotBlank()) { "Parameter `indexName` is required when calling `deleteConfig`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = listOf("1", "configs", "$indexName"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Send requests to the Algolia REST API.
* 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 requestOptions additional request configuration.
*/
public suspend fun get(path: String, parameters: Map? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `get`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = "/1{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* List configurations.
* List all Query Suggestions configurations of your Algolia application.
* @param requestOptions additional request configuration.
*/
public suspend fun getAllConfigs(requestOptions: RequestOptions? = null): List {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "configs"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Get a configuration.
* Get a single Query Suggestions configuration.
* @param indexName Query Suggestions index name.
* @param requestOptions additional request configuration.
*/
public suspend fun getConfig(indexName: String, requestOptions: RequestOptions? = null): QuerySuggestionsConfigurationResponse {
require(indexName.isNotBlank()) { "Parameter `indexName` is required when calling `getConfig`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "configs", "$indexName"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Get configuration status.
* Report the status of a Query Suggestions index.
* @param indexName Query Suggestions index name.
* @param requestOptions additional request configuration.
*/
public suspend fun getConfigStatus(indexName: String, requestOptions: RequestOptions? = null): GetConfigStatus200Response {
require(indexName.isNotBlank()) { "Parameter `indexName` is required when calling `getConfigStatus`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "configs", "$indexName", "status"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Get logs.
* Get the logs for a single Query Suggestions index.
* @param indexName Query Suggestions index name.
* @param requestOptions additional request configuration.
*/
public suspend fun getLogFile(indexName: String, requestOptions: RequestOptions? = null): GetLogFile200Response {
require(indexName.isNotBlank()) { "Parameter `indexName` is required when calling `getLogFile`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "logs", "$indexName"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Send requests to the Algolia REST API.
* 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.
* @param requestOptions additional request configuration.
*/
public suspend fun post(path: String, parameters: Map? = null, body: JsonObject? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `post`." }
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = "/1{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
body = body,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Send requests to the Algolia REST API.
* 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.
* @param requestOptions additional request configuration.
*/
public suspend fun put(path: String, parameters: Map? = null, body: JsonObject? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `put`." }
val requestConfig = RequestConfig(
method = RequestMethod.PUT,
path = "/1{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
body = body,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Update a configuration.
* Update a QuerySuggestions configuration.
* @param indexName Query Suggestions index name.
* @param querySuggestionsConfiguration
* @param requestOptions additional request configuration.
*/
public suspend fun updateConfig(indexName: String, querySuggestionsConfiguration: QuerySuggestionsConfiguration, requestOptions: RequestOptions? = null): BaseResponse {
require(indexName.isNotBlank()) { "Parameter `indexName` is required when calling `updateConfig`." }
val requestConfig = RequestConfig(
method = RequestMethod.PUT,
path = listOf("1", "configs", "$indexName"),
body = querySuggestionsConfiguration,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy