All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.microsoft.bingads.v13.bulk.entities.BulkNegativeSite Maven / Gradle / Ivy

package com.microsoft.bingads.v13.bulk.entities;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

import com.microsoft.bingads.internal.functionalinterfaces.BiConsumer;
import com.microsoft.bingads.internal.functionalinterfaces.Function;
import com.microsoft.bingads.v13.internal.bulk.BulkMapping;
import com.microsoft.bingads.v13.internal.bulk.MappingHelpers;
import com.microsoft.bingads.v13.internal.bulk.RowValues;
import com.microsoft.bingads.v13.internal.bulk.SimpleBulkMapping;
import com.microsoft.bingads.v13.internal.bulk.StringTable;
import com.microsoft.bingads.v13.internal.bulk.entities.BulkNegativeSiteIdentifier;
import com.microsoft.bingads.v13.internal.bulk.entities.MultiRecordBulkEntity;
import com.microsoft.bingads.v13.internal.bulk.entities.SingleRecordBulkEntity;

/**
 * This abstract base class for the bulk negative sites that are assigned
 * individually to a campaign or ad group entity.
 *
 * @see BulkAdGroupNegativeSite
 * @see BulkCampaignNegativeSite
 */
abstract class BulkNegativeSite extends SingleRecordBulkEntity {

    private TIdentifier identifier;

    public TIdentifier getIdentifier() {
        return identifier;
    }

    public void setIdentifier(TIdentifier identifier) {
        this.identifier = identifier;
    }

    /**
     * Gets the status of the negative site association.
     *
     * 

* The value is Active if the negative site is assigned to the parent entity identified by the EntityId. * The value is Deleted if the negative site is removed from the * parent entity, or should be removed in a subsequent upload operation. * Corresponds to the 'Status' field in the bulk file. *

*/ public Status getStatus() { return this.identifier.getStatus(); } /** * Sets the status of the negative site association. * *

* The value is Active if the negative site is assigned to the parent entity identified by the EntityId. * The value is Deleted if the negative site is removed from the * parent entity, or should be removed in a subsequent upload operation. * Corresponds to the 'Status' field in the bulk file. *

*/ public void setStatus(Status status) { this.identifier.setStatus(status); } /** * The URL of a website on which you do not want your ads displayed. * Corresponds to the 'Website' field in the bulk file. */ private String website; /** * Gets the URL of a website on which you do not want your ads displayed. * *

* Corresponds to the 'Website' field in the bulk file. *

*/ public String getWebsite() { return website; } /** * Sets the URL of a website on which you do not want your ads displayed. * *

* Corresponds to the 'Website' field in the bulk file. *

*/ public void setWebsite(String website) { this.website = website; } protected BulkNegativeSite(TIdentifier identifier) { this.identifier = identifier; } private static final List> MAPPINGS; static { List> m = new ArrayList>(); m.add(new SimpleBulkMapping(StringTable.Website, new Function() { @Override public String apply(BulkNegativeSite c) { return c.getWebsite(); } }, new BiConsumer() { @Override public void accept(String v, BulkNegativeSite c) { c.setWebsite(v); } } )); MAPPINGS = Collections.unmodifiableList(m); } @Override public void processMappingsFromRowValues(RowValues values) { this.identifier.readFromRowValues(values); MappingHelpers.convertToEntity(values, MAPPINGS, this); } @Override public void processMappingsToRowValues(RowValues values, boolean excludeReadonlyData) { this.identifier.writeToRowValues(values, excludeReadonlyData); MappingHelpers.convertToValues(this, values, MAPPINGS); } @Override public boolean canEncloseInMultilineEntity() { return true; } @Override public MultiRecordBulkEntity encloseInMultilineEntity() { return createNegativeSitesWithThisNegativeSite(); } abstract MultiRecordBulkEntity createNegativeSitesWithThisNegativeSite(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy