2 * ============LICENSE_START=======================================================
3 * DCAEGEN2-SERVICES-SDK
4 * ================================================================================
5 * Copyright (C) 2019 Nokia. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
20 package org.onap.dcaegen2.services.sdk.services.hvves.client.producer.api;
22 import java.util.Iterator;
23 import java.util.ServiceLoader;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
28 * @author <a href="mailto:piotr.jaszczyk@nokia.com">Piotr Jaszczyk</a>
30 final class FactoryLoader {
32 private FactoryLoader() {
35 private static final Logger LOGGER = LoggerFactory.getLogger(FactoryLoader.class);
37 static <T> T findInstance(Class<T> clazz) {
38 Iterator<T> instances = ServiceLoader.load(clazz).iterator();
39 if (instances.hasNext()) {
40 final T head = instances.next();
41 if (instances.hasNext()) {
42 LOGGER.warn("Found more than one implementation of {} on the class path. Using {}.",
43 clazz.getSimpleName(), head.getClass().getName());
47 throw new IllegalStateException(
48 "No " + clazz.getSimpleName() + " instances were configured. Are you sure you have runtime dependency on an implementation module?");