001    /**
002     * Copyright 2005-2013 The Kuali Foundation
003     *
004     * Licensed under the Educational Community License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.opensource.org/licenses/ecl2.php
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    package org.kuali.rice.kew.api.document.attribute;
017    
018    import javax.xml.bind.annotation.XmlAccessType;
019    import javax.xml.bind.annotation.XmlAccessorType;
020    import javax.xml.bind.annotation.XmlElement;
021    import javax.xml.bind.annotation.XmlRootElement;
022    import javax.xml.bind.annotation.XmlType;
023    
024    /**
025     * A document attribute which contains character data.  Construct instances of {@code DocumentAttributeString} using
026     * it's builder or the {@link DocumentAttributeFactory}.
027     *
028     * @author Kuali Rice Team (rice.collab@kuali.org)
029     */
030    @XmlRootElement(name = DocumentAttributeString.Constants.ROOT_ELEMENT_NAME)
031    @XmlAccessorType(XmlAccessType.NONE)
032    @XmlType(name = DocumentAttributeString.Constants.TYPE_NAME, propOrder = {
033        DocumentAttributeString.Elements.VALUE
034    })
035    public final class DocumentAttributeString extends DocumentAttribute {
036    
037        @XmlElement(name = Elements.VALUE, required = false)
038        private final String value;
039    
040        @SuppressWarnings("unused")
041        private DocumentAttributeString() {
042            this.value = null;
043        }
044    
045        private DocumentAttributeString(Builder builder) {
046            super(builder.getName());
047            this.value = builder.getValue();
048        }
049    
050        @Override
051        public String getValue() {
052            return value;
053        }
054    
055        @Override
056        public DocumentAttributeDataType getDataType() {
057            return DocumentAttributeDataType.STRING;
058        }
059    
060        /**
061         * A builder implementation which allows for construction of a {@code DocumentAttributeString}.
062         */
063        public static final class Builder extends AbstractBuilder<String> {
064    
065            private Builder(String name) {
066                super(name);
067            }
068    
069            /**
070             * Create a builder for the document attribute using the given attribute name.
071             *
072             * @param name the name of the document attribute which should be built by this builder, should never be a
073             * null or blank value
074             * @return a builder instance initialized with the given attribute name
075             */
076            public static Builder create(String name) {
077                return new Builder(name);
078            }
079    
080            @Override
081            public DocumentAttributeDataType getDataType() {
082                return DocumentAttributeDataType.STRING;
083            }
084    
085            @Override
086            public DocumentAttributeString build() {
087                return new DocumentAttributeString(this);
088            }
089    
090        }
091    
092        /**
093         * Defines some internal constants used on this class.
094         */
095        static class Constants {
096            final static String ROOT_ELEMENT_NAME = "documentAttributeString";
097            final static String TYPE_NAME = "DocumentAttributeStringType";
098        }
099    
100        /**
101         * A private class which exposes constants which define the XML element names to use when this object is marshalled to XML.
102         */
103        static class Elements {
104            final static String VALUE = "value";
105        }
106    
107    }