/* * Copyright 2010-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Portions copyright 2006-2009 James Murty. Please see LICENSE.txt * for applicable license terms and NOTICE.txt for applicable notices. * * 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. */ package com.amazonaws.services.s3.model; /** * Represents an e-mail grantee. An e-mail grantee is a grantee identified by * their e-mail address and authenticated by an Amazon system. * <p> * E-mail grants are internally converted to the canonical user representation * when creating the ACL. If the grantee changes their e-mail address, it will * not affect existing Amazon S3 permissions. * </p> * <p> * Adding a grantee by e-mail address only works if exactly one Amazon account * corresponds to the specified e-mail address. If multiple Amazon accounts are * associated with the e-mail address, an <code>AmbiguousGrantByEmail</code> * error message is returned. This happens rarely, but usually occurs if a user * created an Amazon account in the past, forgotten the password, and created * another Amazon account using the same e-mail address. If this occurs, the * user should contact Amazon customer service to have the accounts merged. * Alernatively, grant user access specifying the canonical user representation. * </p> * * @see EmailAddressGrantee#EmailAddressGrantee(String) */ public class EmailAddressGrantee implements Grantee { private String emailAddress = null; /* * (non-Javadoc) * @see com.amazonaws.services.s3.model.Grantee#getTypeIdentifier() */ @Override public String getTypeIdentifier() { return "emailAddress"; } /** * Constructs a new {@link EmailAddressGrantee} object with the given email * address. * * @param emailAddress The e-mail address used to identify the e-mail * grantee. */ public EmailAddressGrantee(String emailAddress) { this.setIdentifier(emailAddress); } /** * Set the e-mail address as the grantee's ID. * * @param emailAddress The e-mail address used to identify the e-mail * grantee. * @see EmailAddressGrantee#getIdentifier() */ @Override public void setIdentifier(String emailAddress) { this.emailAddress = emailAddress; } /** * Gets the grantee's e-mail address. * * @see EmailAddressGrantee#setIdentifier(string) */ @Override public String getIdentifier() { return emailAddress; } /* * (non-Javadoc) * @see java.lang.Object#hashCode() */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((emailAddress == null) ? 0 : emailAddress.hashCode()); return result; } /* * (non-Javadoc) * @see java.lang.Object#equals(java.lang.Object) */ @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; EmailAddressGrantee other = (EmailAddressGrantee) obj; if (emailAddress == null) { if (other.emailAddress != null) return false; } else if (!emailAddress.equals(other.emailAddress)) return false; return true; } @Override public String toString() { return emailAddress; } }