Copyright© 2008-2022 Sitevision AB, all rights reserved.
public interface QueryObjectModelFactory extends QueryObjectModelConstants
QueryObjectModelFactory
creates instances of the JCR query
object model.
Refer to QueryObjectModel
for a description of the query object
model.
Sitevision note: Unsupported operation
JCR_JOIN_TYPE_INNER, JCR_JOIN_TYPE_LEFT_OUTER, JCR_JOIN_TYPE_RIGHT_OUTER, JCR_OPERATOR_EQUAL_TO, JCR_OPERATOR_GREATER_THAN, JCR_OPERATOR_GREATER_THAN_OR_EQUAL_TO, JCR_OPERATOR_LESS_THAN, JCR_OPERATOR_LESS_THAN_OR_EQUAL_TO, JCR_OPERATOR_LIKE, JCR_OPERATOR_NOT_EQUAL_TO, JCR_ORDER_ASCENDING, JCR_ORDER_DESCENDING
Modifier and Type | Method and Description |
---|---|
And |
and(Constraint constraint1,
Constraint constraint2)
Performs a logical conjunction of two other constraints.
|
Ordering |
ascending(DynamicOperand operand)
Orders by the value of the specified operand, in ascending order.
|
BindVariableValue |
bindVariable(String bindVariableName)
Evaluates to the value of a bind variable.
|
ChildNode |
childNode(String selectorName,
String path)
Tests whether a node in the specified selector is a child of a node
reachable by a specified absolute path.
|
ChildNodeJoinCondition |
childNodeJoinCondition(String childSelectorName,
String parentSelectorName)
Tests whether a first selector's node is a child of a second selector's
node.
|
Column |
column(String selectorName,
String propertyName,
String columnName)
Identifies a property in the specified selector to include in the tabular
view of query results.
|
Comparison |
comparison(DynamicOperand operand1,
String operator,
StaticOperand operand2)
Filters node-tuples based on the outcome of a binary operation.
|
QueryObjectModel |
createQuery(Source source,
Constraint constraint,
Ordering[] orderings,
Column[] columns)
Creates a query with one or more selectors.
|
DescendantNode |
descendantNode(String selectorName,
String path)
Tests whether a node in the specified selector is a descendant of a node
reachable by a specified absolute path.
|
DescendantNodeJoinCondition |
descendantNodeJoinCondition(String descendantSelectorName,
String ancestorSelectorName)
Tests whether a first selector's node is a descendant of a second
selector's node.
|
Ordering |
descending(DynamicOperand operand)
Orders by the value of the specified operand, in descending order.
|
EquiJoinCondition |
equiJoinCondition(String selector1Name,
String property1Name,
String selector2Name,
String property2Name)
Tests whether the value of a property in a first selector is equal to the
value of a property in a second selector.
|
FullTextSearch |
fullTextSearch(String selectorName,
String propertyName,
StaticOperand fullTextSearchExpression)
Performs a full-text search against the specified selector.
|
FullTextSearchScore |
fullTextSearchScore(String selectorName)
Evaluates to a
DOUBLE value equal to the full-text search
score of a node in the specified selector. |
Join |
join(Source left,
Source right,
String joinType,
JoinCondition joinCondition)
Performs a join between two node-tuple sources.
|
Length |
length(PropertyValue propertyValue)
Evaluates to the length (or lengths, if multi-valued) of a property.
|
Literal |
literal(Value literalValue)
Evaluates to a literal value.
|
LowerCase |
lowerCase(DynamicOperand operand)
Evaluates to the lower-case string value (or values, if multi-valued) of
an operand.
|
NodeLocalName |
nodeLocalName(String selectorName)
Evaluates to a
NAME value equal to the local (unprefixed)
name of a node in the specified selector. |
NodeName |
nodeName(String selectorName)
Evaluates to a
NAME value equal to the prefix-qualified name
of a node in the specified selector. |
Not |
not(Constraint constraint)
Performs a logical negation of another constraint.
|
Or |
or(Constraint constraint1,
Constraint constraint2)
Performs a logical disjunction of two other constraints.
|
PropertyExistence |
propertyExistence(String selectorName,
String propertyName)
Tests the existence of a property in the specified selector.
|
PropertyValue |
propertyValue(String selectorName,
String propertyName)
Evaluates to the value (or values, if multi-valued) of a property in the
specified selector.
|
SameNode |
sameNode(String selectorName,
String path)
Tests whether a node in the specified selector is reachable by a
specified absolute path.
|
SameNodeJoinCondition |
sameNodeJoinCondition(String selector1Name,
String selector2Name,
String selector2Path)
Tests whether a first selector's node is the same as a node identified by
relative path from a second selector's node.
|
Selector |
selector(String nodeTypeName,
String selectorName)
Selects a subset of the nodes in the repository based on node type.
|
UpperCase |
upperCase(DynamicOperand operand)
Evaluates to the upper-case string value (or values, if multi-valued) of
an operand.
|
QueryObjectModel createQuery(Source source, Constraint constraint, Ordering[] orderings, Column[] columns) throws InvalidQueryException, RepositoryException
source
- the node-tuple source; non-nullconstraint
- the constraint, or null if noneorderings
- zero or more orderings; null is equivalent to a
zero-length arraycolumns
- the columns; null is equivalent to a zero-length arrayInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test and the
parameters given fail that test. See the individual QOM factory methods
for the validity criteria of each query element.RepositoryException
- if another error occurs.Selector selector(String nodeTypeName, String selectorName) throws InvalidQueryException, RepositoryException
The query is invalid if nodeTypeName
or
selectorName
is not a syntactically valid JCR name.
The query is invalid if selectorName
} is identical to the
name of another selector in the query.
The query is also invalid if nodeType
is not a valid JCR
name or is a valid JCR name but not the name of a node type available in
the repository.
nodeTypeName
- the name of the required node type; non-nullselectorName
- the selector name; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsJoin join(Source left, Source right, String joinType, JoinCondition joinCondition) throws InvalidQueryException, RepositoryException
The query is invalid if left
is the same source as
right
.
left
- the left node-tuple source; non-nullright
- the right node-tuple source; non-nulljoinType
- either joinCondition
- the join condition; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsEquiJoinCondition equiJoinCondition(String selector1Name, String property1Name, String selector2Name, String property2Name) throws InvalidQueryException, RepositoryException
The query is invalid if:
selector1
is not the name of a selector in the query, orselector2
is not the name of a selector in the query, orselector1
is the same as selector2
, orproperty1
is not a syntactically valid JCR name, orproperty2
is not a syntactically valid JCR name, orproperty1
is not the same property type as the value of property2
, orproperty1
is a multi-valued property, orproperty2
is a multi-valued property, orproperty1
is a BINARY
property, orproperty2
is a BINARY
property.selector1Name
- the name of the first selector; non-nullproperty1Name
- the property name in the first selector; non-nullselector2Name
- the name of the second selector; non-nullproperty2Name
- the property name in the second selector; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implementation chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsSameNodeJoinCondition sameNodeJoinCondition(String selector1Name, String selector2Name, String selector2Path) throws InvalidQueryException, RepositoryException
The query is invalid if:
selector1
is not the name
of a selector in the query, orselector2
is not the
name of a selector in the query, orselector1
is
the same as selector2, orselector2Path
is not a
syntactically valid relative path. Note, however, that if the path is
syntactically valid but does not identify a node visible to the current
session, the query is valid but the constraint is not satisfied.selector1Name
- the name of the first selector; non-nullselector2Name
- the name of the second selector; non-nullselector2Path
- the path relative to the second selector; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsChildNodeJoinCondition childNodeJoinCondition(String childSelectorName, String parentSelectorName) throws InvalidQueryException, RepositoryException
The query is invalid if:
childSelector
is not the
name of a selector in the query, orparentSelector
is not the name of a selector in the query, orchildSelector
is the same as parentSelector
.
childSelectorName
- the name of the child selector; non-nullparentSelectorName
- the name of the parent selector; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsDescendantNodeJoinCondition descendantNodeJoinCondition(String descendantSelectorName, String ancestorSelectorName) throws InvalidQueryException, RepositoryException
The query is invalid if:
descendantSelector
is not
the name of a selector in the query, orancestorSelector
is not the name of a selector in the query, ordescendantSelector
is the same as
ancestorSelector
. descendantSelectorName
- the name of the descendant selector;
non-nullancestorSelectorName
- the name of the ancestor selector; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsAnd and(Constraint constraint1, Constraint constraint2) throws InvalidQueryException, RepositoryException
constraint1
- the first constraint; non-nullconstraint2
- the second constraint; non-nullAnd
constraint; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsOr or(Constraint constraint1, Constraint constraint2) throws InvalidQueryException, RepositoryException
constraint1
- the first constraint; non-nullconstraint2
- the second constraint; non-nullOr
constraint; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsNot not(Constraint constraint) throws InvalidQueryException, RepositoryException
constraint
- the constraint to be negated; non-nullNot
constraint; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsComparison comparison(DynamicOperand operand1, String operator, StaticOperand operand2) throws InvalidQueryException, RepositoryException
operand1
- the first operand; non-nulloperator
- the operator; either QueryObjectModelConstants.JCR_OPERATOR_EQUAL_TO
,QueryObjectModelConstants.JCR_OPERATOR_NOT_EQUAL_TO
,QueryObjectModelConstants.JCR_OPERATOR_LESS_THAN
,QueryObjectModelConstants.JCR_OPERATOR_LESS_THAN_OR_EQUAL_TO
,QueryObjectModelConstants.JCR_OPERATOR_GREATER_THAN
,QueryObjectModelConstants.JCR_OPERATOR_GREATER_THAN_OR_EQUAL_TO
,
orQueryObjectModelConstants.JCR_OPERATOR_LIKE
operand2
- the second operand; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsPropertyExistence propertyExistence(String selectorName, String propertyName) throws InvalidQueryException, RepositoryException
The query is invalid if:
selector
is not the name
of a selector in the query, orproperty
is not a
syntactically valid JCR name.selectorName
- the selector name; non-nullpropertyName
- the property name; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsFullTextSearch fullTextSearch(String selectorName, String propertyName, StaticOperand fullTextSearchExpression) throws InvalidQueryException, RepositoryException
The query is invalid if:
selector
is not the name of a selector in the query, orproperty
is specified but is not a syntactically valid JCR name, orfullTextSearchExpression
does not evaluate to a JCR STRING Value (or convertible to STRING) that conforms to the full text search grammar.
If property
is specified but, for a node-tuple, the selector
node does not have a property named property
, the query is
valid but the constraint is not satisfied.
selectorName
- the selector name; non-nullpropertyName
- the property name, or null to search all full-text
indexed properties of the node (or node subgraph, in some
implementations)fullTextSearchExpression
- the full-text search expression as a
static operand; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsSameNode sameNode(String selectorName, String path) throws InvalidQueryException, RepositoryException
The query is invalid if:
selector
is not the name
of a selector in the query, orpath
is not a
syntactically valid absolute path. Note, however, that if the path is
syntactically valid but does not identify a node in the repository (or
the node is not visible to this session, because of access control
constraints), the query is valid but the constraint is not
satisfied.selectorName
- the selector name; non-nullpath
- an absolute path; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsChildNode childNode(String selectorName, String path) throws InvalidQueryException, RepositoryException
selector
is not the name of a selector in the query,
orpath
is not a syntactically valid absolute path.
Note, however, that if the path is syntactically valid but does not
identify a node in the repository (or the node is not visible to this
session, because of access control constraints), the query is valid but
the constraint is not satisfied.selectorName
- the selector name; non-nullpath
- an absolute path; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsDescendantNode descendantNode(String selectorName, String path) throws InvalidQueryException, RepositoryException
The query is invalid if:
selector
is not the name
of a selector in the query, orpath
is not a
syntactically valid absolute path. Note, however, that if the path is
syntactically valid but does not identify a node in the repository (or
the node is not visible to this session, because of access control
constraints), the query is valid but the constraint is not
satisfied.selectorName
- the selector name; non-nullpath
- an absolute path; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsPropertyValue propertyValue(String selectorName, String propertyName) throws InvalidQueryException, RepositoryException
The query is invalid if:
selector
is not the name
of a selector in the query, orproperty
is not a
syntactically valid JCR name.selectorName
- the selector name; non-nullpropertyName
- the property name; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsLength length(PropertyValue propertyValue) throws InvalidQueryException, RepositoryException
propertyValue
- the property value for which to compute the length;
non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsNodeName nodeName(String selectorName) throws InvalidQueryException, RepositoryException
NAME
value equal to the prefix-qualified name
of a node in the specified selector.
The query is invalid if selector
is not the name of a
selector in the query.
selectorName
- the selector name; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsNodeLocalName nodeLocalName(String selectorName) throws InvalidQueryException, RepositoryException
NAME
value equal to the local (unprefixed)
name of a node in the specified selector.
The query is invalid if selector
is not the name of a
selector in the query.
selectorName
- the selector name; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsFullTextSearchScore fullTextSearchScore(String selectorName) throws InvalidQueryException, RepositoryException
DOUBLE
value equal to the full-text search
score of a node in the specified selector.
The query is invalid if selector
is not the name of a
selector in the query.
selectorName
- the selector name; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsLowerCase lowerCase(DynamicOperand operand) throws InvalidQueryException, RepositoryException
operand
- the operand whose value is converted to a lower-case
string; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsUpperCase upperCase(DynamicOperand operand) throws InvalidQueryException, RepositoryException
operand
- the operand whose value is converted to a upper-case
string; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsBindVariableValue bindVariable(String bindVariableName) throws InvalidQueryException, RepositoryException
The query is invalid if bindVariableName
is not a valid JCR
prefix.
bindVariableName
- the bind variable name; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that test.RepositoryException
- if the operation otherwise failsLiteral literal(Value literalValue) throws InvalidQueryException, RepositoryException
literalValue
- the valueInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses
to perform that test (and not leave it
until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
),
and the parameter given fails that testRepositoryException
- if the operation otherwise failsOrdering ascending(DynamicOperand operand) throws InvalidQueryException, RepositoryException
operand
does not evaluate to a scalar
value.operand
- the operand by which to order; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsOrdering descending(DynamicOperand operand) throws InvalidQueryException, RepositoryException
operand
does not evaluate to a scalar
value.operand
- the operand by which to order; non-nullInvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsColumn column(String selectorName, String propertyName, String columnName) throws InvalidQueryException, RepositoryException
The query is invalid if:
selectorName
is not the name
of a selector in the query, orpropertyName
is specified but does not evaluate to a scalar
value, orpropertyName
is specified but
columnName
is omitted, orpropertyName
is
omitted but columnName
is specified, orcolumnName
(if propertyName
is
specified) or generated as described above (if propertyName
is
omitted).propertyName
is specified but, for a
node-tuple, the selector node does not have a property named
propertyName
, the query is valid and the column has null value.selectorName
- the selector name; non-nullpropertyName
- the property name, or null to include a column for
each single-value non-residual property of the selector's node typecolumnName
- the column name; must be null if propertyName
is null;
must be non-null if propertyName
is non-null.InvalidQueryException
- if a particular validity test is possible
on this method, the implemention chooses to perform that test (and not
leave it until later, on createQuery(javax.jcr.query.qom.Source, javax.jcr.query.qom.Constraint, javax.jcr.query.qom.Ordering[], javax.jcr.query.qom.Column[])
), and the parameters given
fail that testRepositoryException
- if the operation otherwise failsSitevision - Portal and Content Management Made Easy
Sitevision is an advanced Java enterprise portal product and a portlet container (JSR 286) that implements Java Content Repository (JSR 283).
Copyright© 2008-2022 Sitevision AB, all rights reserved.