PHP code example of jakim-pj / yii2-authserver
1. Go to this page and download the library: Download jakim-pj/yii2-authserver library . Choose the download type require .
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
jakim-pj / yii2-authserver example snippets
'components' => [
'authServer' => [
'class' => \jakim\authserver\Server::class,
'grantTypes' => [
'password' => \jakim\authserver\grants\PasswordCredentials::class,
'refresh_token' => \jakim\authserver\grants\RefreshToken::class,
'facebook_token' => [
'class' => \jakim\authserver\grants\FacebookToken::class,
'app_id' => $params['facebook.app_id'],
'app_secret' => $params['facebook.app_secret'],
'fields' => 'birthday,email,name,about,gender,picture.type(large){url}',
],
],
],
],
public static function findIdentityByCredentials($username, $password)
{
$security = \Yii::$app->security;
$model = static::findOne(['email' => $username]);
if ($model && $security->validatePassword($password, $model->password)) {
return $model;
}
return null;
}
public static function findIdentityByRefreshToken($refreshToken)
{
return static::findOne(['refresh_token' => $refreshToken]);
}
public static function findIdentityByFacebookGraphUser($user)
{
/** @var GraphUser $user */
$model = static::findOne(['facebook_id' => $user->getId()]);
if ($model === null) {
$model = static::findOne(['email' => $user->getEmail()]);
}
// auto create user from facebook
if ($model === null) {
/** @var User $model */
$model = UserFactory::newFromFacebookGraphUser($user);
if (!$model->save()) {
\Yii::error('Unable to create new user from facebook: ' . print_r($model->getErrors(), true), __METHOD__);
return null;
}
} else {
$model = UserFactory::updateFromFacebookGraphUser($model, $user);
if (!$model->save()) {
\Yii::error('Unable to update user from facebook: ' . print_r($model->getErrors(), true), __METHOD__);
return null;
}
}
return $model;
}
public function setAccessToken($token)
{
$this->access_token = $token;
}
public function getAccessToken()
{
return $this->access_token;
}
public function setRefreshToken($token)
{
$this->refresh_token = $token;
}
public function getRefreshToken()
{
return $this->refresh_token;
}
public function actionToken()
{
/** @var Server $server */
$server = Instance::ensure('authServer', Server::class);
if (($response = $server->getResponse()) === null) {
return $server->getError();
}
return $response;
}
public function actions()
{
return [
'token' => TokenAction::class,
];
}