All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.jackrabbit.commons.cnd.DefinitionBuilderFactory Maven / Gradle / Ivy

There is a newer version: 6.5.21
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * 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.apache.jackrabbit.commons.cnd;

import javax.jcr.RepositoryException;
import javax.jcr.PropertyType;
import javax.jcr.query.qom.QueryObjectModelConstants;
import javax.jcr.nodetype.ItemDefinition;
import javax.jcr.nodetype.NodeTypeDefinition;
import javax.jcr.nodetype.PropertyDefinition;

/**
 * Builder for node type definitions, node definitions and property definitions.
 * @param   type of the node type definition
 * @param   type of the namespace mapping
 */
public abstract class DefinitionBuilderFactory {

    /**
     * Create a new instance of a {@link AbstractNodeTypeDefinitionBuilder}
     * @return
     * @throws RepositoryException
     */
    public abstract AbstractNodeTypeDefinitionBuilder newNodeTypeDefinitionBuilder()
            throws RepositoryException;

    /**
     * Set the namespace mapping to use for the node type definition being built
     * @param nsMapping
     */
    public abstract void setNamespaceMapping(N nsMapping);

    /**
     * @return  the namespace mapping used for the node type definition being built
     */
    public abstract N getNamespaceMapping();

    /**
     * Add a mapping to the namespace map
     * @param prefix
     * @param uri
     * @throws RepositoryException
     */
    public abstract void setNamespace(String prefix, String uri) throws RepositoryException;

    /**
     * Builder for a node type definition of type T.
     * @param 
     */
    public static abstract class AbstractNodeTypeDefinitionBuilder {

        /** See {@link #setName(String)} */
        protected String name;

        /** See {@link #setMixin(boolean)} */
        protected boolean isMixin;

        /** See {@link #setOrderableChildNodes(boolean)} */
        protected boolean isOrderable;

        /** See {@link #setAbstract(boolean)} */
        protected boolean isAbstract;

        /** See {@link #setQueryable(boolean)} */
        protected boolean queryable;

        /**
         * Set the name of the node type definition being built
         * @param name
         * @throws RepositoryException  if the name is not valid
         * @see NodeTypeDefinition#getName()
         */
        public void setName(String name) throws RepositoryException {
            this.name = name;
        }

        /**
         * Returns the name of the node type definition being built
         * @return
         */
        public String getName() {
            return name;
        }

        /**
         * Add the given name to the set of supertypes of the node type definition
         * being built
         * @param name  name of the the supertype
         * @throws RepositoryException  if the name is not valid
         * @see NodeTypeDefinition#getDeclaredSupertypeNames()
         */
        public abstract void addSupertype(String name) throws RepositoryException;

        /**
         * @param isMixin true if building a mixin node type
         * definition; false otherwise.
         * @throws RepositoryException
         * @see NodeTypeDefinition#isMixin()
         */
        public void setMixin(boolean isMixin) throws RepositoryException {
            this.isMixin = isMixin;
        }

        /**
         * @param isOrderable true if building a node type having
         * orderable child nodes; false otherwise.
         * @throws RepositoryException
         * @see NodeTypeDefinition#hasOrderableChildNodes()
         */
        public void setOrderableChildNodes(boolean isOrderable) throws RepositoryException {
            this.isOrderable = isOrderable;
        }

        /**
         * @param name  the name of the primary item.
         * @throws RepositoryException
         * @see NodeTypeDefinition#getPrimaryItemName()
         */
        public abstract void setPrimaryItemName(String name) throws RepositoryException;

        /**
         * @param isAbstract true if building a node type that is abstract.
         * @throws RepositoryException
         * @see NodeTypeDefinition#isAbstract()
         */
        public void setAbstract(boolean isAbstract) throws RepositoryException {
            this.isAbstract = isAbstract;
        }

        /**
         * @param queryable true if building a node type that is queryable
         * @throws RepositoryException
         * @see NodeTypeDefinition#isQueryable()
         */
        public void setQueryable(boolean queryable) throws RepositoryException {
            this.queryable = queryable;
        }

        /**
         * Create a new instance of a {@link DefinitionBuilderFactory.AbstractPropertyDefinitionBuilder}
         * which can be used to add property definitions to the node type definition being built.
         * @return
         * @throws RepositoryException
         */
        public abstract AbstractPropertyDefinitionBuilder newPropertyDefinitionBuilder()
                throws RepositoryException;

        /**
         * Create a new instance fo a {@link DefinitionBuilderFactory.AbstractNodeDefinitionBuilder}
         * which can be used to add child node definitions to the node type definition being built.
         * @return
         * @throws RepositoryException
         */
        public abstract AbstractNodeDefinitionBuilder newNodeDefinitionBuilder() throws RepositoryException;

        /**
         * Build this node type definition
         * @return
         * @throws RepositoryException
         */
        public abstract T build() throws RepositoryException;
    }

    /**
     * Builder for item definitions of type T
     * @param 
     */
    public static abstract class AbstractItemDefinitionBuilder {

        /** See {@link #setName(String)} */
        protected String name;

        /** See {@link #setAutoCreated(boolean)} */
        protected boolean autocreate;

        /** See {@link #setOnParentVersion(int)} */
        protected int onParent;

        /** See {@link #setProtected(boolean)} */
        protected boolean isProtected;

        /** See {@link #setMandatory(boolean)} */
        protected boolean isMandatory;

        /**
         * @param name  the name of the child item definition being build
         * @throws RepositoryException
         * @see ItemDefinition#getName()
         */
        public void setName(String name) throws RepositoryException {
            this.name = name;
        }

        /**
         * Name of the child item definition being built
         * @return
         */
        public String getName() {
            return name;
        }

        /**
         * @param name the name of the declaring node type.
         * @throws RepositoryException
         * @see ItemDefinition#getDeclaringNodeType()
         */
        public abstract void setDeclaringNodeType(String name) throws RepositoryException;

        /**
         * @param autocreate true if building a 'autocreate' child item
         * definition, false otherwise.
         * @throws RepositoryException
         * @see ItemDefinition#isAutoCreated()
         */
        public void setAutoCreated(boolean autocreate) throws RepositoryException {
            this.autocreate = autocreate;
        }

        /**
         * @param onParent the 'onParentVersion' attribute of the child item definition being built
         * @throws RepositoryException
         * @see ItemDefinition#getOnParentVersion()
         */
        public void setOnParentVersion(int onParent) throws RepositoryException {
            this.onParent = onParent;
        }

        /**
         * @param isProtected true if building a 'protected' child
         * item definition, false otherwise.
         * @throws RepositoryException
         * @see ItemDefinition#isProtected()
         */
        public void setProtected(boolean isProtected) throws RepositoryException {
            this.isProtected = isProtected;
        }

        /**
         * @param isMandatory true if building a 'mandatory' child
         * item definition, false otherwise.
         * @throws RepositoryException
         */
        public void setMandatory(boolean isMandatory) throws RepositoryException {
            this.isMandatory = isMandatory;
        }

        /**
         * Build this item definition an add it to its parent node type definition
         * @throws RepositoryException
         */
        public abstract void build() throws RepositoryException;
    }

    /**
     * Builder for property definitions of type T
     * @param 
     */
    public static abstract class AbstractPropertyDefinitionBuilder extends AbstractItemDefinitionBuilder {

        private static final String[] ALL_OPERATORS = new String[]{
                QueryObjectModelConstants.JCR_OPERATOR_EQUAL_TO,
                QueryObjectModelConstants.JCR_OPERATOR_GREATER_THAN,
                QueryObjectModelConstants.JCR_OPERATOR_GREATER_THAN_OR_EQUAL_TO,
                QueryObjectModelConstants.JCR_OPERATOR_LESS_THAN,
                QueryObjectModelConstants.JCR_OPERATOR_LESS_THAN_OR_EQUAL_TO,
                QueryObjectModelConstants.JCR_OPERATOR_LIKE,
                QueryObjectModelConstants.JCR_OPERATOR_NOT_EQUAL_TO
        };

        /** See {@link #setRequiredType(int)} */
        protected int requiredType = PropertyType.UNDEFINED;

        /** See {@link #setMultiple(boolean)} */
        protected boolean isMultiple = false;

        /** See {@link #setFullTextSearchable(boolean)} */
        protected boolean fullTextSearchable = true;

        /** See {@link #setQueryOrderable(boolean)} */
        protected boolean queryOrderable = true;

        /** See {@link #setAvailableQueryOperators(String[])} */
        protected String[] queryOperators = ALL_OPERATORS;

        /**
         * @param type the required type of the property definition being built.
         * @throws RepositoryException
         * @see PropertyDefinition#getRequiredType()
         */
        public void setRequiredType(int type) throws RepositoryException {
            this.requiredType = type;
        }

        /**
         * The required type of the property definition being built.
         * @return
         */
        public int getRequiredType() {
            return requiredType;
        }

        /**
         * @param constraint  add a value constraint to the list of value constraints of the property
         * definition being built.
         * @throws RepositoryException
         * @see PropertyDefinition#getValueConstraints()
         */
        public abstract void addValueConstraint(String constraint) throws RepositoryException;

        /**
         * @param value  add a default value to the list of default values of the property definition
         * being built.
         * @throws RepositoryException
         * @see PropertyDefinition#getDefaultValues()
         */
        public abstract void addDefaultValues(String value) throws RepositoryException;

         /**
         * @param isMultiple true if building a 'multiple' property definition.
         * @throws RepositoryException
         * @see PropertyDefinition#isMultiple()
         */
        public void setMultiple(boolean isMultiple) throws RepositoryException {
            this.isMultiple = isMultiple;
        }

        /**
         * @param fullTextSearchable true if building a
         * 'fulltext searchable' property definition
         * @throws RepositoryException
         * @see PropertyDefinition#isFullTextSearchable()
         */
        public void setFullTextSearchable(boolean fullTextSearchable) throws RepositoryException {
            this.fullTextSearchable = fullTextSearchable;
        }

        /**
         * @param queryOrderable true if the property is orderable in a query
         * @throws RepositoryException
         * @see PropertyDefinition#isQueryOrderable()
         */
        public void setQueryOrderable(boolean queryOrderable) throws RepositoryException {
            this.queryOrderable = queryOrderable;
        }

        /**
         * @param queryOperators the query operators of the property
         * @throws RepositoryException
         * @see PropertyDefinition#getAvailableQueryOperators()
         */
        public void setAvailableQueryOperators(String[] queryOperators) throws RepositoryException {
            if (queryOperators == null) {
                throw new NullPointerException("queryOperators");
            }
            this.queryOperators = queryOperators;
        }
    }

    /**
     * Builder for child node definitions of type T
     * @param 
     */
    public static abstract class AbstractNodeDefinitionBuilder extends AbstractItemDefinitionBuilder {
        protected boolean allowSns;

        /**
         * @param name the name of the default primary type of the node definition being built.
         * @throws RepositoryException
         */
        public abstract void setDefaultPrimaryType(String name) throws RepositoryException;

        /**
         * @param name  add a required primary type to the list of names of the required primary types of
         * the node definition being built.
         * @throws RepositoryException
         */
        public abstract void addRequiredPrimaryType(String name) throws RepositoryException;

        /**
         * @param allowSns true if building a node definition with same name siblings, false otherwise.
         * @throws RepositoryException
         */
        public void setAllowsSameNameSiblings(boolean allowSns) throws RepositoryException {
            this.allowSns = allowSns;
        }

    }

}






© 2015 - 2024 Weber Informatics LLC | Privacy Policy