diff options
author | Robert Jaros <rjaros@finn.pl> | 2018-04-26 15:41:32 +0200 |
---|---|---|
committer | Robert Jaros <rjaros@finn.pl> | 2018-04-26 15:41:32 +0200 |
commit | 95c1cdec5b0e65a0f617d5fa88d1d49a7abcfe95 (patch) | |
tree | b3dc67083cad67d44a385605e4c915a0a05f47bb /kvision-common/src/main/kotlin/pl/treksoft/kvision/remote/ServiceManager.kt | |
parent | 5b9535e9964816eb228d3797f4c8a3e7676d1f53 (diff) | |
download | kvision-95c1cdec5b0e65a0f617d5fa88d1d49a7abcfe95.tar.gz kvision-95c1cdec5b0e65a0f617d5fa88d1d49a7abcfe95.tar.bz2 kvision-95c1cdec5b0e65a0f617d5fa88d1d49a7abcfe95.zip |
Automatic JSON-RPC conectivity.
CallAgent component for remote JSON-RPC and AJAX.
Diffstat (limited to 'kvision-common/src/main/kotlin/pl/treksoft/kvision/remote/ServiceManager.kt')
-rw-r--r-- | kvision-common/src/main/kotlin/pl/treksoft/kvision/remote/ServiceManager.kt | 58 |
1 files changed, 49 insertions, 9 deletions
diff --git a/kvision-common/src/main/kotlin/pl/treksoft/kvision/remote/ServiceManager.kt b/kvision-common/src/main/kotlin/pl/treksoft/kvision/remote/ServiceManager.kt index 4a6be56b..b3db5d0e 100644 --- a/kvision-common/src/main/kotlin/pl/treksoft/kvision/remote/ServiceManager.kt +++ b/kvision-common/src/main/kotlin/pl/treksoft/kvision/remote/ServiceManager.kt @@ -23,7 +23,20 @@ package pl.treksoft.kvision.remote import kotlinx.coroutines.experimental.Deferred -const val SERVICE_PREFIX = "/kv_service" +enum class RpcHttpMethod { + POST, + PUT, + DELETE, + OPTIONS +} + +enum class HttpMethod { + GET, + POST, + PUT, + DELETE, + OPTIONS +} /** * Multiplatform service manager. @@ -33,57 +46,84 @@ expect open class ServiceManager<out T>(service: T? = null) { * Binds a given route with a function of the receiver. * @param route a route * @param function a function of the receiver + * @param method a HTTP method + * @param prefix an URL address prefix */ - protected inline fun <reified RET> bind(route: String, noinline function: T.(Request?) -> Deferred<RET>) + protected inline fun <reified RET> bind( + route: String, + noinline function: T.(Request?) -> Deferred<RET>, + method: RpcHttpMethod = RpcHttpMethod.POST, + prefix: String = "/" + ) /** * Binds a given route with a function of the receiver. * @param route a route * @param function a function of the receiver + * @param method a HTTP method + * @param prefix an URL address prefix */ protected inline fun <reified PAR, reified RET> bind( route: String, - noinline function: T.(PAR, Request?) -> Deferred<RET> + noinline function: T.(PAR, Request?) -> Deferred<RET>, + method: RpcHttpMethod = RpcHttpMethod.POST, + prefix: String = "/" ) /** * Binds a given route with a function of the receiver. * @param route a route * @param function a function of the receiver + * @param method a HTTP method + * @param prefix an URL address prefix */ protected inline fun <reified PAR1, reified PAR2, reified RET> bind( route: String, - noinline function: T.(PAR1, PAR2, Request?) -> Deferred<RET> + noinline function: T.(PAR1, PAR2, Request?) -> Deferred<RET>, + method: RpcHttpMethod = RpcHttpMethod.POST, + prefix: String = "/" ) /** * Binds a given route with a function of the receiver. * @param route a route * @param function a function of the receiver + * @param method a HTTP method + * @param prefix an URL address prefix */ protected inline fun <reified PAR1, reified PAR2, reified PAR3, reified RET> bind( route: String, - noinline function: T.(PAR1, PAR2, PAR3, Request?) -> Deferred<RET> + noinline function: T.(PAR1, PAR2, PAR3, Request?) -> Deferred<RET>, + method: RpcHttpMethod = RpcHttpMethod.POST, + prefix: String = "/" ) /** * Binds a given route with a function of the receiver. * @param route a route * @param function a function of the receiver + * @param method a HTTP method + * @param prefix an URL address prefix */ protected inline fun <reified PAR1, reified PAR2, reified PAR3, reified PAR4, reified RET> bind( route: String, - noinline function: T.(PAR1, PAR2, PAR3, PAR4, Request?) -> Deferred<RET> + noinline function: T.(PAR1, PAR2, PAR3, PAR4, Request?) -> Deferred<RET>, + method: RpcHttpMethod = RpcHttpMethod.POST, + prefix: String = "/" ) /** * Binds a given route with a function of the receiver. * @param route a route * @param function a function of the receiver + * @param method a HTTP method + * @param prefix an URL address prefix */ protected inline fun <reified PAR1, reified PAR2, reified PAR3, reified PAR4, reified PAR5, reified RET> bind( route: String, - noinline function: T.(PAR1, PAR2, PAR3, PAR4, PAR5, Request?) -> Deferred<RET> + noinline function: T.(PAR1, PAR2, PAR3, PAR4, PAR5, Request?) -> Deferred<RET>, + method: RpcHttpMethod = RpcHttpMethod.POST, + prefix: String = "/" ) /** @@ -93,7 +133,7 @@ expect open class ServiceManager<out T>(service: T? = null) { fun applyRoutes(k: JoobyServer) /** - * Returns the list of defined bindings. + * Returns the map of defined paths. */ - fun getCalls(): Map<String, String> + fun getCalls(): Map<String, Pair<String, RpcHttpMethod>> } |