mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-22 15:12:38 +00:00
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@19348 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
307 lines
11 KiB
Java
307 lines
11 KiB
Java
/*
|
|
* Copyright (C) 2005-2010 Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco 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 Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
package org.alfresco.service.cmr.attributes;
|
|
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
|
|
import org.alfresco.repo.attributes.Attribute;
|
|
import org.alfresco.service.PublicService;
|
|
import org.alfresco.util.Pair;
|
|
|
|
/**
|
|
* This provides services for reading, writing, and querying global attributes.
|
|
* <p>
|
|
* Attributes are organized hierarchically.
|
|
* Each segment within the hierarchy is referred to as a "key".
|
|
* Keys are indexed so that they may be queried efficiently.
|
|
* Because databases may impose length restrictions
|
|
* on index of primary keys, you are strongly advised to keep
|
|
* "large" strings in <em>values</em>, not <em>keys</em>.
|
|
* For example,
|
|
* http://dev.mysql.com/tech-resources/crash-me.php reports
|
|
* that the index length limit of MySQL-4.1.1pre InnoDB is 1024,
|
|
* bytes. Assuming keys are stored in UTF8, this means keys
|
|
* should be no longer 170 chars (170*6 + 1 = 1020 < 1024).
|
|
* <p>
|
|
*
|
|
* When an attribute within the hierarchy is represented as a "path",
|
|
* the set of keys used to reach it is concatenated using the '/' character.
|
|
* Thus, "a/b/c" refers to attribute "c" within "b" within "a".
|
|
* This "path" notation is merely a convenience; if you prefer,
|
|
* lower-level functions can also be used that allow you to
|
|
* supply the list of keys directly. If you need to create a "path"
|
|
* that includes a key with an embedded '/' character, you must
|
|
* escape it with '\' (e.g.: "silly\/example"). No such restriction
|
|
* applies when you use an API that accepts a list of keys directly.
|
|
* <p>
|
|
* Lookups for attributes never attempt to search any other
|
|
* leaf key (final path segment) than the one specified
|
|
* function call. Thus, if you have an attribute named
|
|
* "egg", but no attribute named "hen/egg", a lookup for
|
|
* "egg" will suceed, but a lookup for "hen/egg" will fail
|
|
* (i.e.: it will return null).
|
|
*
|
|
* @author britt
|
|
*/
|
|
@PublicService
|
|
public interface AttributeService
|
|
{
|
|
/**
|
|
* Get an Attribute using a path.
|
|
*
|
|
* @param path The path of the Attribute
|
|
* @return The value of the attribute or null.
|
|
*/
|
|
public Attribute getAttribute(String path);
|
|
|
|
/**
|
|
* Get an attribute using a list of keys.
|
|
*
|
|
* @param keys List of attribute path keys (path components).
|
|
* @return The value of the attribute or null.
|
|
*/
|
|
public Attribute getAttribute(List<String> keys);
|
|
|
|
/**
|
|
* Set an attribute, overwriting its prior value if it already existed.
|
|
*
|
|
* @param name The name of the Attribute.
|
|
* @param value The value to set.
|
|
*/
|
|
public void setAttribute(String path, String name, Attribute value);
|
|
|
|
/**
|
|
* Set an attribute, overwriting its prior value if it already existed.
|
|
*
|
|
* @param keys List of attribute path keys (path components).
|
|
* @param name The name of the attribute to set.
|
|
* @param value The Attribute to set.
|
|
*/
|
|
public void setAttribute(List<String> keys, String name, Attribute value);
|
|
|
|
/**
|
|
* Set a set of attributes on a map.
|
|
* @param path The path to the map.
|
|
* @param entries The entries to set.
|
|
*/
|
|
public void setAttributes(String path, Map<String, Attribute> entries);
|
|
|
|
/**
|
|
* Set a set of attributes on a map.
|
|
* @param keys The List of path keys to the map.
|
|
* @param entries The entries to set.
|
|
*/
|
|
public void setAttributes(List<String> keys, Map<String, Attribute> entries);
|
|
|
|
/**
|
|
* Set an attribute in a list.
|
|
*
|
|
* @param path The path to the {@link org.alfresco.repo.attributes.ListAttribute ListAttribute}.
|
|
* @param index The list index.
|
|
* @param value The Attribute to set.
|
|
*/
|
|
public void setAttribute(String path, int index, Attribute value);
|
|
|
|
/**
|
|
* Set an attribute in a list.
|
|
* @param keys List of attribute path keys (path components).
|
|
* @param index The list index.
|
|
* @param value The Attribute to set within the {@link org.alfresco.repo.attributes.ListAttribute ListAttribute}
|
|
*/
|
|
public void setAttribute(List<String> keys, int index, Attribute value);
|
|
|
|
/**
|
|
* Add an attribute to a list.
|
|
*
|
|
* @param path The path to the list.
|
|
* @param value The Attribute to add to the {@link org.alfresco.repo.attributes.ListAttribute ListAttribute}
|
|
*/
|
|
public void addAttribute(String path, Attribute value);
|
|
|
|
/**
|
|
* Add an attribute to a list.
|
|
*
|
|
* @param keys List of attribute path keys (path components).
|
|
* @param value The Attribute to add to the {@link org.alfresco.repo.attributes.ListAttribute ListAttribute}
|
|
*/
|
|
public void addAttribute(List<String> keys, Attribute value);
|
|
|
|
/**
|
|
* Add a list of attributes to the end of a list.
|
|
* @param path The path to the list.
|
|
* @param values The values to add.
|
|
*/
|
|
public void addAttributes(String path, List<Attribute> values);
|
|
|
|
/**
|
|
* Add a list of attributes to the end of a list.
|
|
* @param keys The List of path keys to the list.
|
|
* @param values The values to add.
|
|
*/
|
|
public void addAttributes(List<String> keys, List<Attribute> values);
|
|
|
|
/**
|
|
* Remove an Attribute.
|
|
* @param name The name of the Attribute.
|
|
*/
|
|
public void removeAttribute(String path, String name);
|
|
|
|
/**
|
|
* Remove an Attribute.
|
|
* @param keys List of attribute path keys (path components).
|
|
* @param name The name of the attribute to remove.
|
|
*/
|
|
public void removeAttribute(List<String> keys, String name);
|
|
|
|
/**
|
|
* Remove an attribute from a list.
|
|
* @param path The path to the list.
|
|
* @param index The index to remove from the
|
|
* {@link org.alfresco.repo.attributes.ListAttribute ListAttribute}
|
|
*/
|
|
public void removeAttribute(String path, int index);
|
|
|
|
/**
|
|
* Remove an attribute from a list.
|
|
* @param keys List of attribute path keys (path components).
|
|
* @param index The index to remove from the
|
|
* {@link org.alfresco.repo.attributes.ListAttribute ListAttribute}
|
|
*/
|
|
public void removeAttribute(List<String> keys, int index);
|
|
|
|
/**
|
|
* Remove entries from the designated map which match the given query.
|
|
* @param keys The list of attribute path entries.
|
|
* @param query The attribute query.
|
|
*/
|
|
public void removeEntries(List<String> keys, AttrQuery query);
|
|
|
|
/**
|
|
* Remove entries from the designated map which match the given query.
|
|
* @param path The path to the map.
|
|
* @param query The attribute query.
|
|
*/
|
|
public void removeEntries(String path, AttrQuery query);
|
|
|
|
/**
|
|
* Query for the list of attributes that is contained in the map
|
|
* defined by the given path and meet the query criteria.
|
|
*
|
|
* <p>
|
|
* <b>Example 1:</b><br>
|
|
* Find all attributes within the nested namespace "a/b"
|
|
* that are lexically greater than or equal to the string "v":
|
|
* <pre>
|
|
* query("a/b", new AttrQueryGTE("v"))
|
|
* </pre>
|
|
* <p>
|
|
* <b>Example 2:</b><br>
|
|
* Find all attributes within the namespace "xyz" that are
|
|
* either lexically less than the string "d" or greater than
|
|
* the string "w":
|
|
* <pre>
|
|
* query("xyz", new AttrOrQuery(new AttrQueryLT("d"),
|
|
* new AttrQueryGT("w")))
|
|
* </pre>
|
|
*
|
|
* @param path
|
|
* @param query
|
|
* @return A List of matching attributes.
|
|
*/
|
|
public List<Pair<String, Attribute>> query(String path, AttrQuery query);
|
|
|
|
/**
|
|
* Query for a list of attributes which are contained in a map defined by the
|
|
* given path and meet the query criteria.
|
|
* @param keys List of attribute path keys (path components).
|
|
* @param query
|
|
* @return A list of matching attributes.
|
|
*/
|
|
public List<Pair<String, Attribute>> query(List<String> keys, AttrQuery query);
|
|
|
|
/**
|
|
* Get all the keys at a given attribute path.
|
|
* When prior call to
|
|
* {@link #setAttribute setAttribute}
|
|
* has associated a path with a
|
|
* {@link org.alfresco.repo.attributes.Attribute.Type#MAP MAP}, you can fetch the
|
|
* keys for that map via this function.
|
|
* <p>
|
|
* <b>Example:</b><br>
|
|
* Suppose <code>AttribSvc</code> is an attribute service object:<pre>
|
|
*
|
|
* MapAttribute x = new MapAttributeValue();
|
|
* x.put("cow", new StringAttributeValue("moo");
|
|
* x.put("bird", new StringAttributeValue("tweet");
|
|
*
|
|
* MapAttribute y = new MapAttributeValue();
|
|
* y.put("pekingese", new StringAttributeValue("yip-yip-yip");
|
|
* y.put("blood hound", new StringAttributeValue("Aroooooooooooo");
|
|
* y.put("labrador", new StringAttributeValue("Hello, kind stranger!");
|
|
*
|
|
* AttribSvc.setAttribute("", "x", x);
|
|
* AttribSvc.setAttribute("x", "y", y);
|
|
*
|
|
* List<String> x_keys = AttribSvc.getKeys("x"); // cow, bird
|
|
* List<String> y_keys = AttribSvc.getKeys("x/y"); // pekingese, blood hound, labrador
|
|
* </pre>
|
|
*
|
|
* @param path The attribute path.
|
|
* @return A list of all keys.
|
|
*/
|
|
public List<String> getKeys(String path);
|
|
|
|
/**
|
|
* Get all the keys at a given attribute path as specified by a list of path components.
|
|
* @param keys List of attribute path keys (path components).
|
|
* @return A list of all keys at the specified Attribute location
|
|
*/
|
|
public List<String> getKeys(List<String> keys);
|
|
|
|
/**
|
|
* Get the size of a map or list.
|
|
* @param keys List of attribute path keys.
|
|
* @return The size of of the list or map.
|
|
*/
|
|
public int getCount(List<String> keys);
|
|
|
|
/**
|
|
* Get the size of a map or list.
|
|
* @param path The path to the map or list.
|
|
* @return The size of the list or map.
|
|
*/
|
|
public int getCount(String path);
|
|
|
|
/**
|
|
* Does an attribute exist.
|
|
* @param keys List of attribute path keys.
|
|
* @return Whether the attribute exists.
|
|
*/
|
|
public boolean exists(List<String> keys);
|
|
|
|
/**
|
|
* Does an attribute exist.
|
|
* @param path The path to the attribute.
|
|
* @return Whether the attribute exists.
|
|
*/
|
|
public boolean exists(String path);
|
|
}
|