com.qcloud.cos.model.BucketReplicationConfiguration Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cos_api-bundle Show documentation
Show all versions of cos_api-bundle Show documentation
A single bundled dependency that includes all service and dependent JARs with third-party libraries
relocated to different namespaces.
/*
* Copyright 2010-2019 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.
* According to cos feature, we modify some class,comment, field name, etc.
*/
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