package com.amazonaws.a2s.model;
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlType;
/**
* <p>Java class for TransactionLookupRequest complex type.
*
* <p>The following schema fragment specifies the expected content contained within this class.
*
* <pre>
* <complexType name="TransactionLookupRequest">
* <complexContent>
* <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
* <sequence>
* <element name="ResponseGroup" maxOccurs="unbounded" minOccurs="0">
* <simpleType>
* <restriction base="{http://www.w3.org/2001/XMLSchema}string">
* <enumeration value="Request"/>
* <enumeration value="TransactionDetails"/>
* </restriction>
* </simpleType>
* </element>
* <element name="TransactionId" type="{http://www.w3.org/2001/XMLSchema}string" maxOccurs="unbounded" minOccurs="0"/>
* </sequence>
* </restriction>
* </complexContent>
* </complexType>
* </pre>
* Generated by AWS Code Generator
* <p/>
* Thu Jan 10 05:27:59 PST 2008
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "TransactionLookupRequest", propOrder = {
"responseGroup",
"transactionId"
})
public class TransactionLookupRequest {
@XmlElement(name = "ResponseGroup")
protected List<String> responseGroup;
@XmlElement(name = "TransactionId")
protected List<String> transactionId;
/**
* Gets the value of the responseGroup property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the responseGroup property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getResponseGroup().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link String }
*
*
*/
public List<String> getResponseGroup() {
if (responseGroup == null) {
responseGroup = new ArrayList<String>();
}
return this.responseGroup;
}
public boolean isSetResponseGroup() {
return ((this.responseGroup!= null)&&(!this.responseGroup.isEmpty()));
}
public void unsetResponseGroup() {
this.responseGroup = null;
}
/**
* Gets the value of the transactionId property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the transactionId property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getTransactionId().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link String }
*
*
*/
public List<String> getTransactionId() {
if (transactionId == null) {
transactionId = new ArrayList<String>();
}
return this.transactionId;
}
public boolean isSetTransactionId() {
return ((this.transactionId!= null)&&(!this.transactionId.isEmpty()));
}
public void unsetTransactionId() {
this.transactionId = null;
}
/**
* Sets the value of the ResponseGroup property.
*
* @param values
* @return
* this instance
*/
public TransactionLookupRequest withResponseGroup(String... values) {
for (String value: values) {
getResponseGroup().add(value);
}
return this;
}
/**
* Sets the value of the TransactionId property.
*
* @param values
* @return
* this instance
*/
public TransactionLookupRequest withTransactionId(String... values) {
for (String value: values) {
getTransactionId().add(value);
}
return this;
}
/**
* Sets the value of the responseGroup property.
*
* @param responseGroup
* allowed object is
* {@link String }
*
*/
public void setResponseGroup(List<String> responseGroup) {
this.responseGroup = responseGroup;
}
/**
* Sets the value of the transactionId property.
*
* @param transactionId
* allowed object is
* {@link String }
*
*/
public void setTransactionId(List<String> transactionId) {
this.transactionId = transactionId;
}
/**
*
* XML fragment representation of this object
*
* @return XML fragment for this object. Name for outer
* tag expected to be set by calling method. This fragment
* returns inner properties representation only
*/
protected String toXMLFragment() {
StringBuffer xml = new StringBuffer();
java.util.List<String> responseGroupList = getResponseGroup();
for (String responseGroup : responseGroupList) {
xml.append("<ResponseGroup>");
xml.append(responseGroup + "");
xml.append("</ResponseGroup>");
}
java.util.List<String> transactionIdList = getTransactionId();
for (String transactionId : transactionIdList) {
xml.append("<TransactionId>");
xml.append(escapeXML(transactionId));
xml.append("</TransactionId>");
}
return xml.toString();
}
/**
*
* Escape XML special characters
*/
private String escapeXML(String string) {
StringBuffer sb = new StringBuffer();
int length = string.length();
for (int i = 0; i < length; ++i) {
char c = string.charAt(i);
switch (c) {
case '&':
sb.append("&");
break;
case '<':
sb.append("<");
break;
case '>':
sb.append(">");
break;
case '\'':
sb.append("'");
break;
case '"':
sb.append(""");
break;
default:
sb.append(c);
}
}
return sb.toString();
}
}
|