// Copyright 2016 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.
/**
* FirstPartyAudienceSegmentRule.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.v201611;
/**
* Rule of a {@link FirstPartyAudienceSegment} that defines user's
* eligibility criteria to be part
* of a segment.
*/
public class FirstPartyAudienceSegmentRule implements java.io.Serializable {
/* Specifies the inventory (i.e. ad units and placements) that
* are part of the rule of a
* {@link FirstPartyAudienceSegment}. This attribute
* is required. */
private com.google.api.ads.dfp.axis.v201611.InventoryTargeting inventoryRule;
/* Specifies the collection of custom criteria that are part of
* the rule of a
* {@link FirstPartyAudienceSegment}.
*
* <p>
* Once the {@link FirstPartyAudienceSegment} is updated
* or modified with custom criteria, the
* server may return a normalized, but equivalent representation
* of the custom criteria rule.
* </p>
*
* <ul>
* {@code customCriteriaRule} will have up to three levels
* including itself.
* <li>
* The top level {@link CustomCriteriaSet} i.e. the {@code
* customTargeting} object can only
* contain a {@link CustomCriteriaSet.LogicalOperator#OR}
* of all its children.
* <li>
* The second level of {@link CustomCriteriaSet} objects
* can only contain
* {@link CustomCriteriaSet.LogicalOperator#AND} of all
* their children. If a
* {@link CustomCriteria} is placed on this level, the
* server will wrap it in a
* {@link CustomCriteriaSet}.
* <li>
* The third level can only comprise of {@link CustomCriteria}
* objects.
* </ul>
*
* <p>
* The resulting custom criteria rule would be of the
* form: <br>
* <img
* src="http://chart.apis.google.com/chart?cht=gv&chl=digraph{customTargeting_LogicalOperator_OR-%3ECustomCriteriaSet_LogicalOperator_AND_1-%3ECustomCriteria_1;CustomCriteriaSet_LogicalOperator_AND_1-%3Eellipsis1;customTargeting_LogicalOperator_OR-%3Eellipsis2;ellipsis1[label=%22...%22,shape=none,fontsize=32];ellipsis2[label=%22...%22,shape=none,fontsize=32]}&chs=450x200"/>
* </p> */
private com.google.api.ads.dfp.axis.v201611.CustomCriteriaSet customCriteriaRule;
public FirstPartyAudienceSegmentRule() {
}
public FirstPartyAudienceSegmentRule(
com.google.api.ads.dfp.axis.v201611.InventoryTargeting inventoryRule,
com.google.api.ads.dfp.axis.v201611.CustomCriteriaSet customCriteriaRule) {
this.inventoryRule = inventoryRule;
this.customCriteriaRule = customCriteriaRule;
}
/**
* Gets the inventoryRule value for this FirstPartyAudienceSegmentRule.
*
* @return inventoryRule * Specifies the inventory (i.e. ad units and placements) that
* are part of the rule of a
* {@link FirstPartyAudienceSegment}. This attribute
* is required.
*/
public com.google.api.ads.dfp.axis.v201611.InventoryTargeting getInventoryRule() {
return inventoryRule;
}
/**
* Sets the inventoryRule value for this FirstPartyAudienceSegmentRule.
*
* @param inventoryRule * Specifies the inventory (i.e. ad units and placements) that
* are part of the rule of a
* {@link FirstPartyAudienceSegment}. This attribute
* is required.
*/
public void setInventoryRule(com.google.api.ads.dfp.axis.v201611.InventoryTargeting inventoryRule) {
this.inventoryRule = inventoryRule;
}
/**
* Gets the customCriteriaRule value for this FirstPartyAudienceSegmentRule.
*
* @return customCriteriaRule * Specifies the collection of custom criteria that are part of
* the rule of a
* {@link FirstPartyAudienceSegment}.
*
* <p>
* Once the {@link FirstPartyAudienceSegment} is updated
* or modified with custom criteria, the
* server may return a normalized, but equivalent representation
* of the custom criteria rule.
* </p>
*
* <ul>
* {@code customCriteriaRule} will have up to three levels
* including itself.
* <li>
* The top level {@link CustomCriteriaSet} i.e. the {@code
* customTargeting} object can only
* contain a {@link CustomCriteriaSet.LogicalOperator#OR}
* of all its children.
* <li>
* The second level of {@link CustomCriteriaSet} objects
* can only contain
* {@link CustomCriteriaSet.LogicalOperator#AND} of all
* their children. If a
* {@link CustomCriteria} is placed on this level, the
* server will wrap it in a
* {@link CustomCriteriaSet}.
* <li>
* The third level can only comprise of {@link CustomCriteria}
* objects.
* </ul>
*
* <p>
* The resulting custom criteria rule would be of the
* form: <br>
* <img
* src="http://chart.apis.google.com/chart?cht=gv&chl=digraph{customTargeting_LogicalOperator_OR-%3ECustomCriteriaSet_LogicalOperator_AND_1-%3ECustomCriteria_1;CustomCriteriaSet_LogicalOperator_AND_1-%3Eellipsis1;customTargeting_LogicalOperator_OR-%3Eellipsis2;ellipsis1[label=%22...%22,shape=none,fontsize=32];ellipsis2[label=%22...%22,shape=none,fontsize=32]}&chs=450x200"/>
* </p>
*/
public com.google.api.ads.dfp.axis.v201611.CustomCriteriaSet getCustomCriteriaRule() {
return customCriteriaRule;
}
/**
* Sets the customCriteriaRule value for this FirstPartyAudienceSegmentRule.
*
* @param customCriteriaRule * Specifies the collection of custom criteria that are part of
* the rule of a
* {@link FirstPartyAudienceSegment}.
*
* <p>
* Once the {@link FirstPartyAudienceSegment} is updated
* or modified with custom criteria, the
* server may return a normalized, but equivalent representation
* of the custom criteria rule.
* </p>
*
* <ul>
* {@code customCriteriaRule} will have up to three levels
* including itself.
* <li>
* The top level {@link CustomCriteriaSet} i.e. the {@code
* customTargeting} object can only
* contain a {@link CustomCriteriaSet.LogicalOperator#OR}
* of all its children.
* <li>
* The second level of {@link CustomCriteriaSet} objects
* can only contain
* {@link CustomCriteriaSet.LogicalOperator#AND} of all
* their children. If a
* {@link CustomCriteria} is placed on this level, the
* server will wrap it in a
* {@link CustomCriteriaSet}.
* <li>
* The third level can only comprise of {@link CustomCriteria}
* objects.
* </ul>
*
* <p>
* The resulting custom criteria rule would be of the
* form: <br>
* <img
* src="http://chart.apis.google.com/chart?cht=gv&chl=digraph{customTargeting_LogicalOperator_OR-%3ECustomCriteriaSet_LogicalOperator_AND_1-%3ECustomCriteria_1;CustomCriteriaSet_LogicalOperator_AND_1-%3Eellipsis1;customTargeting_LogicalOperator_OR-%3Eellipsis2;ellipsis1[label=%22...%22,shape=none,fontsize=32];ellipsis2[label=%22...%22,shape=none,fontsize=32]}&chs=450x200"/>
* </p>
*/
public void setCustomCriteriaRule(com.google.api.ads.dfp.axis.v201611.CustomCriteriaSet customCriteriaRule) {
this.customCriteriaRule = customCriteriaRule;
}
private java.lang.Object __equalsCalc = null;
public synchronized boolean equals(java.lang.Object obj) {
if (!(obj instanceof FirstPartyAudienceSegmentRule)) return false;
FirstPartyAudienceSegmentRule other = (FirstPartyAudienceSegmentRule) obj;
if (obj == null) return false;
if (this == obj) return true;
if (__equalsCalc != null) {
return (__equalsCalc == obj);
}
__equalsCalc = obj;
boolean _equals;
_equals = true &&
((this.inventoryRule==null && other.getInventoryRule()==null) ||
(this.inventoryRule!=null &&
this.inventoryRule.equals(other.getInventoryRule()))) &&
((this.customCriteriaRule==null && other.getCustomCriteriaRule()==null) ||
(this.customCriteriaRule!=null &&
this.customCriteriaRule.equals(other.getCustomCriteriaRule())));
__equalsCalc = null;
return _equals;
}
private boolean __hashCodeCalc = false;
public synchronized int hashCode() {
if (__hashCodeCalc) {
return 0;
}
__hashCodeCalc = true;
int _hashCode = 1;
if (getInventoryRule() != null) {
_hashCode += getInventoryRule().hashCode();
}
if (getCustomCriteriaRule() != null) {
_hashCode += getCustomCriteriaRule().hashCode();
}
__hashCodeCalc = false;
return _hashCode;
}
// Type metadata
private static org.apache.axis.description.TypeDesc typeDesc =
new org.apache.axis.description.TypeDesc(FirstPartyAudienceSegmentRule.class, true);
static {
typeDesc.setXmlType(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201611", "FirstPartyAudienceSegmentRule"));
org.apache.axis.description.ElementDesc elemField = new org.apache.axis.description.ElementDesc();
elemField.setFieldName("inventoryRule");
elemField.setXmlName(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201611", "inventoryRule"));
elemField.setXmlType(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201611", "InventoryTargeting"));
elemField.setMinOccurs(0);
elemField.setNillable(false);
typeDesc.addFieldDesc(elemField);
elemField = new org.apache.axis.description.ElementDesc();
elemField.setFieldName("customCriteriaRule");
elemField.setXmlName(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201611", "customCriteriaRule"));
elemField.setXmlType(new javax.xml.namespace.QName("https://www.google.com/apis/ads/publisher/v201611", "CustomCriteriaSet"));
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);
}
}