aboutsummaryrefslogtreecommitdiff
path: root/shared/src/commonMain/kotlin/mx/trackermap/TrackerMap/client/apis/DevicesApi.kt
blob: 307ffc8eee6994bb3497332c993f0ba67329ba04 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/**
 * Traccar
 * Traccar GPS tracking server API documentation. To use the API you need to have a server instance. For testing purposes you can use one of free [demo servers](https://www.traccar.org/demo-server/). For production use you can install your own server or get a [subscription service](https://www.traccar.org/product/tracking-server/).
 *
 * OpenAPI spec version: 4.14
 * Contact: support@traccar.org
 *
 * NOTE: This class is auto generated by the swagger code generator program.
 * https://github.com/swagger-api/swagger-codegen.git
 * Do not edit the class manually.
 */
package mx.trackermap.TrackerMap.client.apis

import mx.trackermap.TrackerMap.Injectable
import mx.trackermap.TrackerMap.client.models.Device

import mx.trackermap.TrackerMap.client.infrastructure.*

class DevicesApi(sessionManager: SessionManager) : ApiClient(sessionManager), Injectable {

    /**
     * Fetch a list of Devices
     * Without any params, returns a list of the user's devices
     * @param all Can only be used by admins or managers to fetch all entities (optional)
     * @param userId Standard users can use this only with their own _userId_ (optional)
     * @param id To fetch one or more devices. Multiple params can be passed like `id=31&id=42` (optional)
     * @param uniqueId To fetch one or more devices. Multiple params can be passed like `uniqueId=333331&uniqieId=44442` (optional)
     * @return kotlin.Array<Device>
     */
    @Suppress("UNCHECKED_CAST")
    suspend fun devicesGet(all: Boolean? = null, userId: Int? = null, id: Int? = null, uniqueId: String? = null): Array<Device> {
        val query: MutableMap<String, List<String>> = mutableMapOf()
        all?.let { query["all"] = listOf("$it") }
        userId?.let { query["userId"] = listOf("$it") }
        id?.let { query["id"] = listOf("$it") }
        uniqueId?.let { query["uniqueId"] = listOf(it) }
        val localVariableQuery: MultiValueMap = query

        val localVariableConfig = RequestConfig(
                RequestMethod.GET,
                "/devices", query = localVariableQuery
        )
        val response = request<Array<Device>>(
                localVariableConfig
        )

        return when (response.responseType) {
            ResponseType.Success -> (response as Success<*>).data as Array<Device>
            ResponseType.Informational -> TODO()
            ResponseType.Redirection -> TODO()
            ResponseType.ClientError -> throw ClientException((response as ClientError<*>).body as? String ?: "Client error")
            ResponseType.ServerError -> throw ServerException((response as ServerError<*>).message ?: "Server error")
        }
    }
}