001/** 002 * Copyright 2005-2015 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 */ 016package org.kuali.rice.kim.api.identity.residency; 017 018import org.apache.commons.lang.StringUtils; 019import org.kuali.rice.core.api.CoreConstants; 020import org.kuali.rice.core.api.mo.AbstractDataTransferObject; 021import org.kuali.rice.core.api.mo.ModelBuilder; 022import org.w3c.dom.Element; 023 024import javax.xml.bind.annotation.XmlAccessType; 025import javax.xml.bind.annotation.XmlAccessorType; 026import javax.xml.bind.annotation.XmlAnyElement; 027import javax.xml.bind.annotation.XmlElement; 028import javax.xml.bind.annotation.XmlRootElement; 029import javax.xml.bind.annotation.XmlType; 030import java.io.Serializable; 031import java.util.Collection; 032 033@XmlRootElement(name = EntityResidency.Constants.ROOT_ELEMENT_NAME) 034@XmlAccessorType(XmlAccessType.NONE) 035@XmlType(name = EntityResidency.Constants.TYPE_NAME, propOrder = { 036 EntityResidency.Elements.ID, 037 EntityResidency.Elements.ENTITY_ID, 038 EntityResidency.Elements.DETERMINATION_METHOD, 039 EntityResidency.Elements.IN_STATE, 040 CoreConstants.CommonElements.VERSION_NUMBER, 041 CoreConstants.CommonElements.OBJECT_ID, 042 CoreConstants.CommonElements.FUTURE_ELEMENTS 043}) 044public final class EntityResidency extends AbstractDataTransferObject 045 implements EntityResidencyContract 046{ 047 048 @XmlElement(name = Elements.ENTITY_ID, required = false) 049 private final String entityId; 050 @XmlElement(name = Elements.DETERMINATION_METHOD, required = false) 051 private final String determinationMethod; 052 @XmlElement(name = Elements.IN_STATE, required = false) 053 private final String inState; 054 @XmlElement(name = CoreConstants.CommonElements.VERSION_NUMBER, required = false) 055 private final Long versionNumber; 056 @XmlElement(name = CoreConstants.CommonElements.OBJECT_ID, required = false) 057 private final String objectId; 058 @XmlElement(name = Elements.ID, required = false) 059 private final String id; 060 @SuppressWarnings("unused") 061 @XmlAnyElement 062 private final Collection<Element> _futureElements = null; 063 064 /** 065 * Private constructor used only by JAXB. 066 * 067 */ 068 private EntityResidency() { 069 this.entityId = null; 070 this.determinationMethod = null; 071 this.inState = null; 072 this.versionNumber = null; 073 this.objectId = null; 074 this.id = null; 075 } 076 077 private EntityResidency(Builder builder) { 078 this.entityId = builder.getEntityId(); 079 this.determinationMethod = builder.getDeterminationMethod(); 080 this.inState = builder.getInState(); 081 this.versionNumber = builder.getVersionNumber(); 082 this.objectId = builder.getObjectId(); 083 this.id = builder.getId(); 084 } 085 086 @Override 087 public String getEntityId() { 088 return this.entityId; 089 } 090 091 @Override 092 public String getDeterminationMethod() { 093 return this.determinationMethod; 094 } 095 096 @Override 097 public String getInState() { 098 return this.inState; 099 } 100 101 @Override 102 public Long getVersionNumber() { 103 return this.versionNumber; 104 } 105 106 @Override 107 public String getObjectId() { 108 return this.objectId; 109 } 110 111 @Override 112 public String getId() { 113 return this.id; 114 } 115 116 117 /** 118 * A builder which can be used to construct {@link EntityResidency} instances. Enforces the constraints of the {@link EntityResidencyContract}. 119 * 120 */ 121 public final static class Builder 122 implements Serializable, ModelBuilder, EntityResidencyContract 123 { 124 125 private String entityId; 126 private String determinationMethod; 127 private String inState; 128 private Long versionNumber; 129 private String objectId; 130 private String id; 131 132 private Builder() { } 133 134 public static Builder create() { 135 return new Builder(); 136 } 137 138 public static Builder create(EntityResidencyContract contract) { 139 if (contract == null) { 140 throw new IllegalArgumentException("contract was null"); 141 } 142 Builder builder = create(); 143 builder.setEntityId(contract.getEntityId()); 144 builder.setDeterminationMethod(contract.getDeterminationMethod()); 145 builder.setInState(contract.getInState()); 146 builder.setVersionNumber(contract.getVersionNumber()); 147 builder.setObjectId(contract.getObjectId()); 148 builder.setId(contract.getId()); 149 return builder; 150 } 151 152 public EntityResidency build() { 153 return new EntityResidency(this); 154 } 155 156 @Override 157 public String getEntityId() { 158 return this.entityId; 159 } 160 161 @Override 162 public String getDeterminationMethod() { 163 return this.determinationMethod; 164 } 165 166 @Override 167 public String getInState() { 168 return this.inState; 169 } 170 171 @Override 172 public Long getVersionNumber() { 173 return this.versionNumber; 174 } 175 176 @Override 177 public String getObjectId() { 178 return this.objectId; 179 } 180 181 @Override 182 public String getId() { 183 return this.id; 184 } 185 186 public void setEntityId(String entityId) { 187 this.entityId = entityId; 188 } 189 190 public void setDeterminationMethod(String determinationMethod) { 191 this.determinationMethod = determinationMethod; 192 } 193 194 public void setInState(String inState) { 195 this.inState = inState; 196 } 197 198 public void setVersionNumber(Long versionNumber) { 199 this.versionNumber = versionNumber; 200 } 201 202 public void setObjectId(String objectId) { 203 this.objectId = objectId; 204 } 205 206 public void setId(String id) { 207 if (StringUtils.isWhitespace(id)) { 208 throw new IllegalArgumentException("id is blank"); 209 } 210 this.id = id; 211 } 212 213 } 214 215 216 /** 217 * Defines some internal constants used on this class. 218 * 219 */ 220 static class Constants { 221 222 final static String ROOT_ELEMENT_NAME = "entityResidency"; 223 final static String TYPE_NAME = "entityResidencyType"; 224 } 225 226 227 /** 228 * A private class which exposes constants which define the XML element names to use when this object is marshalled to XML. 229 * 230 */ 231 static class Elements { 232 233 final static String ENTITY_ID = "entityId"; 234 final static String DETERMINATION_METHOD = "determinationMethod"; 235 final static String IN_STATE = "inState"; 236 final static String ID = "id"; 237 238 } 239 240}