equality based on the ids of the contents of SingleRouterConfig.
[xmlrouter] / config / src / main / java / org / wamblee / xmlrouter / config / Config.java
index 940b34622fcdd3d454c683cba5e083fca59ad6db..baa4c8b4d72d0f6d2c38bba418ba7f354882721c 100644 (file)
@@ -20,28 +20,36 @@ import java.util.Collection;
 import org.wamblee.xmlrouter.common.Id;
 
 /**
- * Configuration API for the XML router.
+ * Interface for managing a set of configuration items of a given type with
+ * unique ids.
  * 
  * @author Erik Brakkee
+ * 
+ * @param <T>
+ *            Type for which ids are generated.
  */
-public interface Config {
-
-    Id<DocumentType> addDocumentType(DocumentType aType);
-
-    void removeDocumentType(Id<DocumentType> aId);
-
-    Collection<DocumentType> getDocumentTypes();
-
-    Id<Transformation> addTransformation(Transformation aTransformation);
-
-    void removeTransformation(Id<Transformation> aId);
-
-    Collection<Transformation> getTransformations();
-
-    Id<Filter> addFilter(Filter aFilter);
-
-    void removeFilter(Id<Filter> aId);
-
-    Collection<Filter> getFilters();
-
-}
+public interface Config<T extends Identifiable> extends Identifiable<Config> {
+    /**
+     * Adds an item. No item with the same id may exist.
+     * 
+     * @param aT
+     *            item
+     * @throws ConfigException
+     *             In case an object with the same id already exists.
+     */
+    void add(T aT);
+
+    /**
+     * Removes the item with a given id.
+     * 
+     * @param aId
+     *            Item id.
+     * @return true iff the item was removed.
+     */
+    boolean remove(Id<T> aId);
+
+    /**
+     * @return All available items.
+     */
+    Collection<T> values();
+}
\ No newline at end of file