• 0 Vote(s) - 0 Average
  • 1
  • 2
  • 3
  • 4
  • 5
Auth/myth - before filter - redirect login

#1
Hi,
I seem to be getting stuck in an infinite loop trying to redirect to the myth:auth login page.  I have set up a filter, below. 

In my browser if I navigate to http://mydomain/login the login page is shown, as expected.

But if i navigate to http://mydomain/   i get caught in an infinite loop?

I do not have any routes configured for login, or anything remotely like it.

Can anyone point me in the right direction (excuse the pun)?

PHP Code:
public function before(RequestInterface $request) {    
        if(
logged_in()!=true && uri_string()!='login') {        
                return 
redirect('login');
        }
            
    
Reply

#2
You can check like this to see if they are logged in.

PHP Code:
$authenticate Services::authentication();

// if no user is logged in then send to the login form
if ( ! $authenticate->check())
{
    session()->set('redirect_url'current_url());

    return redirect('login');


This is from a filter.
What did you Try? What did you Get? What did you Expect?

Joined CodeIgniter Community 2009.  ( Skype: insitfx )
Reply

#3
(08-03-2020, 09:35 AM)InsiteFX Wrote: You can check like this to see if they are logged in.

PHP Code:
$authenticate Services::authentication();

// if no user is logged in then send to the login form
if ( ! $authenticate->check())
{
    session()->set('redirect_url'current_url());

    return redirect('login');


This is from a filter.
 Thanks InsiteFX

But something wired is happenning.

As advised I setup my filter
PHP Code:
<?php namespace Config;

use 
CodeIgniter\Config\BaseConfig;

class 
Filters extends BaseConfig
{
    
// Makes reading things below nicer,
    // and simpler to change out script that's used.
    
public $aliases = [
        
'csrf'        => \CodeIgniter\Filters\CSRF::class,
        
'toolbar'    => \CodeIgniter\Filters\DebugToolbar::class,
        
'honeypot'    => \CodeIgniter\Filters\Honeypot::class,
        
'CheckStatus'    => \CodeIgniter\Filters\CheckStatus::class,
        
    ];

    
// Always applied before every request
    
public $globals = [
        
'before' => [
        
'CheckStatus',
            
//'honeypot',
            // 'csrf',
        
],
        
'after'  => [
            
'toolbar',
            
//'honeypot'
        
],
    ]; 
then in the Filters folder I created the file CheckStatus.php with the code you suggested

PHP Code:
<?php namespace App\Filters;

use 
CodeIgniter\HTTP\RequestInterface;
use 
CodeIgniter\HTTP\ResponseInterface;
use 
CodeIgniter\Filters\FilterInterface;

class 
CheckStatus implements FilterInterface {
    
    public function 
before(RequestInterface $request) {    
        
        
$authenticate Services::authentication();

        
// if no user is logged in then send to the login form
        
if ( ! $authenticate->check())
        {
            
session()->set('redirect_url'current_url());
        
            return 
redirect('login');
        } 
            
    }

    public function after(RequestInterface $requestResponseInterface $response) {
    }

but I am getting an exception.  And I've tried every which way to try and resolve this.  Any ideas?
[img][/img]
Reply

#4
Your missing the arguments.

PHP Code:
public function before(RequestInterface $request$arguments null

The arguments were added to version 4.0.4

Not sure if that would cause your problem but I would fix that first

The after also takes the arguments.
What did you Try? What did you Get? What did you Expect?

Joined CodeIgniter Community 2009.  ( Skype: insitfx )
Reply

#5
(08-04-2020, 10:52 AM)InsiteFX Wrote: Your missing the arguments.

PHP Code:
public function before(RequestInterface $request$arguments null

The arguments were added to version 4.0.4

Not sure if that would cause your problem but I would fix that first

The after also takes the arguments.

Thanks for your help, but I am still getting the same exception after adding the arguments to both before and after functions.  Very wierd!!
Reply

#6
This is the login filter for Myth::Auth

PHP Code:
<?php namespace Myth\Auth\Filters;

use 
Config\Services;
use 
CodeIgniter\HTTP\RequestInterface;
use 
CodeIgniter\HTTP\ResponseInterface;
use 
CodeIgniter\Filters\FilterInterface;

class 
LoginFilter implements FilterInterface
{
    
/**
     * Do whatever processing this filter needs to do.
     * By default it should not return anything during
     * normal execution. However, when an abnormal state
     * is found, it should return an instance of
     * CodeIgniter\HTTP\Response. If it does, script
     * execution will end and that Response will be
     * sent back to the client, allowing for error pages,
     * redirects, etc.
     *
     * @param \CodeIgniter\HTTP\RequestInterface $request
     * @param array|null                         $params
     *
     * @return mixed
     */
    
public function before(RequestInterface $request$params null)
    {
        if (! 
function_exists('logged_in'))
        {
            
helper('auth');
        }

        
$current = (string)current_url(true)
            ->
setHost('')
            ->
setScheme('')
            ->
stripQuery('token');

        
// Make sure this isn't already a login route
        
if (in_array((string)$current, [route_to('login'), route_to('forgot'), route_to('reset-password'), route_to('register')]))
        {
            return;
        }

        
// if no user is logged in then send to the login form
        
$authenticate Services::authentication();
        if (! 
$authenticate->check())
        {
            
session()->set('redirect_url'current_url());
            return 
redirect('login');
        }
    }

    
//--------------------------------------------------------------------

    /**
     * Allows After filters to inspect and modify the response
     * object as needed. This method does not allow any way
     * to stop execution of other after filters, short of
     * throwing an Exception or Error.
     *
     * @param \CodeIgniter\HTTP\RequestInterface  $request
     * @param \CodeIgniter\HTTP\ResponseInterface $response
     * @param array|null                          $arguments
     *
     * @return void
     */
    
public function after(RequestInterface $requestResponseInterface $response$arguments null)
    {

    }

    
//--------------------------------------------------------------------


.app/Config/Filters

PHP Code:
'login'      => \Myth\Auth\Filters\LoginFilter::class, 

I would make sure that your using the version CI 4 4.0.4
Or get the developer version from here.

CodeIgniter Developer Version
What did you Try? What did you Get? What did you Expect?

Joined CodeIgniter Community 2009.  ( Skype: insitfx )
Reply

#7
Thank you very much. But (I think you knew there was a but).

When I run composer update i get the following, and codeigniter.php (const CI_VERSION = '4.0.3');

Does this mean a total uninstall and then a clean install ??? (i really hope not :-))

Loading composer repositories with package information
Updating dependencies (including require-dev)
Nothing to install or update
Generating autoload files

Fatal error: Uncaught Error: Class 'Composer\XdebugHandler\XdebugHandler' not found in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer:16
Stack trace:
#0 C:\ProgramData\ComposerSetup\bin\composer.phar(24): require()
#1 {main}
thrown in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer on line 16
PHP Fatal error: Uncaught Error: Class 'Composer\XdebugHandler\XdebugHandler' not found in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer:16
Stack trace:
#0 C:\ProgramData\ComposerSetup\bin\composer.phar(24): require()
#1 {main}
thrown in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer on line 16
Script @composer dump-autoload handling the post-update-cmd event returned with error code 255
Reply

#8
Yes because they made changes to the app folder! What I do is backup the project to another folder then I can open both files in
my editor and make the changes file by file.
What did you Try? What did you Get? What did you Expect?

Joined CodeIgniter Community 2009.  ( Skype: insitfx )
Reply

#9
Thank You. I know we went a bit off topic ...

Hopefully, I can get the login redirect to work :-)
Reply

#10
Hi, As suggested I backed up my project and tried to install version CI 4 4.0.4 (instead of update) and got a very similar error. I also noticed there was not a system or vendor folder.

C:\mydrive\myfolder>composer create-project codeigniter4/appstarter --no-dev
Installing codeigniter4/appstarter (v4.0.4)
- Installing codeigniter4/appstarter (v4.0.4): Loading from cache
Created project in C:\mydrive\myfolder\appstarter
Loading composer repositories with package information
Updating dependencies
Package operations: 5 installs, 0 updates, 0 removals
- Installing psr/log (1.1.3): Loading from cache
- Installing laminas/laminas-zendframework-bridge (1.0.4): Loading from cache
- Installing laminas/laminas-escaper (2.6.1): Loading from cache
- Installing kint-php/kint (3.3): Loading from cache
- Installing codeigniter4/framework (v4.0.4): Loading from cache
Writing lock file
Generating autoload files

Fatal error: Uncaught Error: Class 'Composer\XdebugHandler\XdebugHandler' not found in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer:16
Stack trace:
#0 C:\ProgramData\ComposerSetup\bin\composer.phar(24): require()
#1 {main}
thrown in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer on line 16
PHP Fatal error: Uncaught Error: Class 'Composer\XdebugHandler\XdebugHandler' not found in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer:16
Stack trace:
#0 C:\ProgramData\ComposerSetup\bin\composer.phar(24): require()
#1 {main}
thrown in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer on line 16
Script @composer dump-autoload handling the post-update-cmd event returned with error code 255





If I try the install WITHOUT --no-dev option I get simialr error


C:\mydrive\myfolder>composer create-project codeigniter4/appstarter
Installing codeigniter4/appstarter (v4.0.4)
- Installing codeigniter4/appstarter (v4.0.4): Loading from cache
Created project in C:\mydrive\myfolder\appstarter
Loading composer repositories with package information
Updating dependencies (including require-dev)
Package operations: 36 installs, 0 updates, 0 removals
- Installing psr/log (1.1.3): Loading from cache
- Installing laminas/laminas-zendframework-bridge (1.0.4): Loading from cache
- Installing laminas/laminas-escaper (2.6.1): Loading from cache
- Installing kint-php/kint (3.3): Loading from cache
- Installing codeigniter4/framework (v4.0.4): Loading from cache
- Installing fzaninotto/faker (dev-master 5337ce5): Cloning 5337ce5261
Failed to download fzaninotto/faker from source: Failed to clone https://github.com/fzaninotto/Faker.git, git was not found, check that it is installed and in your PATH env.

'git' is not recognized as an internal or external command,
operable program or batch file.

Now trying to download from dist
- Installing fzaninotto/faker (dev-master 5337ce5): Loading from cache
- Installing mikey179/vfsstream (v1.6.8): Loading from cache
- Installing sebastian/version (2.0.1): Loading from cache
- Installing sebastian/type (1.1.3): Loading from cache
- Installing sebastian/resource-operations (2.0.1): Loading from cache
- Installing sebastian/recursion-context (3.0.0): Loading from cache
- Installing sebastian/object-reflector (1.1.1): Loading from cache
- Installing sebastian/object-enumerator (3.0.3): Loading from cache
- Installing sebastian/global-state (3.0.0): Loading from cache
- Installing sebastian/exporter (3.1.2): Loading from cache
- Installing sebastian/environment (4.2.3): Loading from cache
- Installing sebastian/diff (3.0.2): Loading from cache
- Installing sebastian/comparator (3.0.2): Loading from cache
- Installing phpunit/php-timer (2.1.2): Loading from cache
- Installing phpunit/php-text-template (1.2.1): Loading from cache
- Installing phpunit/php-file-iterator (2.0.2): Loading from cache
- Installing theseer/tokenizer (1.2.0): Loading from cache
- Installing sebastian/code-unit-reverse-lookup (1.0.1): Loading from cache
- Installing phpunit/php-token-stream (3.1.1): Loading from cache
- Installing phpunit/php-code-coverage (7.0.10): Loading from cache
- Installing doctrine/instantiator (1.3.1): Loading from cache
- Installing phpdocumentor/reflection-common (2.2.0): Loading from cache
- Installing symfony/polyfill-ctype (v1.18.1): Loading from cache
- Installing webmozart/assert (1.9.1): Loading from cache
- Installing phpdocumentor/type-resolver (1.3.0): Loading from cache
- Installing phpdocumentor/reflection-docblock (5.2.0): Loading from cache
- Installing phpspec/prophecy (1.11.1): Loading from cache
- Installing phar-io/version (2.0.1): Loading from cache
- Installing phar-io/manifest (1.0.3): Loading from cache
- Installing myclabs/deep-copy (1.10.1): Loading from cache
- Installing phpunit/phpunit (8.5.8): Loading from cache
kint-php/kint suggests installing kint-php/kint-twig (Provides d() and s() functions in twig templates)
kint-php/kint suggests installing kint-php/kint-js (Provides a simplified dump to console.log())
kint-php/kint suggests installing symfony/polyfill-mbstring (Replacement for ext-mbstring if missing)
kint-php/kint suggests installing symfony/polyfill-iconv (Replacement for ext-iconv if missing)
sebastian/global-state suggests installing ext-uopz (*)
sebastian/environment suggests installing ext-posix (*)
phpunit/php-code-coverage suggests installing ext-xdebug (^2.7.2)
phpunit/phpunit suggests installing phpunit/php-invoker (^2.0.0)
phpunit/phpunit suggests installing ext-soap (*)
phpunit/phpunit suggests installing ext-xdebug (*)
Writing lock file
Generating autoload files

Fatal error: Uncaught Error: Class 'Composer\XdebugHandler\XdebugHandler' not found in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer:16
Stack trace:
#0 C:\ProgramData\ComposerSetup\bin\composer.phar(24): require()
#1 {main}
thrown in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer on line 16
PHP Fatal error: Uncaught Error: Class 'Composer\XdebugHandler\XdebugHandler' not found in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer:16
Stack trace:
#0 C:\ProgramData\ComposerSetup\bin\composer.phar(24): require()
#1 {main}
thrown in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/bin/composer on line 16
Script @composer dump-autoload handling the post-update-cmd event returned with error code 255


Any thoughts?
Reply


Digg   Delicious   Reddit   Facebook   Twitter   StumbleUpon  


  Theme © 2014 iAndrew  
Powered By MyBB, © 2002-2020 MyBB Group.