org.apache.camel.component.reactive.streams.ReactiveStreamsHelper Maven / Gradle / Ivy
/*
* 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.
*/
package org.apache.camel.component.reactive.streams;
import org.apache.camel.CamelContext;
import org.apache.camel.Exchange;
import org.apache.camel.ExchangePattern;
import org.apache.camel.component.reactive.streams.api.CamelReactiveStreamsService;
import org.apache.camel.component.reactive.streams.api.CamelReactiveStreamsServiceFactory;
import org.apache.camel.component.reactive.streams.api.DispatchCallback;
import org.apache.camel.component.reactive.streams.engine.ReactiveStreamsEngineConfiguration;
import org.apache.camel.spi.FactoryFinder;
import org.apache.camel.support.CamelContextHelper;
import org.apache.camel.support.DefaultExchange;
import org.apache.camel.util.ObjectHelper;
public final class ReactiveStreamsHelper {
private ReactiveStreamsHelper() {
}
public static DispatchCallback getCallback(Exchange exchange) {
return exchange.getIn().getHeader(ReactiveStreamsConstants.REACTIVE_STREAMS_CALLBACK, DispatchCallback.class);
}
public static DispatchCallback attachCallback(Exchange exchange, DispatchCallback callback) {
exchange.getIn().setHeader(ReactiveStreamsConstants.REACTIVE_STREAMS_CALLBACK, callback);
return callback;
}
public static DispatchCallback detachCallback(Exchange exchange) {
DispatchCallback callback = getCallback(exchange);
if (callback != null) {
exchange.getIn().removeHeader(ReactiveStreamsConstants.REACTIVE_STREAMS_CALLBACK);
}
return callback;
}
public static boolean invokeDispatchCallback(Exchange exchange) {
return invokeDispatchCallback(exchange, null);
}
public static boolean invokeDispatchCallback(Exchange exchange, Throwable error) {
DispatchCallback callback = getCallback(exchange);
if (callback != null) {
callback.processed(exchange, error);
return true;
}
return false;
}
public static Exchange convertToExchange(CamelContext context, Object data) {
Exchange exchange;
if (data instanceof Exchange) {
exchange = (Exchange) data;
} else {
exchange = new DefaultExchange(context);
exchange.setPattern(ExchangePattern.InOut);
exchange.getIn().setBody(data);
}
return exchange;
}
public static T findInstance(CamelContext context, String name, Class type) {
return ObjectHelper.isEmpty(name)
? CamelContextHelper.findSingleByType(context, type)
: CamelContextHelper.lookup(context, name, type);
}
/**
* Helper to lookup/create an instance of {@link CamelReactiveStreamsService}
*/
public static CamelReactiveStreamsService resolveReactiveStreamsService(
CamelContext context, String serviceType, ReactiveStreamsEngineConfiguration configuration) {
// First try to find out if a service has already been bound to the registry
CamelReactiveStreamsService service
= ReactiveStreamsHelper.findInstance(context, serviceType, CamelReactiveStreamsService.class);
if (service != null) {
// If the service is bound to the registry we assume it is already
// configured so let's return it as it is.
return service;
} else {
// Then try to find out if a service factory is bound to the registry
CamelReactiveStreamsServiceFactory factory
= ReactiveStreamsHelper.findInstance(context, serviceType, CamelReactiveStreamsServiceFactory.class);
if (factory == null) {
// Try to find out a service factory with service loader style
// using the provided service with fallback to default one
factory = resolveServiceFactory(context,
serviceType != null ? serviceType : ReactiveStreamsConstants.DEFAULT_SERVICE_NAME);
}
return factory.newInstance(context, configuration);
}
}
public static CamelReactiveStreamsServiceFactory resolveServiceFactory(CamelContext context, String serviceType) {
try {
FactoryFinder finder
= context.getCamelContextExtension().getFactoryFinder(ReactiveStreamsConstants.SERVICE_PATH);
Class> serviceClass = finder.findClass(serviceType).orElse(null);
if (serviceClass != null) {
return (CamelReactiveStreamsServiceFactory) context.getInjector().newInstance(serviceClass);
} else {
throw new IllegalStateException(
"Class referenced in '" + ReactiveStreamsConstants.SERVICE_PATH + serviceType + "' not found");
}
} catch (Exception e) {
throw new IllegalStateException(
"Unable to create the reactive stream service defined in '" + ReactiveStreamsConstants.SERVICE_PATH
+ serviceType + "'",
e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy