CakePHP
  • Documentation
    • Book
    • API
    • Videos
    • Reporting Security Issues
    • Privacy Policy
    • Logos & Trademarks
  • Business Solutions
  • Swag
  • Road Trip
  • Team
  • Community
    • Community
    • Get Involved
    • Issues (Github)
    • Bakery
    • Featured Resources
    • Training
    • Meetups
    • My CakePHP
    • CakeFest
    • Newsletter
    • Linkedin
    • YouTube
    • Facebook
    • Twitter
    • Mastodon
    • Help & Support
    • Forum
    • Stack Overflow
    • IRC
    • Slack
    • Paid Support
CakePHP

C Authentication 2.x API

  • Project:
    • Authentication
      • CakePHP
      • Authentication
      • Authorization
      • Chronos
      • Elastic Search
      • Queue
  • Version:
    • 2.x
      • 3.x
      • 2.x

Namespaces

  • Authentication
    • Authenticator
    • Controller
    • Identifier
    • Middleware
    • PasswordHasher
    • UrlChecker
    • View

Class TokenAuthenticator

Token Authenticator

Authenticates an identity based on a token in a query param or the header.

Namespace: Authentication\Authenticator

Property Summary

  • $_config protected
    array<string, mixed>

    Runtime config

  • $_configInitialized protected
    bool

    Whether the config property has already been configured with defaults

  • $_defaultConfig protected
    array

    Default config for this object.

    • fields The fields to use to identify a user by.
  • $_identifier protected
    Authentication\Identifier\IdentifierInterface

    Identifier or identifiers collection.

Method Summary

  • __construct() public

    Constructor

  • _configDelete() protected

    Deletes a single config key.

  • _configRead() protected

    Reads a config key.

  • _configWrite() protected

    Writes a config key.

  • authenticate() public

    Authenticates the identity by token contained in a request. Token could be passed as query using config.queryParam or as header param using config.header. Token prefix will be stripped if config.tokenPrefix is set. Will return false if no token is provided or if the scope conditions have not been met.

  • configShallow() public

    Merge provided config with existing config. Unlike config() which does a recursive merge for nested keys, this method does a simple merge.

  • getConfig() public

    Returns the config.

  • getConfigOrFail() public

    Returns the config for this specific key.

  • getIdentifier() public

    Gets the identifier.

  • getToken() protected

    Checks if the token is in the headers or a request parameter

  • getTokenFromHeader() protected

    Gets the token from the request headers

  • getTokenFromQuery() protected

    Gets the token from the request query

  • setConfig() public

    Sets the config.

  • setIdentifier() public

    Sets the identifier.

  • stripTokenPrefix() protected

    Strips a prefix from a token

  • unauthorizedChallenge() public

    No-op method.

Method Detail

__construct() ¶ public

__construct(Authentication\Identifier\IdentifierInterface $identifier, array $config = [])

Constructor

Parameters
Authentication\Identifier\IdentifierInterface $identifier

Identifier or identifiers collection.

array $config optional

Configuration settings.

_configDelete() ¶ protected

_configDelete(string $key): void

Deletes a single config key.

Parameters
string $key

Key to delete.

Returns
void
Throws
Cake\Core\Exception\CakeException
if attempting to clobber existing config

_configRead() ¶ protected

_configRead(string|null $key): mixed

Reads a config key.

Parameters
string|null $key

Key to read.

Returns
mixed

_configWrite() ¶ protected

_configWrite(array<string, mixed>|string $key, mixed $value, string|bool $merge = false): void

Writes a config key.

Parameters
array<string, mixed>|string $key

Key to write to.

mixed $value

Value to write.

string|bool $merge optional

True to merge recursively, 'shallow' for simple merge, false to overwrite, defaults to false.

Returns
void
Throws
Cake\Core\Exception\CakeException
if attempting to clobber existing config

authenticate() ¶ public

authenticate(Psr\Http\Message\ServerRequestInterface $request): Authentication\Authenticator\ResultInterface

Authenticates the identity by token contained in a request. Token could be passed as query using config.queryParam or as header param using config.header. Token prefix will be stripped if config.tokenPrefix is set. Will return false if no token is provided or if the scope conditions have not been met.

Parameters
Psr\Http\Message\ServerRequestInterface $request

The request that contains login information.

Returns
Authentication\Authenticator\ResultInterface

configShallow() ¶ public

configShallow(array<string, mixed>|string $key, mixed|null $value = null): $this

Merge provided config with existing config. Unlike config() which does a recursive merge for nested keys, this method does a simple merge.

Setting a specific value:

$this->configShallow('key', $value);

Setting a nested value:

$this->configShallow('some.nested.key', $value);

Updating multiple config settings at the same time:

$this->configShallow(['one' => 'value', 'another' => 'value']);
Parameters
array<string, mixed>|string $key

The key to set, or a complete array of configs.

mixed|null $value optional

The value to set.

Returns
$this

getConfig() ¶ public

getConfig(string|null $key = null, mixed $default = null): mixed

Returns the config.

Usage

Reading the whole config:

$this->getConfig();

Reading a specific value:

$this->getConfig('key');

Reading a nested value:

$this->getConfig('some.nested.key');

Reading with default value:

$this->getConfig('some-key', 'default-value');
Parameters
string|null $key optional

The key to get or null for the whole config.

mixed $default optional

The return value when the key does not exist.

Returns
mixed

getConfigOrFail() ¶ public

getConfigOrFail(string $key): mixed

Returns the config for this specific key.

The config value for this key must exist, it can never be null.

Parameters
string $key

The key to get.

Returns
mixed
Throws
InvalidArgumentException

getIdentifier() ¶ public

getIdentifier(): Authentication\Identifier\IdentifierInterface

Gets the identifier.

Returns
Authentication\Identifier\IdentifierInterface

getToken() ¶ protected

getToken(Psr\Http\Message\ServerRequestInterface $request): string|null

Checks if the token is in the headers or a request parameter

Parameters
Psr\Http\Message\ServerRequestInterface $request

The request that contains login information.

Returns
string|null

getTokenFromHeader() ¶ protected

getTokenFromHeader(Psr\Http\Message\ServerRequestInterface $request, string|null $headerLine): string|null

Gets the token from the request headers

Parameters
Psr\Http\Message\ServerRequestInterface $request

The request that contains login information.

string|null $headerLine

Header name

Returns
string|null

getTokenFromQuery() ¶ protected

getTokenFromQuery(Psr\Http\Message\ServerRequestInterface $request, string $queryParam): string|null

Gets the token from the request query

Parameters
Psr\Http\Message\ServerRequestInterface $request

The request that contains login information.

string $queryParam

Request query parameter name

Returns
string|null

setConfig() ¶ public

setConfig(array<string, mixed>|string $key, mixed|null $value = null, bool $merge = true): $this

Sets the config.

Usage

Setting a specific value:

$this->setConfig('key', $value);

Setting a nested value:

$this->setConfig('some.nested.key', $value);

Updating multiple config settings at the same time:

$this->setConfig(['one' => 'value', 'another' => 'value']);
Parameters
array<string, mixed>|string $key

The key to set, or a complete array of configs.

mixed|null $value optional

The value to set.

bool $merge optional

Whether to recursively merge or overwrite existing config, defaults to true.

Returns
$this
Throws
Cake\Core\Exception\CakeException
When trying to set a key that is invalid.

setIdentifier() ¶ public

setIdentifier(Authentication\Identifier\IdentifierInterface $identifier): $this

Sets the identifier.

Parameters
Authentication\Identifier\IdentifierInterface $identifier

IdentifierInterface instance.

Returns
$this

stripTokenPrefix() ¶ protected

stripTokenPrefix(string $token, string $prefix): string

Strips a prefix from a token

Parameters
string $token

Token string

string $prefix

Prefix to strip

Returns
string

unauthorizedChallenge() ¶ public

unauthorizedChallenge(Psr\Http\Message\ServerRequestInterface $request): void

No-op method.

Create an exception with the appropriate headers and response body to challenge a request that has missing or invalid credentials.

This is primarily used by authentication methods that use the WWW-Authorization header.

Parameters
Psr\Http\Message\ServerRequestInterface $request

A request object.

Returns
void

Property Detail

$_config ¶ protected

Runtime config

Type
array<string, mixed>

$_configInitialized ¶ protected

Whether the config property has already been configured with defaults

Type
bool

$_defaultConfig ¶ protected

Default config for this object.

  • fields The fields to use to identify a user by.
Type
array

$_identifier ¶ protected

Identifier or identifiers collection.

Type
Authentication\Identifier\IdentifierInterface
OpenHub
Pingping
Linode
  • Business Solutions
  • Showcase
  • Documentation
  • Book
  • API
  • Videos
  • Reporting Security Issues
  • Privacy Policy
  • Logos & Trademarks
  • Community
  • Get Involved
  • Issues (Github)
  • Bakery
  • Featured Resources
  • Training
  • Meetups
  • My CakePHP
  • CakeFest
  • Newsletter
  • Linkedin
  • YouTube
  • Facebook
  • Twitter
  • Mastodon
  • Help & Support
  • Forum
  • Stack Overflow
  • IRC
  • Slack
  • Paid Support

Generated using CakePHP API Docs