blob: 6d34f4cdbb7b79a64aec789e22681df95cb3b3e4 [file] [log] [blame]
/*
* 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.googlecloudstorage.domain;
import org.jclouds.googlecloudstorage.domain.DomainResourceReferences.ObjectRole;
import org.jclouds.javax.annotation.Nullable;
import org.jclouds.json.SerializedNames;
import com.google.auto.value.AutoValue;
/**
* Represents a Object Access Control Resource.
*
* @see <a href= "https://developers.google.com/storage/docs/json_api/v1/objectAccessControls"/>
*/
@AutoValue
public abstract class ObjectAccessControls {
private final String kind = "storage#objectAccessControl";
@Nullable public abstract String id();
@Nullable public abstract String bucket();
@Nullable public abstract String object();
@Nullable public abstract Long generation();
public abstract String entity();
@Nullable public abstract String entityId();
public abstract ObjectRole role();
@Nullable public abstract String email();
@Nullable public abstract String domain();
@Nullable public abstract ProjectTeam projectTeam();
@SerializedNames(
{ "id", "bucket", "object", "generation", "entity", "entityId", "role", "email", "domain", "projectTeam" })
public static ObjectAccessControls create(String id, String bucket, String object, Long generation, String entity,
String entityId, ObjectRole role, String email, String domain, ProjectTeam projectTeam) {
return new AutoValue_ObjectAccessControls(id, bucket, object, generation, entity, entityId, role, email, domain,
projectTeam);
}
public static Builder builder() {
return new Builder();
}
public static final class Builder {
private String id;
private String object;
private Long generation;
private String bucket;
private String entity;
private String entityId;
private ObjectRole role;
private String email;
private String domain;
private ProjectTeam projectTeam;
public Builder id(String id) {
this.id = id;
return this;
}
public Builder bucket(String bucket) {
this.bucket = bucket;
return this;
}
public Builder object(String object) {
this.object = object;
return this;
}
public Builder generation(Long generation) {
this.generation = generation;
return this;
}
public Builder entity(String entity) {
this.entity = entity;
return this;
}
public Builder entityId(String entityId) {
this.entityId = entityId;
return this;
}
public Builder role(ObjectRole role) {
this.role = role;
return this;
}
public Builder email(String email) {
this.email = email;
return this;
}
public Builder domain(String domain) {
this.domain = domain;
return this;
}
public Builder projectTeam(ProjectTeam projectTeam) {
this.projectTeam = projectTeam;
return this;
}
public ObjectAccessControls build() {
return ObjectAccessControls
.create(id, bucket, object, generation, entity, entityId, role, email, domain, projectTeam);
}
}
}