Query: web::dispatch::httpmethods
OS: debian
Section: 3pm
Format: Original Unix Latex Style Formatted with HTML and a Horizontal Scroll Bar
Web::Dispatch::HTTPMethods(3pm) User Contributed Perl Documentation Web::Dispatch::HTTPMethods(3pm)NAMEWeb::Dispatch::HTTPMethods - Helpers to make RESTFul Dispatchers EasierSYNOPSISpackage MyApp:WithHTTPMethods; use Web::Simple; use Web::Dispatch::HTTPMethods; sub as_text { [200, ['Content-Type' => 'text/plain'], [$_[0]->{REQUEST_METHOD}, $_[0]->{REQUEST_URI}] ] } sub dispatch_request { sub (/get) { GET { as_text(pop) } }, sub (/get-head) { GET { as_text(pop) } HEAD { [204,[],[]] }, }, sub (/get-post-put) { GET { as_text(pop) } ## NOTE: no commas separating http methods POST { as_text(pop) } PUT { as_text(pop) } }, }DESCRIPTIONExports the most commonly used HTTP methods as subroutine helps into your Web::Simple based application. Additionally adds an automatic HTTP code 405 "Method Not Allow" if none of the HTTP methods match for a given dispatch and also adds a dispatch rule for "HEAD" if no "HEAD" exists but a "GET" does (in which case the "HEAD" returns the "GET" dispatch with an empty body.) We also add at the end of the chain support for the OPTIONS method (if you do not add one yourself. This defaults to http 200 ok + Allows http headers. Also we try to set correct HTTP headers such as "Allows" as makes sense based on your dispatch chain. The following dispatch chains are basically the same: sub dispatch_request { sub (/get-http-methods) { GET { [200, ['Content-Type' => 'text/plain'], ['Hello World']] } }, sub(/get-classic) { sub (GET) { [200, ['Content-Type' => 'text/plain'], ['Hello World']] }, sub (HEAD) { [200, ['Content-Type' => 'text/plain'], []] }, sub (OPTIONS) { [200, ['Content-Type' => 'text/plain', Allows=>'GET,HEAD,OPTIONS'], []]; }, sub () { [405, ['Content-Type' => 'text/plain', Allows=>'GET,HEAD,OPTIONS'], ['Method Not Allowed']] }, } } The idea here is less boilerplate to distract the reader from the main point of the code and also to encapsulate some best practices. NOTE You currently cannot mix http method style and prototype sub style in the same scope, as in the following example: sub dispatch_request { sub (/get-head) { GET { ... } sub (HEAD) { ... } }, } If you try this our code will notice and issue a "die". If you have a good use case please bring it to the authors. EXPORTS This automatically exports the following subroutines: GET PUT POST HEAD DELETE OPTIONSAUTHORSee Web::Simple for AUTHORCONTRIBUTORSSee Web::Simple for CONTRIBUTORSCOPYRIGHTSee Web::Simple for COPYRIGHTLICENSESee Web::Simple for LICENSE perl v5.14.2 2012-05-07 Web::Dispatch::HTTPMethods(3pm)
Related Man Pages |
---|
post(1) - redhat |
get(1) - centos |
http::request::common(3) - mojave |
http::request::common(3) - osx |
web::dispatch::httpmethods(3pm) - debian |
Similar Topics in the Unix Linux Community |
---|
Spammers: Advice being sought |
Drupal Content Management System JumpBox 1.0.6 (Default branch) |
change field content awk |
separating comma delimited words |
search needed part in text file (awk?) |