NAME Web::Machine - A Perl port of Webmachine VERSION version 0.16 SYNOPSIS use strict; use warnings; use Web::Machine; { package HelloWorld::Resource; use strict; use warnings; use parent 'Web::Machine::Resource'; sub content_types_provided { [{ 'text/html' => 'to_html' }] } sub to_html { q{<html> <head> <title>Hello World Resource</title> </head> <body> <h1>Hello World</h1> </body> </html>} } } Web::Machine->new( resource => 'HelloWorld::Resource' )->to_app; DESCRIPTION Web::Machine provides a RESTful web framework modeled as a state machine. You define one or more resource classes. Each resource represents a single RESTful URI end point, such as a user, an email, etc. The resource class can also be the target for POST requests to create a new user, email, etc. Each resource is a state machine, and each request for a resource is handled by running the request through that state machine. Web::Machine is built on top of Plack, but it handles the full request and response cycle. See Web::Machine::Manual for more details on using Web::Machine in general, and how Web::Machine and Plack interact. This is a port of Webmachine <https://github.com/basho/webmachine>, actually it is much closer to the Ruby version <https://github.com/seancribbs/webmachine-ruby>, with a little bit of the JavaScript version <https://github.com/tautologistics/nodemachine> and even some of the Python version <https://github.com/benoitc/pywebmachine> thrown in for good measure. You can learn a bit about Web::Machine's history from the slides for my 2012 YAPC::NA talk <https://speakerdeck.com/stevan_little/rest-from-the-trenches>. To learn more about Webmachine, take a look at the links in the SEE ALSO section. METHODS NOTE: This module is a Plack::Component subclass and so follows the interface set forward by that module. new( resource => $resource_classname, ?resource_args => $arg_list, ?tracing => 1|0, ?streaming => 1|0, ?request_class => $request_class ) The constructor expects to get a $resource_classname, which it will use to load and create an instance of the resource class. If that class requires any additional arguments, they can be specified with the resource_args parameter. The contents of the resource_args parameter will be made available to the init() method of Web::Machine::Resource. The new method can also take an optional tracing parameter which it will pass on to Web::Machine::FSM and an optional streaming parameter, which if true will run the request in a PSGI <http://plackperl.org/> streaming response. This can be useful if you need to run your content generation asynchronously. The optional request_class parameter accepts the name of a module that will be used as the request object. The module must be a class that inherits from Plack::Request. Use this if you have a subclass of Plack::Request that you would like to use in your Web::Machine::Resource. inflate_request( $env ) This takes a raw PSGI $env and inflates it into a Plack::Request instance. By default this also uses HTTP::Headers::ActionPack to inflate the headers of the request to be complex objects. create_fsm This will create the Web::Machine::FSM object to run. It will get passed the value of the tracing constructor parameter. create_resource( $request ) This will create the Web::Machine::Resource instance using the class specified in the resource constructor parameter. It will pass in the $request object and call new_response on the $request object to get a Plack::Response instance. finalize_response( $response ) Given a $response which is a Plack::Response object, this will finalize it and return a raw PSGI response. call( $env ) This is the call method overridden from the Plack::Component superclass. DEBUGGING If you set the WM_DEBUG environment variable to 1 we will print out information about the path taken through the state machine to STDERR. If you set WM_DEBUG to diag then debugging information will be printed using Test::More's diag() sub instead. SEE ALSO The diagram - https://github.com/Webmachine/webmachine/wiki/Diagram Original Erlang - https://github.com/basho/webmachine Ruby port - https://github.com/seancribbs/webmachine-ruby Node JS port - https://github.com/tautologistics/nodemachine Python port - https://github.com/benoitc/pywebmachine 2012 YAPC::NA slides - https://speakerdeck.com/stevan_little/rest-from-the-trenches an elaborate machine is indispensable: a blog post by Justin Sheehy - http://blog.therestfulway.com/2008/09/webmachine-is-resource-server-for-web.html Resources, For Real This Time (with Webmachine): a video by Sean Cribbs - http://www.youtube.com/watch?v=odRrLK87s_Y AUTHORS * Stevan Little <stevan@cpan.org> * Dave Rolsky <autarch@urth.org> CONTRIBUTORS * Andreas Marienborg <andreas.marienborg@gmail.com> * Andrew Nelson <anelson@cpan.org> * Arthur Axel 'fREW' Schmidt <frioux@gmail.com> * Carlos Fernando Avila Gratz <cafe@q1software.com> * Fayland Lam <fayland@gmail.com> * George Hartzell <hartzell@alerce.com> * Gregory Oschwald <goschwald@maxmind.com> * Jesse Luehrs <doy@tozt.net> * John SJ Anderson <genehack@genehack.org> * Mike Raynham <enquiries@mikeraynham.co.uk> * Mike Raynham <mike.raynham@spareroom.co.uk> * Nathan Cutler <ncutler@suse.cz> * Olaf Alders <olaf@wundersolutions.com> * Thomas Sibley <tsibley@cpan.org> COPYRIGHT AND LICENSE This software is copyright (c) 2015 by Infinity Interactive, Inc.. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.