
org.jclouds.s3.domain.BucketLogging Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jclouds-shaded Show documentation
Show all versions of jclouds-shaded Show documentation
Provides a shaded jclouds with relocated guava and guice
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.
*/
package org.jclouds.s3.domain;
import java.util.Set;
import org.jclouds.s3.domain.AccessControlList.Grant;
import shaded.com.google.common.collect.Iterables;
import shaded.com.google.common.collect.Sets;
/**
* Each Amazon S3 bucket has an associated XML sub-resource that you can read and write in order to
* inspect or change the logging status for that bucket.
*/
public class BucketLogging {
private final String targetBucket;
private final String targetPrefix;
private final Set targetGrants = Sets.newHashSet();
/**
*
* @param targetBucket
* {@link #getTargetBucket}
* @param targetPrefix
* {@link #getTargetPrefix}
* @param targetGrants
* {@link #getTargetGrants}
*/
public BucketLogging(String targetBucket, String targetPrefix, Iterable targetGrants) {
this.targetBucket = targetBucket;
this.targetPrefix = targetPrefix;
Iterables.addAll(this.targetGrants, targetGrants);
}
/**
*
* @param targetBucket
* {@link #getTargetBucket}
* @param targetPrefix
* {@link #getTargetPrefix}
*/
public BucketLogging(String targetBucket, String targetPrefix) {
this.targetBucket = targetBucket;
this.targetPrefix = targetPrefix;
}
/**
* The bucket owner is automatically granted FULL_CONTROL to all logs delivered to the bucket.
* This optional element enables you grant access to others. Any specified TargetGrants are added
* to the default ACL. For more information about ACLs, see Access Control Lists.
*/
public Set getTargetGrants() {
return targetGrants;
}
/**
* Specifies the bucket where server access logs will be delivered. You can have your logs
* delivered to any bucket that you own, including the same bucket that is being logged. You can
* also configure multiple buckets to deliver their logs to the same target bucket. In this case
* you should choose a different TargetPrefix for each source bucket so that the delivered log
* files can be distinguished by key.
*
*
Note
*
* The source and the target buckets must be in the same location. For more information about
* bucket location constraints, see Buckets and Regions
*/
public String getTargetBucket() {
return targetBucket;
}
/**
* This element lets you specify a prefix for the keys that the delivered log files will be
* stored under. For information on how the key name for log files is constructed, see Delivery
* of Server Access Logs.
*/
public String getTargetPrefix() {
return targetPrefix;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((targetBucket == null) ? 0 : targetBucket.hashCode());
result = prime * result + ((targetGrants == null) ? 0 : targetGrants.hashCode());
result = prime * result + ((targetPrefix == null) ? 0 : targetPrefix.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
BucketLogging other = (BucketLogging) obj;
if (targetBucket == null) {
if (other.targetBucket != null)
return false;
} else if (!targetBucket.equals(other.targetBucket))
return false;
if (targetGrants == null) {
if (other.targetGrants != null)
return false;
} else if (!targetGrants.equals(other.targetGrants))
return false;
if (targetPrefix == null) {
if (other.targetPrefix != null)
return false;
} else if (!targetPrefix.equals(other.targetPrefix))
return false;
return true;
}
@Override
public String toString() {
return "BucketLogging [targetBucket=" + targetBucket + ", targetGrants=" + targetGrants
+ ", targetPrefix=" + targetPrefix + "]";
}
}