OAuth2
extends BaseOAuth
in package
OAuth2 serves as a client for the OAuth 2 flow.
In oder to acquire access token perform following sequence:
use yii\authclient\OAuth2;
// assuming class MyAuthClient extends OAuth2
$oauthClient = new MyAuthClient();
$url = $oauthClient->buildAuthUrl(); // Build authorization URL
Yii::$app->getResponse()->redirect($url); // Redirect to authorization URL.
// After user returns at our site:
$code = Yii::$app->getRequest()->get('code');
$accessToken = $oauthClient->fetchAccessToken($code); // Get access token
Tags
Table of Contents
Constants
- ACCESS_TOKEN_LOCATION_BODY = 'body'
- Apply the access token to the request body
- ACCESS_TOKEN_LOCATION_HEADER = 'header'
- Apply the access token to the request header
Properties
- $accessToken : OAuthToken
- $accessTokenLocation : string
- $apiBaseUrl : string
- $authUrl : string
- $autoRefreshAccessToken : bool
- $behaviors : array<string|int, Behavior>
- $clientId : string
- $clientSecret : string
- $enablePkce : bool
- $httpClient : Client
- $id : string
- $name : string
- $normalizeUserAttributeMap : array<string|int, mixed>
- $parametersToKeepInReturnUrl : array<string|int, mixed>
- $requestOptions : array<string|int, mixed>
- $returnUrl : string
- $scope : string
- $signatureMethod : BaseMethod
- $stateStorage : StateStorageInterface
- $title : string
- $tokenUrl : string
- $userAttributes : array<string|int, mixed>
- $validateAuthState : bool
- $version : string
- $viewOptions : array<string|int, mixed>
- $_accessToken : OAuthToken|array<string|int, mixed>|null
- $_behaviors : array<string|int, Behavior>|null
- $_events : array<string|int, mixed>
- $_eventWildcards : array<string|int, mixed>
- $_httpClient : Client|array<string|int, mixed>|string
- $_id : string
- $_name : string
- $_normalizeUserAttributeMap : array<string|int, mixed>
- $_requestOptions : array<string|int, mixed>
- $_returnUrl : string
- $_signatureMethod : BaseMethod|array<string|int, mixed>
- $_stateStorage : StateStorageInterface|array<string|int, mixed>|string
- $_title : string
- $_userAttributes : array<string|int, mixed>
- $_viewOptions : array<string|int, mixed>
Methods
- __call() : mixed
- Calls the named method which is not a class method.
- __clone() : mixed
- This method is called after the object is created by cloning an existing one.
- __construct() : mixed
- Constructor.
- __get() : mixed
- Returns the value of a component property.
- __isset() : bool
- Checks if a property is set, i.e. defined and not null.
- __set() : mixed
- Sets the value of a component property.
- __unset() : mixed
- Sets a component property to be null.
- api() : array<string|int, mixed>
- Performs request to the OAuth API returning response data.
- applyAccessTokenToRequest() : mixed
- Applies access token to the HTTP request instance.
- attachBehavior() : Behavior
- Attaches a behavior to this component.
- attachBehaviors() : mixed
- Attaches a list of behaviors to the component.
- authenticateClient() : OAuthToken
- Authenticate OAuth client directly at the provider without third party (user) involved, using 'client_credentials' grant type.
- authenticateUser() : OAuthToken
- Authenticates user directly by 'username/password' pair, using 'password' grant type.
- authenticateUserJwt() : OAuthToken
- Authenticates user directly using JSON Web Token (JWT).
- beforeApiRequestSend() : mixed
- Handles [[Request::EVENT_BEFORE_SEND]] event.
- behaviors() : array<string|int, mixed>
- Returns a list of behaviors that this component should behave as.
- buildAuthUrl() : string
- Composes user authorization URL.
- canGetProperty() : bool
- Returns a value indicating whether a property can be read.
- canSetProperty() : bool
- Returns a value indicating whether a property can be set.
- className() : string
- Returns the fully qualified name of this class.
- createApiRequest() : Request
- Creates an HTTP request for the API call.
- createRequest() : Request
- Creates HTTP request instance.
- detachBehavior() : Behavior|null
- Detaches a behavior from the component.
- detachBehaviors() : mixed
- Detaches all behaviors from the component.
- ensureBehaviors() : mixed
- Makes sure that the behaviors declared in [[behaviors()]] are attached to this component.
- fetchAccessToken() : OAuthToken
- Fetches access token from authorization code.
- getAccessToken() : OAuthToken
- getBehavior() : Behavior|null
- Returns the named behavior object.
- getBehaviors() : array<string|int, Behavior>
- Returns all behaviors attached to this component.
- getHttpClient() : Client
- Returns HTTP client.
- getId() : string
- getName() : string
- getNormalizeUserAttributeMap() : array<string|int, mixed>
- getRequestOptions() : array<string|int, mixed>
- getReturnUrl() : string
- getSignatureMethod() : BaseMethod
- getStateStorage() : StateStorageInterface
- getTitle() : string
- getUserAttributes() : array<string|int, mixed>
- getViewOptions() : array<string|int, mixed>
- hasEventHandlers() : bool
- Returns a value indicating whether there is any handler attached to the named event.
- hasMethod() : bool
- Returns a value indicating whether a method is defined.
- hasProperty() : bool
- Returns a value indicating whether a property is defined for this component.
- init() : mixed
- Initializes the object.
- off() : bool
- Detaches an existing event handler from this component.
- on() : mixed
- Attaches an event handler to an event.
- refreshAccessToken() : OAuthToken
- Gets new auth token to replace expired one.
- setAccessToken() : mixed
- Sets access token to be used.
- setHttpClient() : mixed
- Sets HTTP client to be used.
- setId() : mixed
- setName() : mixed
- setNormalizeUserAttributeMap() : mixed
- setRequestOptions() : mixed
- setReturnUrl() : mixed
- setSignatureMethod() : mixed
- Set signature method to be used.
- setStateStorage() : mixed
- setTitle() : mixed
- setUserAttributes() : mixed
- setViewOptions() : mixed
- trigger() : mixed
- Triggers an event.
- applyClientCredentialsToRequest() : mixed
- Applies client credentials (e.g. [[clientId]] and [[clientSecret]]) to the HTTP request instance.
- composeUrl() : string
- Composes URL from base URL and GET params.
- createHttpClient() : Client
- Creates HTTP client instance from reference or configuration.
- createSignatureMethod() : BaseMethod
- Creates signature method instance from its configuration.
- createToken() : OAuthToken
- Creates token from its configuration.
- defaultName() : string
- Generates service name.
- defaultNormalizeUserAttributeMap() : array<string|int, mixed>
- Returns the default [[normalizeUserAttributeMap]] value.
- defaultRequestOptions() : array<string|int, mixed>
- Returns default HTTP request options.
- defaultReturnUrl() : string
- Composes default [[returnUrl]] value.
- defaultTitle() : string
- Generates service title.
- defaultViewOptions() : array<string|int, mixed>
- Returns the default [[viewOptions]] value.
- generateAuthState() : string
- Generates the auth state value.
- getState() : mixed
- Returns persistent state value.
- getStateKeyPrefix() : string
- Returns session key prefix, which is used to store internal states.
- initUserAttributes() : array<string|int, mixed>
- Initializes authenticated user attributes.
- normalizeUserAttributes() : array<string|int, mixed>
- Normalize given user attributes according to [[normalizeUserAttributeMap]].
- removeState() : bool
- Removes persistent state value.
- restoreAccessToken() : OAuthToken
- Restores access token.
- saveAccessToken() : $this
- Saves token as persistent state.
- sendRequest() : array<string|int, mixed>|string|null
- Sends the given HTTP request, returning response data.
- setState() : $this
- Sets persistent state.
- attachBehaviorInternal() : Behavior
- Attaches a behavior to this component.
Constants
ACCESS_TOKEN_LOCATION_BODY
Apply the access token to the request body
public
mixed
ACCESS_TOKEN_LOCATION_BODY
= 'body'
Tags
ACCESS_TOKEN_LOCATION_HEADER
Apply the access token to the request header
public
mixed
ACCESS_TOKEN_LOCATION_HEADER
= 'header'
Tags
Properties
$accessToken
public
OAuthToken
$accessToken
Auth token instance. Note that the type of this property differs in getter and setter. See [[getAccessToken()]] and [[setAccessToken()]] for details.
$accessTokenLocation
public
string
$accessTokenLocation
= self::ACCESS_TOKEN_LOCATION_BODY
The location of the access token when it is applied to the request.
NOTE: According to the OAuth2 specification this should be header
by default,
however, for backwards compatibility the default value used here is body
.
Tags
$apiBaseUrl
public
string
$apiBaseUrl
API base URL. This field will be used as [[\yii\httpclient\Client::baseUrl]] value of [[httpClient]]. Note: changing this property will take no effect after [[httpClient]] is instantiated.
$authUrl
public
string
$authUrl
authorize URL.
$autoRefreshAccessToken
public
bool
$autoRefreshAccessToken
= true
whether to automatically perform 'refresh access token' request on expired access token.
Tags
$behaviors read-only
public
array<string|int, Behavior>
$behaviors
List of behaviors attached to this component.
$clientId
public
string
$clientId
OAuth client ID.
$clientSecret
public
string
$clientSecret
OAuth client secret.
$enablePkce
public
bool
$enablePkce
= false
Whether to enable proof key for code exchange (PKCE) support and add
a code_challenge
and code_verifier
to the auth request.
Tags
$httpClient
public
Client
$httpClient
Internal HTTP client. Note that the type of this property differs in getter and setter. See [[getHttpClient()]] and [[setHttpClient()]] for details.
$id
public
string
$id
Service id.
$name
public
string
$name
Service name.
$normalizeUserAttributeMap
public
array<string|int, mixed>
$normalizeUserAttributeMap
Normalize user attribute map.
$parametersToKeepInReturnUrl
public
array<string|int, mixed>
$parametersToKeepInReturnUrl
= ['authclient']
List of the parameters to keep in default return url.
Tags
$requestOptions read-only
public
array<string|int, mixed>
$requestOptions
HTTP request options.
$returnUrl
public
string
$returnUrl
Return URL.
$scope
public
string
$scope
auth request scope.
$signatureMethod
public
BaseMethod
$signatureMethod
Signature method instance. Note that the type of this property differs in getter and setter. See [[getSignatureMethod()]] and [[setSignatureMethod()]] for details.
$stateStorage
public
StateStorageInterface
$stateStorage
Stage storage. Note that the type of this property differs in getter and setter. See [[getStateStorage()]] and [[setStateStorage()]] for details.
$title
public
string
$title
Service title.
$tokenUrl
public
string
$tokenUrl
token request URL endpoint.
$userAttributes
public
array<string|int, mixed>
$userAttributes
List of user attributes.
$validateAuthState
public
bool
$validateAuthState
= true
whether to use and validate auth 'state' parameter in authentication flow. If enabled - the opaque value will be generated and applied to auth URL to maintain state between the request and callback. The authorization server includes this value, when redirecting the user-agent back to the client. The option is used for preventing cross-site request forgery.
Tags
$version
public
string
$version
= '2.0'
protocol version.
$viewOptions
public
array<string|int, mixed>
$viewOptions
View options in format: optionName => optionValue.
$_accessToken
private
OAuthToken|array<string|int, mixed>|null
$_accessToken
access token instance, its array configuration or null that means that token would be restored from token store.
$_behaviors
private
array<string|int, Behavior>|null
$_behaviors
the attached behaviors (behavior name => behavior). This is null
when not initialized.
$_events
private
array<string|int, mixed>
$_events
= []
the attached event handlers (event name => handlers)
$_eventWildcards
private
array<string|int, mixed>
$_eventWildcards
= []
the event handlers attached for wildcard patterns (event name wildcard => handlers)
Tags
$_httpClient
private
Client|array<string|int, mixed>|string
$_httpClient
= 'yii\httpclient\Client'
internal HTTP client.
Tags
$_id
private
string
$_id
auth service id. This value mainly used as HTTP request parameter.
$_name
private
string
$_name
auth service name. This value may be used in database records, CSS files and so on.
$_normalizeUserAttributeMap
private
array<string|int, mixed>
$_normalizeUserAttributeMap
map used to normalize user attributes fetched from external auth service in format: normalizedAttributeName => sourceSpecification 'sourceSpecification' can be:
- string, raw attribute name
- array, pass to raw attribute value
- callable, PHP callback, which should accept array of raw attributes and return normalized value.
For example:
'normalizeUserAttributeMap' => [
'about' => 'bio',
'language' => ['languages', 0, 'name'],
'fullName' => function ($attributes) {
return $attributes['firstName'] . ' ' . $attributes['lastName'];
},
],
$_requestOptions
private
array<string|int, mixed>
$_requestOptions
= []
cURL request options. Option values from this field will overwrite corresponding values from [[defaultRequestOptions()]].
Tags
$_returnUrl
private
string
$_returnUrl
URL, which user will be redirected after authentication at the OAuth provider web site. Note: this should be absolute URL (with http:// or https:// leading). By default current URL will be used.
$_signatureMethod
private
BaseMethod|array<string|int, mixed>
$_signatureMethod
= []
signature method instance or its array configuration.
$_stateStorage
private
StateStorageInterface|array<string|int, mixed>|string
$_stateStorage
= 'yii\authclient\SessionStateStorage'
state storage to be used.
$_title
private
string
$_title
auth service title to display in views.
$_userAttributes
private
array<string|int, mixed>
$_userAttributes
authenticated user attributes.
$_viewOptions
private
array<string|int, mixed>
$_viewOptions
view options in format: optionName => optionValue
Methods
__call()
Calls the named method which is not a class method.
public
__call(string $name, array<string|int, mixed> $params) : mixed
This method will check if any attached behavior has the named method and will execute it if available.
Do not call this method directly as it is a PHP magic method that will be implicitly called when an unknown method is being invoked.
Parameters
- $name : string
-
the method name
- $params : array<string|int, mixed>
-
method parameters
Tags
Return values
mixed —the method return value
__clone()
This method is called after the object is created by cloning an existing one.
public
__clone() : mixed
It removes all behaviors because they are attached to the old object.
__construct()
Constructor.
public
__construct([array<string|int, mixed> $config = [] ]) : mixed
The default implementation does two things:
- Initializes the object with the given configuration
$config
. - Call [[init()]].
If this method is overridden in a child class, it is recommended that
- the last parameter of the constructor is a configuration array, like
$config
here. - call the parent implementation at the end of the constructor.
Parameters
- $config : array<string|int, mixed> = []
-
name-value pairs that will be used to initialize the object properties
__get()
Returns the value of a component property.
public
__get(string $name) : mixed
This method will check in the following order and act accordingly:
- a property defined by a getter: return the getter result
- a property of a behavior: return the behavior property value
Do not call this method directly as it is a PHP magic method that
will be implicitly called when executing $value = $component->property;
.
Parameters
- $name : string
-
the property name
Tags
Return values
mixed —the property value or the value of a behavior's property
__isset()
Checks if a property is set, i.e. defined and not null.
public
__isset(string $name) : bool
This method will check in the following order and act accordingly:
- a property defined by a setter: return whether the property is set
- a property of a behavior: return whether the property is set
- return
false
for non existing properties
Do not call this method directly as it is a PHP magic method that
will be implicitly called when executing isset($component->property)
.
Parameters
- $name : string
-
the property name or the event name
Tags
Return values
bool —whether the named property is set
__set()
Sets the value of a component property.
public
__set(string $name, mixed $value) : mixed
This method will check in the following order and act accordingly:
- a property defined by a setter: set the property value
- an event in the format of "on xyz": attach the handler to the event "xyz"
- a behavior in the format of "as xyz": attach the behavior named as "xyz"
- a property of a behavior: set the behavior property value
Do not call this method directly as it is a PHP magic method that
will be implicitly called when executing $component->property = $value;
.
Parameters
- $name : string
-
the property name or the event name
- $value : mixed
-
the property value
Tags
__unset()
Sets a component property to be null.
public
__unset(string $name) : mixed
This method will check in the following order and act accordingly:
- a property defined by a setter: set the property value to be null
- a property of a behavior: set the property value to be null
Do not call this method directly as it is a PHP magic method that
will be implicitly called when executing unset($component->property)
.
Parameters
- $name : string
-
the property name
Tags
api()
Performs request to the OAuth API returning response data.
public
api(string|array<string|int, mixed> $apiSubUrl[, string $method = 'GET' ][, array<string|int, mixed>|string $data = [] ][, array<string|int, mixed> $headers = [] ]) : array<string|int, mixed>
You may use [[createApiRequest()]] method instead, gaining more control over request execution.
Parameters
- $apiSubUrl : string|array<string|int, mixed>
-
API sub URL, which will be append to [[apiBaseUrl]], or absolute API URL.
- $method : string = 'GET'
-
request method.
- $data : array<string|int, mixed>|string = []
-
request data or content.
- $headers : array<string|int, mixed> = []
-
additional request headers.
Tags
Return values
array<string|int, mixed> —API response data.
applyAccessTokenToRequest()
Applies access token to the HTTP request instance.
public
applyAccessTokenToRequest(mixed $request, mixed $accessToken) : mixed
Parameters
- $request : mixed
-
HTTP request instance.
- $accessToken : mixed
-
access token instance.
Tags
attachBehavior()
Attaches a behavior to this component.
public
attachBehavior(string $name, string|array<string|int, mixed>|Behavior $behavior) : Behavior
This method will create the behavior object based on the given configuration. After that, the behavior object will be attached to this component by calling the [[Behavior::attach()]] method.
Parameters
- $name : string
-
the name of the behavior.
- $behavior : string|array<string|int, mixed>|Behavior
-
the behavior configuration. This can be one of the following:
- a [[Behavior]] object
- a string specifying the behavior class
- an object configuration array that will be passed to [[Yii::createObject()]] to create the behavior object.
Tags
Return values
Behavior —the behavior object
attachBehaviors()
Attaches a list of behaviors to the component.
public
attachBehaviors(array<string|int, mixed> $behaviors) : mixed
Each behavior is indexed by its name and should be a [[Behavior]] object, a string specifying the behavior class, or an configuration array for creating the behavior.
Parameters
- $behaviors : array<string|int, mixed>
-
list of behaviors to be attached to the component
Tags
authenticateClient()
Authenticate OAuth client directly at the provider without third party (user) involved, using 'client_credentials' grant type.
public
authenticateClient([array<string|int, mixed> $params = [] ]) : OAuthToken
Parameters
- $params : array<string|int, mixed> = []
-
additional request params.
Tags
Return values
OAuthToken —access token.
authenticateUser()
Authenticates user directly by 'username/password' pair, using 'password' grant type.
public
authenticateUser(string $username, string $password[, array<string|int, mixed> $params = [] ]) : OAuthToken
Parameters
- $username : string
-
user name.
- $password : string
-
user password.
- $params : array<string|int, mixed> = []
-
additional request params.
Tags
Return values
OAuthToken —access token.
authenticateUserJwt()
Authenticates user directly using JSON Web Token (JWT).
public
authenticateUserJwt(string $username[, BaseMethod|array<string|int, mixed> $signature = null ][, array<string|int, mixed> $options = [] ][, array<string|int, mixed> $params = [] ]) : OAuthToken
Parameters
- $username : string
- $signature : BaseMethod|array<string|int, mixed> = null
-
signature method or its array configuration. If empty - [[signatureMethod]] will be used.
- $options : array<string|int, mixed> = []
-
additional options. Valid options are:
- header: array, additional JWS header parameters.
- payload: array, additional JWS payload (message or claim-set) parameters.
- signatureKey: string, signature key to be used, if not set - [[clientSecret]] will be used.
- $params : array<string|int, mixed> = []
-
additional request params.
Tags
Return values
OAuthToken —access token.
beforeApiRequestSend()
Handles [[Request::EVENT_BEFORE_SEND]] event.
public
beforeApiRequestSend(RequestEvent $event) : mixed
Applies [[accessToken]] to the request.
Parameters
- $event : RequestEvent
-
event instance.
Tags
behaviors()
Returns a list of behaviors that this component should behave as.
public
behaviors() : array<string|int, mixed>
Child classes may override this method to specify the behaviors they want to behave as.
The return value of this method should be an array of behavior objects or configurations indexed by behavior names. A behavior configuration can be either a string specifying the behavior class or an array of the following structure:
'behaviorName' => [
'class' => 'BehaviorClass',
'property1' => 'value1',
'property2' => 'value2',
]
Note that a behavior class must extend from [[Behavior]]. Behaviors can be attached using a name or anonymously. When a name is used as the array key, using this name, the behavior can later be retrieved using [[getBehavior()]] or be detached using [[detachBehavior()]]. Anonymous behaviors can not be retrieved or detached.
Behaviors declared in this method will be attached to the component automatically (on demand).
Return values
array<string|int, mixed> —the behavior configurations.
buildAuthUrl()
Composes user authorization URL.
public
buildAuthUrl([array<string|int, mixed> $params = [] ]) : string
Parameters
- $params : array<string|int, mixed> = []
-
additional auth GET params.
Return values
string —authorization URL.
canGetProperty()
Returns a value indicating whether a property can be read.
public
canGetProperty(string $name[, bool $checkVars = true ][, bool $checkBehaviors = true ]) : bool
A property can be read if:
- the class has a getter method associated with the specified name (in this case, property name is case-insensitive);
- the class has a member variable with the specified name (when
$checkVars
is true); - an attached behavior has a readable property of the given name (when
$checkBehaviors
is true).
Parameters
- $name : string
-
the property name
- $checkVars : bool = true
-
whether to treat member variables as properties
- $checkBehaviors : bool = true
-
whether to treat behaviors' properties as properties of this component
Tags
Return values
bool —whether the property can be read
canSetProperty()
Returns a value indicating whether a property can be set.
public
canSetProperty(string $name[, bool $checkVars = true ][, bool $checkBehaviors = true ]) : bool
A property can be written if:
- the class has a setter method associated with the specified name (in this case, property name is case-insensitive);
- the class has a member variable with the specified name (when
$checkVars
is true); - an attached behavior has a writable property of the given name (when
$checkBehaviors
is true).
Parameters
- $name : string
-
the property name
- $checkVars : bool = true
-
whether to treat member variables as properties
- $checkBehaviors : bool = true
-
whether to treat behaviors' properties as properties of this component
Tags
Return values
bool —whether the property can be written
className()
Returns the fully qualified name of this class.
public
static className() : string
Tags
Return values
string —the fully qualified name of this class.
createApiRequest()
Creates an HTTP request for the API call.
public
createApiRequest() : Request
The created request will be automatically processed adding access token parameters and signature before sending. You may use [[createRequest()]] to gain full control over request composition and execution.
Tags
Return values
Request —HTTP request instance.
createRequest()
Creates HTTP request instance.
public
createRequest() : Request
Tags
Return values
Request —HTTP request instance.
detachBehavior()
Detaches a behavior from the component.
public
detachBehavior(string $name) : Behavior|null
The behavior's [[Behavior::detach()]] method will be invoked.
Parameters
- $name : string
-
the behavior's name.
Return values
Behavior|null —the detached behavior. Null if the behavior does not exist.
detachBehaviors()
Detaches all behaviors from the component.
public
detachBehaviors() : mixed
ensureBehaviors()
Makes sure that the behaviors declared in [[behaviors()]] are attached to this component.
public
ensureBehaviors() : mixed
fetchAccessToken()
Fetches access token from authorization code.
public
fetchAccessToken(string $authCode[, array<string|int, mixed> $params = [] ]) : OAuthToken
Parameters
- $authCode : string
-
authorization code, usually comes at GET parameter 'code'.
- $params : array<string|int, mixed> = []
-
additional request params.
Tags
Return values
OAuthToken —access token.
getAccessToken()
public
getAccessToken() : OAuthToken
Return values
OAuthToken —auth token instance.
getBehavior()
Returns the named behavior object.
public
getBehavior(string $name) : Behavior|null
Parameters
- $name : string
-
the behavior name
Return values
Behavior|null —the behavior object, or null if the behavior does not exist
getBehaviors()
Returns all behaviors attached to this component.
public
getBehaviors() : array<string|int, Behavior>
Return values
array<string|int, Behavior> —list of behaviors attached to this component
getHttpClient()
Returns HTTP client.
public
getHttpClient() : Client
Tags
Return values
Client —internal HTTP client.
getId()
public
getId() : string
Return values
string —service id
getName()
public
getName() : string
Return values
string —service name.
getNormalizeUserAttributeMap()
public
getNormalizeUserAttributeMap() : array<string|int, mixed>
Return values
array<string|int, mixed> —normalize user attribute map.
getRequestOptions()
public
getRequestOptions() : array<string|int, mixed>
Tags
Return values
array<string|int, mixed> —HTTP request options.
getReturnUrl()
public
getReturnUrl() : string
Return values
string —return URL.
getSignatureMethod()
public
getSignatureMethod() : BaseMethod
Return values
BaseMethod —signature method instance.
getStateStorage()
public
getStateStorage() : StateStorageInterface
Return values
StateStorageInterface —stage storage.
getTitle()
public
getTitle() : string
Return values
string —service title.
getUserAttributes()
public
getUserAttributes() : array<string|int, mixed>
Return values
array<string|int, mixed> —list of user attributes
getViewOptions()
public
getViewOptions() : array<string|int, mixed>
Return values
array<string|int, mixed> —view options in format: optionName => optionValue
hasEventHandlers()
Returns a value indicating whether there is any handler attached to the named event.
public
hasEventHandlers(string $name) : bool
Parameters
- $name : string
-
the event name
Return values
bool —whether there is any handler attached to the event.
hasMethod()
Returns a value indicating whether a method is defined.
public
hasMethod(string $name[, bool $checkBehaviors = true ]) : bool
A method is defined if:
- the class has a method with the specified name
- an attached behavior has a method with the given name (when
$checkBehaviors
is true).
Parameters
- $name : string
-
the property name
- $checkBehaviors : bool = true
-
whether to treat behaviors' methods as methods of this component
Return values
bool —whether the method is defined
hasProperty()
Returns a value indicating whether a property is defined for this component.
public
hasProperty(string $name[, bool $checkVars = true ][, bool $checkBehaviors = true ]) : bool
A property is defined if:
- the class has a getter or setter method associated with the specified name (in this case, property name is case-insensitive);
- the class has a member variable with the specified name (when
$checkVars
is true); - an attached behavior has a property of the given name (when
$checkBehaviors
is true).
Parameters
- $name : string
-
the property name
- $checkVars : bool = true
-
whether to treat member variables as properties
- $checkBehaviors : bool = true
-
whether to treat behaviors' properties as properties of this component
Tags
Return values
bool —whether the property is defined
init()
Initializes the object.
public
init() : mixed
This method is invoked at the end of the constructor after the object is initialized with the given configuration.
off()
Detaches an existing event handler from this component.
public
off(string $name[, callable|null $handler = null ]) : bool
This method is the opposite of [[on()]].
Note: in case wildcard pattern is passed for event name, only the handlers registered with this wildcard will be removed, while handlers registered with plain names matching this wildcard will remain.
Parameters
- $name : string
-
event name
- $handler : callable|null = null
-
the event handler to be removed. If it is null, all handlers attached to the named event will be removed.
Tags
Return values
bool —if a handler is found and detached
on()
Attaches an event handler to an event.
public
on(string $name, callable $handler[, mixed $data = null ][, bool $append = true ]) : mixed
The event handler must be a valid PHP callback. The following are some examples:
function ($event) { ... } // anonymous function
[$object, 'handleClick'] // $object->handleClick()
['Page', 'handleClick'] // Page::handleClick()
'handleClick' // global function handleClick()
The event handler must be defined with the following signature,
function ($event)
where $event
is an [[Event]] object which includes parameters associated with the event.
Since 2.0.14 you can specify event name as a wildcard pattern:
$component->on('event.group.*', function ($event) {
Yii::trace($event->name . ' is triggered.');
});
Parameters
- $name : string
-
the event name
- $handler : callable
-
the event handler
- $data : mixed = null
-
the data to be passed to the event handler when the event is triggered. When the event handler is invoked, this data can be accessed via [[Event::data]].
- $append : bool = true
-
whether to append new event handler to the end of the existing handler list. If false, the new handler will be inserted at the beginning of the existing handler list.
Tags
refreshAccessToken()
Gets new auth token to replace expired one.
public
refreshAccessToken(OAuthToken $token) : OAuthToken
Parameters
- $token : OAuthToken
-
expired auth token.
Return values
OAuthToken —new auth token.
setAccessToken()
Sets access token to be used.
public
setAccessToken(array<string|int, mixed>|OAuthToken|null $token) : mixed
Parameters
- $token : array<string|int, mixed>|OAuthToken|null
-
access token or its configuration. Set to null to restore token from token store.
setHttpClient()
Sets HTTP client to be used.
public
setHttpClient(mixed $httpClient) : mixed
Parameters
- $httpClient : mixed
-
internal HTTP client.
setId()
public
setId(string $id) : mixed
Parameters
- $id : string
-
service id.
setName()
public
setName(string $name) : mixed
Parameters
- $name : string
-
service name.
setNormalizeUserAttributeMap()
public
setNormalizeUserAttributeMap(array<string|int, mixed> $normalizeUserAttributeMap) : mixed
Parameters
- $normalizeUserAttributeMap : array<string|int, mixed>
-
normalize user attribute map.
setRequestOptions()
public
setRequestOptions(array<string|int, mixed> $options) : mixed
Parameters
- $options : array<string|int, mixed>
-
HTTP request options.
Tags
setReturnUrl()
public
setReturnUrl(string $returnUrl) : mixed
Parameters
- $returnUrl : string
-
return URL
setSignatureMethod()
Set signature method to be used.
public
setSignatureMethod(array<string|int, mixed>|BaseMethod $signatureMethod) : mixed
Parameters
- $signatureMethod : array<string|int, mixed>|BaseMethod
-
signature method instance or its array configuration.
Tags
setStateStorage()
public
setStateStorage(StateStorageInterface|array<string|int, mixed>|string $stateStorage) : mixed
Parameters
- $stateStorage : StateStorageInterface|array<string|int, mixed>|string
-
stage storage to be used.
setTitle()
public
setTitle(string $title) : mixed
Parameters
- $title : string
-
service title.
setUserAttributes()
public
setUserAttributes(array<string|int, mixed> $userAttributes) : mixed
Parameters
- $userAttributes : array<string|int, mixed>
-
list of user attributes
setViewOptions()
public
setViewOptions(array<string|int, mixed> $viewOptions) : mixed
Parameters
- $viewOptions : array<string|int, mixed>
-
view options in format: optionName => optionValue
trigger()
Triggers an event.
public
trigger(string $name[, Event|null $event = null ]) : mixed
This method represents the happening of an event. It invokes all attached handlers for the event including class-level handlers.
Parameters
- $name : string
-
the event name
- $event : Event|null = null
-
the event instance. If not set, a default [[Event]] object will be created.
applyClientCredentialsToRequest()
Applies client credentials (e.g. [[clientId]] and [[clientSecret]]) to the HTTP request instance.
protected
applyClientCredentialsToRequest(Request $request) : mixed
This method should be invoked before sending any HTTP request, which requires client credentials.
Parameters
- $request : Request
-
HTTP request instance.
Tags
composeUrl()
Composes URL from base URL and GET params.
protected
composeUrl(string $url[, array<string|int, mixed> $params = [] ]) : string
Parameters
- $url : string
-
base URL.
- $params : array<string|int, mixed> = []
-
GET params.
Return values
string —composed URL.
createHttpClient()
Creates HTTP client instance from reference or configuration.
protected
createHttpClient(mixed $reference) : Client
Parameters
- $reference : mixed
-
component name or array configuration.
Return values
Client —HTTP client instance.
createSignatureMethod()
Creates signature method instance from its configuration.
protected
createSignatureMethod(array<string|int, mixed> $signatureMethodConfig) : BaseMethod
Parameters
- $signatureMethodConfig : array<string|int, mixed>
-
signature method configuration.
Return values
BaseMethod —signature method instance.
createToken()
Creates token from its configuration.
protected
createToken([array<string|int, mixed> $tokenConfig = [] ]) : OAuthToken
Parameters
- $tokenConfig : array<string|int, mixed> = []
-
token configuration.
Return values
OAuthToken —token instance.
defaultName()
Generates service name.
protected
defaultName() : string
Return values
string —service name.
defaultNormalizeUserAttributeMap()
Returns the default [[normalizeUserAttributeMap]] value.
protected
defaultNormalizeUserAttributeMap() : array<string|int, mixed>
Particular client may override this method in order to provide specific default map.
Return values
array<string|int, mixed> —normalize attribute map.
defaultRequestOptions()
Returns default HTTP request options.
protected
defaultRequestOptions() : array<string|int, mixed>
Return values
array<string|int, mixed> —HTTP request options.
defaultReturnUrl()
Composes default [[returnUrl]] value.
protected
defaultReturnUrl() : string
Return values
string —return URL.
defaultTitle()
Generates service title.
protected
defaultTitle() : string
Return values
string —service title.
defaultViewOptions()
Returns the default [[viewOptions]] value.
protected
defaultViewOptions() : array<string|int, mixed>
Particular client may override this method in order to provide specific default view options.
Return values
array<string|int, mixed> —list of default [[viewOptions]]
generateAuthState()
Generates the auth state value.
protected
generateAuthState() : string
Tags
Return values
string —auth state value.
getState()
Returns persistent state value.
protected
getState(string $key) : mixed
Parameters
- $key : string
-
state key.
Return values
mixed —state value.
getStateKeyPrefix()
Returns session key prefix, which is used to store internal states.
protected
getStateKeyPrefix() : string
Return values
string —session key prefix.
initUserAttributes()
Initializes authenticated user attributes.
protected
abstract initUserAttributes() : array<string|int, mixed>
Return values
array<string|int, mixed> —auth user attributes.
normalizeUserAttributes()
Normalize given user attributes according to [[normalizeUserAttributeMap]].
protected
normalizeUserAttributes(array<string|int, mixed> $attributes) : array<string|int, mixed>
Parameters
- $attributes : array<string|int, mixed>
-
raw attributes.
Tags
Return values
array<string|int, mixed> —normalized attributes.
removeState()
Removes persistent state value.
protected
removeState(string $key) : bool
Parameters
- $key : string
-
state key.
Return values
bool —success.
restoreAccessToken()
Restores access token.
protected
restoreAccessToken() : OAuthToken
Return values
OAuthToken —auth token.
saveAccessToken()
Saves token as persistent state.
protected
saveAccessToken(OAuthToken|null $token) : $this
Parameters
- $token : OAuthToken|null
-
auth token to be saved.
Return values
$this —the object itself.
sendRequest()
Sends the given HTTP request, returning response data.
protected
sendRequest(Request $request) : array<string|int, mixed>|string|null
Parameters
- $request : Request
-
HTTP request to be sent.
Tags
Return values
array<string|int, mixed>|string|null —response data.
setState()
Sets persistent state.
protected
setState(string $key, mixed $value) : $this
Parameters
- $key : string
-
state key.
- $value : mixed
-
state value
Return values
$this —the object itself
attachBehaviorInternal()
Attaches a behavior to this component.
private
attachBehaviorInternal(string|int $name, string|array<string|int, mixed>|Behavior $behavior) : Behavior
Parameters
- $name : string|int
-
the name of the behavior. If this is an integer, it means the behavior is an anonymous one. Otherwise, the behavior is a named one and any existing behavior with the same name will be detached first.
- $behavior : string|array<string|int, mixed>|Behavior
-
the behavior to be attached
Return values
Behavior —the attached behavior.