/******************************************************************************* * Australian National University Data Commons * Copyright (C) 2013 The Australian National University * * This file is part of Australian National University Data Commons. * * Australian National University Data Commons is free software: you * can redistribute it and/or modify it under the terms of the GNU * General Public License as published by the Free Software Foundation, * either version 3 of the License, or (at your option) any later * version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. ******************************************************************************/ package au.edu.anu.datacommons.ands.xml; import javax.validation.constraints.NotNull; import javax.validation.constraints.Pattern; import javax.xml.bind.annotation.XmlAttribute; /** * ElectronicAddressArgument * * Australian National University Data Commons * * Class for the arg element in the ANDS RIF-CS schema * * JUnit Coverage: * None * * <pre> * Version Date Developer Description * 0.1 12/10/2012 Genevieve Turner (GT) Initial * </pre> * */ public class ElectronicAddressArgument { private String required; private String type; private String use; /** * getRequired * * Get whether the electronic address argument is required * * <pre> * Version Date Developer Description * 0.1 03/10/2012 Genevieve Turner(GT) Initial * </pre> * * @return the required */ @NotNull(message = "Whether an argument is required or not needs to be specified for an electronic argument") @Pattern(regexp="^true|false$", message="The required field of an argument must be true or false") @XmlAttribute public String getRequired() { return required; } /** * setRequired * * Set whether the electronic address argument is required * * <pre> * Version Date Developer Description * 0.1 03/10/2012 Genevieve Turner(GT) Initial * </pre> * * @param required the required to set */ public void setRequired(String required) { this.required = required; } /** * getType * * Get the argument type * * <pre> * Version Date Developer Description * 0.1 03/10/2012 Genevieve Turner(GT) Initial * </pre> * * @return the type */ @NotNull(message="The type of an electronic argument must not be null") @Pattern(regexp="^string|object$", message="The type an electronic argument must be string or object") @XmlAttribute public String getType() { return type; } /** * setType * * Set the argument type * * <pre> * Version Date Developer Description * 0.1 03/10/2012 Genevieve Turner(GT) Initial * </pre> * * @param type the type to set */ public void setType(String type) { this.type = type; } /** * getUse * * Get the use of the argument * * <pre> * Version Date Developer Description * 0.1 03/10/2012 Genevieve Turner(GT) Initial * </pre> * * @return the use */ @Pattern(regexp="^inline|keyValue$", message="The use field of an electronic argument must be inline or keyValue") @XmlAttribute public String getUse() { return use; } /** * setUse * * Set the use of the argument * * <pre> * Version Date Developer Description * 0.1 03/10/2012 Genevieve Turner(GT) Initial * </pre> * * @param use the use to set */ public void setUse(String use) { this.use = use; } }