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

com.ibm.cloud.objectstorage.services.s3.model.ReplicationRule Maven / Gradle / Ivy

/*
 * Copyright 2015-2023 Amazon.com, Inc. or its affiliates. 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.
 * A copy of the License is located at
 *
 *  http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file 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.
 */
package com.ibm.cloud.objectstorage.services.s3.model;
import java.io.Serializable;

import com.ibm.cloud.objectstorage.util.json.Jackson;
import com.ibm.cloud.objectstorage.services.s3.model.replication.ReplicationFilter;

/**
 * Rule that specifies the replication configuration.
 */
public class ReplicationRule implements Serializable {

    /**
     * The Amazon S3 object prefix for the replication rule. This rule will be
     * applied if an Amazon S3 object matches this prefix.
     */
    private String prefix;

    /**
     * The status of this replication rule. Valid values are Enabled, Disabled.
     * The rule will be applied only if the status is Enabled.
     */
    private String status;

    /**
     * Destination configuration for the replication rule.
     */
    private ReplicationDestinationConfig destinationConfig;

    /**
     * Filter associated with the replication rule.
     * Only valid for Replication configuration V2
     */
    private ReplicationFilter filter;

    /**
     * The priority of this replication rule. Valid values are from INT_MIN to INT_MAX.
     * Only valid for Replication configuration V2
     */
    private Integer priority;

    /**
     * The status of the replication of existing objects in this replication rule. Valid values are Enabled, Disabled.
     * The rule will be applied only if the status is Enabled, and is only valid for Replication configuration V2.
     */
    // IBM Unsupported
    // private ExistingObjectReplication existingObjectReplication;

    /**
     * The status of the replication of delete markers in this replication rule. Valid values are Enabled, Disabled.
     * The rule will be applied only if the status is Enabled, and is only valid for Replication configuration V2.
     */
    private DeleteMarkerReplication deleteMarkerReplication;

    /**
     * Returns the priority of current rule.
     * 

* The priority indicates which rule has precedence whenever two or more replication rules conflict. Amazon S3 will * attempt to replicate objects according to all replication rules. However, if there are two or more rules with the * same destination bucket, then objects will be replicated according to the rule with the highest priority. The * higher the number, the higher the priority. *

*

* For more information, see Replication in the Amazon Simple * Storage Service Developer Guide. *

* * @return The priority indicates which rule has precedence whenever two or more replication rules conflict. Amazon * S3 will attempt to replicate objects according to all replication rules. However, if there are two or * more rules with the same destination bucket, then objects will be replicated according to the rule with * the highest priority. The higher the number, the higher the priority.

*

* For more information, see Replication in the Amazon * Simple Storage Service Developer Guide. */ public Integer getPriority() { return priority; } /** * Set the priority of current rule. *

* Priority must be unique in a configuration (you cannot have two different rules with the same priority). * attempt to replicate objects according to all replication rules. However, if there are two or more rules with the * same destination bucket, then objects will be replicated according to the rule with the highest priority. The * higher the number, the higher the priority. *

* * For more information, see Replication in the Amazon Simple * Storage Service Developer Guide. *

* @param priority int */ public void setPriority(Integer priority) { if (priority < 0) { throw new IllegalArgumentException("Priority has to be a positive number"); } this.priority = priority; } /** * Set the priority of current rule. *

* Priority must be unique in a configuration (you cannot have two different rules with the same priority). * attempt to replicate objects according to all replication rules. However, if there are two or more rules with the * same destination bucket, then objects will be replicated according to the rule with the highest priority. The * higher the number, the higher the priority. *

* * For more information, see Replication in the Amazon Simple * Storage Service Developer Guide. *

* @param priority int * @return This object for method chaining. */ public ReplicationRule withPriority(Integer priority) { setPriority(priority); return this; } /** * Returns the status of delete marker replication of current rule. */ public DeleteMarkerReplication getDeleteMarkerReplication() { return deleteMarkerReplication; } /** * Sets the status of delete marker replication of the current rule. * * @param deleteMarkerReplication Status of delete markers replication. */ public void setDeleteMarkerReplication(DeleteMarkerReplication deleteMarkerReplication) { this.deleteMarkerReplication = deleteMarkerReplication; } /** * Fluent method to set the DeleteMarkerReplication that is indicate if delete * markers have or don't have to be replicated in Replication configuration V2. * * @param deleteMarkerReplication Status of delete markers replication. * @return This object for method chaining. */ public ReplicationRule withDeleteMarkerReplication(DeleteMarkerReplication deleteMarkerReplication) { setDeleteMarkerReplication(deleteMarkerReplication); return this; } /** * Returns the prefix associated with the replication rule. */ public String getPrefix() { return prefix; } /** * Sets the Amazon S3 Object prefix for the replication rule. * * @throws IllegalArgumentException * if the prefix is null. */ public void setPrefix(String prefix) { if (prefix == null) { throw new IllegalArgumentException( "Prefix cannot be null for a replication rule"); } if (filter != null) { throw new IllegalArgumentException( "You cannot use both prefix and filter at the same time in a replication rule"); } this.prefix = prefix; } /** * Sets the Amazon S3 Object prefix for the replication rule. Returns the * updated object. * * @return the updated {@link ReplicationRule} object. * @throws IllegalArgumentException * if the prefix is null. */ public ReplicationRule withPrefix(String prefix) { setPrefix(prefix); return this; } /** * Returns a {@link ReplicationFilter} that is used to identify objects that a CRR Rule applies to. */ public ReplicationFilter getFilter() { return filter; } /** * Sets the {@link ReplicationFilter} that is used to identify objects that a CRR Rule applies to. * A rule cannot have both {@link ReplicationFilter} and the deprecated {@link #prefix}. * * @param filter {@link ReplicationFilter} */ public void setFilter(ReplicationFilter filter) { if (filter == null) { throw new IllegalArgumentException( "Filter cannot be null for a replication rule"); } if (prefix != null) { throw new IllegalArgumentException( "You cannot use both prefix and filter at the same time in a replication rule"); } this.filter = filter; } /** * Fluent method to set the {@link ReplicationFilter} that is used to identify objects * that a CRR Rule applies to. A rule cannot have both {@link ReplicationFilter} * and the deprecated {@link #prefix}. * * @param filter {@link ReplicationFilter} * @return This object for method chaining. */ public ReplicationRule withFilter(ReplicationFilter filter) { setFilter(filter); return this; } /** * Returns the status of the replication rule. */ public String getStatus() { return status; } /** * Sets the status of this replication rule. Valid values are Enabled, * Disabled. The rule will be applied only if the status is Enabled. * * @param status * the status of the replication rule. */ public void setStatus(String status) { this.status = status; } /** * Sets the status of this replication rule. Valid values are Enabled, * Disabled. The rule will be applied only if the status is Enabled. * * @param status * the status of replication rule. * * @return the updated {@link ReplicationRule} object. */ public ReplicationRule withStatus(String status) { setStatus(status); return this; } /** * Sets the status of this replication rule. Valid values are Enabled, * Disabled. The rule will be applied only if the status is Enabled. * * @param status * the status of the replication rule. */ public void setStatus(ReplicationRuleStatus status) { setStatus(status.getStatus()); } /** * Sets the status of this replication rule. Valid values are Enabled, * Disabled. The rule will be applied only if the status is Enabled. * * @param status * the status of replication rule. * * @return the updated {@link ReplicationRule} object. */ public ReplicationRule withStatus(ReplicationRuleStatus status) { setStatus(status.getStatus()); return this; } /** * Returns the destination configuration for the replication rule. */ public ReplicationDestinationConfig getDestinationConfig() { return destinationConfig; } /** * Sets the destination configuration for the replication rule. * * @throws IllegalArgumentException * if the destinationConfig is null. */ public void setDestinationConfig(ReplicationDestinationConfig destinationConfig) { if (destinationConfig == null) { throw new IllegalArgumentException( "Destination cannot be null in the replication rule"); } this.destinationConfig = destinationConfig; } /** * Sets the destination configuration for the replication rule.Returns the * updated object. * * @throws IllegalArgumentException * if the destinationConfig is null. * @return the updated {@link ReplicationRule} object. */ public ReplicationRule withDestinationConfig( ReplicationDestinationConfig destinationConfig) { setDestinationConfig(destinationConfig); return this; } /** * Returns the status of existing object replication of current rule. */ // IBM Unsupported // public ExistingObjectReplication getExistingObjectReplication() { // return existingObjectReplication; // } /** * Sets the status of existing object replication of current rule. * * @param existingObjectReplication Status of existing object replication. */ // IBM Unsupported // public void setExistingObjectReplication(ExistingObjectReplication existingObjectReplication) { // this.existingObjectReplication = existingObjectReplication; // } /** * Fluent method to set the ExistingObjectReplication that is indicate if existing * objects are replicated in Replication configuration V2. * * @param existingObjectReplication Status of existing object replication. * @return This object for method chaining. */ // IBM Unsupported // public ReplicationRule withExistingObjectReplication(ExistingObjectReplication existingObjectReplication) { // setExistingObjectReplication(existingObjectReplication); // return this; // } @Override public String toString() { return Jackson.toJsonString(this); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy