blob: a31dc1962711385ae759d4c33e0ea183cf1495eb [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// kamel run NettySecureServer.java --resource file:KeyStore.jks@/etc/ssl/keystore.jks
// --resource file:truststore.jks@/etc/ssl/truststore.jks -t container.port=8443 --dev
//
// recover the service location. If you're running on minikube, "minikube service netty-secure-server --url=true --https=true"
// curl https://<service-location>/hello
//
import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.support.jsse.*;
public class NettySecureServer extends RouteBuilder {
@Override
public void configure() throws Exception {
registerSslContextParameter();
from("netty-http:https://0.0.0.0:8443/hello?sslContextParameters=#sslContextParameters&ssl=true")
.transform().constant("Hello Secure World");
}
private void registerSslContextParameter() throws Exception {
KeyStoreParameters ksp = new KeyStoreParameters();
ksp.setResource("/etc/ssl/keystore.jks");
ksp.setPassword("changeit");
KeyManagersParameters kmp = new KeyManagersParameters();
kmp.setKeyPassword("changeit");
kmp.setKeyStore(ksp);
KeyStoreParameters tsp = new KeyStoreParameters();
tsp.setResource("/etc/ssl/truststore.jks");
tsp.setPassword("changeit");
TrustManagersParameters tmp = new TrustManagersParameters();
tmp.setKeyStore(tsp);
SSLContextParameters sslContextParameters = new SSLContextParameters();
sslContextParameters.setKeyManagers(kmp);
sslContextParameters.setTrustManagers(tmp);
this.getContext().getRegistry().bind("sslContextParameters", sslContextParameters);
}
}