Package org.jets3t.service.acl

Source Code of org.jets3t.service.acl.AccessControlList

/*
* JetS3t : Java S3 Toolkit
* Project hosted at http://bitbucket.org/jmurty/jets3t/
*
* Copyright 2006-2010 James Murty
*
* Licensed 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.jets3t.service.acl;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;

import javax.xml.parsers.FactoryConfigurationError;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.TransformerException;

import org.jets3t.service.Constants;
import org.jets3t.service.ServiceException;
import org.jets3t.service.model.StorageOwner;

import com.jamesmurty.utils.XMLBuilder;

/**
* Represents an Amazon S3 Access Control List (ACL), including the ACL's set of grantees and the
* permissions assigned to each grantee.
*
* @author James Murty
*
*/
public class AccessControlList implements Serializable {

    private static final long serialVersionUID = -4616688515622838285L;

    /**
     * A pre-canned REST ACL to set an object's permissions to Private (only owner can read/write)
     */
    public static final AccessControlList REST_CANNED_PRIVATE = new AccessControlList();

    /**
     * A pre-canned REST ACL to set an object's permissions to Public Read (anyone can read, only owner
     * can write)
     */
    public static final AccessControlList REST_CANNED_PUBLIC_READ = new AccessControlList();

    /**
     * A pre-canned REST ACL to set an object's permissions to Public Read and Write (anyone can
     * read/write)
     */
    public static final AccessControlList REST_CANNED_PUBLIC_READ_WRITE = new AccessControlList();

    /**
     * A pre-canned REST ACL to set an object's permissions to Authenticated Read (authenticated Amazon
     * users can read, only owner can write)
     */
    public static final AccessControlList REST_CANNED_AUTHENTICATED_READ = new AccessControlList();

    protected final HashSet<GrantAndPermission> grants = new HashSet<GrantAndPermission>();
    protected StorageOwner owner = null;

    /**
     * Returns a string representation of the ACL contents, useful for debugging.
     */
    @Override
    public String toString() {
        return "AccessControlList [owner=" + owner + ", grants=" + Arrays.toString(getGrantAndPermissions()) + "]";
    }

    public StorageOwner getOwner() {
        return owner;
    }

    public void setOwner(StorageOwner owner) {
        this.owner = owner;
    }

    /**
     * @param grantee
     *        the grantee to whom the permission will apply
     * @return list of permissions assigned to the given grantee in this ACL
     */
    public List<Permission> getPermissionsForGrantee(GranteeInterface grantee) {
        List<Permission> permissions = new ArrayList<Permission>();
        for (GrantAndPermission gap: grants) {
            if (gap.getGrantee().equals(grantee)) {
                permissions.add(gap.getPermission());
            }
        }
        return permissions;
    }

    /**
     * @param permission Permission
     * @return list of grantees assigned the given permission in this ACL
     */
    public List<GranteeInterface> getGranteesWithPermission(Permission permission) {
        List<GranteeInterface> grantees = new ArrayList<GranteeInterface>();
        for (GrantAndPermission gap: grants) {
            if (gap.getPermission().equals(permission)) {
                grantees.add(gap.getGrantee());
            }
        }
        return grantees;
    }

    /**
     * @param grantee
     *        the grantee to whom the permission will apply
     * @param permission
     *        the permission to apply to the grantee.
     * @return true if the given grantee has the given permission in this ACL
     */
    public boolean hasGranteeAndPermission(GranteeInterface grantee, Permission permission) {
        return getPermissionsForGrantee(grantee).contains(permission);
    }

    /**
     * Adds a grantee to the ACL with the given permission. If this ACL already contains the grantee
     * (ie the same grantee object) the permission for the grantee will be updated.
     *
     * @param grantee
     *        the grantee to whom the permission will apply
     * @param permission
     *        the permission to apply to the grantee.
     */
    public void grantPermission(GranteeInterface grantee, Permission permission) {
        grants.add(new GrantAndPermission(grantee, permission));
    }

    /**
     * Adds a set of grantee/permission pairs to the ACL, where each item in the set is a
     * {@link GrantAndPermission} object.
     *
     * @param grantAndPermissions
     * the grant and permission combinations to add.
     */
    public void grantAllPermissions(GrantAndPermission[] grantAndPermissions) {
        for(GrantAndPermission gap : grantAndPermissions) {
            grantPermission(gap.getGrantee(), gap.getPermission());
        }
    }

    /**
     * Revokes the permissions of a grantee by removing the grantee from the ACL.
     *
     * @param grantee
     *        the grantee to remove from this ACL.
     */
    public void revokeAllPermissions(GranteeInterface grantee) {
        List<GrantAndPermission> grantsToRemove = new ArrayList<GrantAndPermission>();
        for (GrantAndPermission gap: grants) {
            if (gap.getGrantee().equals(grantee)) {
                grantsToRemove.add(gap);
            }
        }
        grants.removeAll(grantsToRemove);
    }

    /**
     * @return
     * the grant and permission collections in this ACL.
     */
    public GrantAndPermission[] getGrantAndPermissions() {
        return grants.toArray(
            new GrantAndPermission[grants.size()]);
    }

    public XMLBuilder toXMLBuilder() throws ServiceException, ParserConfigurationException,
        FactoryConfigurationError, TransformerException
    {
        if (owner == null) {
            throw new ServiceException("Invalid AccessControlList: missing an owner");
        }
        if (owner.getId() == null || "".equals(owner.getId())) {
            throw new ServiceException("Invalid AccessControlList: missing owner ID");
        }
        XMLBuilder builder = XMLBuilder.create("AccessControlPolicy")
            .attr("xmlns", Constants.XML_NAMESPACE)
            .elem("Owner")
                .elem("ID").text(owner.getId()).up()
                .elem("DisplayName").text(owner.getDisplayName()).up()
            .up();

        XMLBuilder accessControlList = builder.elem("AccessControlList");
        for (GrantAndPermission gap: grants) {
            GranteeInterface grantee = gap.getGrantee();
            Permission permission = gap.getPermission();
            accessControlList
                .elem("Grant")
                    .importXMLBuilder(grantee.toXMLBuilder())
                    .elem("Permission").text(permission.toString());
        }
        return builder;
    }

    /**
     * @return
     * an XML representation of the Access Control List object, suitable to send to
     * a storage service in the request body.
     */
    public String toXml() throws ServiceException {
        try {
            return toXMLBuilder().asString();
        } catch (Exception e) {
            throw new ServiceException("Failed to build XML document for ACL", e);
        }
    }

    /**
     * @return
     * true if this ACL is a REST pre-canned one, in which case REST/HTTP implementations can use
     * the <tt>x-amz-acl</tt> header as a short-cut to set permissions on upload rather than using
     * a full ACL XML document.
     *
     * @deprecated 0.8.0
     */
    @Deprecated
    public boolean isCannedRestACL() {
        return isRESTHeaderACL();
    }

    /**
     * @return true if this ACL can be set via an HTTP header, rather than via an XML document.
     */
    public boolean isRESTHeaderACL() {
        return getValueForRESTHeaderACL() != null;
    }

    /**
     * @return the header value string for this ACL if it is a canned ACL, otherwise return null;
     */
    public String getValueForRESTHeaderACL() {
        if (AccessControlList.REST_CANNED_PRIVATE.equals(this)) {
            return "private";
        } else if (AccessControlList.REST_CANNED_PUBLIC_READ.equals(this)) {
            return "public-read";
        } else if (AccessControlList.REST_CANNED_PUBLIC_READ_WRITE.equals(this)) {
            return "public-read-write";
        } else if (AccessControlList.REST_CANNED_AUTHENTICATED_READ.equals(this)) {
            return "authenticated-read";
        }
        return null;
    }

}
TOP

Related Classes of org.jets3t.service.acl.AccessControlList

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.