NAME
Mojolicious::Plugin::RESTRoutes - routing helpers for RESTful operations
VERSION
version 0.0100062
DESCRIPTION
This Mojolicious plugin adds some routing helpers for RESTful CRUD operations via HTTP to the app.
The routes are intended, but not restricted to be used by AJAX applications.
EXTENDS
METHODS
register
Adds the routing helpers. Is called by Mojolicious.
MOJOLICIOUS SHORTCUTS
rest_routes
Can be used to easily generate the needed RESTful routes for a resource.
$self->rest_routes(name => 'user');
# Installs the following routes (given that $r->namespaces == ['My::Mojo']):
# GET /api/users --> My::Mojo::User::rest_list()
# POST /api/users --> My::Mojo::User::rest_create()
# GET /api/users/:userid --> My::Mojo::User::rest_show()
# PUT /api/users/:userid --> My::Mojo::User::rest_update()
# DELETE /api/users/:userid --> My::Mojo::User::rest_remove()
The target controller has to implement the following methods:
rest_list
rest_create
rest_show
rest_update
rest_remove
There are some options to control the route creation:
Parameters
- name
-
The name of the resource, e.g. a "user", a "book" etc. This name will be used to build the route URL as well as the controller name (see example above).
- readonly
-
(optional) if set to 1, no create/update/delete routes will be created
- controller
-
Default behaviour is to use the resource name to build the CamelCase controller name (this is done by Mojolicious::Routes::Route). You can change this by directly specifying the controller's name via the controller attribute.
Note that you have to give the real controller class name (i.e. CamelCased or whatever you class name looks like) including the full namespace.
$self->rest_routes(name => 'user', controller => 'My::Mojo::Person'); # Installs the following routes: # GET /api/users --> My::Mojo::Person::rest_list() # ...
AUTHOR
Jens Berthold <cpan-mp-restroutes@jebecs.de>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2013 by Jens Berthold.
This is free software, licensed under:
The MIT (X11) License