Skip to content

Commit

Permalink
Leverage platform http service in camel-knative #264
Browse files Browse the repository at this point in the history
  • Loading branch information
lburgazzoli committed Mar 24, 2020
1 parent 15e692a commit 46b9371
Show file tree
Hide file tree
Showing 34 changed files with 618 additions and 762 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@
import io.vertx.core.json.JsonArray;
import io.vertx.core.json.JsonObject;
import io.vertx.ext.web.Route;
import io.vertx.ext.web.Router;
import org.apache.camel.CamelContext;
import org.apache.camel.Ordered;
import org.apache.camel.health.HealthCheck;
Expand All @@ -35,7 +34,7 @@
import org.apache.camel.impl.health.ContextHealthCheck;
import org.apache.camel.impl.health.RoutesHealthCheckRepository;
import org.apache.camel.k.ContextCustomizer;
import org.apache.camel.k.http.PlatformHttpRouter;
import org.apache.camel.k.http.PlatformHttp;

public class HealthContextCustomizer implements ContextCustomizer {
public static final String DEFAULT_PATH = "/health";
Expand Down Expand Up @@ -110,12 +109,17 @@ public void apply(CamelContext camelContext) {
// add health route
addRoute(
camelContext,
PlatformHttpRouter.lookup(camelContext).get()
PlatformHttp.lookup(camelContext)
);
}

private Route addRoute(CamelContext camelContext, Router router) {
return router.route(HttpMethod.GET, path).handler(routingContext -> {
private Route addRoute(CamelContext camelContext, PlatformHttp platformHttp) {
Route route = platformHttp.router().route(HttpMethod.GET, path);

// add global handlers first i.e. body handler
platformHttp.handlers().forEach(route::handler);

route.handler(routingContext -> {
int code = 200;

Collection<HealthCheck.Result> results = HealthCheckHelper.invoke(
Expand Down Expand Up @@ -158,5 +162,7 @@ private Route addRoute(CamelContext camelContext, Router router) {
.setStatusCode(code)
.end(Json.encodePrettily(response));
});

return route;
}
}
1 change: 0 additions & 1 deletion camel-k-main/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@
<modules>
<module>camel-k-runtime-main</module>
<module>camel-k-runtime-health</module>
<module>camel-k-runtime-http</module>
</modules>

</project>
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@
import io.quarkus.deployment.annotations.Record;
import io.quarkus.deployment.builditem.nativeimage.ReflectiveClassBuildItem;
import io.quarkus.vertx.core.deployment.CoreVertxBuildItem;
import io.quarkus.vertx.http.deployment.BodyHandlerBuildItem;
import io.quarkus.vertx.http.deployment.VertxWebRouterBuildItem;
import org.apache.camel.component.knative.spi.KnativeEnvironment;
import org.apache.camel.k.quarkus.knative.KnativeRecorder;
import org.apache.camel.quarkus.core.deployment.CamelRuntimeBeanBuildItem;
Expand All @@ -41,11 +43,19 @@ void servicesFilters(BuildProducer<CamelServiceFilterBuildItem> serviceFilter) {

@Record(ExecutionTime.RUNTIME_INIT)
@BuildStep
CamelRuntimeBeanBuildItem knativeComponent(KnativeRecorder recorder, CoreVertxBuildItem vertx) {
CamelRuntimeBeanBuildItem knativeComponent(
KnativeRecorder recorder,
CoreVertxBuildItem vertx,
VertxWebRouterBuildItem router,
BodyHandlerBuildItem bodyHandlerBuildItem) {

return new CamelRuntimeBeanBuildItem(
"knative",
"org.apache.camel.component.knative.KnativeComponent",
recorder.createKnativeComponent(vertx.getVertx())
recorder.createKnativeComponent(
vertx.getVertx(),
router.getRouter(),
bodyHandlerBuildItem.getHandler())
);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,19 +16,32 @@
*/
package org.apache.camel.k.quarkus.knative;

import java.util.Collections;
import java.util.function.Supplier;

import io.quarkus.runtime.RuntimeValue;
import io.quarkus.runtime.annotations.Recorder;
import io.vertx.core.Handler;
import io.vertx.core.Vertx;
import io.vertx.ext.web.Router;
import io.vertx.ext.web.RoutingContext;
import org.apache.camel.component.knative.KnativeComponent;
import org.apache.camel.component.knative.http.KnativeHttpTransport;
import org.apache.camel.k.http.PlatformHttp;

@Recorder
public class KnativeRecorder {
public RuntimeValue<KnativeComponent> createKnativeComponent(Supplier<Vertx> vertx) {
public RuntimeValue<KnativeComponent> createKnativeComponent(
Supplier<Vertx> vertx,
RuntimeValue<Router> router,
Handler<RoutingContext> bodyHandler) {

KnativeHttpTransport transport = new KnativeHttpTransport();
transport.setVertx(vertx.get());
transport.setPlatformHttp(new PlatformHttp(
vertx.get(),
router.getValue(),
Collections.singletonList(bodyHandler)
));

KnativeComponent component = new KnativeComponent();
component.setTransport(transport);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,10 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<groupId>org.apache.camel.k</groupId>
<artifactId>camel-k-main</artifactId>
<artifactId>camel-k-runtime-parent</artifactId>
<version>1.2.2-SNAPSHOT</version>
</parent>

<modelVersion>4.0.0</modelVersion>

<artifactId>camel-k-runtime-http</artifactId>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,35 +16,60 @@
*/
package org.apache.camel.k.http;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

import io.vertx.core.Handler;
import io.vertx.core.Vertx;
import io.vertx.ext.web.Router;
import io.vertx.ext.web.RoutingContext;
import org.apache.camel.CamelContext;
import org.apache.camel.component.platform.http.PlatformHttpConstants;
import org.apache.camel.support.CamelContextHelper;

public class PlatformHttpRouter {
public class PlatformHttp {
public static final String PLATFORM_HTTP_ROUTER_NAME = PlatformHttpConstants.PLATFORM_HTTP_COMPONENT_NAME + "-router";

private final Vertx vertx;
private final Router router;
private final List<Handler<RoutingContext>> handlers;

public PlatformHttp(Vertx vertx, Router router) {
this.vertx = vertx;
this.router = router;
this.handlers = Collections.emptyList();
}

public PlatformHttpRouter(Router router) {
public PlatformHttp(Vertx vertx, Router router, List<Handler<RoutingContext>> handlers) {
this.vertx = vertx;
this.router = router;
this.handlers = Collections.unmodifiableList(new ArrayList<>(handlers));
}

public Router get() {
public Vertx vertx() {
return vertx;
}

public Router router() {
return router;
}

public List<Handler<RoutingContext>> handlers() {
return handlers;
}

// **********************
//
// Helpers
//
// **********************

public static PlatformHttpRouter lookup(CamelContext camelContext) {
public static PlatformHttp lookup(CamelContext camelContext) {
return CamelContextHelper.mandatoryLookup(
camelContext,
PlatformHttpRouter.PLATFORM_HTTP_ROUTER_NAME,
PlatformHttpRouter.class
PlatformHttp.PLATFORM_HTTP_ROUTER_NAME,
PlatformHttp.class
);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
*/
package org.apache.camel.k.http;

import java.util.Collections;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CompletionStage;
import java.util.concurrent.CountDownLatch;
Expand All @@ -33,7 +34,7 @@
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

final class PlatformHttpServer extends ServiceSupport {
public final class PlatformHttpServer extends ServiceSupport {
private static final Logger LOGGER = LoggerFactory.getLogger(PlatformHttpServer.class);

private final CamelContext context;
Expand Down Expand Up @@ -70,16 +71,12 @@ private CompletionStage<Void> startAsync() {
final Router router = Router.router(vertx);
final Router subRouter = Router.router(vertx);

router.route()
.order(Integer.MIN_VALUE)
.handler(ctx -> {
ctx.request().resume();
createBodyHandler().handle(ctx);
});

router.mountSubRouter(configuration.getPath(), subRouter);

context.getRegistry().bind(PlatformHttpRouter.PLATFORM_HTTP_ROUTER_NAME, new PlatformHttpRouter(subRouter));
context.getRegistry().bind(
PlatformHttp.PLATFORM_HTTP_ROUTER_NAME,
new PlatformHttp(vertx, subRouter, Collections.singletonList(createBodyHandler()))
);

//HttpServerOptions options = new HttpServerOptions();
if (configuration.getSslContextParameters() != null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ public class PlatformHttpServiceConfiguration {
private String path = DEFAULT_PATH;
private BigInteger maxBodySize;

private BodyHandler bodyHandler = new BodyHandler();
private BodyHandlerConfiguration bodyHandlerConfiguration = new BodyHandlerConfiguration();
private SSLContextParameters sslContextParameters;

public String getBindHost() {
Expand Down Expand Up @@ -65,12 +65,12 @@ public void setMaxBodySize(BigInteger maxBodySize) {
this.maxBodySize = maxBodySize;
}

public BodyHandler getBodyHandler() {
return bodyHandler;
public BodyHandlerConfiguration getBodyHandler() {
return bodyHandlerConfiguration;
}

public void setBodyHandler(BodyHandler bodyHandler) {
this.bodyHandler = bodyHandler;
public void setBodyHandler(BodyHandlerConfiguration bodyHandler) {
this.bodyHandlerConfiguration = bodyHandler;
}

public SSLContextParameters getSslContextParameters() {
Expand All @@ -81,7 +81,7 @@ public void setSslContextParameters(SSLContextParameters sslContextParameters) {
this.sslContextParameters = sslContextParameters;
}

public static class BodyHandler {
public static class BodyHandlerConfiguration {
private boolean handleFileUploads = true;
private String uploadsDirectory = "file-uploads";
private boolean mergeFormAttributes = true;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@
import org.apache.camel.TypeConverter;
import org.apache.camel.component.platform.http.PlatformHttpEndpoint;
import org.apache.camel.component.platform.http.spi.Method;
import org.apache.camel.k.http.PlatformHttpRouter;
import org.apache.camel.k.http.PlatformHttp;
import org.apache.camel.spi.HeaderFilterStrategy;
import org.apache.camel.support.DefaultConsumer;
import org.apache.camel.support.DefaultMessage;
Expand Down Expand Up @@ -75,10 +75,12 @@ protected void doStart() throws Exception {
super.doStart();

final PlatformHttpEndpoint endpoint = getEndpoint();
final PlatformHttpRouter router = PlatformHttpRouter.lookup(endpoint.getCamelContext());
final PlatformHttp router = PlatformHttp.lookup(endpoint.getCamelContext());
final String path = endpoint.getPath();
final String vertxPathParamPath = PATH_PARAMETER_PATTERN.matcher(path).replaceAll(":$1");
final Route newRoute = router.get().route(vertxPathParamPath);
final Route newRoute = router.router().route(vertxPathParamPath);

router.handlers().forEach(newRoute::handler);

final Set<Method> methods = Method.parseList(endpoint.getHttpMethodRestrict());
if (!methods.equals(Method.getAll())) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ public void testPlatformHttpServiceCustomizer(String path) throws Exception {

httpService.apply(runtime.getCamelContext());

PlatformHttpRouter.lookup(runtime.getCamelContext()).get().route(HttpMethod.GET, "/my/path")
PlatformHttp.lookup(runtime.getCamelContext()).router().route(HttpMethod.GET, "/my/path")
.handler(routingContext -> {
JsonObject response = new JsonObject();
response.put("status", "UP");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
import org.apache.camel.k.Source;
import org.apache.camel.k.SourceLoader;
import org.apache.camel.k.Sources;
import org.apache.camel.k.http.PlatformHttpServiceContextCustomizer;
import org.apache.camel.k.listener.RoutesConfigurer;
import org.apache.camel.k.loader.java.JavaSourceLoader;
import org.apache.camel.model.ModelCamelContext;
Expand Down Expand Up @@ -69,6 +70,7 @@ public void testWrapLoader(String uri) throws Exception {
LOGGER.info("uri: {}", uri);

final int port = AvailablePortFinder.getNextAvailable();
final int platformHttpPort = AvailablePortFinder.getNextAvailable();
final String data = UUID.randomUUID().toString();

KnativeComponent component = new KnativeComponent();
Expand Down Expand Up @@ -173,10 +175,16 @@ public void testWrapLoaderWithBeanRegistration() throws Exception {
static class TestRuntime implements Runtime {
private final CamelContext camelContext;
private final List<RoutesBuilder> builders;
private final int platformHttpPort;

public TestRuntime() {
this.camelContext = new DefaultCamelContext();
this.builders = new ArrayList<>();
this.platformHttpPort = AvailablePortFinder.getNextAvailable();

PlatformHttpServiceContextCustomizer httpService = new PlatformHttpServiceContextCustomizer();
httpService.setBindPort(platformHttpPort);
httpService.apply(this.camelContext);
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,17 @@ public static KnativeServiceDefinition endpoint(Knative.EndpointKind endpointKin
);
}

public static KnativeServiceDefinition sourceEndpoint(String name, Map<String, String> metadata) {
return entry(
Knative.EndpointKind.source,
Knative.Type.endpoint,
name,
null,
-1,
metadata
);
}

public static KnativeServiceDefinition channel(Knative.EndpointKind endpointKind, String name, String host, int port) {
return entry(
endpointKind,
Expand Down Expand Up @@ -157,6 +168,28 @@ public static KnativeServiceDefinition event(Knative.EndpointKind endpointKind,
);
}

public static KnativeServiceDefinition sourceEvent(String name) {
return entry(
Knative.EndpointKind.source,
Knative.Type.event,
name,
null,
-1,
Collections.emptyMap()
);
}

public static KnativeServiceDefinition sourceEvent(String name, Map<String, String> metadata) {
return entry(
Knative.EndpointKind.source,
Knative.Type.event,
name,
null,
-1,
metadata
);
}

public static KnativeServiceDefinition event(Knative.EndpointKind endpointKind, String name, String host, int port, Map<String, String> metadata) {
return entry(
endpointKind,
Expand Down Expand Up @@ -198,8 +231,8 @@ public static final class KnativeServiceDefinition extends DefaultServiceDefinit
public KnativeServiceDefinition(
@JsonProperty(value = "type", required = true) Knative.Type type,
@JsonProperty(value = "name", required = true) String name,
@JsonProperty(value = "host", required = true) String host,
@JsonProperty(value = "port", required = true) int port,
@JsonProperty(value = "host", required = false) String host,
@JsonProperty(value = "port", required = false) int port,
@JsonProperty(value = "metadata", required = false) Map<String, String> metadata) {

super(
Expand Down
Loading

0 comments on commit 46b9371

Please sign in to comment.