Cakephp 3.6 oauth с помощью проблемы перенаправления google-plus - PullRequest
0 голосов
/ 28 ноября 2018

Добрый день, мама / сэр

Я хотел бы знать, почему я не перенаправил на страницу панели инструментов после входа в систему с помощью google-plus в cakephp.Все выглядит нормально, и сообщения об ошибках не появляется, поэтому отладка кода очень сложна.Во время моего исследования я нашел этот сайт [http://caketuts.key -conseil.fr / index.php / 2015/05/22 / integrarer-lapi-oauth2-de-google-avec-cakephp-v3 /] [1] .Я все еще новичок в Cakephp 3.6, и я впервые использую oauth google + в моем проекте.

AdminController

    public function googlelogin() {

    $client = new Google_Client();
    $client->setClientId(GOOGLE_OAUTH_CLIENT_ID);
    $client->setClientSecret(GOOGLE_OAUTH_CLIENT_SECRET);
    $client->setRedirectUri(GOOGLE_OAUTH_REDIRECT_URI);

    $client->setScopes(array(
            'https://www.googleapis.com/auth/userinfo.profile',
            'https://www.googleapis.com/auth/userinfo.email'
    ));

    $client->setApprovalPrompt('auto');

    $url = $client->createAuthUrl();
    $this->redirect($url);

}

public function google_login() {

    $client = new Google_Client();
    $client->setClientId(GOOGLE_OAUTH_CLIENT_ID);
    $client->setClientSecret(GOOGLE_OAUTH_CLIENT_SECRET);
    $client->setRedirectUri(GOOGLE_OAUTH_REDIRECT_URI);

    $client->setScopes(array(
            'https://www.googleapis.com/auth/userinfo.profile',
            'https://www.googleapis.com/auth/userinfo.email'
    ));

    $client->setApprovalPrompt('auto');

    if (!empty($this->request->getQuery('code'))) {
        $client->authenticate($this->request->getQuery('code'));
        $this->request->Session()->write('access_token', $client->getAccessToken());
    }
    if ($this->request->Session()->check('access_token') && ($this->request->Session()->read('access_token'))) {
        $client->setAccessToken($this->request->Session()->read('access_token'));
    }
    if ($client->getAccessToken()) {
        $this->request->Session()->write('access_token', $client->getAccessToken());
        $oauth2 = new Google_Service_Oauth2($client);
        $user = $oauth2->userinfo->get();
        try {
            if (!empty($user)) {

                $result = $this->Admins->find('all')
                              ->where(['email' => $user['email']])
                              ->first();
                if ($result) {
                    $data = array();
                    $data['email'] = $user['email'];
                    $data['fname'] = $user['givenName'];
                    $data['lname'] = $user['familyName'];
                    $data['social_id'] = $user['id'];
                    $data['avatar'] = $user['picture'];
                    $data['link'] = $user['link'];
                    $data['uuid'] = Text::uuid();
                    $entity = $this->Admins->newEntity($data);

                    if ($this->Admins->save($entity)) {
                        $data['id'] = $entity->id;
                        $this->Auth->setUser($data);
                        $this->redirect($this->Auth->redirectUrl());
                    } else {
                        $this->Flash->error('Unable to connect to google');
                        #return $this->redirect(['action' => 'login']);
                    }
                }

            } else {
                $this->Flash->error('Unable to retrieve google data');
                #return $this->redirect(['action' => 'login']);
            }
        } catch (\Exception $e) {
            $this->Flash->error($e);
            #return $this->redirect(['action' => 'login']);
        }
    }
}

На мой взгляд

    <?= $this->Form->create() ?>
        <div class="form-group">
            <input type="text" class="form-control" placeholder="Username" required="" name="username">
        </div>
        <div class="form-group">
            <input type="password" class="form-control" placeholder="Password" required="" name="password">
        </div>
        <button type="submit" class="btn btn-default block full-width m-b">Login</button>

        <!--<a href="#"><small>Forgot password?</small></a>-->
        <a class="btn btn-block google btn-danger" href="<?= $this->Url->build(['action' => 'googlelogin']); ?>"> <i
            class="fa fa-google-plus modal-icons"></i> Login using Google Account </a>

</div>
    <?= $this->Form->end() ?>


  In My AppController


public function initialize()
{
    parent::initialize();
    #$this->loadComponent('Csrf');
    $this->loadComponent('RequestHandler', [
        'enableBeforeRedirect' => false,
    ]);
    $this->loadComponent('Flash');
    $this->viewBuilder()->setLayout('inspinia');
    $this->loadComponent('Auth', [
        'authenticate' => [
            'Form' => [
                'fields' => [
                    'username' => 'username',
                    'password' => 'password'
                ], 
                'userModel' => 'Admins'
            ]
        ],
        #'authError'  => __('Invalid username or password'),
        'loginRedirect' => [
            'controller' => 'Admins',
            'action' => 'dashboard'
        ],
        'logoutRedirect' => [
            'controller' => 'Admins',
            'action' => 'login',
            // 'home'
        ],
        'loginAction' => [
            'controller' => 'Admins',
            'action' => 'login'
        ],
        #'storage' => 'Session',
         //use isAuthorized in Controllers
        'authorize' => ['Controller'],
         // If unauthorized, return them to page they were just on
        'unauthorizedRedirect' => $this->referer()
    ]);

}

public function beforeFilter(Event $event){
    $this->viewBuilder()->setLayout('inspinia');
    $userId = "";
    if($this->Auth->user()){
        $userId = $this->Auth->user('id');
        $username = $this->Auth->user('username');
        $userFname = $this->Auth->user('fname');
        $userLname = $this->Auth->user('lname');
        $userRole = "";
    }

    if($userId) {
        $roles = TableRegistry::get('Roles');
        $userRole = $roles->get($this->Auth->user('role_id'))->name;
    }
    $this->set(compact('userId', 'username', 'userFname', 'userLname', 'userRole'));
}

public function isAuthorized($user)
{

    if (isset($user['role_id']) && $user['role_id'] === 1) {
        return true;
    }

    return false;
}

}

1 Ответ

0 голосов
/ 30 ноября 2018

Я решаю проблему с помощью cakephp / social-auth Вот ссылка на плагин

...