commonMain.com.algolia.client.api.IngestionClient.kt 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 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.ingestion.*
import com.algolia.client.transport.*
import com.algolia.client.transport.internal.*
import kotlinx.serialization.json.*
public class IngestionClient(
override val appId: String,
override var 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 = "Ingestion", 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 = "data.$region.algolia.com"
listOf(Host(url))
}
/**
* Creates a new authentication resource.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param authenticationCreate
* @param requestOptions additional request configuration.
*/
public suspend fun createAuthentication(authenticationCreate: AuthenticationCreate, requestOptions: RequestOptions? = null): AuthenticationCreateResponse {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "authentications"),
body = authenticationCreate,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Creates a new destination.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param destinationCreate
* @param requestOptions additional request configuration.
*/
public suspend fun createDestination(destinationCreate: DestinationCreate, requestOptions: RequestOptions? = null): DestinationCreateResponse {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "destinations"),
body = destinationCreate,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Creates a new source.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param sourceCreate
* @param requestOptions additional request configuration.
*/
public suspend fun createSource(sourceCreate: SourceCreate, requestOptions: RequestOptions? = null): SourceCreateResponse {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "sources"),
body = sourceCreate,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Creates a new task.
* @param taskCreate Request body for creating a task.
* @param requestOptions additional request configuration.
*/
public suspend fun createTask(taskCreate: TaskCreate, requestOptions: RequestOptions? = null): TaskCreateResponse {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("2", "tasks"),
body = taskCreate,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Creates a new task using the v1 endpoint, please use `createTask` instead.
* @param taskCreate Request body for creating a task.
* @param requestOptions additional request configuration.
*/
public suspend fun createTaskV1(taskCreate: TaskCreateV1, requestOptions: RequestOptions? = null): TaskCreateResponse {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "tasks"),
body = taskCreate,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Creates a new transformation.
* @param transformationCreate Request body for creating a transformation.
* @param requestOptions additional request configuration.
*/
public suspend fun createTransformation(transformationCreate: TransformationCreate, requestOptions: RequestOptions? = null): TransformationCreateResponse {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "transformations"),
body = transformationCreate,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = 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 requestOptions additional request configuration.
*/
public suspend fun customDelete(path: String, parameters: Map? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `customDelete`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = "/{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = 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 requestOptions additional request configuration.
*/
public suspend fun customGet(path: String, parameters: Map? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `customGet`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = "/{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = 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.
* @param requestOptions additional request configuration.
*/
public suspend fun customPost(path: String, parameters: Map? = null, body: JsonObject? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `customPost`." }
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = "/{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
body = body,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = 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.
* @param requestOptions additional request configuration.
*/
public suspend fun customPut(path: String, parameters: Map? = null, body: JsonObject? = null, requestOptions: RequestOptions? = null): JsonObject {
require(path.isNotBlank()) { "Parameter `path` is required when calling `customPut`." }
val requestConfig = RequestConfig(
method = RequestMethod.PUT,
path = "/{path}".replace("{path}", path),
query = buildMap {
parameters?.let { putAll(it) }
},
body = body,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Deletes an authentication resource. You can't delete authentication resources that are used by a source or a destination.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param authenticationID Unique identifier of an authentication resource.
* @param requestOptions additional request configuration.
*/
public suspend fun deleteAuthentication(authenticationID: String, requestOptions: RequestOptions? = null): DeleteResponse {
require(authenticationID.isNotBlank()) { "Parameter `authenticationID` is required when calling `deleteAuthentication`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = listOf("1", "authentications", "$authenticationID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Deletes a destination by its ID. You can't delete destinations that are referenced in tasks.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param destinationID Unique identifier of a destination.
* @param requestOptions additional request configuration.
*/
public suspend fun deleteDestination(destinationID: String, requestOptions: RequestOptions? = null): DeleteResponse {
require(destinationID.isNotBlank()) { "Parameter `destinationID` is required when calling `deleteDestination`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = listOf("1", "destinations", "$destinationID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Deletes a source by its ID. You can't delete sources that are referenced in tasks.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param sourceID Unique identifier of a source.
* @param requestOptions additional request configuration.
*/
public suspend fun deleteSource(sourceID: String, requestOptions: RequestOptions? = null): DeleteResponse {
require(sourceID.isNotBlank()) { "Parameter `sourceID` is required when calling `deleteSource`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = listOf("1", "sources", "$sourceID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Deletes a task by its ID.
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun deleteTask(taskID: String, requestOptions: RequestOptions? = null): DeleteResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `deleteTask`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = listOf("2", "tasks", "$taskID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Deletes a task by its ID using the v1 endpoint, please use `deleteTask` instead.
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun deleteTaskV1(taskID: String, requestOptions: RequestOptions? = null): DeleteResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `deleteTaskV1`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = listOf("1", "tasks", "$taskID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Deletes a transformation by its ID.
* @param transformationID Unique identifier of a transformation.
* @param requestOptions additional request configuration.
*/
public suspend fun deleteTransformation(transformationID: String, requestOptions: RequestOptions? = null): DeleteResponse {
require(transformationID.isNotBlank()) { "Parameter `transformationID` is required when calling `deleteTransformation`." }
val requestConfig = RequestConfig(
method = RequestMethod.DELETE,
path = listOf("1", "transformations", "$transformationID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Disables a task.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun disableTask(taskID: String, requestOptions: RequestOptions? = null): TaskUpdateResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `disableTask`." }
val requestConfig = RequestConfig(
method = RequestMethod.PUT,
path = listOf("2", "tasks", "$taskID", "disable"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Disables a task using the v1 endpoint, please use `disableTask` instead.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun disableTaskV1(taskID: String, requestOptions: RequestOptions? = null): TaskUpdateResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `disableTaskV1`." }
val requestConfig = RequestConfig(
method = RequestMethod.PUT,
path = listOf("1", "tasks", "$taskID", "disable"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Enables a task.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun enableTask(taskID: String, requestOptions: RequestOptions? = null): TaskUpdateResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `enableTask`." }
val requestConfig = RequestConfig(
method = RequestMethod.PUT,
path = listOf("2", "tasks", "$taskID", "enable"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Enables a task using the v1 endpoint, please use `enableTask` instead.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun enableTaskV1(taskID: String, requestOptions: RequestOptions? = null): TaskUpdateResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `enableTaskV1`." }
val requestConfig = RequestConfig(
method = RequestMethod.PUT,
path = listOf("1", "tasks", "$taskID", "enable"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves an authentication resource by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param authenticationID Unique identifier of an authentication resource.
* @param requestOptions additional request configuration.
*/
public suspend fun getAuthentication(authenticationID: String, requestOptions: RequestOptions? = null): Authentication {
require(authenticationID.isNotBlank()) { "Parameter `authenticationID` is required when calling `getAuthentication`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "authentications", "$authenticationID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a destination by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param destinationID Unique identifier of a destination.
* @param requestOptions additional request configuration.
*/
public suspend fun getDestination(destinationID: String, requestOptions: RequestOptions? = null): Destination {
require(destinationID.isNotBlank()) { "Parameter `destinationID` is required when calling `getDestination`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "destinations", "$destinationID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a single task run event by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param runID Unique identifier of a task run.
* @param eventID Unique identifier of an event.
* @param requestOptions additional request configuration.
*/
public suspend fun getEvent(runID: String, eventID: String, requestOptions: RequestOptions? = null): Event {
require(runID.isNotBlank()) { "Parameter `runID` is required when calling `getEvent`." }
require(eventID.isNotBlank()) { "Parameter `eventID` is required when calling `getEvent`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "runs", "$runID", "events", "$eventID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieve a single task run by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param runID Unique identifier of a task run.
* @param requestOptions additional request configuration.
*/
public suspend fun getRun(runID: String, requestOptions: RequestOptions? = null): Run {
require(runID.isNotBlank()) { "Parameter `runID` is required when calling `getRun`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "runs", "$runID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieve a source by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param sourceID Unique identifier of a source.
* @param requestOptions additional request configuration.
*/
public suspend fun getSource(sourceID: String, requestOptions: RequestOptions? = null): Source {
require(sourceID.isNotBlank()) { "Parameter `sourceID` is required when calling `getSource`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "sources", "$sourceID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a task by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun getTask(taskID: String, requestOptions: RequestOptions? = null): Task {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `getTask`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("2", "tasks", "$taskID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a task by its ID using the v1 endpoint, please use `getTask` instead.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun getTaskV1(taskID: String, requestOptions: RequestOptions? = null): TaskV1 {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `getTaskV1`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "tasks", "$taskID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a transformation by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param transformationID Unique identifier of a transformation.
* @param requestOptions additional request configuration.
*/
public suspend fun getTransformation(transformationID: String, requestOptions: RequestOptions? = null): Transformation {
require(transformationID.isNotBlank()) { "Parameter `transformationID` is required when calling `getTransformation`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "transformations", "$transformationID"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a list of all authentication resources.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param type Type of authentication resource to retrieve.
* @param platform Ecommerce platform for which to retrieve authentications.
* @param sort Property by which to sort the list of authentications. (default to createdAt)
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param requestOptions additional request configuration.
*/
public suspend fun listAuthentications(itemsPerPage: Int? = null, page: Int? = null, type: List? = null, platform: List? = null, sort: AuthenticationSortKeys? = null, order: OrderKeys? = null, requestOptions: RequestOptions? = null): ListAuthenticationsResponse {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "authentications"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
type?.let { put("type", it.joinToString(",")) }
platform?.let { put("platform", it.joinToString(",")) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a list of destinations.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param type Destination type.
* @param authenticationID Authentication ID used by destinations.
* @param transformationID Get the list of destinations used by a transformation.
* @param sort Property by which to sort the destinations. (default to createdAt)
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param requestOptions additional request configuration.
*/
public suspend fun listDestinations(itemsPerPage: Int? = null, page: Int? = null, type: List? = null, authenticationID: List? = null, transformationID: String? = null, sort: DestinationSortKeys? = null, order: OrderKeys? = null, requestOptions: RequestOptions? = null): ListDestinationsResponse {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "destinations"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
type?.let { put("type", it.joinToString(",")) }
authenticationID?.let { put("authenticationID", it.joinToString(",")) }
transformationID?.let { put("transformationID", it) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a list of events for a task run, identified by its ID.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param runID Unique identifier of a task run.
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param status Event status for filtering the list of task runs.
* @param type Event type for filtering the list of task runs.
* @param sort Property by which to sort the list of task run events.
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param startDate Date and time in RFC 3339 format for the earliest events to retrieve. By default, the current time minus three hours is used.
* @param endDate Date and time in RFC 3339 format for the latest events to retrieve. By default, the current time is used.
* @param requestOptions additional request configuration.
*/
public suspend fun listEvents(runID: String, itemsPerPage: Int? = null, page: Int? = null, status: List? = null, type: List? = null, sort: EventSortKeys? = null, order: OrderKeys? = null, startDate: String? = null, endDate: String? = null, requestOptions: RequestOptions? = null): ListEventsResponse {
require(runID.isNotBlank()) { "Parameter `runID` is required when calling `listEvents`." }
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "runs", "$runID", "events"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
status?.let { put("status", it.joinToString(",")) }
type?.let { put("type", it.joinToString(",")) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
startDate?.let { put("startDate", it) }
endDate?.let { put("endDate", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieve a list of task runs.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param status Run status for filtering the list of task runs.
* @param type Run type for filtering the list of task runs.
* @param taskID Task ID for filtering the list of task runs.
* @param sort Property by which to sort the list of task runs. (default to createdAt)
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param startDate Date in RFC 3339 format for the earliest run to retrieve. By default, the current day minus seven days is used.
* @param endDate Date in RFC 3339 format for the latest run to retrieve. By default, the current day is used.
* @param requestOptions additional request configuration.
*/
public suspend fun listRuns(itemsPerPage: Int? = null, page: Int? = null, status: List? = null, type: List? = null, taskID: String? = null, sort: RunSortKeys? = null, order: OrderKeys? = null, startDate: String? = null, endDate: String? = null, requestOptions: RequestOptions? = null): RunListResponse {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "runs"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
status?.let { put("status", it.joinToString(",")) }
type?.let { put("type", it.joinToString(",")) }
taskID?.let { put("taskID", it) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
startDate?.let { put("startDate", it) }
endDate?.let { put("endDate", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a list of sources.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param type Source type. Some sources require authentication.
* @param authenticationID Authentication IDs of the sources to retrieve. 'none' returns sources that doesn't have an authentication.
* @param sort Property by which to sort the list of sources. (default to createdAt)
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param requestOptions additional request configuration.
*/
public suspend fun listSources(itemsPerPage: Int? = null, page: Int? = null, type: List? = null, authenticationID: List? = null, sort: SourceSortKeys? = null, order: OrderKeys? = null, requestOptions: RequestOptions? = null): ListSourcesResponse {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "sources"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
type?.let { put("type", it.joinToString(",")) }
authenticationID?.let { put("authenticationID", it.joinToString(",")) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a list of tasks.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param action Actions for filtering the list of tasks.
* @param enabled Whether to filter the list of tasks by the `enabled` status.
* @param sourceID Source IDs for filtering the list of tasks.
* @param destinationID Destination IDs for filtering the list of tasks.
* @param triggerType Type of task trigger for filtering the list of tasks.
* @param sort Property by which to sort the list of tasks. (default to createdAt)
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param requestOptions additional request configuration.
*/
public suspend fun listTasks(itemsPerPage: Int? = null, page: Int? = null, action: List? = null, enabled: Boolean? = null, sourceID: List? = null, destinationID: List? = null, triggerType: List? = null, sort: TaskSortKeys? = null, order: OrderKeys? = null, requestOptions: RequestOptions? = null): ListTasksResponse {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("2", "tasks"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
action?.let { put("action", it.joinToString(",")) }
enabled?.let { put("enabled", it) }
sourceID?.let { put("sourceID", it.joinToString(",")) }
destinationID?.let { put("destinationID", it.joinToString(",")) }
triggerType?.let { put("triggerType", it.joinToString(",")) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a list of tasks using the v1 endpoint, please use `getTasks` instead.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param action Actions for filtering the list of tasks.
* @param enabled Whether to filter the list of tasks by the `enabled` status.
* @param sourceID Source IDs for filtering the list of tasks.
* @param destinationID Destination IDs for filtering the list of tasks.
* @param triggerType Type of task trigger for filtering the list of tasks.
* @param sort Property by which to sort the list of tasks. (default to createdAt)
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param requestOptions additional request configuration.
*/
public suspend fun listTasksV1(itemsPerPage: Int? = null, page: Int? = null, action: List? = null, enabled: Boolean? = null, sourceID: List? = null, destinationID: List? = null, triggerType: List? = null, sort: TaskSortKeys? = null, order: OrderKeys? = null, requestOptions: RequestOptions? = null): ListTasksResponseV1 {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "tasks"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
action?.let { put("action", it.joinToString(",")) }
enabled?.let { put("enabled", it) }
sourceID?.let { put("sourceID", it.joinToString(",")) }
destinationID?.let { put("destinationID", it.joinToString(",")) }
triggerType?.let { put("triggerType", it.joinToString(",")) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Retrieves a list of transformations.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param itemsPerPage Number of items per page. (default to 10)
* @param page Page number of the paginated API response.
* @param sort Property by which to sort the list of transformations. (default to createdAt)
* @param order Sort order of the response, ascending or descending. (default to desc)
* @param requestOptions additional request configuration.
*/
public suspend fun listTransformations(itemsPerPage: Int? = null, page: Int? = null, sort: TransformationSortKeys? = null, order: OrderKeys? = null, requestOptions: RequestOptions? = null): ListTransformationsResponse {
val requestConfig = RequestConfig(
method = RequestMethod.GET,
path = listOf("1", "transformations"),
query = buildMap {
itemsPerPage?.let { put("itemsPerPage", it) }
page?.let { put("page", it) }
sort?.let { put("sort", it) }
order?.let { put("order", it) }
},
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Push a `batch` request payload through the Pipeline. You can check the status of task pushes with the observability endpoints.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param pushTaskPayload Request body of a Search API `batch` request that will be pushed in the Connectors pipeline.
* @param requestOptions additional request configuration.
*/
public suspend fun pushTask(taskID: String, pushTaskPayload: PushTaskPayload, requestOptions: RequestOptions? = null): RunResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `pushTask`." }
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("2", "tasks", "$taskID", "push"),
body = pushTaskPayload,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Runs all tasks linked to a source, only available for Shopify sources. It will create 1 run per task.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param sourceID Unique identifier of a source.
* @param runSourcePayload
* @param requestOptions additional request configuration.
*/
public suspend fun runSource(sourceID: String, runSourcePayload: RunSourcePayload? = null, requestOptions: RequestOptions? = null): RunSourceResponse {
require(sourceID.isNotBlank()) { "Parameter `sourceID` is required when calling `runSource`." }
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "sources", "$sourceID", "run"),
body = runSourcePayload,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Runs a task. You can check the status of task runs with the observability endpoints.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun runTask(taskID: String, requestOptions: RequestOptions? = null): RunResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `runTask`." }
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("2", "tasks", "$taskID", "run"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Runs a task using the v1 endpoint, please use `runTask` instead. You can check the status of task runs with the observability endpoints.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param taskID Unique identifier of a task.
* @param requestOptions additional request configuration.
*/
public suspend fun runTaskV1(taskID: String, requestOptions: RequestOptions? = null): RunResponse {
require(taskID.isNotBlank()) { "Parameter `taskID` is required when calling `runTaskV1`." }
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "tasks", "$taskID", "run"),
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Searches for authentication resources.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param authenticationSearch
* @param requestOptions additional request configuration.
*/
public suspend fun searchAuthentications(authenticationSearch: AuthenticationSearch, requestOptions: RequestOptions? = null): List {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "authentications", "search"),
body = authenticationSearch,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Searches for destinations.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param destinationSearch
* @param requestOptions additional request configuration.
*/
public suspend fun searchDestinations(destinationSearch: DestinationSearch, requestOptions: RequestOptions? = null): List {
val requestConfig = RequestConfig(
method = RequestMethod.POST,
path = listOf("1", "destinations", "search"),
body = destinationSearch,
)
return requester.execute(
requestConfig = requestConfig,
requestOptions = requestOptions,
)
}
/**
* Searches for sources.
*
* Required API Key ACLs:
* - addObject
* - deleteIndex
* - editSettings
* @param sourceSearch
* @param requestOptions additional request configuration.
*/
public suspend fun searchSources(sourceSearch: SourceSearch, requestOptions: RequestOptions? = null): List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy