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

com.google.appengine.api.users.User Maven / Gradle / Ivy

There is a newer version: 2.0.31
Show newest version
/*
 * Copyright 2021 Google LLC
 *
 * 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
 *
 *     https://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 com.google.appengine.api.users;

import java.io.Serializable;
import org.checkerframework.checker.nullness.qual.Nullable;

/**
 * {@code User} represents a specific user, represented by the
 * combination of an email address and a specific Google Apps domain
 * (which we call an {@code authDomain}).  For normal Google login,
 * {@code authDomain} will be set to "gmail.com".
 *
 */
public final class User implements Serializable, Comparable {
  static final long serialVersionUID = 8691571286358652288L;

  private String email;

  // TODO: We don't really need to expose this to user code
  // -- it's only going to be significant for trusted applications
  // (e.g. an admin console).
  //
  // Should we bother trying to hide this from user code?  If so, how?
  // We could do something with annotations that would remove the
  // fields/methods from public docs and possibly from the source code
  // that we hand people. People would still see the elements from
  // their IDEs though.
  //
  // This isn't a security issue, but rather a "friendliness"
  // issue. Why confuse people with capabilities that they'll
  // never be able to use?
  private String authDomain;

  private @Nullable String userId;

  private String federatedIdentity;

  /**
   * This constructor exists for frameworks (e.g. Google Web Toolkit)
   * that require it for serialization purposes.  It should not be
   * called explicitly.
   */
  @SuppressWarnings("unused")
  private User() {
    // Don't remove this.  GWT serialization calls it via reflection.
  }

  /**
   * Creates a new User.
   *
   * @param email a not {@code null} email address.
   * @param authDomain a not {@code null} domain name into which this
   * user has authenticated, or "gmail.com" for normal Google
   * authentication.
   */
  public User(String email, String authDomain) {
    this(email, authDomain, null);
  }

  /**
   * Creates a new User.
   *
   * @param email a not {@code null} email address.
   * @param authDomain a not {@code null} domain name into which this
   * user has authenticated, or "gmail.com" for normal Google
   * authentication.
   * @param userId a possibly-null string uniquely identifying the specified user.
   */
  public User(String email, String authDomain, @Nullable String userId) {
    if (email == null) {
      throw new NullPointerException("email must be specified");
    }
    if (authDomain == null) {
      throw new NullPointerException("authDomain must be specified");
    }
    this.email = email;
    this.authDomain = authDomain;
    this.userId = userId;
  }

  /**
   * Creates a new User with a federated identity.
   *
   * @param email an optional field holding the user's email.
   * @param authDomain the URL of the identity provider. Could be null.
   * @param userId a unique id for this user. Could be null.
   * @param federatedIdentity a not {@code null} asserted federated identity.
   */
  public User(
      String email,
      @Nullable String authDomain,
      @Nullable String userId,
      String federatedIdentity) {
    if (federatedIdentity == null) {
      throw new NullPointerException("Identity must be specified");
    }
    if (authDomain == null) {
      this.authDomain = "";
    } else {
      this.authDomain = authDomain;
    }
    if (userId == null) {
      this.userId = "";
    } else {
      this.userId = userId;
    }
    this.email = email;
    this.federatedIdentity = federatedIdentity;
  }

  /**
   * Return this user's nickname.
   *
   * The nickname will be a unique, human readable identifier for this user
   * with respect to this application. It will be an email address for some
   * users, but not all.
   */
  public String getNickname() {
    int indexOfDomain = email.indexOf("@" + authDomain);
    if (indexOfDomain == -1) {
      return email;
    }
    return email.substring(0, indexOfDomain);
  }

  public String getAuthDomain() {
    return authDomain;
  }

  public String getEmail() {
    return email;
  }

  /**
   * Returns an opaque string that uniquely identifies the user
   * represented by this {@code User} object.
   *
   * 

May be null if this {@code User} object was created explicitly * and no user ID was supplied. */ public @Nullable String getUserId() { return userId; } public String getFederatedIdentity() { return federatedIdentity; } @Override public String toString() { return email; } @Override public boolean equals(@Nullable Object object) { // We're intentionally ignoring userId here because it is not // guaranteed to be present. This is consistent with the Python // API. if (!(object instanceof User)) { return false; } User user = (User) object; if ((federatedIdentity != null) && (!federatedIdentity.isEmpty())) { return user.federatedIdentity.equals(federatedIdentity); } return user.email.equals(email) && user.authDomain.equals(authDomain); } @Override public int hashCode() { // We're intentionally ignoring userId here because it is not // guaranteed to be present. This is consistent with the Python // API. return 17 * email.hashCode() + authDomain.hashCode(); } @Override public int compareTo(User user) { return email.compareTo(user.email); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy