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

com.unboundid.scim2.extension.messages.externalidentity.ExternalIdentity Maven / Gradle / Ivy

/*
 * Copyright 2015-2019 Ping Identity Corporation
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License (GPLv2 only)
 * or the terms of the GNU Lesser General Public License (LGPLv2.1 only)
 * as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, see .
 */

package com.unboundid.scim2.extension.messages.externalidentity;

import com.fasterxml.jackson.databind.node.ObjectNode;
import com.unboundid.scim2.common.BaseScimResource;
import com.unboundid.scim2.common.annotations.Attribute;
import com.unboundid.scim2.common.annotations.Schema;
import com.unboundid.scim2.common.types.AttributeDefinition;

/**
 * External identity provider information.
 */
@Schema(description = "Contains information about external identities.",
    id = "urn:pingidentity:scim:api:messages:2.0:ExternalIdentity",
    name = "ExternalIdentity")
public final class ExternalIdentity extends BaseScimResource
{
  @Attribute(description = "The external IDP.",
      mutability = AttributeDefinition.Mutability.READ_WRITE,
      isRequired = true)
  private final Provider provider;

  @Attribute(description = "The user ID at the provider. If not available, " +
      "the user is not linked to any external identities at the provider.",
      mutability = AttributeDefinition.Mutability.READ_WRITE)
  private final String providerUserId;

  @Attribute(description = "The access token issued by the provider that " +
      "may be used to retrieve additional data.",
      mutability = AttributeDefinition.Mutability.READ_WRITE)
  private final String accessToken;

  @Attribute(description = "The refresh token issued by the provider that " +
      "may be used to retrieve a new access token.",
      mutability = AttributeDefinition.Mutability.READ_WRITE)
  private final String refreshToken;

  @Attribute(description = "The provider redirect url can be used to obtain " +
      "an auth code for this external identity provider.",
      mutability = AttributeDefinition.Mutability.READ_ONLY)
  private final String providerRedirectUrl;

  @Attribute(description = "The OAuth2 callback url",
      mutability = AttributeDefinition.Mutability.READ_WRITE)
  private final String callbackUrl;

  @Attribute(description = "The parameters received during an OAuth2 callback",
      mutability = AttributeDefinition.Mutability.READ_WRITE)
  private ObjectNode callbackParameters;

  // private no-arg constructor for Jackson.  Jackson will construct
  // this object and set all fields (even private final ones).
  private ExternalIdentity()
  {
    this(null);
  }

  /**
   * Creates an external identity link request from a callback uri.
   * Use this when the request is to create a link interactively.  This
   * request will return information that can be used to authenticate the
   * user, and then an additional replace request is needed to complete the
   * link.
   *
   * @param providerName the name of the external identity provider.
   * @param callbackUrl the callback uri that is used for the external
   *                    identity provider.
   */
  public ExternalIdentity(final String providerName,
                          final String callbackUrl)
  {
    this.provider = new Provider.Builder().setName(providerName).build();
    this.providerUserId = null;
    this.accessToken = null;
    this.refreshToken = null;
    this.providerRedirectUrl = null;
    this.callbackUrl = callbackUrl;
  }

  /**
   * Constructs a new ExternalIdentity object.  This should only be needed
   * by the server.
   *
   * @param provider the provider
   */
  public ExternalIdentity(final Provider provider)
  {
    this.provider = provider;
    this.providerUserId = null;
    this.accessToken = null;
    this.refreshToken = null;
    this.providerRedirectUrl = null;
    this.callbackUrl = null;
  }

  /**
   * Constructs a new ExternalIdentity object.  This should only be needed
   * by the server.
   *
   * @param provider the provider
   * @param providerRedirectUrl the provider redirect url from the external
   *                            identity.
   */
  public ExternalIdentity(final Provider provider,
                          final String providerRedirectUrl)
  {
    this.provider = provider;
    this.providerUserId = null;
    this.accessToken = null;
    this.refreshToken = null;
    this.providerRedirectUrl = providerRedirectUrl;
    this.callbackUrl = null;
  }

  /**
   * Constructs a new ExternalIdentity object.  This should only be needed
   * by the server.
   *
   * @param provider the provider
   * @param providerUserId the provider user id.
   * @param accessToken the access token.
   * @param refreshToken the refresh token (optional.  May be null.).
   */
  public ExternalIdentity(final Provider provider, final String providerUserId,
      final String accessToken, final String refreshToken)
  {
    this.provider = provider;
    this.providerUserId = providerUserId;
    this.accessToken = accessToken;
    this.refreshToken = refreshToken;
    this.providerRedirectUrl = null;
    this.callbackUrl = null;
  }

  /**
   * Gets the external identity provider.
   *
   * @return the external idenity provider.
   */
  public Provider getProvider()
  {
    return provider;
  }

  /**
   * Gets the user id for the external identity provider.
   *
   * @return the user id for the external identity provider.
   */
  public String getProviderUserId()
  {
    return providerUserId;
  }

  /**
   * Gets the access token for the external identity provider.
   *
   * @return the access token for the external identity provider.
   */
  public String getAccessToken()
  {
    return accessToken;
  }

  /**
   * Gets the refresh token for the external identity provider.
   *
   * @return the refresh token for the external identity provider.
   */
  public String getRefreshToken()
  {
    return refreshToken;
  }

  /**
   * Gets the provider redirect url from the external identity.  The provider
   * redirect url can be used to obtain an auth code for this external
   * identity provider.
   *
   * @return the provider redirect url.
   */
  public String getProviderRedirectUrl()
  {
    return providerRedirectUrl;
  }

  /**
   * Gets the callback uri.
   *
   * @return the callback uri.
   */
  public String getcallbackUrl()
  {
    return callbackUrl;
  }

  /**
   * Gets the callback parameters.
   *
   * @return the callback parameters.
   */
  public ObjectNode getCallbackParameters()
  {
    return callbackParameters;
  }

  /**
   * Sets the callback parameters.
   *
   * @param callbackParameters the callback parameters.
   */
  public void setCallbackParameters(final ObjectNode callbackParameters)
  {
    this.callbackParameters = callbackParameters;
  }

  @Override
  public boolean equals(final Object o)
  {
    if (this == o)
    {
      return true;
    }
    if (o == null || getClass() != o.getClass())
    {
      return false;
    }
    if (!super.equals(o))
    {
      return false;
    }

    ExternalIdentity that = (ExternalIdentity) o;

    if (provider != null ? !provider.equals(that.provider) :
        that.provider != null)
    {
      return false;
    }
    if (providerUserId != null ? !providerUserId.equals(that.providerUserId) :
        that.providerUserId != null)
    {
      return false;
    }
    if (accessToken != null ? !accessToken.equals(that.accessToken) :
        that.accessToken != null)
    {
      return false;
    }
    if (refreshToken != null ? !refreshToken.equals(that.refreshToken) :
        that.refreshToken != null)
    {
      return false;
    }
    if (providerRedirectUrl != null ?
        !providerRedirectUrl.equals(that.providerRedirectUrl) :
        that.providerRedirectUrl != null)
    {
      return false;
    }
    if (callbackUrl != null ? !callbackUrl.equals(that.callbackUrl) :
        that.callbackUrl != null)
    {
      return false;
    }
    return callbackParameters != null ?
        callbackParameters.equals(that.callbackParameters) :
        that.callbackParameters == null;

  }

  @Override
  public int hashCode()
  {
    int result = super.hashCode();
    result = 31 * result + (provider != null ? provider.hashCode() : 0);
    result = 31 * result +
        (providerUserId != null ? providerUserId.hashCode() : 0);
    result = 31 * result + (accessToken != null ? accessToken.hashCode() : 0);
    result = 31 * result + (refreshToken != null ? refreshToken.hashCode() : 0);
    result = 31 * result +
        (providerRedirectUrl != null ? providerRedirectUrl.hashCode() : 0);
    result = 31 * result + (callbackUrl != null ? callbackUrl.hashCode() : 0);
    result = 31 * result +
        (callbackParameters != null ? callbackParameters.hashCode() : 0);
    return result;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy