/******************************************************************************* * Copyright (c) 2005, 2006 Erkki Lindpere and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Erkki Lindpere - initial API and implementation *******************************************************************************/ package org.eclipse.ecf.internal.bulletinboard.commons; import java.net.URL; import java.util.Map; import org.eclipse.ecf.bulletinboard.IBBObject; import org.eclipse.ecf.core.identity.ID; import org.eclipse.ecf.core.identity.IDCreateException; import org.eclipse.ecf.core.identity.Namespace; /** * Factory interface for creating IBBObjectId's and IBBObjects from id's. * * TODO: perhaps creating objects directly shouldn't be exposed to clients? * * @author Erkki */ public interface IBBObjectFactory { /** * Creates an object that implements IBBObjectId. * * @param namespace * the namespace * * @param stringValue * the value that the id is to be created from * @return the created IBBObjectId implementation * @throws IDCreateException */ public ID createBBObjectId(Namespace namespace, String stringValue) throws IDCreateException; public ID createBBObjectId(Namespace namespace, URL baseURL, String stringValue) throws IDCreateException; /** * Creates a named and identified IBBObject implementation. * * @param id * the object's identifier * @param name * the object's name * @param parameters any parameters * @return the created IBBObject implementation */ public IBBObject createBBObject(ID id, String name, Map<String, Object> parameters); }