All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.camel.ExtendedCamelContext Maven / Gradle / Ivy

There is a newer version: 4.9.0
Show newest version
/*
 * 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;

import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ScheduledExecutorService;

import org.apache.camel.catalog.RuntimeCamelCatalog;
import org.apache.camel.console.DevConsoleResolver;
import org.apache.camel.health.HealthCheckResolver;
import org.apache.camel.spi.AnnotationBasedProcessorFactory;
import org.apache.camel.spi.AsyncProcessorAwaitManager;
import org.apache.camel.spi.BeanIntrospection;
import org.apache.camel.spi.BeanProcessorFactory;
import org.apache.camel.spi.BeanProxyFactory;
import org.apache.camel.spi.BootstrapCloseable;
import org.apache.camel.spi.CamelBeanPostProcessor;
import org.apache.camel.spi.CamelDependencyInjectionAnnotationFactory;
import org.apache.camel.spi.ComponentNameResolver;
import org.apache.camel.spi.ComponentResolver;
import org.apache.camel.spi.ConfigurerResolver;
import org.apache.camel.spi.DataFormatResolver;
import org.apache.camel.spi.DeferServiceFactory;
import org.apache.camel.spi.EndpointStrategy;
import org.apache.camel.spi.EndpointUriFactory;
import org.apache.camel.spi.ExchangeFactory;
import org.apache.camel.spi.ExchangeFactoryManager;
import org.apache.camel.spi.FactoryFinder;
import org.apache.camel.spi.FactoryFinderResolver;
import org.apache.camel.spi.HeadersMapFactory;
import org.apache.camel.spi.InterceptEndpointFactory;
import org.apache.camel.spi.InterceptStrategy;
import org.apache.camel.spi.InternalProcessorFactory;
import org.apache.camel.spi.LanguageResolver;
import org.apache.camel.spi.LifecycleStrategy;
import org.apache.camel.spi.LogListener;
import org.apache.camel.spi.ManagementMBeanAssembler;
import org.apache.camel.spi.ModelJAXBContextFactory;
import org.apache.camel.spi.ModelToXMLDumper;
import org.apache.camel.spi.ModelineFactory;
import org.apache.camel.spi.NodeIdFactory;
import org.apache.camel.spi.NormalizedEndpointUri;
import org.apache.camel.spi.PackageScanClassResolver;
import org.apache.camel.spi.PackageScanResourceResolver;
import org.apache.camel.spi.ProcessorExchangeFactory;
import org.apache.camel.spi.ProcessorFactory;
import org.apache.camel.spi.ReactiveExecutor;
import org.apache.camel.spi.Registry;
import org.apache.camel.spi.ResourceLoader;
import org.apache.camel.spi.RestBindingJaxbDataFormatFactory;
import org.apache.camel.spi.RouteController;
import org.apache.camel.spi.RouteFactory;
import org.apache.camel.spi.RouteStartupOrder;
import org.apache.camel.spi.RoutesLoader;
import org.apache.camel.spi.StartupStepRecorder;
import org.apache.camel.spi.UnitOfWorkFactory;
import org.apache.camel.spi.UriFactoryResolver;
import org.apache.camel.spi.XMLRoutesDefinitionLoader;

/**
 * Extended {@link CamelContext} which contains the methods and APIs that are not primary intended for Camel end users
 * but for SPI, custom components, or more advanced used-cases with Camel.
 */
public interface ExtendedCamelContext extends CamelContext {

    /**
     * Sets the name (id) of this context.
     * 

* This operation is mostly only used by different Camel runtimes such as camel-spring, camel-cdi, camel-spring-boot * etc. Important: Setting the name should only be set before CamelContext is started. * * @param name the name */ void setName(String name); /** * Sets the registry Camel should use for looking up beans by name or type. *

* This operation is mostly only used by different Camel runtimes such as camel-spring, camel-cdi, camel-spring-boot * etc. Important: Setting the registry should only be set before CamelContext is started. * * @param registry the registry such as DefaultRegistry or */ void setRegistry(Registry registry); /** * Method to signal to {@link CamelContext} that the process to initialize setup routes is in progress. * * @param done false to start the process, call again with true to signal its done. * @see #isSetupRoutes() */ void setupRoutes(boolean done); /** * Indicates whether current thread is setting up route(s) as part of starting Camel. *

* This can be useful to know by {@link LifecycleStrategy} or the likes, in case they need to react differently. *

* As the startup procedure of {@link CamelContext} is slightly different when using plain Java versus * camel-spring-xml or camel-blueprint, then we need to know when spring/blueprint are setting up the routes, which * can happen after the {@link CamelContext} itself is in started state, due the asynchronous event nature of * especially blueprint. * * @return true if current thread is setting up route(s), or false if not. */ boolean isSetupRoutes(); /** * Registers a {@link org.apache.camel.spi.EndpointStrategy callback} to allow you to do custom logic when an * {@link Endpoint} is about to be registered to the {@link org.apache.camel.spi.EndpointRegistry}. *

* When a callback is registered it will be executed on the already registered endpoints allowing you to catch-up * * @param strategy callback to be invoked */ void registerEndpointCallback(EndpointStrategy strategy); /** * Resolves the given name to an {@link Endpoint} of the specified type (scope is prototype). If the name has a * singleton endpoint registered, then the singleton is returned. Otherwise, a new {@link Endpoint} is created. * * The endpoint is NOT registered in the {@link org.apache.camel.spi.EndpointRegistry} as its prototype scoped, and * therefore expected to be short lived and discarded after use (you must stop and shutdown the endpoint when no * longer in use). * * @param uri the URI of the endpoint * @return the endpoint * * @see #getEndpoint(String) */ Endpoint getPrototypeEndpoint(String uri); /** * Resolves the given name to an {@link Endpoint} of the specified type (scope is prototype). If the name has a * singleton endpoint registered, then the singleton is returned. Otherwise, a new {@link Endpoint} is created. * * The endpoint is NOT registered in the {@link org.apache.camel.spi.EndpointRegistry} as its prototype scoped, and * therefore expected to be short lived and discarded after use (you must stop and shutdown the endpoint when no * longer in use). * * @param uri the URI of the endpoint * @return the endpoint * * @see #getEndpoint(String) */ Endpoint getPrototypeEndpoint(NormalizedEndpointUri uri); /** * Is the given endpoint already registered in the {@link org.apache.camel.spi.EndpointRegistry} * * @param uri the URI of the endpoint * @return the registered endpoint or null if not registered */ Endpoint hasEndpoint(NormalizedEndpointUri uri); /** * Resolves the given name to an {@link Endpoint} of the specified type. If the name has a singleton endpoint * registered, then the singleton is returned. Otherwise, a new {@link Endpoint} is created and registered in the * {@link org.apache.camel.spi.EndpointRegistry}. * * @param uri the URI of the endpoint * @return the endpoint * * @see #getPrototypeEndpoint(String) */ Endpoint getEndpoint(NormalizedEndpointUri uri); /** * Resolves the given name to an {@link Endpoint} of the specified type. If the name has a singleton endpoint * registered, then the singleton is returned. Otherwise, a new {@link Endpoint} is created and registered in the * {@link org.apache.camel.spi.EndpointRegistry}. * * @param uri the URI of the endpoint * @param parameters the parameters to customize the endpoint * @return the endpoint * * @see #getPrototypeEndpoint(String) */ Endpoint getEndpoint(NormalizedEndpointUri uri, Map parameters); /** * Normalizes the given uri. * * @param uri the uri * @return a normalized uri */ NormalizedEndpointUri normalizeUri(String uri); /** * Returns the order in which the route inputs was started. *

* The order may not be according to the startupOrder defined on the route. For example a route could be started * manually later, or new routes added at runtime. * * @return a list in the order how routes was started */ List getRouteStartupOrder(); /** * Adds a {@link BootstrapCloseable} task. */ void addBootstrap(BootstrapCloseable bootstrap); /** * Returns an unmodifiable list of the services registered currently in this {@link CamelContext}. */ List getServices(); /** * Gets the exchange factory to use. */ ExchangeFactory getExchangeFactory(); /** * Sets a custom exchange factory to use. */ void setExchangeFactory(ExchangeFactory exchangeFactory); /** * Gets the exchange factory manager to use. */ ExchangeFactoryManager getExchangeFactoryManager(); /** * Sets a custom exchange factory manager to use. */ void setExchangeFactoryManager(ExchangeFactoryManager exchangeFactoryManager); /** * Gets the processor exchange factory to use. */ ProcessorExchangeFactory getProcessorExchangeFactory(); /** * Sets a custom processor exchange factory to use. */ void setProcessorExchangeFactory(ProcessorExchangeFactory processorExchangeFactory); /** * Returns the bean post processor used to do any bean customization. * * @return the bean post processor. */ CamelBeanPostProcessor getBeanPostProcessor(); /** * Sets a custom bean post processor to use. */ void setBeanPostProcessor(CamelBeanPostProcessor beanPostProcessor); /** * Returns the annotation dependency injection factory. */ CamelDependencyInjectionAnnotationFactory getDependencyInjectionAnnotationFactory(); /** * Sets a custom annotation dependency injection factory. */ void setDependencyInjectionAnnotationFactory(CamelDependencyInjectionAnnotationFactory factory); /** * Returns the management mbean assembler * * @return the mbean assembler */ ManagementMBeanAssembler getManagementMBeanAssembler(); /** * Gets the default error handler builder which is inherited by the routes * * @return the builder */ ErrorHandlerFactory getErrorHandlerFactory(); /** * Sets the default error handler builder which is inherited by the routes * * @param errorHandlerFactory the builder */ void setErrorHandlerFactory(ErrorHandlerFactory errorHandlerFactory); /** * Gets the node id factory * * @return the node id factory */ NodeIdFactory getNodeIdFactory(); /** * Uses a custom node id factory when generating auto assigned ids to the nodes in the route definitions * * @param factory custom factory to use */ void setNodeIdFactory(NodeIdFactory factory); /** * Gets the {@link ComponentResolver} to use. */ ComponentResolver getComponentResolver(); /** * Sets a custom {@link ComponentResolver} to use. */ void setComponentResolver(ComponentResolver componentResolver); /** * Gets the {@link ComponentNameResolver} to use. */ ComponentNameResolver getComponentNameResolver(); /** * Sets a custom {@link ComponentNameResolver} to use. */ void setComponentNameResolver(ComponentNameResolver componentNameResolver); /** * Gets the {@link LanguageResolver} to use. */ LanguageResolver getLanguageResolver(); /** * Sets a custom {@link LanguageResolver} to use. */ void setLanguageResolver(LanguageResolver languageResolver); /** * Gets the current data format resolver * * @return the resolver */ DataFormatResolver getDataFormatResolver(); /** * Sets a custom data format resolver * * @param dataFormatResolver the resolver */ void setDataFormatResolver(DataFormatResolver dataFormatResolver); /** * Gets the current health check resolver * * @return the resolver */ HealthCheckResolver getHealthCheckResolver(); /** * Sets a custom health check resolver * * @param healthCheckResolver the resolver */ void setHealthCheckResolver(HealthCheckResolver healthCheckResolver); /** * Gets the current dev console resolver * * @return the resolver */ DevConsoleResolver getDevConsoleResolver(); /** * Sets a custom dev console resolver * * @param devConsoleResolver the resolver */ void setDevConsoleResolver(DevConsoleResolver devConsoleResolver); /** * Returns the package scanning class resolver * * @return the resolver */ PackageScanClassResolver getPackageScanClassResolver(); /** * Sets the package scanning class resolver to use * * @param resolver the resolver */ void setPackageScanClassResolver(PackageScanClassResolver resolver); /** * Returns the package scanning resource resolver * * @return the resolver */ PackageScanResourceResolver getPackageScanResourceResolver(); /** * Sets the package scanning resource resolver to use * * @param resolver the resolver */ void setPackageScanResourceResolver(PackageScanResourceResolver resolver); /** * Gets the default FactoryFinder which will be used for the loading the factory class from META-INF * * @return the default factory finder * @see #getBootstrapFactoryFinder() */ FactoryFinder getDefaultFactoryFinder(); /** * Gets the bootstrap FactoryFinder which will be used for the loading the factory class from META-INF. This * bootstrap factory finder is only intended to be used during bootstrap (starting) CamelContext. * * @return the bootstrap factory finder * @see #getDefaultFactoryFinder() */ FactoryFinder getBootstrapFactoryFinder(); /** * Sets the bootstrap FactoryFinder which will be used for the loading the factory class from META-INF. This * bootstrap factory finder is only intended to be used during bootstrap (starting) CamelContext. * * @see #getDefaultFactoryFinder() */ void setBootstrapFactoryFinder(FactoryFinder factoryFinder); /** * Gets the bootstrap FactoryFinder which will be used for the loading the factory class from META-INF in the given * path. This bootstrap factory finder is only intended to be used during bootstrap (starting) CamelContext. * * @param path the META-INF path * @return the bootstrap factory finder * @see #getDefaultFactoryFinder() */ FactoryFinder getBootstrapFactoryFinder(String path); /** * Gets the bootstrap {@link ConfigurerResolver} to use. This bootstrap resolver is only intended to be used during * bootstrap (starting) CamelContext. */ ConfigurerResolver getBootstrapConfigurerResolver(); /** * sets the bootstrap {@link ConfigurerResolver} to use. This bootstrap resolver is only intended to be used during * bootstrap (starting) CamelContext. */ void setBootstrapConfigurerResolver(ConfigurerResolver configurerResolver); /** * Gets the FactoryFinder which will be used for the loading the factory class from META-INF in the given path * * @param path the META-INF path * @return the factory finder */ FactoryFinder getFactoryFinder(String path); /** * Gets the factory finder resolver to use * * @return the factory finder resolver */ FactoryFinderResolver getFactoryFinderResolver(); /** * Sets the factory finder resolver to use. * * @param resolver the factory finder resolver */ void setFactoryFinderResolver(FactoryFinderResolver resolver); /** * Gets the current {@link org.apache.camel.spi.ProcessorFactory} * * @return the factory, can be null if no custom factory has been set */ ProcessorFactory getProcessorFactory(); /** * Sets a custom {@link org.apache.camel.spi.ProcessorFactory} * * @param processorFactory the custom factory */ void setProcessorFactory(ProcessorFactory processorFactory); /** * Gets the current {@link org.apache.camel.spi.InternalProcessorFactory} * * @return the factory */ InternalProcessorFactory getInternalProcessorFactory(); /** * Sets a custom {@link org.apache.camel.spi.InternalProcessorFactory} * * @param internalProcessorFactory the custom factory */ void setInternalProcessorFactory(InternalProcessorFactory internalProcessorFactory); /** * Gets the current {@link org.apache.camel.spi.InterceptEndpointFactory} * * @return the factory */ InterceptEndpointFactory getInterceptEndpointFactory(); /** * Sets a custom {@link org.apache.camel.spi.InterceptEndpointFactory} * * @param interceptEndpointFactory the custom factory */ void setInterceptEndpointFactory(InterceptEndpointFactory interceptEndpointFactory); /** * Gets the current {@link org.apache.camel.spi.RouteFactory} * * @return the factory */ RouteFactory getRouteFactory(); /** * Sets a custom {@link org.apache.camel.spi.RouteFactory} * * @param routeFactory the custom factory */ void setRouteFactory(RouteFactory routeFactory); /** * Returns the JAXB Context factory used to create Models. * * @return the JAXB Context factory used to create Models. */ ModelJAXBContextFactory getModelJAXBContextFactory(); /** * Sets a custom JAXB Context factory to be used * * @param modelJAXBContextFactory a JAXB Context factory */ void setModelJAXBContextFactory(ModelJAXBContextFactory modelJAXBContextFactory); /** * Gets the {@link DeferServiceFactory} to use. */ DeferServiceFactory getDeferServiceFactory(); /** * Sets a custom {@link DeferServiceFactory} to use. */ void setDeferServiceFactory(DeferServiceFactory deferServiceFactory); /** * Gets the {@link UnitOfWorkFactory} to use. */ UnitOfWorkFactory getUnitOfWorkFactory(); /** * Sets a custom {@link UnitOfWorkFactory} to use. */ void setUnitOfWorkFactory(UnitOfWorkFactory unitOfWorkFactory); /** * Gets the {@link AnnotationBasedProcessorFactory} to use. */ AnnotationBasedProcessorFactory getAnnotationBasedProcessorFactory(); /** * Sets a custom {@link AnnotationBasedProcessorFactory} to use. */ void setAnnotationBasedProcessorFactory(AnnotationBasedProcessorFactory annotationBasedProcessorFactory); /** * Gets the {@link BeanProxyFactory} to use. */ BeanProxyFactory getBeanProxyFactory(); /** * Gets the {@link BeanProcessorFactory} to use. */ BeanProcessorFactory getBeanProcessorFactory(); /** * Gets the default shared thread pool for error handlers which leverages this for asynchronous redelivery tasks. */ ScheduledExecutorService getErrorHandlerExecutorService(); /** * Adds the given interceptor strategy * * @param interceptStrategy the strategy */ void addInterceptStrategy(InterceptStrategy interceptStrategy); /** * Gets the interceptor strategies * * @return the list of current interceptor strategies */ List getInterceptStrategies(); /** * Setup management according to whether JMX is enabled or disabled. * * @param options optional parameters to configure {@link org.apache.camel.spi.ManagementAgent}. */ void setupManagement(Map options); /** * Gets a list of {@link LogListener} (can be null if empty). */ Set getLogListeners(); /** * Adds a {@link LogListener}. */ void addLogListener(LogListener listener); /** * Gets the {@link org.apache.camel.AsyncProcessor} await manager. * * @return the manager */ AsyncProcessorAwaitManager getAsyncProcessorAwaitManager(); /** * Sets a custom {@link org.apache.camel.AsyncProcessor} await manager. * * @param manager the manager */ void setAsyncProcessorAwaitManager(AsyncProcessorAwaitManager manager); /** * Gets the {@link BeanIntrospection} */ BeanIntrospection getBeanIntrospection(); /** * Sets a custom {@link BeanIntrospection}. */ void setBeanIntrospection(BeanIntrospection beanIntrospection); /** * Gets the {@link HeadersMapFactory} to use. */ HeadersMapFactory getHeadersMapFactory(); /** * Sets a custom {@link HeadersMapFactory} to be used. */ void setHeadersMapFactory(HeadersMapFactory factory); /** * Gets the {@link ReactiveExecutor} to use. */ ReactiveExecutor getReactiveExecutor(); /** * Sets a custom {@link ReactiveExecutor} to be used. */ void setReactiveExecutor(ReactiveExecutor reactiveExecutor); /** * Whether exchange event notification is applicable (possible). This API is used internally in Camel as * optimization. * * This is only for exchange events as this allows Camel to optimize to avoid preparing exchange events if * there are no event listeners that are listening for exchange events. */ boolean isEventNotificationApplicable(); /** * Used as internal optimization in Camel to flag whether exchange event notification is applicable or not. * * This is only for exchange events as this allows Camel to optimize to avoid preparing exchange events if * there are no event listeners that are listening for exchange events. */ void setEventNotificationApplicable(boolean eventNotificationApplicable); /** * Gets the {@link XMLRoutesDefinitionLoader} to be used. * * @deprecated use {@link #getRoutesLoader()} */ @Deprecated XMLRoutesDefinitionLoader getXMLRoutesDefinitionLoader(); /** * Sets a custom {@link XMLRoutesDefinitionLoader} to be used. */ void setXMLRoutesDefinitionLoader(XMLRoutesDefinitionLoader xmlRoutesDefinitionLoader); /** * Gets the {@link RoutesLoader} to be used. */ RoutesLoader getRoutesLoader(); /** * Sets a custom {@link RoutesLoader} to be used. */ void setRoutesLoader(RoutesLoader routesLoader); /** * Gets the {@link ResourceLoader} to be used. */ ResourceLoader getResourceLoader(); /** * Sets a custom {@link ResourceLoader} to be used. */ void setResourceLoader(ResourceLoader resourceLoader); /** * Gets the {@link ModelToXMLDumper} to be used. */ ModelToXMLDumper getModelToXMLDumper(); /** * Sets a custom {@link ModelToXMLDumper} to be used. */ void setModelToXMLDumper(ModelToXMLDumper modelToXMLDumper); /** * Gets the {@link RestBindingJaxbDataFormatFactory} to be used. */ RestBindingJaxbDataFormatFactory getRestBindingJaxbDataFormatFactory(); /** * Sets a custom {@link RestBindingJaxbDataFormatFactory} to be used. */ void setRestBindingJaxbDataFormatFactory(RestBindingJaxbDataFormatFactory restBindingJaxbDataFormatFactory); /** * Gets the {@link RuntimeCamelCatalog} if available on the classpath. */ RuntimeCamelCatalog getRuntimeCamelCatalog(); /** * Sets the {@link RuntimeCamelCatalog} to use. */ void setRuntimeCamelCatalog(RuntimeCamelCatalog runtimeCamelCatalog); /** * Gets the {@link ConfigurerResolver} to use. */ ConfigurerResolver getConfigurerResolver(); /** * Sets the {@link ConfigurerResolver} to use. */ void setConfigurerResolver(ConfigurerResolver configurerResolver); /** * Gets the {@link UriFactoryResolver} to use. */ UriFactoryResolver getUriFactoryResolver(); /** * Sets the {@link UriFactoryResolver} to use. */ void setUriFactoryResolver(UriFactoryResolver uriFactoryResolver); /** * Internal {@link RouteController} that are only used internally by Camel to perform basic route operations. Do not * use this as end user. */ RouteController getInternalRouteController(); /** * Gets the {@link EndpointUriFactory} for the given component name. */ EndpointUriFactory getEndpointUriFactory(String scheme); /** * Gets the {@link StartupStepRecorder} to use. */ StartupStepRecorder getStartupStepRecorder(); /** * Sets the {@link StartupStepRecorder} to use. */ void setStartupStepRecorder(StartupStepRecorder startupStepRecorder); /** * Internal API for adding routes. Do not use this as end user. */ void addRoute(Route route); /** * Internal API for removing routes. Do not use this as end user. */ void removeRoute(Route route); /** * Internal API for creating error handler. Do not use this as end user. */ Processor createErrorHandler(Route route, Processor processor) throws Exception; /** * Whether to run in lightweight mode which triggers some optimizations and memory reduction. Danger this causes * Camel to be less dynamic such as adding new route after Camel is started would not be possible. */ boolean isLightweight(); /** * Whether to run in lightweight mode which triggers some optimizations and memory reduction. Danger this causes * Camel to be less dynamic such as adding new route after Camel is started would not be possible. */ void setLightweight(boolean lightweight); /** * Danger!!! This will dispose the route model from the {@link CamelContext} which is used for lightweight mode. * This means afterwards no new routes can be dynamically added. Any operations on the * org.apache.camel.model.ModelCamelContext will return null or be a noop operation. */ void disposeModel(); /** * Used during unit-testing where it is possible to specify a set of routes to exclude from discovery */ String getTestExcludeRoutes(); /** * Parses the given text and resolve any property placeholders - using {{key}}. *

* Important: If resolving placeholders on an endpoint uri, then you SHOULD use * EndpointHelper#resolveEndpointUriPropertyPlaceholders instead. * * @param text the text such as an endpoint uri or the likes * @param keepUnresolvedOptional whether to keep placeholders that are optional and was unresolved * @return the text with resolved property placeholders * @throws IllegalArgumentException is thrown if property placeholders was used and there was an error resolving * them */ String resolvePropertyPlaceholders(String text, boolean keepUnresolvedOptional); /** * Package name to use as base (offset) for classpath scanning of custom services, type converters, and the likes * * @return the base package name (can bre null if not configured) */ String getBasePackageScan(); /** * Package name to use as base (offset) for classpath scanning of custom services, type converters, and the likes * * @param basePackageScan the base package name */ void setBasePackageScan(String basePackageScan); /** * Gets the {@link ModelineFactory}. */ ModelineFactory getModelineFactory(); /** * Sets a custom {@link ModelineFactory}. */ void setModelineFactory(ModelineFactory modelineFactory); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy