com.qcloud.cos.model.BucketReplicationConfiguration Maven / Gradle / Ivy
package com.qcloud.cos.model;
import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
import com.qcloud.cos.utils.Jackson;
public class BucketReplicationConfiguration implements Serializable {
private String roleName;
/** Collection of replication rules associated with the QCloud bucket. */
private Map rules = new HashMap();
/**
* Returns the role name associated with this replication configuration.
*/
public String getRoleName() {
return roleName;
}
/**
* Sets the role name that will be used by QCloud while replication.
*
* @param role The role name for this configuration.
*/
public void setRoleName(String roleName) {
this.roleName = roleName;
}
/**
* Sets the role name that will be used by QCloud while replication. Returns the updated object.
*
* @param roleName The role for this configuration.
* @return The updated {@link BucketReplicationConfiguration} object.
*/
public BucketReplicationConfiguration withRoleName(String roleName) {
setRoleName(roleName);
return this;
}
/**
* Returns the replication rules associated with this QCloud bucket.
*
* @return the replication rules associated with this QCloud bucket.
*/
public Map getRules() {
return rules;
}
/**
* Returns the replication rule for the given rule id.
*
* @param id the unique identifier representing a rule in the replication configuration.
* @return the replication rule for the given rule id.
*/
public ReplicationRule getRule(String id) {
return rules.get(id);
}
/**
* Sets the replication rules for the QCloud bucket.
*
* @param rules the replication rules for the QCloud bucket.
* @throws IllegalArgumentException if the rules are null.
*/
public void setRules(Map rules) {
if (rules == null) {
throw new IllegalArgumentException("Replication rules cannot be null");
}
this.rules = new HashMap(rules);
}
/**
* Sets the replication rules for the QCloud bucket. Returns the updated object.
*
* @param rules the replication rules for the QCloud bucket.
* @throws IllegalArgumentException if the rules are null.
* @return the updated {@link BucketReplicationConfiguration} object.
*/
public BucketReplicationConfiguration withRules(Map rules) {
setRules(rules);
return this;
}
/**
* Adds a new rule to the replication configuration associated with this QCloud bucket. Returns
* the updated object.
*
* @param id the id for the rule.
* @param rule the replication rule for the QCloud bucket.
* @throws IllegalArgumentException if the given id or rule is null.
* @return the updated {@link BucketReplicationConfiguration} object.
*/
public BucketReplicationConfiguration addRule(String id, ReplicationRule rule) {
if (id == null || id.trim().isEmpty()) {
throw new IllegalArgumentException("Rule id cannot be null or empty.");
}
if (rule == null) {
throw new IllegalArgumentException("Replication rule cannot be null");
}
rules.put(id, rule);
return this;
}
/**
* Removes the replication rule with the given id from the replication configuration associated
* with QCloud bucket. Returns the updated object.
*
* @param id the id of the replication rule to be removed.
* @return the updated {@link BucketReplicationConfiguration} object.
*/
public BucketReplicationConfiguration removeRule(String id) {
rules.remove(id);
return this;
}
@Override
public String toString() {
return Jackson.toJsonString(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy