Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[HTTP] Call controller actions using URL from _publicApi instead of _query endpoint #73

Merged
merged 37 commits into from
Apr 27, 2022
Merged
Show file tree
Hide file tree
Changes from 36 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
b5e846f
Build and Call controller actions using URL from _publicApi
Shiranuit Apr 19, 2022
e7b8a5d
use built HTTP Endpoint
Shiranuit Apr 20, 2022
cb1aa32
lint
Shiranuit Apr 20, 2022
971f50e
fix route builder
Shiranuit Apr 20, 2022
53fe55a
lint
Shiranuit Apr 20, 2022
ec77f11
enhance error messages, use proper serialization for header
Shiranuit Apr 20, 2022
1a87c45
lint
Shiranuit Apr 20, 2022
2c9788a
lint
Shiranuit Apr 20, 2022
206cd35
remove toString
Shiranuit Apr 20, 2022
6306341
remove toString
Shiranuit Apr 20, 2022
ed1e26d
remove unused import
Shiranuit Apr 20, 2022
ab72a5d
add custom headers
Shiranuit Apr 20, 2022
d8470a2
LINT
Shiranuit Apr 20, 2022
4b0a1b1
add index and collection in querystring
Shiranuit Apr 20, 2022
e4aa3d5
add comments to explain what has been done in the code
Shiranuit Apr 20, 2022
153b25f
add headers to response object and RequestPayload
Shiranuit Apr 25, 2022
b6115ea
add documentation for headers field in HTTP Request
Shiranuit Apr 25, 2022
242fc0c
add headers field in response
Shiranuit Apr 25, 2022
7c33d83
ensure RawJson is properly stringified
Shiranuit Apr 25, 2022
3cb8d81
remove weird behaviour copied from SDK-JS
Shiranuit Apr 25, 2022
7494137
add other payload properties to skip
Shiranuit Apr 25, 2022
0aec276
lint
Shiranuit Apr 25, 2022
101715a
remove unused import
Shiranuit Apr 25, 2022
3712719
add default headers
Shiranuit Apr 25, 2022
05af4e1
fix body properties not transfered
Shiranuit Apr 25, 2022
366642d
rollback
Apr 25, 2022
e3bc10b
fix tests
Apr 25, 2022
140944c
Merge branch 'call-proper-http-routes' of https://github.com/kuzzleio…
Shiranuit Apr 26, 2022
ddd5752
apply requested changes
Shiranuit Apr 26, 2022
3a5611b
lint
Shiranuit Apr 26, 2022
b840f3d
fix query string
Apr 26, 2022
71b25b4
Merge branch 'call-proper-http-routes' of github.com:kuzzleio/sdk-jvm…
Apr 26, 2022
569b9f1
add better error when failed to parse JSON response
Shiranuit Apr 26, 2022
7d4c70c
remove debug print
Shiranuit Apr 26, 2022
84c3e53
lint
Shiranuit Apr 26, 2022
109d78b
lint
Shiranuit Apr 26, 2022
aeedba3
update compatibility matrix
Shiranuit Apr 27, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
59 changes: 31 additions & 28 deletions doc/1/core-classes/kuzzle/query/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,15 +46,15 @@ public CompletableFuture<Response> query(

<br/>

| Argument | Type | Description |
| --------- | ----------------- | ---------------------- |
| `query` | <pre>Map<String, Object> | API request |
| Argument | Type | Description |
| -------- | ------------------------ | ----------- |
| `query` | <pre>Map<String, Object> | API request |

<SinceBadge version="1.2.3"/>

| Argument | Type | Description |
| --------- | ----------------- | ---------------------- |
| `query` | <pre>Map<String, Object><br>or String<br>or RawJson<br>or RequestPayload<br>or Object</pre> | API request |
| Argument | Type | Description |
| -------- | ------------------------------------------------------------------------------------------- | ----------- |
| `query` | <pre>Map<String, Object><br>or String<br>or RawJson<br>or RequestPayload<br>or Object</pre> | API request |

::: info
Calling query with a `String` or `RawJson` makes no differences, and will be interpreted as raw json strings.
Expand All @@ -74,15 +74,17 @@ This will avoid the deserialization + reserialization slowdown
All properties necessary for the Kuzzle API can be added in the query object.
The following properties are the most common.

| Property | Type | Description |
| ------------ | ----------------- | ---------------------------------------- |
| `controller` | <pre>String</pre> | Controller name (mandatory) |
| `action` | <pre>String</pre> | Action name (mandatory) |
| Property | Type | Description |
| ------------ | --------------------------------------------------------- | ---------------------------------------- |
| `controller` | <pre>String</pre> | Controller name (mandatory) |
| `action` | <pre>String</pre> | Action name (mandatory) |
| `body` | <pre>Map<String, Object><br>or RawJson<br>or Object</pre> | Query body for this action |
| `index` | <pre>String</pre> | Index name for this action |
| `collection` | <pre>String</pre> | Collection name for this action |
| `_id` | <pre>String</pre> | id for this action |
| `index` | <pre>String</pre> | Index name for this action |
| `collection` | <pre>String</pre> | Collection name for this action |
| `_id` | <pre>String</pre> | id for this action |
| `volatile` | <pre>Map<String, Object><br>or RawJson<br>or Object</pre> | Additional information to send to Kuzzle |
| `headers` | <pre>Map<String, Object></pre> | Optionnal headers to send (HTTP Only) |


## Returns

Expand Down Expand Up @@ -112,15 +114,15 @@ fun query(query: Any): CompletableFuture<Response>

<br/>

| Argument | Type | Description |
| --------- | ----------------- | ---------------------- |
| `query` | <pre>Map<String?, Any?> | API request |
| Argument | Type | Description |
| -------- | ----------------------- | ----------- |
| `query` | <pre>Map<String?, Any?> | API request |

<SinceBadge version="1.2.3"/>

| Argument | Type | Description |
| --------- | ----------------- | ---------------------- |
| `query` | <pre>Map<String?, Any?><br>or RawJson<br>or String<br>or RequestPayload<br>or Any</pre> | API request |
| Argument | Type | Description |
| -------- | --------------------------------------------------------------------------------------- | ----------- |
| `query` | <pre>Map<String?, Any?><br>or RawJson<br>or String<br>or RequestPayload<br>or Any</pre> | API request |

::: info
Calling query with a `String` or `RawJson` makes no differences, and will be interpreted as raw json strings.
Expand All @@ -140,15 +142,16 @@ This will avoid the deserialization + reserialization slowdown
All properties necessary for the Kuzzle API can be added in the query object.
The following properties are the most common.

| Property | Type | Description |
| ------------ | ----------------- | ---------------------------------------- |
| `controller` | <pre>String</pre> | Controller name (mandatory) |
| `action` | <pre>String</pre> | Action name (mandatory) |
| `body` | <pre>Map<String, Object><br>or RawJson<br>or Any</pre> | Query body for this action |
| `index` | <pre>String</pre> | Index name for this action |
| `collection` | <pre>String</pre> | Collection name for this action |
| `_id` | <pre>String</pre> | id for this action |
| `volatile` | <pre>Map<String, Object><br>or RawJson<br>or Any</pre> | Additional information to send to Kuzzle |
| Property | Type | Description |
| ------------ | ---------------------------------------------------- | ---------------------------------------- |
| `controller` | <pre>String</pre> | Controller name (mandatory) |
| `action` | <pre>String</pre> | Action name (mandatory) |
| `body` | <pre>Map<String, Any?><br>or RawJson<br>or Any</pre> | Query body for this action |
| `index` | <pre>String</pre> | Index name for this action |
| `collection` | <pre>String</pre> | Collection name for this action |
| `_id` | <pre>String</pre> | id for this action |
| `volatile` | <pre>Map<String, Any?><br>or RawJson<br>or Any</pre> | Additional information to send to Kuzzle |
| `headers` | <pre>Map<String, Any?></pre> | Optionnal headers to send (HTTP Only) |

## Returns

Expand Down
33 changes: 17 additions & 16 deletions doc/1/core-classes/response/introduction/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,19 +12,20 @@ order: 0

## Properties

| Property | Type | Description |
|--- |--- |--- |
| `action` | <pre>String</pre> | Executed Kuzzle API controller's action |
| `collection` | <pre>String</pre> | Impacted collection |
| `controller` | <pre>String</pre> | Executed Kuzzle API controller |
| `error` | <pre>[ErrorResponse](/sdk/jvm/1/core-classes/error-response)</pre> | Error object (null if the request finished successfully) |
| `index` | <pre>String</pre> | Impacted index |
| `protocol` | <pre>String</pre> | Network protocol at the origin of the real-time notification |
| `requestId` | <pre>String</pre> | Request unique identifier |
| `result` | <pre>Object</pre> | Response payload (depends on the executed API action) |
| `room` | <pre>String</pre> | Room identifier (realtime only) |
| `scope` | <pre>String</pre> | Document scope ("in" or "out", realtime only) |
| `state` | <pre>String</pre> | Document state (realtime only) |
| `status` | <pre>int</pre> | Response status, following HTTP status codes |
| `timestamp` | <pre>Long</pre> | Notification timestamp (UTC) |
| `volatile` | <pre>Map<String, Object></pre> | Volatile data |
| Property | Type | Description |
| ------------ | ------------------------------------------------------------------ | ------------------------------------------------------------ |
| `action` | <pre>String</pre> | Executed Kuzzle API controller's action |
| `collection` | <pre>String</pre> | Impacted collection |
| `controller` | <pre>String</pre> | Executed Kuzzle API controller |
| `error` | <pre>[ErrorResponse](/sdk/jvm/1/core-classes/error-response)</pre> | Error object (null if the request finished successfully) |
| `headers` | <pre>Map<String, Object></pre> | Headers returned in the response |
| `index` | <pre>String</pre> | Impacted index |
| `protocol` | <pre>String</pre> | Network protocol at the origin of the real-time notification |
| `requestId` | <pre>String</pre> | Request unique identifier |
| `result` | <pre>Object</pre> | Response payload (depends on the executed API action) |
| `room` | <pre>String</pre> | Room identifier (realtime only) |
| `scope` | <pre>String</pre> | Document scope ("in" or "out", realtime only) |
| `state` | <pre>String</pre> | Document state (realtime only) |
| `status` | <pre>int</pre> | Response status, following HTTP status codes |
| `timestamp` | <pre>Long</pre> | Notification timestamp (UTC) |
| `volatile` | <pre>Map<String, Object></pre> | Volatile data |
28 changes: 21 additions & 7 deletions src/main/kotlin/io/kuzzle/sdk/Kuzzle.kt
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import io.kuzzle.sdk.controllers.RealtimeController
import io.kuzzle.sdk.controllers.ServerController
import io.kuzzle.sdk.coreClasses.RequestPayload
import io.kuzzle.sdk.coreClasses.exceptions.ApiErrorException
import io.kuzzle.sdk.coreClasses.exceptions.InvalidJSON
import io.kuzzle.sdk.coreClasses.exceptions.KuzzleExceptionCode
import io.kuzzle.sdk.coreClasses.exceptions.NotConnectedException
import io.kuzzle.sdk.coreClasses.json.JsonSerializer
Expand Down Expand Up @@ -50,22 +51,34 @@ open class Kuzzle {
collectionController = CollectionController(this)
bulkController = BulkController(this)
// @TODO Create enums for events
protocol.addListener<MessageReceivedEvent>(::onMessageReceived)
protocol.addListener<NetworkStateChangeEvent>(::onNetworkStateChange)
protocol.addListener<RequestErrorEvent>(::onRequestError)
protocol.addListener(::onMessageReceived)
protocol.addListener(::onNetworkStateChange)
protocol.addListener(::onRequestError)
}

private fun onRequestError(event: RequestErrorEvent) {
if (event.requestId != null && queries[event.requestId] != null) {
queries[event.requestId]?.completeExceptionally(event.exception)
queries.remove(event.requestId)
if (event.requestId != null && queries[event.requestId!!] != null) {
queries[event.requestId!!]?.completeExceptionally(event.exception)
queries.remove(event.requestId!!)
}
}

private fun onMessageReceived(event: MessageReceivedEvent) {
val message = event.message
val jsonObject: Map<String?, Any?>
try {
jsonObject = JsonSerializer.deserialize(message) as Map<String?, Any?>
} catch (e: Exception) {
if (event.requestId != null) {
queries[event.requestId]?.completeExceptionally(InvalidJSON(event.message ?: "null"))
queries.remove(event.requestId)
} else {
protocol.trigger(UnhandledResponseEvent(message))
}
return
}
val response = Response().apply {
fromMap(JsonSerializer.deserialize(message) as Map<String?, Any?>)
fromMap(jsonObject)
}

val requestId = event.requestId ?: response.room ?: response.requestId
Expand All @@ -90,6 +103,7 @@ open class Kuzzle {
}

queries[requestId]?.completeExceptionally(ApiErrorException(response))
queries.remove(requestId)
protocol.trigger(TokenExpiredEvent())
}

Expand Down
6 changes: 5 additions & 1 deletion src/main/kotlin/io/kuzzle/sdk/controllers/AuthController.kt
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import io.kuzzle.sdk.coreClasses.lang.Lang
import io.kuzzle.sdk.coreClasses.maps.KuzzleMap
import io.kuzzle.sdk.coreClasses.responses.Response
import io.kuzzle.sdk.events.LoginAttemptEvent
import io.kuzzle.sdk.events.LogoutAttemptEvent
import java.util.concurrent.CompletableFuture

class AuthController(kuzzle: Kuzzle) : BaseController(kuzzle) {
Expand Down Expand Up @@ -164,7 +165,10 @@ class AuthController(kuzzle: Kuzzle) : BaseController(kuzzle) {
put("controller", "auth")
put("action", "logout")
}
return kuzzle.query(query)
return kuzzle.query(query).thenApplyAsync { response ->
kuzzle.protocol.trigger(LogoutAttemptEvent())
response
}
}

@JvmOverloads
Expand Down
7 changes: 6 additions & 1 deletion src/main/kotlin/io/kuzzle/sdk/coreClasses/RequestPayload.kt
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ data class RequestPayload(
var volatile: Any? = null,
var body: Any? = null,
var requestId: String? = null,
var other: Map<String?, Any?>? = null
var other: Map<String?, Any?>? = null,
var headers: Map<String?, Any?>? = null,
) {
fun toMap(): Map<String?, Any?> {
val map = HashMap<String?, Any?>()
Expand Down Expand Up @@ -64,6 +65,10 @@ data class RequestPayload(
map["requestId"] = requestId
}

if (headers != null) {
map["headers"] = headers
}

if (other != null) {
map.putAll(other!!)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,8 @@ class ApiErrorException : KuzzleException {
constructor(response: Response) :
super(response.error?.message, response.status) {
if (response.error != null) {
this.stack = response.error?.stack
this.id = response.error?.id
this.stack = response.error!!.stack
this.id = response.error!!.id
OlivierCavadenti marked this conversation as resolved.
Show resolved Hide resolved
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
package io.kuzzle.sdk.coreClasses.exceptions

class InvalidJSON(json: String) : KuzzleException("Invalid JSON \"$json\".", 0)
Original file line number Diff line number Diff line change
@@ -1,7 +1,13 @@
package io.kuzzle.sdk.coreClasses.exceptions

enum class KuzzleExceptionCode {
MISSING_REQUESTID(0, "Missing field requestId"), MISSING_QUERY(400, "You must provide a query"), NOT_CONNECTED(500, "Not connected."), CONNECTION_LOST(500, "Connection lost"), WRONG_VOLATILE_TYPE(
MISSING_REQUESTID(0, "Missing field requestId"),
MISSING_CONTROLLER(0, "Missing field controller"),
MISSING_ACTION(0, "Missing field action"),
MISSING_QUERY(400, "You must provide a query"),
NOT_CONNECTED(500, "Not connected."),
CONNECTION_LOST(500, "Connection lost"),
WRONG_VOLATILE_TYPE(
400,
"Volatile data must be a Map<String, Object>"
);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
package io.kuzzle.sdk.coreClasses.exceptions

open class MissingActionException : KuzzleException(KuzzleExceptionCode.MISSING_ACTION)
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
package io.kuzzle.sdk.coreClasses.exceptions

open class MissingControllerException : KuzzleException(KuzzleExceptionCode.MISSING_CONTROLLER)
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
package io.kuzzle.sdk.coreClasses.exceptions

/**
* Thrown when attempting to interact with the network while not connected.
*/
class MissingURLParamException(templateParam: String, baseURL: String) : KuzzleException("Missing URL Param $templateParam in $baseURL", 0)
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
package io.kuzzle.sdk.coreClasses.exceptions

class URLNotFoundException(controller: String, action: String) : KuzzleException("No URL found for \"$controller:$action\".", 400)
10 changes: 10 additions & 0 deletions src/main/kotlin/io/kuzzle/sdk/coreClasses/http/HttpRequest.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
package io.kuzzle.sdk.coreClasses.http

import io.kuzzle.sdk.coreClasses.maps.KuzzleMap

data class HttpRequest(
val verb: String,
val url: String,
val body: KuzzleMap?,
val headers: KuzzleMap,
)
Loading