// Copyright 2017 Google Inc. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/**
* DayPartTargeting.java
*
* This file was auto-generated from WSDL
* by the Apache Axis 1.4 Mar 02, 2009 (07:08:06 PST) WSDL2Java emitter.
*/
package com.google.api.ads.dfp.axis.v201702;
/**
* Modify the delivery times of line items for particular days of
* the week. By
* default, line items are served at all days and times.
*/
public class DayPartTargeting implements java.io.Serializable {
/* Specifies days of the week and times at which a {@code LineItem}
* will be
* delivered.
* <p>
* If targeting all days and times, this value will be
* ignored. */
private com.google.api.ads.dfp.axis.v201702.DayPart[] dayParts;
/* Specifies the time zone to be used for delivering {@link LineItem}
* objects.
* This attribute is optional and defaults to
* {@link DeliveryTimeZone#BROWSER}.
* <p>
* Setting this has no effect if targeting all days and
* times. */
private com.google.api.ads.dfp.axis.v201702.DeliveryTimeZone timeZone;
public DayPartTargeting() {
}
public DayPartTargeting(
com.google.api.ads.dfp.axis.v201702.DayPart[] dayParts,
com.google.api.ads.dfp.axis.v201702.DeliveryTimeZone timeZone) {
this.dayParts = dayParts;
this.timeZone = timeZone;
}
/**
* Gets the dayParts value for this DayPartTargeting.
*
* @return dayParts * Specifies days of the week and times at which a {@code LineItem}
* will be
* delivered.
* <p>
* If targeting all days and times, this value will be
* ignored.
*/
public com.google.api.ads.dfp.axis.v201702.DayPart[] getDayParts() {
return dayParts;
}
/**
* Sets the dayParts value for this DayPartTargeting.
*
* @param dayParts * Specifies days of the week and times at which a {@code LineItem}
* will be
* delivered.
* <p>
* If targeting all days and times, this value will be
* ignored.
*/
public void setDayParts(com.google.api.ads.dfp.axis.v201702.DayPart[] dayParts) {
this.dayParts = dayParts;
}
public com.google.api.ads.dfp.axis.v201702.DayPart getDayParts(int i) {
return this.dayParts[i];
}
public void setDayParts(int i, com.google.api.ads.dfp.axis.v201702.DayPart _value) {
this.dayParts[i] = _value;
}
/**
* Gets the timeZone value for this DayPartTargeting.
*
* @return timeZone * Specifies the time zone to be used for delivering {@link LineItem}
* objects.
* This attribute is optional and defaults to
* {@link DeliveryTimeZone#BROWSER}.
* <p>
* Setting this has no effect if targeting all days and
* times.
*/
public com.google.api.ads.dfp.axis.v201702.DeliveryTimeZone getTimeZone() {
return timeZone;
}
/**
* Sets the timeZone value for this DayPartTargeting.
*
* @param timeZone * Specifies the time zone to be used for delivering {@link LineItem}
* objects.
* This attribute is optional and defaults to
* {@link DeliveryTimeZone#BROWSER}.
* <p>
* Setting this has no effect if targeting all days and
* times.
*/
public void setTimeZone(com.google.api.ads.dfp.axis.v201702.DeliveryTimeZone timeZone) {
this.timeZone = timeZone;
}
private java.lang.Object __equalsCalc = null;
public synchronized boolean equals(java.lang.Object obj) {
if (!(obj instanceof DayPartTargeting)) return false;
DayPartTargeting other = (DayPartTargeting) obj;
if (obj == null) return false;
if (this == obj) return true;
if (__equalsCalc != null) {
return (__equalsCalc == obj);
}
__equalsCalc = obj;
boolean _equals;
_equals = true &&
((this.dayParts==null && other.getDayParts()==null) ||
(this.dayParts!=null &&
java.util.Arrays.equals(this.dayParts, other.getDayParts()))) &&
((this.timeZone==null && other.getTimeZone()==null) ||
(this.timeZone!=null &&
this.timeZone.equals(other.getTimeZone())));
__equalsCalc = null;
return _equals;
}
private boolean __hashCodeCalc = false;
public synchronized int hashCode() {
if (__hashCodeCalc) {
return 0;
}
__hashCodeCalc = true;
int _hashCode = 1;
if (getDayParts() != null) {
for (int i=0;
i<java.lang.reflect.Array.getLength(getDayParts());
i++) {
java.lang.Object obj = java.lang.reflect.Array.get(getDayParts(), i);
if (obj != null &&
!obj.getClass().isArray()) {
_hashCode += obj.hashCode();
}
}
}
if (getTimeZone() != null) {
_hashCode += getTimeZone().hashCode();
}
__hashCodeCalc = false;
return _hashCode;
}
// Type metadata
private static org.apache.axis.description.TypeDesc typeDesc =
new org.apache.axis.description.TypeDesc(DayPartTargeting.class, true);
static {
typeDesc.setXmlType(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201702", "DayPartTargeting"));
org.apache.axis.description.ElementDesc elemField = new org.apache.axis.description.ElementDesc();
elemField.setFieldName("dayParts");
elemField.setXmlName(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201702", "dayParts"));
elemField.setXmlType(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201702", "DayPart"));
elemField.setMinOccurs(0);
elemField.setNillable(false);
elemField.setMaxOccursUnbounded(true);
typeDesc.addFieldDesc(elemField);
elemField = new org.apache.axis.description.ElementDesc();
elemField.setFieldName("timeZone");
elemField.setXmlName(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201702", "timeZone"));
elemField.setXmlType(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201702", "DeliveryTimeZone"));
elemField.setMinOccurs(0);
elemField.setNillable(false);
typeDesc.addFieldDesc(elemField);
}
/**
* Return type metadata object
*/
public static org.apache.axis.description.TypeDesc getTypeDesc() {
return typeDesc;
}
/**
* Get Custom Serializer
*/
public static org.apache.axis.encoding.Serializer getSerializer(
java.lang.String mechType,
java.lang.Class _javaType,
javax.xml.namespace.QName _xmlType) {
return
new org.apache.axis.encoding.ser.BeanSerializer(
_javaType, _xmlType, typeDesc);
}
/**
* Get Custom Deserializer
*/
public static org.apache.axis.encoding.Deserializer getDeserializer(
java.lang.String mechType,
java.lang.Class _javaType,
javax.xml.namespace.QName _xmlType) {
return
new org.apache.axis.encoding.ser.BeanDeserializer(
_javaType, _xmlType, typeDesc);
}
}