001 /** 002 * Copyright 2010 The Kuali Foundation Licensed under the 003 * Educational Community License, Version 2.0 (the "License"); you may 004 * not use this file except in compliance with the License. You may 005 * obtain a copy of the License at 006 * 007 * http://www.osedu.org/licenses/ECL-2.0 008 * 009 * Unless required by applicable law or agreed to in writing, 010 * software distributed under the License is distributed on an "AS IS" 011 * BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 012 * or implied. See the License for the specific language governing 013 * permissions and limitations under the License. 014 */ 015 016 package org.kuali.student.lum.lo.dto; 017 018 import java.io.Serializable; 019 import java.util.Date; 020 import java.util.HashMap; 021 import java.util.Map; 022 023 import javax.xml.bind.annotation.XmlAccessType; 024 import javax.xml.bind.annotation.XmlAccessorType; 025 import javax.xml.bind.annotation.XmlAttribute; 026 import javax.xml.bind.annotation.XmlElement; 027 import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter; 028 029 import org.kuali.student.core.dto.MetaInfo; 030 import org.kuali.student.core.ws.binding.JaxbAttributeMapListAdapter; 031 032 /** 033 * 034 * 035 * @Author KSContractMojo 036 * @Author jimt 037 * @Since Tue Dec 08 10:01:34 PST 2009 038 * @See <a href="https://test.kuali.org/confluence/display/KULSTU/loLoRelationInfo+Structure+v1.0-rc2">LoLoRelationInfo</> 039 * 040 */ 041 @XmlAccessorType(XmlAccessType.FIELD) 042 public class LoLoRelationInfo implements Serializable { 043 044 private static final long serialVersionUID = 1L; 045 046 @XmlElement 047 private String loId; 048 049 @XmlElement 050 private String relatedLoId; 051 052 @XmlElement 053 private Date effectiveDate; 054 055 @XmlElement 056 private Date expirationDate; 057 058 @XmlElement 059 @XmlJavaTypeAdapter(JaxbAttributeMapListAdapter.class) 060 private Map<String, String> attributes; 061 062 @XmlElement 063 private MetaInfo metaInfo; 064 065 @XmlAttribute 066 private String type; 067 068 @XmlAttribute 069 private String state; 070 071 @XmlAttribute 072 private String id; 073 074 /** 075 * Unique identifier for a learning objective record. This is the "From" or "Parent" in the relation. 076 */ 077 public String getLoId() { 078 return loId; 079 } 080 081 public void setLoId(String loId) { 082 this.loId = loId; 083 } 084 085 /** 086 * Unique identifier for a learning objective record. This is the "To" or "Child" of the relation. 087 */ 088 public String getRelatedLoId() { 089 return relatedLoId; 090 } 091 092 public void setRelatedLoId(String relatedLoId) { 093 this.relatedLoId = relatedLoId; 094 } 095 096 /** 097 * Date and time that this LO to LO relationship became effective. This is a similar concept to the effective date on enumerated values. When an expiration date has been specified, this field must be less than or equal to the expiration date. 098 */ 099 public Date getEffectiveDate() { 100 return effectiveDate; 101 } 102 103 public void setEffectiveDate(Date effectiveDate) { 104 this.effectiveDate = effectiveDate; 105 } 106 107 /** 108 * Date and time that this LO to LO relationship expires. This is a similar concept to the expiration date on enumerated values. If specified, this should be greater than or equal to the effective date. If this field is not specified, then no expiration date has been currently defined and should automatically be considered greater than the effective date. 109 */ 110 public Date getExpirationDate() { 111 return expirationDate; 112 } 113 114 public void setExpirationDate(Date expirationDate) { 115 this.expirationDate = expirationDate; 116 } 117 118 /** 119 * List of key/value pairs, typically used for dynamic attributes. 120 */ 121 public Map<String, String> getAttributes() { 122 if (attributes == null) { 123 attributes = new HashMap<String, String>(); 124 } 125 return attributes; 126 } 127 128 public void setAttributes(Map<String, String> attributes) { 129 this.attributes = attributes; 130 } 131 132 /** 133 * Create and last update info for the structure. This is optional and treated as read only since the data is set by the internals of the service during maintenance operations. 134 */ 135 public MetaInfo getMetaInfo() { 136 return metaInfo; 137 } 138 139 public void setMetaInfo(MetaInfo metaInfo) { 140 this.metaInfo = metaInfo; 141 } 142 143 /** 144 * Unique identifier for the LO to LO relation type. 145 */ 146 public String getType() { 147 return type; 148 } 149 150 public void setType(String type) { 151 this.type = type; 152 } 153 154 /** 155 * Identifier for the current status of a LO to LO relationship. The values for this field are constrained to those in the luLuRelationState enumeration. A separate setup operation does not exist for retrieval of the meta data around this value. 156 */ 157 public String getState() { 158 return state; 159 } 160 161 public void setState(String state) { 162 this.state = state; 163 } 164 165 /** 166 * Unique identifier for a LO to LO relationship. This is optional, due to the identifier being set at the time of creation. Once the relation has been created, this should be seen as required. 167 */ 168 public String getId() { 169 return id; 170 } 171 172 public void setId(String id) { 173 this.id = id; 174 } 175 }