All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.cloud.objectstorage.services.s3.model.EmailAddressGrantee Maven / Gradle / Ivy

Go to download

The IBM COS Java SDK for Amazon S3 module holds the client classes that are used for communicating with IBM Cloud Object Storage Service

There is a newer version: 2.14.0
Show newest version
/*
 * Copyright 2010-2022 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.ibm.cloud.objectstorage.services.s3.model;
import java.io.Serializable;

/**
 * Represents an e-mail grantee.  An e-mail grantee is a grantee 
 * identified by their e-mail
 * address and authenticated by an Amazon system.
 * 

* 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. *

*

* 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 AmbiguousGrantByEmail * 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. *

* * @see EmailAddressGrantee#EmailAddressGrantee(String) */ public class EmailAddressGrantee implements Grantee,Serializable { private String emailAddress = null; /* (non-Javadoc) * @see com.ibm.cloud.objectstorage.services.s3.model.Grantee#getTypeIdentifier() */ 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() */ public void setIdentifier(String emailAddress) { this.emailAddress = emailAddress; } /** * Gets the grantee's e-mail address. * * @see #setIdentifier(String) */ 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; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy