X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=config%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fxmlrouter%2Fconfig%2FRouterConfigService.java;fp=config%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fxmlrouter%2Fconfig%2FRouterConfigService.java;h=baefd944799cf3e31d1adcd60bbd84722a3db405;hb=b2375f35a2f897e1417e8b5ec5b19b3257a11586;hp=0000000000000000000000000000000000000000;hpb=5b4ee8d862b98d127abb04c646017c184d005838;p=xmlrouter diff --git a/config/src/main/java/org/wamblee/xmlrouter/config/RouterConfigService.java b/config/src/main/java/org/wamblee/xmlrouter/config/RouterConfigService.java new file mode 100644 index 0000000..baefd94 --- /dev/null +++ b/config/src/main/java/org/wamblee/xmlrouter/config/RouterConfigService.java @@ -0,0 +1,52 @@ +/* + * Copyright 2005-2011 the original author or authors. + * + * 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. + */ +package org.wamblee.xmlrouter.config; + +import org.wamblee.xmlrouter.common.Id; + +/** + * Router configuration service that provides atomic configuration of the + * router. This is the entry point for configuring the router. + * + * @author Erik Brakkee + */ +public interface RouterConfigService { + + /** + * @return New empty configuration. + */ + RouterConfig emptyConfig(); + + /** + * Applies a given configuration. + * + * @param aConfig + * Configuration to use. + * @param aOldConfig + * Id of the configuration to replace or null if this is a new + * configuration. + * @return Id of the applied configuration. + */ + Id apply(RouterConfig aConfig, Id aOldConfig); + + /** + * Clears the configuration for a given id. + * + * @param aConfig + * Configuration id. + */ + void clear(Id aConfig); +}