mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
.externalToolBuilders
config
source
cpp
java
org
alfresco
email
filesys
jcr
linkvalidation
model
repo
action
admin
patch
registry
RegistryKey.java
RegistryService.java
RegistryServiceImpl.java
RegistryServiceImplTest.java
BaseInterpreter.java
ConfigurationChecker.java
Log4JHierarchyInit.java
RepoAdminInterpreter.java
RepoAdminService.java
RepoAdminServiceImpl.java
RepoModelDefinition.java
RepoServerMgmt.java
RepoServerMgmtMBean.java
attributes
audit
avm
blogIntegration
cache
clt
coci
config
configuration
content
copy
deploy
descriptor
dictionary
domain
exporter
forum
i18n
importer
jscript
lock
model
module
node
ownable
policy
processor
remote
rule
search
security
service
template
tenant
transaction
usage
version
workflow
sandbox
service
tools
util
apache
queryRegister.dtd
meta-inf
test-resources
web
.classpath
.project
build.xml
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@5557 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
140 lines
4.6 KiB
Java
140 lines
4.6 KiB
Java
/*
|
|
* Copyright (C) 2005-2007 Alfresco Software Limited.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
* As a special exception to the terms and conditions of version 2.0 of
|
|
* the GPL, you may redistribute this Program in connection with Free/Libre
|
|
* and Open Source Software ("FLOSS") applications as described in Alfresco's
|
|
* FLOSS exception. You should have recieved a copy of the text describing
|
|
* the FLOSS exception, and it is also available here:
|
|
* http://www.alfresco.com/legal/licensing"
|
|
*/
|
|
package org.alfresco.repo.admin.registry;
|
|
|
|
import java.io.Serializable;
|
|
|
|
/**
|
|
* Key for looking up registry metadata.
|
|
*
|
|
* @author Derek Hulley
|
|
*/
|
|
public class RegistryKey implements Serializable
|
|
{
|
|
private static final long serialVersionUID = 1137822242292626854L;
|
|
|
|
static final String REGISTRY_1_0_URI = "http://www.alfresco.org/system/registry/1.0";
|
|
|
|
private String namespaceUri;
|
|
private String[] path;
|
|
private String property;
|
|
|
|
/**
|
|
* Build a registry key from a given array of elements.
|
|
*/
|
|
private static String buildPathString(String... elements)
|
|
{
|
|
if (elements.length == 0)
|
|
{
|
|
return "/";
|
|
}
|
|
StringBuilder sb = new StringBuilder();
|
|
for (String element : elements)
|
|
{
|
|
if (element == null || element.length() == 0)
|
|
{
|
|
throw new IllegalArgumentException("Key elements may not be empty or null");
|
|
}
|
|
sb.append("/").append(element);
|
|
}
|
|
return sb.toString();
|
|
}
|
|
|
|
/**
|
|
* For path /a/b/c and property 'x', put in <pre>"a", "b", "c", "x"</pre>
|
|
* The property can also be <tt>null</tt> as in <pre>"a", "b", "c", null</pre>
|
|
*
|
|
* @param namespaceUri the key namespace to use. If left <tt>null</tt> then the
|
|
* {@link #REGISTRY_1_0_URI default} will be used.
|
|
* @param key the path elements followed by the property name.
|
|
*/
|
|
public RegistryKey(String namespaceUri, String... key)
|
|
{
|
|
if (namespaceUri == null)
|
|
{
|
|
namespaceUri = REGISTRY_1_0_URI;
|
|
}
|
|
this.namespaceUri = namespaceUri;
|
|
// The last value is the property
|
|
int length = key.length;
|
|
if (length == 0)
|
|
{
|
|
throw new IllegalArgumentException("No value supplied for the RegistryKey property");
|
|
}
|
|
this.property = key[length - 1];
|
|
this.path = new String[length - 1];
|
|
System.arraycopy(key, 0, path, 0, length - 1);
|
|
}
|
|
|
|
/**
|
|
* A constructor to specifically declare the path and property portions of the key.
|
|
*
|
|
* @param namespaceUri the key namespace to use. If left <tt>null</tt> then the
|
|
* {@link #REGISTRY_1_0_URI default} will be used.
|
|
* @param path the path part of the key
|
|
* @param property the property name for the key. This may be <tt>null</tt>.
|
|
*/
|
|
public RegistryKey(String namespaceUri, String[] path, String property)
|
|
{
|
|
if (namespaceUri == null)
|
|
{
|
|
namespaceUri = REGISTRY_1_0_URI;
|
|
}
|
|
this.namespaceUri = namespaceUri;
|
|
if ((path == null || path.length == 0) && property == null)
|
|
{
|
|
throw new IllegalArgumentException("No path or property supplied for the RegistryKey");
|
|
}
|
|
this.property = property;
|
|
this.path = path;
|
|
}
|
|
|
|
@Override
|
|
public String toString()
|
|
{
|
|
StringBuilder sb = new StringBuilder(128);
|
|
sb.append("RegistryKey")
|
|
.append("[ ").append(RegistryKey.buildPathString(path)).append("/").append(property)
|
|
.append(" ]");
|
|
return sb.toString();
|
|
}
|
|
|
|
public String getNamespaceUri()
|
|
{
|
|
return namespaceUri;
|
|
}
|
|
|
|
public String[] getPath()
|
|
{
|
|
return path;
|
|
}
|
|
|
|
public String getProperty()
|
|
{
|
|
return property;
|
|
}
|
|
|
|
}
|