001    /**
002     * Copyright 2005-2014 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.kim.api.role;
017    
018    import org.apache.commons.lang.StringUtils;
019    import org.apache.commons.lang.builder.EqualsBuilder;
020    import org.apache.commons.lang.builder.HashCodeBuilder;
021    import org.apache.commons.lang.builder.ToStringBuilder;
022    import org.kuali.rice.core.api.CoreConstants;
023    import org.kuali.rice.core.api.mo.AbstractDataTransferObject;
024    import org.kuali.rice.core.api.mo.ModelBuilder;
025    import org.kuali.rice.core.api.mo.ModelObjectComplete;
026    import org.kuali.rice.kim.api.KimConstants;
027    import org.w3c.dom.Element;
028    
029    import javax.xml.bind.annotation.XmlAccessType;
030    import javax.xml.bind.annotation.XmlAccessorType;
031    import javax.xml.bind.annotation.XmlAnyElement;
032    import javax.xml.bind.annotation.XmlElement;
033    import javax.xml.bind.annotation.XmlRootElement;
034    import javax.xml.bind.annotation.XmlType;
035    import java.util.Collection;
036    
037    
038    /**
039     * This is a description of what this class does - shyu don't forget to fill this in.
040     *
041     * @author Kuali Rice Team (rice.collab@kuali.org)
042     */
043    @XmlRootElement(name = Role.Constants.ROOT_ELEMENT_NAME)
044    @XmlAccessorType(XmlAccessType.NONE)
045    @XmlType(name = Role.Constants.TYPE_NAME, propOrder = {
046            Role.Elements.ID,
047            Role.Elements.NAME,
048            Role.Elements.NAMESPACE_CODE,
049            Role.Elements.DESCRIPTION,
050            Role.Elements.KIM_TYPE_ID,
051            Role.Elements.ACTIVE,
052            CoreConstants.CommonElements.VERSION_NUMBER,
053            CoreConstants.CommonElements.OBJECT_ID,
054            CoreConstants.CommonElements.FUTURE_ELEMENTS
055    })
056    public final class Role extends AbstractDataTransferObject implements RoleContract {
057        private static final long serialVersionUID = 1L;
058    
059        @XmlElement(name = Role.Elements.ID, required = true)
060        private final String id;
061    
062        @XmlElement(name = Role.Elements.NAME, required = true)
063        private final String name;
064    
065        @XmlElement(name = Role.Elements.NAMESPACE_CODE, required = true)
066        private final String namespaceCode;
067    
068        @XmlElement(name = Role.Elements.DESCRIPTION)
069        private final String description;
070    
071        @XmlElement(name = Role.Elements.KIM_TYPE_ID, required = true)
072        private final String kimTypeId;
073    
074        @XmlElement(name = CoreConstants.CommonElements.ACTIVE, required = true)
075        private final boolean active;
076    
077        @XmlElement(name = CoreConstants.CommonElements.VERSION_NUMBER)
078        private final Long versionNumber;
079    
080        @XmlElement(name = CoreConstants.CommonElements.OBJECT_ID, required = false)
081        private final String objectId;
082    
083        @SuppressWarnings("unused")
084        @XmlAnyElement
085        private final Collection<Element> _futureElements = null;
086    
087    
088        /**
089         * This constructor should never be called except during JAXB unmarshalling.
090         */
091        @SuppressWarnings("unused")
092        private Role() {
093            id = null;
094            name = null;
095            namespaceCode = null;
096            description = null;
097            kimTypeId = null;
098            active = false;
099            objectId = null;
100            versionNumber = null;
101        }
102    
103        private Role(Builder builder) {
104            id = builder.getId();
105            name = builder.getName();
106            namespaceCode = builder.getNamespaceCode();
107            description = builder.getDescription();
108            kimTypeId = builder.getKimTypeId();
109            active = builder.isActive();
110            versionNumber = builder.getVersionNumber();
111            objectId = builder.getObjectId();
112        }
113    
114    
115        /**
116         * Unique identifier for this role.
117         */
118        @Override
119        public String getId() {
120            return id;
121        }
122    
123        /**
124         * Namespace for this role - identifies the system/module to which this role applies
125         */
126        @Override
127        public String getNamespaceCode() {
128            return namespaceCode;
129        }
130    
131        /**
132         * Name for this role.  This value will be seen by the users.
133         */
134        @Override
135        public String getName() {
136            return name;
137        }
138    
139        /**
140         * Verbose description of the role and functionally what permissions it implies.
141         */
142        @Override
143        public String getDescription() {
144            return description;
145        }
146    
147        /**
148         * Type identifier for this role.  This will control what additional attributes are available
149         */
150        @Override
151        public String getKimTypeId() {
152            return kimTypeId;
153        }
154    
155        @Override
156        public Long getVersionNumber() {
157            return versionNumber;
158        }
159    
160        @Override
161        public String getObjectId() {
162            return objectId;
163        }
164    
165        @Override
166        public boolean isActive() {
167            return active;
168        }
169    
170        public static final class Builder implements RoleContract, ModelBuilder, ModelObjectComplete {
171    
172            private String id;
173            private String name;
174            private String namespaceCode;
175            private String description;
176            private String kimTypeId;
177            private boolean active;
178            private Long versionNumber;
179            private String objectId;
180    
181            private Builder() {
182            }
183    
184            public static Builder create() {
185                return new Builder();
186            }
187    
188            public static Builder create(String id, String name, String namespaceCode, String description, String kimTypeId) {
189                Builder b = new Builder();
190                b.setId(id);
191                b.setName(name);
192                b.setNamespaceCode(namespaceCode);
193                b.setDescription(description);
194                b.setKimTypeId(kimTypeId);
195                b.setActive(true);
196    
197                return b;
198            }
199    
200            public static Builder create(RoleContract roleContract) {
201                Builder b = new Builder();
202                b.setId(roleContract.getId());
203                b.setName(roleContract.getName());
204                b.setNamespaceCode(roleContract.getNamespaceCode());
205                b.setDescription(roleContract.getDescription());
206                b.setKimTypeId(roleContract.getKimTypeId());
207                b.setActive(roleContract.isActive());
208                b.setVersionNumber(roleContract.getVersionNumber());
209                b.setObjectId(roleContract.getObjectId());
210                return b;
211            }
212    
213            @Override
214            public Role build() {
215                return new Role(this);
216            }
217    
218            public void setId(String id) {
219                if (StringUtils.isWhitespace(id)) {
220                    throw new IllegalArgumentException("id cannot be blank");
221                }
222                this.id = id;
223            }
224    
225            @Override
226            public String getId() {
227                return id;
228            }
229    
230            public void setNamespaceCode(String namespaceCode) {
231                if (StringUtils.isBlank(namespaceCode)) {
232                    throw new IllegalArgumentException("namespaceCode cannot be blank or null");
233                }
234                this.namespaceCode = namespaceCode;
235            }
236    
237            @Override
238            public String getNamespaceCode() {
239                return namespaceCode;
240            }
241    
242            public void setName(String name) {
243                if (StringUtils.isBlank(name)) {
244                    throw new IllegalArgumentException("name cannot be blank or null");
245                }
246                this.name = name;
247            }
248    
249            @Override
250            public String getName() {
251                return name;
252            }
253    
254            public void setDescription(String description) {
255                this.description = description;
256            }
257    
258            @Override
259            public String getDescription() {
260                return description;
261            }
262    
263            public void setKimTypeId(String kimTypeId) {
264                if (StringUtils.isBlank(kimTypeId)) {
265                    throw new IllegalArgumentException("kimTypeId cannot be blank or null");
266                }
267                this.kimTypeId = kimTypeId;
268            }
269    
270            @Override
271            public String getKimTypeId() {
272                return kimTypeId;
273            }
274    
275            public void setActive(boolean active) {
276                this.active = active;
277            }
278    
279            @Override
280            public boolean isActive() {
281                return active;
282            }
283    
284            public void setVersionNumber(Long versionNumber) {
285                this.versionNumber = versionNumber;
286            }
287    
288            @Override
289            public Long getVersionNumber() {
290                return versionNumber;
291            }
292    
293            public void setObjectId(String objectId) {
294                this.objectId = objectId;
295            }
296    
297            @Override
298            public String getObjectId() {
299                return objectId;
300            }
301    
302            @Override
303            public int hashCode() {
304                return HashCodeBuilder.reflectionHashCode(this);
305            }
306    
307            @Override
308            public boolean equals(Object obj) {
309                return EqualsBuilder.reflectionEquals(obj, this);
310            }
311    
312            @Override
313            public String toString() {
314                return ToStringBuilder.reflectionToString(this);
315            }
316        }
317    
318        /**
319         * A private class which exposes constants which define the XML element names to use
320         * when this object is marshalled to XML.
321         */
322        static class Elements {
323            final static String ID = "id";
324            final static String NAME = "name";
325            final static String DESCRIPTION = "description";
326            final static String KIM_TYPE_ID = "kimTypeId";
327            final static String NAMESPACE_CODE = "namespaceCode";
328            final static String ACTIVE = "active";
329        }
330    
331        /**
332         * Defines some internal constants used on this class.
333         */
334        static class Constants {
335            final static String ROOT_ELEMENT_NAME = "role";
336            final static String TYPE_NAME = "RoleType";
337        }
338    
339        public static class Cache {
340            public static final String NAME = KimConstants.Namespaces.KIM_NAMESPACE_2_0 + "/" + Role.Constants.TYPE_NAME;
341        }
342    }