blob: 548b11484b743d71c8c538bf87c7730b52fe11a7 [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.
*/
// Generate keystore.jks and truststore.jks (for this example, keystore and truststore password = changeit):
//
// keytool -genkeypair -alias EntryName -keyalg RSA -keysize 2048 -keystore keystore.jks
// keytool -exportcert -alias EntryName -keystore keystore.jks -rfc -file public.cert
// keytool -import -alias EntryName -file public.cert -storetype JKS -keystore truststore.jks
// Run the integration:
//
// 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
// Test
//
// 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);
}
}