2006-09-02 18:19:00 +00:00

72 lines
2.1 KiB
Java

/*
* Copyright (C) 2005 Alfresco, Inc.
*
* Licensed under the Mozilla Public License version 1.1
* with a permitted attribution clause. You may obtain a
* copy of the License at
*
* http://www.alfresco.org/legal/license.txt
*
* 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.alfresco.service.namespace;
import java.util.Collection;
import org.alfresco.service.Auditable;
import org.alfresco.service.PublicService;
/**
* The <code>NamespacePrefixResolver</code> provides a mapping between
* namespace prefixes and namespace URIs.
*
* @author David Caruana
*/
@PublicService
public interface NamespacePrefixResolver
{
/**
* Gets the namespace URI registered for the given prefix
*
* @param prefix prefix to lookup
* @return the namespace
* @throws NamespaceException if prefix has not been registered
*/
@Auditable(parameters = {"prefix"})
public String getNamespaceURI(String prefix)
throws NamespaceException;
/**
* Gets the registered prefixes for the given namespace URI
*
* @param namespaceURI namespace URI to lookup
* @return the prefixes (or empty collection, if no prefixes registered against URI)
* @throws NamespaceException if URI has not been registered
*/
@Auditable(parameters = {"namespaceURI"})
public Collection<String> getPrefixes(String namespaceURI)
throws NamespaceException;
/**
* Gets all registered Prefixes
*
* @return collection of all registered namespace prefixes
*/
@Auditable
Collection<String> getPrefixes();
/**
* Gets all registered Uris
*
* @return collection of all registered namespace uris
*/
@Auditable
Collection<String> getURIs();
}