/* * #%L * GarethHealy :: JBoss Fuse Examples :: WS Playground :: WS Security HTTPS CXF Client * %% * Copyright (C) 2013 - 2017 Gareth Healy * %% * Licensed 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. * #L% */ package com.garethahealy.wssecurity.https.cxf.client.resolvers; import java.util.HashMap; import java.util.Map; import com.garethahealy.wssecurity.https.cxf.client.config.WsEndpointConfiguration; import org.apache.cxf.jaxws.JaxWsProxyFactoryBean; public class CachedResolver<T> implements Resolver<T> { private Map<String, T> cached; private WsEndpointConfiguration<?> config; private JaxWsProxyFactoryBean factory; public CachedResolver(WsEndpointConfiguration<?> config, JaxWsProxyFactoryBean factory) { this.cached = new HashMap<String, T>(); this.config = config; this.factory = factory; } @SuppressWarnings("unchecked") @Override public synchronized T createEndpoint() { T port = null; //NOTE: We want to cache endpoints, but since endpoints are configured with keystores for //signatures we need to cache via a key such as below String url = config.getWsAddress(); String certAlias = config.getCertifactionAlias(); String signatureKeystore = config.getSignatureKeystoreFilename(); String key = String.format("%s_%s_%s", url, certAlias, signatureKeystore); if (cached.containsKey(key)) { port = cached.get(key); } else { port = (T)factory.create(); cached.put(key, port); } return port; } }