Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to go back to referer page in CakePHP after login

I have a problem on going back to referer page:

first url: http://site.com/venue/apartments/1564/venue-name
referer url: null

In this page I can edit stuff inside, so I have a login button to go to the login page, after a successful login, I would like to turn back to the first url.

second url: http://site.com/users/login
referer url: http://site.com/venue/apartments/1564/venue-name

when I try to login, due to the CakePHP action rules, i have to refresh the login page to check the credentials, the problem starts here:

third url: http://site.com/users/login
referer url: http://site.com/users/login

by refreshing the page, and checking the credentials in the login action of users controller I get as refer the same page where I was before, and now I can't going back to the first url.

I tried some solution by setting a session variable in the AppController which checks if I'm not in the login action page and doing this:

AppController.php

public function beforeFilter () {
    $this->setRedirect();
}

public function setRedirect () {
    if ($this->request->params['controller'] != 'users' && $this->request->params['action'] != 'login') {
        $this->Session->write('redir', array('controller'=>$this->request->params['controller'], 'action'=>$this->request->params['action'], implode($this->request->params['pass'], '/')));
    }
}

By testing the session var with debug($this->Session->write('redir')); everything would seem to works perfect until I go to the login action:

UsersController.php

public function login () {
    if ($this->request->is ('post')){
        if ($this->Auth->login()) {
            $redir = $this->Session->read('redir');
            if (!empty($redir)) {
                $this->redirect ($redir);
            } else {
                $this->redirect ($this->Auth->redirect());
            }
        }
    }
}

Doing this break the application and if I debug($redir); var i get:

array(
    'controller' => 'js',
    'action' => 'jquery',
    (int) 0 => 'plugin/jquery.validata.1.7.min' // just a jquery plugin loaded in default.ctp
)

instead of

array(
    'controller' => 'venue',
    'action' => 'apartments',
    (int) 0 => '1564/venue-name'
)

If I debug($redir); in any other view of the entire site, everything works well and I get the right data.

I thought in some kind of Session protection routine for $this->Auth->login() action but it's totally nonsense for me.

How can I just redirect the user logged to the last page which isn't the login view page?

like image 635
vitto Avatar asked Jan 04 '13 19:01

vitto


2 Answers

Have you tried this: $this->redirect(Controller::referer());?

I'd have to reread your whole question to be sure, but this should also work: $this->redirect( $this->referer() );

like image 114
emersonthis Avatar answered Oct 23 '22 02:10

emersonthis


I used sessions to keep the last url accessed and if the login is successful the user will be redirected to it.

First in AppController.php I save in session the url, except for login and logout actions:

public function beforeFilter() {
    $url = Router::url(NULL, true); //complete url
    if (!preg_match('/login|logout/i', $url)){
        $this->Session->write('lastUrl', $url);
    }
}

In the UserController.php for login action I have the following code:

public function login() {
    if ($this->request->is('post')) {
        if ($this->Auth->login()) {
            if ($this->Session->read('lastUrl')){
                $this->redirect($this->Session->read('lastUrl'));
                exit;
            }else{
                return $this->redirect($this->Auth->redirect());
            }
        }
        $this->Session->setFlash(__('Invalid username or password'));
    }
}
like image 45
Silvanu Avatar answered Oct 23 '22 03:10

Silvanu