/perl-mvc-neaf

Not Even A (Web Application) Framework - by the lazy, for the lazy

Primary LanguagePerl

NAME

MVC::Neaf [ni:f] stands for Not Even A Framework.

OVERVIEW

The following code can be run as a PSGI application or CGI script:

    use strict;
    use warnings;
    use MVC::Neaf;

    get + post "/" => sub {
        my $req = shift;

        return {
            -view     => 'TT',
            -template => \'Hello, [% name %]!',
            -type     => 'text/plain',
            name      => $req->param( name => qr/\w+/, "Stranger" ),
        };
    };

    neaf->run;

Just like many other frameworks, Neaf organises an application into a prefix tree of routes. Each route has a handler sub which receives one and only argument - a request object.

The request contains everything the application needs to know about the outside world.

The handler must either return a hash for rendering, or die. A 3-digit exception is a valid way of returning a configurable error page.

The return hash may contain dash-prefixed keys to control Neaf itself. For instance, the default view is JSON-based but adding

    -view => 'TT', -template => 'my.tpl'

to the hash would result in using Template::Toolkit instead.

NOTABLE FEATURES

  • Mandatory validation - parameters and cookies are always regex-checked.

  • Forms that validate a bunch of input parameters, additionally producing hashes of errors and raw values for resubmission.

  • Path-based defaults that can be overridden in route definition or by controller itself:

      neaf default => { -view => 'JS', version => $VERSION }, path => '/api';
    
  • Hooks that may be executed at different stages:

      neaf pre_logic => sub {
          my $req = shift;
          die 403 unless $req->session->{is_admin};
      }, path => '/admin';
    
  • Easy CLI debugging - see perl myapp.pl --help

See examples for more.

INSTALLATION

To install this module, run the following commands:

    perl Makefile.PL
    make
    make test
    make install

BUGS

This package is still under heavy development (with a test coverage of about 80% though).

Use github or CPAN RT to report bugs and propose features.

Bug reports, feature requests, and overall critique are welcome.

CONTRIBUTING TO THIS PROJECT

See STYLE.md for the style guide.

See CHECKLIST if you plan to release a version.

See TODO for a rough development plan. It changes rapidly though.

LICENSE AND COPYRIGHT

Copyright 2016-2019 Konstantin S. Uvarin aka KHEDIN

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.