Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php /** * Abstract interface to an identity provider or authentication source, like *..

Decoded Output download

<?php

/**
 * Abstract interface to an identity provider or authentication source, like
 * Twitter, Facebook, or Google.
 *
 * Generally, adapters are handed some set of credentials particular to the
 * provider they adapt, and they turn those credentials into standard
 * information about the user's identity. For example, the LDAP adapter is given
 * a username and password (and some other configuration information), uses them
 * to talk to the LDAP server, and produces a username, email, and so forth.
 *
 * Since the credentials a provider requires are specific to each provider, the
 * base adapter does not specify how an adapter should be constructed or
 * configured -- only what information it is expected to be able to provide once
 * properly configured.
 */
abstract class PhutilAuthAdapter extends Phobject {

  final public function getAccountIdentifiers() {
    $result = $this->newAccountIdentifiers();
    assert_instances_of($result, 'PhabricatorExternalAccountIdentifier');
    return $result;
  }

  protected function newAccountIdentifiers() {
    $identifiers = array();

    $raw_identifier = $this->getAccountID();
    if ($raw_identifier !== null) {
      $identifiers[] = $this->newAccountIdentifier($raw_identifier);
    }

    return $identifiers;
  }

  final protected function newAccountIdentifier($raw_identifier) {
    return id(new PhabricatorExternalAccountIdentifier())
      ->setIdentifierRaw($raw_identifier);
  }

  /**
   * Get a unique identifier associated with the account.
   *
   * This identifier should be permanent, immutable, and uniquely identify
   * the account. If possible, it should be nonsensitive. For providers that
   * have a GUID or PHID value for accounts, these are the best values to use.
   *
   * You can implement @{method:newAccountIdentifiers} instead if a provider
   * is unable to emit identifiers with all of these properties.
   *
   * If the adapter was unable to authenticate an identity, it should return
   * `null`.
   *
   * @return string|null Unique account identifier, or `null` if authentication
   *                     failed.
   */
  public function getAccountID() {
    throw new PhutilMethodNotImplementedException();
  }


  /**
   * Get a string identifying this adapter, like "ldap". This string should be
   * unique to the adapter class.
   *
   * @return string Unique adapter identifier.
   */
  abstract public function getAdapterType();


  /**
   * Get a string identifying the domain this adapter is acting on. This allows
   * an adapter (like LDAP) to act against different identity domains without
   * conflating credentials. For providers like Facebook or Google, the adapters
   * just return the relevant domain name.
   *
   * @return string Domain the adapter is associated with.
   */
  abstract public function getAdapterDomain();


  /**
   * Generate a string uniquely identifying this adapter configuration. Within
   * the scope of a given key, all account IDs must uniquely identify exactly
   * one identity.
   *
   * @return string  Unique identifier for this adapter configuration.
   */
  public function getAdapterKey() {
    return $this->getAdapterType().':'.$this->getAdapterDomain();
  }


  /**
   * Optionally, return an email address associated with this account.
   *
   * @return string|null  An email address associated with the account, or
   *                      `null` if data is not available.
   */
  public function getAccountEmail() {
    return null;
  }


  /**
   * Optionally, return a human readable username associated with this account.
   *
   * @return string|null  Account username, or `null` if data isn't available.
   */
  public function getAccountName() {
    return null;
  }


  /**
   * Optionally, return a URI corresponding to a human-viewable profile for
   * this account.
   *
   * @return string|null  A profile URI associated with this account, or
   *                      `null` if the data isn't available.
   */
  public function getAccountURI() {
    return null;
  }


  /**
   * Optionally, return a profile image URI associated with this account.
   *
   * @return string|null  URI for an account profile image, or `null` if one is
   *                      not available.
   */
  public function getAccountImageURI() {
    return null;
  }


  /**
   * Optionally, return a real name associated with this account.
   *
   * @return string|null  A human real name, or `null` if this data is not
   *                      available.
   */
  public function getAccountRealName() {
    return null;
  }

}
 ?>

Did this file decode correctly?

Original Code

<?php

/**
 * Abstract interface to an identity provider or authentication source, like
 * Twitter, Facebook, or Google.
 *
 * Generally, adapters are handed some set of credentials particular to the
 * provider they adapt, and they turn those credentials into standard
 * information about the user's identity. For example, the LDAP adapter is given
 * a username and password (and some other configuration information), uses them
 * to talk to the LDAP server, and produces a username, email, and so forth.
 *
 * Since the credentials a provider requires are specific to each provider, the
 * base adapter does not specify how an adapter should be constructed or
 * configured -- only what information it is expected to be able to provide once
 * properly configured.
 */
abstract class PhutilAuthAdapter extends Phobject {

  final public function getAccountIdentifiers() {
    $result = $this->newAccountIdentifiers();
    assert_instances_of($result, 'PhabricatorExternalAccountIdentifier');
    return $result;
  }

  protected function newAccountIdentifiers() {
    $identifiers = array();

    $raw_identifier = $this->getAccountID();
    if ($raw_identifier !== null) {
      $identifiers[] = $this->newAccountIdentifier($raw_identifier);
    }

    return $identifiers;
  }

  final protected function newAccountIdentifier($raw_identifier) {
    return id(new PhabricatorExternalAccountIdentifier())
      ->setIdentifierRaw($raw_identifier);
  }

  /**
   * Get a unique identifier associated with the account.
   *
   * This identifier should be permanent, immutable, and uniquely identify
   * the account. If possible, it should be nonsensitive. For providers that
   * have a GUID or PHID value for accounts, these are the best values to use.
   *
   * You can implement @{method:newAccountIdentifiers} instead if a provider
   * is unable to emit identifiers with all of these properties.
   *
   * If the adapter was unable to authenticate an identity, it should return
   * `null`.
   *
   * @return string|null Unique account identifier, or `null` if authentication
   *                     failed.
   */
  public function getAccountID() {
    throw new PhutilMethodNotImplementedException();
  }


  /**
   * Get a string identifying this adapter, like "ldap". This string should be
   * unique to the adapter class.
   *
   * @return string Unique adapter identifier.
   */
  abstract public function getAdapterType();


  /**
   * Get a string identifying the domain this adapter is acting on. This allows
   * an adapter (like LDAP) to act against different identity domains without
   * conflating credentials. For providers like Facebook or Google, the adapters
   * just return the relevant domain name.
   *
   * @return string Domain the adapter is associated with.
   */
  abstract public function getAdapterDomain();


  /**
   * Generate a string uniquely identifying this adapter configuration. Within
   * the scope of a given key, all account IDs must uniquely identify exactly
   * one identity.
   *
   * @return string  Unique identifier for this adapter configuration.
   */
  public function getAdapterKey() {
    return $this->getAdapterType().':'.$this->getAdapterDomain();
  }


  /**
   * Optionally, return an email address associated with this account.
   *
   * @return string|null  An email address associated with the account, or
   *                      `null` if data is not available.
   */
  public function getAccountEmail() {
    return null;
  }


  /**
   * Optionally, return a human readable username associated with this account.
   *
   * @return string|null  Account username, or `null` if data isn't available.
   */
  public function getAccountName() {
    return null;
  }


  /**
   * Optionally, return a URI corresponding to a human-viewable profile for
   * this account.
   *
   * @return string|null  A profile URI associated with this account, or
   *                      `null` if the data isn't available.
   */
  public function getAccountURI() {
    return null;
  }


  /**
   * Optionally, return a profile image URI associated with this account.
   *
   * @return string|null  URI for an account profile image, or `null` if one is
   *                      not available.
   */
  public function getAccountImageURI() {
    return null;
  }


  /**
   * Optionally, return a real name associated with this account.
   *
   * @return string|null  A human real name, or `null` if this data is not
   *                      available.
   */
  public function getAccountRealName() {
    return null;
  }

}

Function Calls

None

Variables

None

Stats

MD5 50629c33828396272f4491f703fff45c
Eval Count 0
Decode Time 102 ms