package MyApp::Controller::Root;

use strict;
use warnings;
use base 'Catalyst::Controller';

# Sets the actions in this controller to be registered with no prefix
# so they function identically to actions created in
__PACKAGE__->config->{namespace} = '';

=head1 NAME

MyApp::Controller::Root - Root Controller for MyApp


[enter your description here]

=head1 METHODS


=head2 default


sub default : Private {
    my ( $self, $c ) = @_;

    # Hello World
    $c->response->body( $c->welcome_message );

=head2 end

Attempt to render a view, if needed.


sub end : ActionClass('RenderView') {}

=head2 auto

Check if there is a user and, if not, forward to login page


# Note that 'auto' runs after 'begin' but before your actions and that
# 'auto' "chain" (all from application path to most specific class are run)
# See the 'Actions' section of 'Catalyst::Manual::Intro' for more info.
sub auto : Private {
    my ($self, $c) = @_;

    # Allow unauthenticated users to reach the login page.  This
    # allows anauthenticated users to reach any action in the Login
    # controller.  To lock it down to a single action, we could use:
    #   if ($c->action eq $c->controller('Login')->action_for('index'))
    # to only allow unauthenticated access to the C<index> action we
    # added above.
    if ($c->controller eq $c->controller('Login')) {
        return 1;

    # If a user doesn't exist, force login
    if (!$c->user_exists) {
        # Dump a log message to the development server debug output
        $c->log->debug('***Root::auto User not found, forwarding to /login');
        # Redirect the user to the login page
        # Return 0 to cancel 'post-auto' processing and prevent use of application
        return 0;

    # User found, so return 1 to continue with processing after this 'auto'
    return 1;

=head1 AUTHOR


=head1 LICENSE

This library is free software, you can redistribute it and/or modify
it under the same terms as Perl itself.