NAME

WWW::REST::Apid - Generic REST API Module

SYNOPSIS

use WWW::REST::Apid;
use Authen::Simple::LDAP;

my $server = WWW::REST::Apid->new(
 host => 'localhost',
 port => 8080,
 apiname => 'my api',
 apiversion => '1.0',
 authbasic => 1,
 sublogin => sub { 
                    my($user, $pass) = @_;
                    my $ldap = Authen::Simple::LDAP->new( 
                    host    => 'ldap.company.com',
                    basedn  => 'ou=People,dc=company,dc=net'
                  );
                  if ( $ldap->authenticate( $user, $pass ) ) {
                    return 1; # ok
                  }
                  return 0; # fail
                },
 log => sub { my $msg = shift; syslog('info', $msg); },
 foreground => 0,
);

$server->mapuri(path => '/', doauth => 1, handler => sub { return { msg => 'ok' } });

$server->run();

DESCRIPTION

The WWW::REST::Apid module can be used to implement a REST API for almost anything.

If you want fast and easy results, please try the apid daemon, which is shipped with the WWW::REST::Apid distribution, first.

METHODS

new

The new method returns a new WWW::REST::Apid object. All parameters are optional and will be preset with reasonable defaults.

Supported parameters:

host

The hostname or ip address where the daemon will listen to. Default: 'localhost'.

port

The TCP port to use. Default: 8080.

apiname

The name of your API.

apiversion

The version of your API.

authbasic

Use HTTP Basic Authentication. The parameter defines the realm.

authuri

Use HTTP POST Authentication with login uri redirect for unauthenticated users.

sublogin

Expects a closure as parameter. The closure gets two parameters supplied during the login process: the username and the password supplied by the client in clear text.

If authentication shall succeed, return 1, otherwise 0.

Default: returns always false.

log

Logging function to use, expects a closure as parameter. One parameter will be given to the closure: the log message. Put it where ever you want.

Default: ignore.

foreground

If set to true, the daemon doesn't fork a child process for new incoming connections, which it does otherwise. If you work with a preforking system as Any::Daemon::HTTP, then set it to true. If you use something like Generic::Daemon, set it to false.

Default: false.

sslcrt AND sslkey

If both are given, files are expected. sslcrt must be a X509 PEM encoded SSL certificate, sslkey must be a PEM encoded SSL unencrypted private key for the certificate.

IO::Socket::SSL-new() parameters>

Any parameter starting with 'SSL' will be fed unaltered to IO::Socket::SSL->new().

lateconfig

Supply any of the above mentioned parameters at some later point, which allows to re-configure certain aspects of the daemon. Some variables cannot be changed once the daemon runs, especially the host and port variables.

Expects the parameters as a hash. Example:

$server->lateconfig(authuri => '/login');

mapuri

The mapuru method is the heart of the module. It expects hash parameters.

Example:

$server->mapuri(path => '/', doauth => 1, handler => sub { return { msg => 'ok' } });

The following parameters are supported:

path

Required: the uri path which shall be mapped to some action.

handler

Required: closure is expected as parameter. The closure gets as its only argument a hash reference supplied which contains data posted by a client (either via POST, PUT or GET query params).

It is expected to return a hash reference with results again.

JSON conversion will be done automatically.

You can access the current HTTP::Request object within the handler by using the variable $req and the HTTP::Response object with $res.

doauth

Optional: turn on authentication for this particular path.

The sublogin closure must be imlemented.

valid

Optional: a hash reference describing the input validation using the notation of Data::Validate::Struct. If defined, data posted by clients will be validated and if found to be invalid, an error will be returned.

run

Finally, start the server.

This method never returns.

AUTHOR

T.v.Dein <tlinden@cpan.org>

BUGS

Report bugs to http://rt.cpan.org/NoAuth/ReportBug.html?Queue=WWW-REST-Apid

SEE ALSO

apid HTTP::Daemon HTTP::Daemon::SSL Daemon::Generic Config::General Data::Validate::Struct

COPYRIGHT

Copyright (c) 2014 by T.v.Dein <tlinden@cpan.org>. All rights reserved.

LICENSE

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

VERSION

apid Version 0.05.