Skip to content

Commit

Permalink
added possibility to add route interceptor to SseThingsRoute
Browse files Browse the repository at this point in the history
Signed-off-by: Thomas Jaeckle <thomas.jaeckle@bosch-si.com>
  • Loading branch information
thjaeckle committed Aug 13, 2018
1 parent a7f0021 commit 88a9e35
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -360,7 +360,7 @@ private Route buildApiSubRoutes(final RequestContext ctx, final DittoHeaders dit
// /api/{apiVersion}/policies
policiesRoute.buildPoliciesRoute(ctx, dittoHeaders),
// /api/{apiVersion}/things SSE support
sseThingsRoute.buildThingsSseRoute(ctx, dittoHeaders),
sseThingsRoute.buildThingsSseRoute(ctx, dittoHeaders, Function.identity()),
// /api/{apiVersion}/things
thingsRoute.buildThingsRoute(ctx, dittoHeaders),
// /api/{apiVersion}/search/things
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
import java.util.UUID;
import java.util.concurrent.TimeUnit;
import java.util.function.BiFunction;
import java.util.function.Function;
import java.util.stream.StreamSupport;

import org.eclipse.ditto.json.JsonField;
Expand Down Expand Up @@ -121,20 +122,23 @@ public SseThingsRoute(final ActorRef proxyActor, final ActorSystem actorSystem,
* @return {@code /things} SSE route.
*/
@SuppressWarnings("squid:S1172") // allow unused ctx-Param in order to have a consistent route-"interface"
public Route buildThingsSseRoute(final RequestContext ctx, final DittoHeaders dittoHeaders) {
public Route buildThingsSseRoute(final RequestContext ctx, final DittoHeaders dittoHeaders,
final Function<Route, Route> inner) {
return rawPathPrefix(mergeDoubleSlashes().concat(PATH_THINGS), () ->
pathEndOrSingleSlash(() ->
get(() ->
headerValuePF(AcceptHeaderExtractor.INSTANCE, accept ->
parameterOptional(ThingsParameter.FIELDS.toString(), fieldsString ->
inner.apply(parameterOptional(ThingsParameter.FIELDS.toString(), fieldsString ->
parameterOptional(ThingsParameter.IDS.toString(),
idsString -> // "ids" is optional for SSE
createSseRoute(dittoHeaders,
calculateSelectedFields(fieldsString).orElse(
null),
idsString.map(ids -> ids.split(",")))
)
idsString.map(ids -> ids.split(","))
)
))
)

)
)
)
Expand Down

0 comments on commit 88a9e35

Please sign in to comment.