Catalyst-Controller-HTML-FormFu-2.02/000755 000765 000024 00000000000 13110553642 017541 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/Changes000644 000765 000024 00000007167 13110553642 021047 0ustar00nigelstaff000000 000000 2.02 2017-05-22 13:20:48+01:00 Europe/London - Stop using Test::Aggregate::Nested for tests - RT#121792 2.01 2016-06-24 - Version numbering now handled in dzil - Example and internal code uses Moose conventions 2.00 2016-06-01 - Silence MooseX::Attribute::Chained warnings with HTML::FormFu 2.0+. - Packaging tweaks including adding travis CI support - Updated version to 2.x to match other modules, requires HTML-FormFu v2.00 1.00 2013-12-16 - Updated for HTML-FormFu v1.00 - Only require MultiForm at runtime when needed 0.09004 2012-09-11 - switch from MooseX::ChainedAccessors to MooseX::Attribute::Chained 0.09003 2011-05-12 - depend on HTML::FormFu 0.09 0.09002 2011-05-11 - fixes #67404 (Missing dependency on MooseX::ChainedAccessors) - fixes #67571 (Minimum requirement for HTML::FormFu is 0.9002) actually it just requires MooseX::ChainedAccessors - hopefully fixes 539965f0-7b0f-11e0-b729-7181c0b02281 0.09001 2011-05-10 - fixed problem with build_per_context_instance that caused errors like http://paste.scsys.co.uk/102966 0.09000 2011-03-29 - Fix mem leak - Resolve Moose extends/runtime bug RT #55780 - fix RequestToken classes to work with new Moosified HTML-FormFu 0.08002 2010-09-22 - Incompatible Change: removed all previously deprecated methods. 0.06001 2009-12-10 - Test setting __uri_for(x)__ in a config file. 0.06000 2009-11-25 - MultiForm actions now also always stash $multi->current_form to $c->stash->{form}. (key-name configurable via 'form_stash' config option). - New method suffixes such as "_FORM_VALID", "_FORM_SUBMITTED" to allow blocks of code that will only be run under certain circumstances. 0.05000 2009-07-06 - Fix RequestToken to be a hidden field. - Fix compatibility problem with moosified controllers. - use tests_recursive() so all tests are run correctly. 0.04003 2009-04-20 - Fix missing prereqs 0.04002 2009-04-20 - Switch to use MRO::Compat 0.04001 2009-04-15 - New RequestToken feature to stop double-submissions of data. - Silence "Reference is already weak" warnings. - Add distribution description to pod (RT #41568) 0.03007 2008-12-08 - Bump required version no. of HTML-FormFu to 0.03007 0.03006 2008-12-03 - Deprecated config setting $config->{config_file_path} use $config->{constructor}{config_file_path} instead. - Bumped HTML-FormFu prereq - need 0.03004 for load_config_filestem() support. 0.03004 2008-09-03 - 'config_file_ext' config setting has been removed. - Automatically search for form config files with any extension supported by Config::Any. - Add __config()__ callback. - Support filestems (without extensions) in the FormConfig('file') attribute syntax. - Forms returned by form() now have the query set with the Catalyst request object. - Switched from ACCEPT_CONTEXT to using Catalyst::Component::InstancePerContext - recommended by mst. - Changed config examples to Config::General, to match Catalyst's core documentation. 0.03000 2008-06-19 - Documented 'model_stash' option. - New Multi* actions - not documented yet - need further testing. 0.02000 2007-12-12 - Only set INCLUDE_PATH if it's not already set, and if 'root/formfu' exists. - Use of $form->render_class_args() changed to tt_args() - Added support for expanding __path_to()__ in config callback 0.01002 2007-09-12 - No longer use HTML::FormFu::Preload - tradeoff CPU for RAM - Fix circular reference / memory leak 0.01001 2007-08-22 - First CPAN release Catalyst-Controller-HTML-FormFu-2.02/dist.ini000644 000765 000024 00000004073 13110553642 021211 0ustar00nigelstaff000000 000000 name = Catalyst-Controller-HTML-FormFu author = Carl Franks license = Perl_5 copyright_holder = Carl Franks copyright_year = 2016 [Prereqs] Catalyst::Runtime = 5.71001 Catalyst::Component::InstancePerContext = 0 Config::Any = 0 File::Spec = 0 HTML::FormFu = 2.00 Moose = 1.00 Regexp::Assemble = 0 Scalar::Util = 0 Task::Weaken = 0 ; make sure Scalar::Util has weaken() namespace::autoclean = 0 [Prereqs / TestRequires] Catalyst::Action::RenderView = 0 Catalyst::Plugin::Session = 0 Catalyst::Plugin::Session::State::Cookie = 0 Catalyst::Plugin::Session::Store::File = 0 Catalyst::View::TT = 0 Template = 0 Test::WWW::Mechanize::Catalyst = 0 Test::WWW::Mechanize = 1.16 ; post_ok came in 1.16 Test::More = 0.92 ; done_testing ;; -- ;; -- Sets of additional tests we want to do as part of release [Test::Perl::Critic] [MetaTests] ;; [PodCoverageTests] ; Currently we comprehensively fail these [OurPkgVersion] [PodVersion] [Test::Kwalitee] [Test::EOL] finder = :InstallModules ; prevents test inputs being flagged [Test::PAUSE::Permissions] ; if doing a release make sure we have PAUSE perms ;; -- Additional information [GithubMeta] ; Grab the repo metadata [NextRelease] ; Mark up the next release in changes ;; -- Additional git [Git::GatherDir] [Git::NextVersion] ; Get the next version tag from git [Git::CheckFor::CorrectBranch] ; ensure on master branch for release [Git::Remote::Check] ; ensure our branch is ahead of remote ;; -- We base the release stuff on the starter module, and tweak a bit [@Starter] -remove = GatherDir ; this is replaced by [Git::GatherDir] ReadmeAnyFromPod.source_filename = lib/Catalyst/Controller/HTML/FormFu.pm [ReadmeAnyFromPod / Pod_Readme] type = pod location = root ; do not include pod readmes in the build! [@Git] changelog = Changes allow_dirty = dist.ini allow_dirty = README.pod allow_dirty = Changes commit_msg = v%v%t - %d%n%n%c tag_format = v%v%t ; see Git::Tag tag_message = v%v%t - %d ; see Git::TagCatalyst-Controller-HTML-FormFu-2.02/lib/000755 000765 000024 00000000000 13110553642 020307 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/LICENSE000644 000765 000024 00000043652 13110553642 020560 0ustar00nigelstaff000000 000000 This software is copyright (c) 2016 by Carl Franks. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. Terms of the Perl programming language system itself a) the GNU General Public License as published by the Free Software Foundation; either version 1, or (at your option) any later version, or b) the "Artistic License" --- The GNU General Public License, Version 1, February 1989 --- This software is Copyright (c) 2016 by Carl Franks. This is free software, licensed under: The GNU General Public License, Version 1, February 1989 GNU GENERAL PUBLIC LICENSE Version 1, February 1989 Copyright (C) 1989 Free Software Foundation, Inc. 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. Preamble The license agreements of most software companies try to keep users at the mercy of those companies. By contrast, our General Public License is intended to guarantee your freedom to share and change free software--to make sure the software is free for all its users. The General Public License applies to the Free Software Foundation's software and to any other program whose authors commit to using it. You can use it for your programs, too. When we speak of free software, we are referring to freedom, not price. Specifically, the General Public License is designed to make sure that you have the freedom to give away or sell copies of free software, that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things. To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it. For example, if you distribute copies of a such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must tell them their rights. We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the software. Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors' reputations. The precise terms and conditions for copying, distribution and modification follow. GNU GENERAL PUBLIC LICENSE TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION 0. This License Agreement applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any work containing the Program or a portion of it, either verbatim or with modifications. Each licensee is addressed as "you". 1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this General Public License and to the absence of any warranty; and give any other recipients of the Program a copy of this General Public License along with the Program. You may charge a fee for the physical act of transferring a copy. 2. You may modify your copy or copies of the Program or any portion of it, and copy and distribute such modifications under the terms of Paragraph 1 above, provided that you also do the following: a) cause the modified files to carry prominent notices stating that you changed the files and the date of any change; and b) cause the whole of any work that you distribute or publish, that in whole or in part contains the Program or any part thereof, either with or without modifications, to be licensed at no charge to all third parties under the terms of this General Public License (except that you may choose to grant warranty protection to some or all third parties, at your option). c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the simplest and most usual way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this General Public License. d) You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. Mere aggregation of another independent work with the Program (or its derivative) on a volume of a storage or distribution medium does not bring the other work under the scope of these terms. 3. You may copy and distribute the Program (or a portion or derivative of it, under Paragraph 2) in object code or executable form under the terms of Paragraphs 1 and 2 above provided that you also do one of the following: a) accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Paragraphs 1 and 2 above; or, b) accompany it with a written offer, valid for at least three years, to give any third party free (except for a nominal charge for the cost of distribution) a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Paragraphs 1 and 2 above; or, c) accompany it with the information you received as to where the corresponding source code may be obtained. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form alone.) Source code for a work means the preferred form of the work for making modifications to it. For an executable file, complete source code means all the source code for all modules it contains; but, as a special exception, it need not include source code for modules which are standard libraries that accompany the operating system on which the executable file runs, or for standard header files or definitions files that accompany that operating system. 4. You may not copy, modify, sublicense, distribute or transfer the Program except as expressly provided under this General Public License. Any attempt otherwise to copy, modify, sublicense, distribute or transfer the Program is void, and will automatically terminate your rights to use the Program under this License. However, parties who have received copies, or rights to use copies, from you under this General Public License will not have their licenses terminated so long as such parties remain in full compliance. 5. By copying, distributing or modifying the Program (or any work based on the Program) you indicate your acceptance of this license to do so, and all its terms and conditions. 6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. 7. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Program specifies a version number of the license which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of the license, you may choose any version ever published by the Free Software Foundation. 8. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally. NO WARRANTY 9. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 10. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. END OF TERMS AND CONDITIONS Appendix: How to Apply These Terms to Your New Programs If you develop a new program, and you want it to be of the greatest possible use to humanity, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms. To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. Copyright (C) 19yy This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 1, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301 USA Also add information on how to contact you by electronic and paper mail. If the program is interactive, make it output a short notice like this when it starts in an interactive mode: Gnomovision version 69, Copyright (C) 19xx name of author Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details. The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, the commands you use may be called something other than `show w' and `show c'; they could even be mouse-clicks or menu items--whatever suits your program. You should also get your employer (if you work as a programmer) or your school, if any, to sign a "copyright disclaimer" for the program, if necessary. Here a sample; alter the names: Yoyodyne, Inc., hereby disclaims all copyright interest in the program `Gnomovision' (a program to direct compilers to make passes at assemblers) written by James Hacker. , 1 April 1989 Ty Coon, President of Vice That's all there is to it! --- The Artistic License 1.0 --- This software is Copyright (c) 2016 by Carl Franks. This is free software, licensed under: The Artistic License 1.0 The Artistic License Preamble The intent of this document is to state the conditions under which a Package may be copied, such that the Copyright Holder maintains some semblance of artistic control over the development of the package, while giving the users of the package the right to use and distribute the Package in a more-or-less customary fashion, plus the right to make reasonable modifications. Definitions: - "Package" refers to the collection of files distributed by the Copyright Holder, and derivatives of that collection of files created through textual modification. - "Standard Version" refers to such a Package if it has not been modified, or has been modified in accordance with the wishes of the Copyright Holder. - "Copyright Holder" is whoever is named in the copyright or copyrights for the package. - "You" is you, if you're thinking about copying or distributing this Package. - "Reasonable copying fee" is whatever you can justify on the basis of media cost, duplication charges, time of people involved, and so on. (You will not be required to justify it to the Copyright Holder, but only to the computing community at large as a market that must bear the fee.) - "Freely Available" means that no fee is charged for the item itself, though there may be fees involved in handling the item. It also means that recipients of the item may redistribute it under the same conditions they received it. 1. You may make and give away verbatim copies of the source form of the Standard Version of this Package without restriction, provided that you duplicate all of the original copyright notices and associated disclaimers. 2. You may apply bug fixes, portability fixes and other modifications derived from the Public Domain or from the Copyright Holder. A Package modified in such a way shall still be considered the Standard Version. 3. You may otherwise modify your copy of this Package in any way, provided that you insert a prominent notice in each changed file stating how and when you changed that file, and provided that you do at least ONE of the following: a) place your modifications in the Public Domain or otherwise make them Freely Available, such as by posting said modifications to Usenet or an equivalent medium, or placing the modifications on a major archive site such as ftp.uu.net, or by allowing the Copyright Holder to include your modifications in the Standard Version of the Package. b) use the modified Package only within your corporation or organization. c) rename any non-standard executables so the names do not conflict with standard executables, which must also be provided, and provide a separate manual page for each non-standard executable that clearly documents how it differs from the Standard Version. d) make other distribution arrangements with the Copyright Holder. 4. You may distribute the programs of this Package in object code or executable form, provided that you do at least ONE of the following: a) distribute a Standard Version of the executables and library files, together with instructions (in the manual page or equivalent) on where to get the Standard Version. b) accompany the distribution with the machine-readable source of the Package with your modifications. c) accompany any non-standard executables with their corresponding Standard Version executables, giving the non-standard executables non-standard names, and clearly documenting the differences in manual pages (or equivalent), together with instructions on where to get the Standard Version. d) make other distribution arrangements with the Copyright Holder. 5. You may charge a reasonable copying fee for any distribution of this Package. You may charge any fee you choose for support of this Package. You may not charge a fee for this Package itself. However, you may distribute this Package in aggregate with other (possibly commercial) programs as part of a larger (possibly commercial) software distribution provided that you do not advertise this Package as a product of your own. 6. The scripts and library files supplied as input to or produced as output from the programs of this Package do not automatically fall under the copyright of this Package, but belong to whomever generated them, and may be sold commercially, and may be aggregated with this Package. 7. C or perl subroutines supplied by you and linked into this Package shall not be considered part of this Package. 8. The name of the Copyright Holder may not be used to endorse or promote products derived from this software without specific prior written permission. 9. THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. The End Catalyst-Controller-HTML-FormFu-2.02/Makefile.PL000644 000765 000024 00000004376 13110553642 021525 0ustar00nigelstaff000000 000000 # This file was automatically generated by Dist::Zilla::Plugin::MakeMaker v6.007. use strict; use warnings; use ExtUtils::MakeMaker; my %WriteMakefileArgs = ( "ABSTRACT" => "Catalyst integration for HTML::FormFu", "AUTHOR" => "Carl Franks ", "CONFIGURE_REQUIRES" => { "ExtUtils::MakeMaker" => 0 }, "DISTNAME" => "Catalyst-Controller-HTML-FormFu", "LICENSE" => "perl", "NAME" => "Catalyst::Controller::HTML::FormFu", "PREREQ_PM" => { "Catalyst::Component::InstancePerContext" => 0, "Catalyst::Runtime" => "5.71001", "Config::Any" => 0, "File::Spec" => 0, "HTML::FormFu" => "2.00", "Moose" => "1.00", "Regexp::Assemble" => 0, "Scalar::Util" => 0, "Task::Weaken" => 0, "namespace::autoclean" => 0 }, "TEST_REQUIRES" => { "Catalyst::Action::RenderView" => 0, "Catalyst::Plugin::Session" => 0, "Catalyst::Plugin::Session::State::Cookie" => 0, "Catalyst::Plugin::Session::Store::File" => 0, "Catalyst::View::TT" => 0, "ExtUtils::MakeMaker" => 0, "File::Spec" => 0, "Template" => 0, "Test::More" => "0.92", "Test::WWW::Mechanize" => "1.16", "Test::WWW::Mechanize::Catalyst" => 0 }, "VERSION" => "2.02", "test" => { "TESTS" => "t/*.t t/elements/*.t" } ); my %FallbackPrereqs = ( "Catalyst::Action::RenderView" => 0, "Catalyst::Component::InstancePerContext" => 0, "Catalyst::Plugin::Session" => 0, "Catalyst::Plugin::Session::State::Cookie" => 0, "Catalyst::Plugin::Session::Store::File" => 0, "Catalyst::Runtime" => "5.71001", "Catalyst::View::TT" => 0, "Config::Any" => 0, "ExtUtils::MakeMaker" => 0, "File::Spec" => 0, "HTML::FormFu" => "2.00", "Moose" => "1.00", "Regexp::Assemble" => 0, "Scalar::Util" => 0, "Task::Weaken" => 0, "Template" => 0, "Test::More" => "0.92", "Test::WWW::Mechanize" => "1.16", "Test::WWW::Mechanize::Catalyst" => 0, "namespace::autoclean" => 0 ); unless ( eval { ExtUtils::MakeMaker->VERSION(6.63_03) } ) { delete $WriteMakefileArgs{TEST_REQUIRES}; delete $WriteMakefileArgs{BUILD_REQUIRES}; $WriteMakefileArgs{PREREQ_PM} = \%FallbackPrereqs; } delete $WriteMakefileArgs{CONFIGURE_REQUIRES} unless eval { ExtUtils::MakeMaker->VERSION(6.52) }; WriteMakefile(%WriteMakefileArgs); Catalyst-Controller-HTML-FormFu-2.02/MANIFEST000644 000765 000024 00000003276 13110553642 020702 0ustar00nigelstaff000000 000000 # This file was automatically generated by Dist::Zilla::Plugin::Manifest v6.007. Changes LICENSE MANIFEST META.json META.yml Makefile.PL README dist.ini lib/Catalyst/Controller/HTML/FormFu.pm lib/Catalyst/Controller/HTML/FormFu/Action/Form.pm lib/Catalyst/Controller/HTML/FormFu/Action/FormConfig.pm lib/Catalyst/Controller/HTML/FormFu/Action/FormMethod.pm lib/Catalyst/Controller/HTML/FormFu/Action/MultiForm.pm lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormConfig.pm lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormMethod.pm lib/Catalyst/Controller/HTML/FormFu/ActionBase/Form.pm lib/Catalyst/Helper/HTML/FormFu.pm lib/HTML/FormFu/Constraint/RequestToken.pm lib/HTML/FormFu/Element/RequestToken.pm lib/HTML/FormFu/Plugin/RequestToken.pm t/00-report-prereqs.dd t/00-report-prereqs.t t/01basic-form.t t/01basic-formconfig.t t/01basic-formconfig_conf_ext.t t/01basic-formmethod.t t/01basic-token.t t/02multiform-multiformconfig.t t/02multiform-multiformmethod.t t/02multiform-token.t t/03instancepercontext.t t/btn_120x50_built.png t/btn_88x31_built.png t/elements/requesttoken.t t/elements/requesttoken.yml t/lib/TestApp.pm t/lib/TestApp/Controller/Basic.pm t/lib/TestApp/Controller/MultiForm.pm t/lib/TestApp/Controller/MultiFormToken.pm t/lib/TestApp/Controller/Root.pm t/lib/TestApp/Controller/Token.pm t/lib/TestApp/Controller/TokenExpire.pm t/lib/TestApp/View/TT.pm t/root/form.tt t/root/forms/basic/formconfig.yml t/root/forms/basic/formconfig_conf_ext.yml t/root/forms/multiform/file_upload.yml t/root/forms/multiform/formconfig.yml t/root/multiform.tt xt/author/00-compile.t xt/author/critic.t xt/author/eol.t xt/author/pod-syntax.t xt/release/distmeta.t xt/release/kwalitee.t xt/release/pause-permissions.t Catalyst-Controller-HTML-FormFu-2.02/META.json000644 000765 000024 00000045146 13110553642 021174 0ustar00nigelstaff000000 000000 { "abstract" : "Catalyst integration for HTML::FormFu", "author" : [ "Carl Franks " ], "dynamic_config" : 0, "generated_by" : "Dist::Zilla version 6.007, CPAN::Meta::Converter version 2.150010", "license" : [ "perl_5" ], "meta-spec" : { "url" : "http://search.cpan.org/perldoc?CPAN::Meta::Spec", "version" : 2 }, "name" : "Catalyst-Controller-HTML-FormFu", "no_index" : { "directory" : [ "eg", "examples", "inc", "share", "t", "xt" ] }, "prereqs" : { "configure" : { "requires" : { "ExtUtils::MakeMaker" : "0" } }, "develop" : { "requires" : { "File::Spec" : "0", "IO::Handle" : "0", "IPC::Open3" : "0", "Test::CPAN::Meta" : "0", "Test::EOL" : "0", "Test::Kwalitee" : "1.21", "Test::More" : "0.88", "Test::PAUSE::Permissions" : "0", "Test::Pod" : "1.41" } }, "runtime" : { "requires" : { "Catalyst::Component::InstancePerContext" : "0", "Catalyst::Runtime" : "5.71001", "Config::Any" : "0", "File::Spec" : "0", "HTML::FormFu" : "2.00", "Moose" : "1.00", "Regexp::Assemble" : "0", "Scalar::Util" : "0", "Task::Weaken" : "0", "namespace::autoclean" : "0" } }, "test" : { "recommends" : { "CPAN::Meta" : "2.120900" }, "requires" : { "Catalyst::Action::RenderView" : "0", "Catalyst::Plugin::Session" : "0", "Catalyst::Plugin::Session::State::Cookie" : "0", "Catalyst::Plugin::Session::Store::File" : "0", "Catalyst::View::TT" : "0", "ExtUtils::MakeMaker" : "0", "File::Spec" : "0", "Template" : "0", "Test::More" : "0.92", "Test::WWW::Mechanize" : "1.16", "Test::WWW::Mechanize::Catalyst" : "0" } } }, "provides" : { "Catalyst::Controller::HTML::FormFu" : { "file" : "lib/Catalyst/Controller/HTML/FormFu.pm", "version" : "2.02" }, "Catalyst::Controller::HTML::FormFu::Action::Form" : { "file" : "lib/Catalyst/Controller/HTML/FormFu/Action/Form.pm", "version" : "2.02" }, "Catalyst::Controller::HTML::FormFu::Action::FormConfig" : { "file" : "lib/Catalyst/Controller/HTML/FormFu/Action/FormConfig.pm", "version" : "2.02" }, "Catalyst::Controller::HTML::FormFu::Action::FormMethod" : { "file" : "lib/Catalyst/Controller/HTML/FormFu/Action/FormMethod.pm", "version" : "2.02" }, "Catalyst::Controller::HTML::FormFu::Action::MultiForm" : { "file" : "lib/Catalyst/Controller/HTML/FormFu/Action/MultiForm.pm", "version" : "2.02" }, "Catalyst::Controller::HTML::FormFu::Action::MultiFormConfig" : { "file" : "lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormConfig.pm", "version" : "2.02" }, "Catalyst::Controller::HTML::FormFu::Action::MultiFormMethod" : { "file" : "lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormMethod.pm", "version" : "2.02" }, "Catalyst::Controller::HTML::FormFu::ActionBase::Form" : { "file" : "lib/Catalyst/Controller/HTML/FormFu/ActionBase/Form.pm", "version" : "2.02" }, "Catalyst::Helper::HTML::FormFu" : { "file" : "lib/Catalyst/Helper/HTML/FormFu.pm", "version" : "2.02" }, "HTML::FormFu::Constraint::RequestToken" : { "file" : "lib/HTML/FormFu/Constraint/RequestToken.pm", "version" : "2.02" }, "HTML::FormFu::Element::RequestToken" : { "file" : "lib/HTML/FormFu/Element/RequestToken.pm", "version" : "2.02" }, "HTML::FormFu::Plugin::RequestToken" : { "file" : "lib/HTML/FormFu/Plugin/RequestToken.pm", "version" : "2.02" } }, "release_status" : "stable", "resources" : { "homepage" : "https://github.com/fireartist/Catalyst-Controller-HTML-FormFu", "repository" : { "type" : "git", "url" : "https://github.com/fireartist/Catalyst-Controller-HTML-FormFu.git", "web" : "https://github.com/fireartist/Catalyst-Controller-HTML-FormFu" } }, "version" : "2.02", "x_Dist_Zilla" : { "perl" : { "version" : "5.024000" }, "plugins" : [ { "class" : "Dist::Zilla::Plugin::Prereqs", "config" : { "Dist::Zilla::Plugin::Prereqs" : { "phase" : "runtime", "type" : "requires" } }, "name" : "Prereqs", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::Prereqs", "config" : { "Dist::Zilla::Plugin::Prereqs" : { "phase" : "test", "type" : "requires" } }, "name" : "TestRequires", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::Test::Perl::Critic", "name" : "Test::Perl::Critic", "version" : "3.000" }, { "class" : "Dist::Zilla::Plugin::MetaTests", "name" : "MetaTests", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::OurPkgVersion", "name" : "OurPkgVersion", "version" : "0.10" }, { "class" : "Dist::Zilla::Plugin::PodVersion", "name" : "PodVersion", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::Test::Kwalitee", "config" : { "Dist::Zilla::Plugin::Test::Kwalitee" : { "filename" : "xt/release/kwalitee.t", "skiptest" : [] } }, "name" : "Test::Kwalitee", "version" : "2.12" }, { "class" : "Dist::Zilla::Plugin::Test::EOL", "config" : { "Dist::Zilla::Plugin::Test::EOL" : { "filename" : "xt/author/eol.t", "finder" : [ ":InstallModules" ], "trailing_whitespace" : 1 } }, "name" : "Test::EOL", "version" : "0.19" }, { "class" : "Dist::Zilla::Plugin::Test::PAUSE::Permissions", "name" : "Test::PAUSE::Permissions", "version" : "0.003" }, { "class" : "Dist::Zilla::Plugin::GithubMeta", "name" : "GithubMeta", "version" : "0.54" }, { "class" : "Dist::Zilla::Plugin::NextRelease", "name" : "NextRelease", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::Git::GatherDir", "config" : { "Dist::Zilla::Plugin::GatherDir" : { "exclude_filename" : [], "exclude_match" : [], "follow_symlinks" : 0, "include_dotfiles" : 0, "prefix" : "", "prune_directory" : [], "root" : "." }, "Dist::Zilla::Plugin::Git::GatherDir" : { "include_untracked" : 0 } }, "name" : "Git::GatherDir", "version" : "2.039" }, { "class" : "Dist::Zilla::Plugin::Git::NextVersion", "config" : { "Dist::Zilla::Plugin::Git::NextVersion" : { "first_version" : "0.001", "version_by_branch" : 0, "version_regexp" : "(?^:^v(.+)$)" }, "Dist::Zilla::Role::Git::Repo" : { "repo_root" : "." } }, "name" : "Git::NextVersion", "version" : "2.039" }, { "class" : "Dist::Zilla::Plugin::Git::CheckFor::CorrectBranch", "config" : { "Dist::Zilla::Role::Git::Repo" : { "repo_root" : "." } }, "name" : "Git::CheckFor::CorrectBranch", "version" : "0.013" }, { "class" : "Dist::Zilla::Plugin::Git::Remote::Check", "name" : "Git::Remote::Check", "version" : "0.1.2" }, { "class" : "Dist::Zilla::Plugin::PruneCruft", "name" : "@Starter/PruneCruft", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::ManifestSkip", "name" : "@Starter/ManifestSkip", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::MetaConfig", "name" : "@Starter/MetaConfig", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::MetaProvides::Package", "config" : { "Dist::Zilla::Plugin::MetaProvides::Package" : { "finder_objects" : [ { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : "@Starter/MetaProvides::Package/AUTOVIV/:InstallModulesPM", "version" : "6.007" } ], "include_underscores" : 0 }, "Dist::Zilla::Role::MetaProvider::Provider" : { "$Dist::Zilla::Role::MetaProvider::Provider::VERSION" : "2.002003", "inherit_missing" : 1, "inherit_version" : 1, "meta_noindex" : 1 }, "Dist::Zilla::Role::ModuleMetadata" : { "Module::Metadata" : "1.000031", "version" : "0.004" } }, "name" : "@Starter/MetaProvides::Package", "version" : "2.004002" }, { "class" : "Dist::Zilla::Plugin::MetaNoIndex", "name" : "@Starter/MetaNoIndex", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::MetaYAML", "name" : "@Starter/MetaYAML", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::MetaJSON", "name" : "@Starter/MetaJSON", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::License", "name" : "@Starter/License", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::ReadmeAnyFromPod", "config" : { "Dist::Zilla::Role::FileWatcher" : { "version" : "0.006" } }, "name" : "@Starter/ReadmeAnyFromPod", "version" : "0.161170" }, { "class" : "Dist::Zilla::Plugin::ExecDir", "name" : "@Starter/ExecDir", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::ShareDir", "name" : "@Starter/ShareDir", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::PodSyntaxTests", "name" : "@Starter/PodSyntaxTests", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::Test::ReportPrereqs", "name" : "@Starter/Test::ReportPrereqs", "version" : "0.025" }, { "class" : "Dist::Zilla::Plugin::Test::Compile", "config" : { "Dist::Zilla::Plugin::Test::Compile" : { "bail_out_on_fail" : 0, "fail_on_warning" : "author", "fake_home" : 0, "filename" : "xt/author/00-compile.t", "module_finder" : [ ":InstallModules" ], "needs_display" : 0, "phase" : "develop", "script_finder" : [ ":PerlExecFiles" ], "skips" : [] } }, "name" : "@Starter/Test::Compile", "version" : "2.054" }, { "class" : "Dist::Zilla::Plugin::MakeMaker", "config" : { "Dist::Zilla::Role::TestRunner" : { "default_jobs" : 1 } }, "name" : "@Starter/MakeMaker", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::Manifest", "name" : "@Starter/Manifest", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::TestRelease", "name" : "@Starter/TestRelease", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::RunExtraTests", "config" : { "Dist::Zilla::Role::TestRunner" : { "default_jobs" : 1 } }, "name" : "@Starter/RunExtraTests", "version" : "0.029" }, { "class" : "Dist::Zilla::Plugin::ConfirmRelease", "name" : "@Starter/ConfirmRelease", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::UploadToCPAN", "name" : "@Starter/UploadToCPAN", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::ReadmeAnyFromPod", "config" : { "Dist::Zilla::Role::FileWatcher" : { "version" : "0.006" } }, "name" : "Pod_Readme", "version" : "0.161170" }, { "class" : "Dist::Zilla::Plugin::Git::Check", "config" : { "Dist::Zilla::Plugin::Git::Check" : { "untracked_files" : "die" }, "Dist::Zilla::Role::Git::DirtyFiles" : { "allow_dirty" : [ "Changes", "README.pod", "dist.ini" ], "allow_dirty_match" : [], "changelog" : "Changes" }, "Dist::Zilla::Role::Git::Repo" : { "repo_root" : "." } }, "name" : "@Git/Check", "version" : "2.039" }, { "class" : "Dist::Zilla::Plugin::Git::Commit", "config" : { "Dist::Zilla::Plugin::Git::Commit" : { "add_files_in" : [], "commit_msg" : "v%v%t - %d%n%n%c" }, "Dist::Zilla::Role::Git::DirtyFiles" : { "allow_dirty" : [ "Changes", "README.pod", "dist.ini" ], "allow_dirty_match" : [], "changelog" : "Changes" }, "Dist::Zilla::Role::Git::Repo" : { "repo_root" : "." }, "Dist::Zilla::Role::Git::StringFormatter" : { "time_zone" : "local" } }, "name" : "@Git/Commit", "version" : "2.039" }, { "class" : "Dist::Zilla::Plugin::Git::Tag", "config" : { "Dist::Zilla::Plugin::Git::Tag" : { "branch" : null, "changelog" : "Changes", "signed" : 0, "tag" : "v2.02", "tag_format" : "v%v%t", "tag_message" : "v%v%t - %d" }, "Dist::Zilla::Role::Git::Repo" : { "repo_root" : "." }, "Dist::Zilla::Role::Git::StringFormatter" : { "time_zone" : "local" } }, "name" : "@Git/Tag", "version" : "2.039" }, { "class" : "Dist::Zilla::Plugin::Git::Push", "config" : { "Dist::Zilla::Plugin::Git::Push" : { "push_to" : [ "origin" ], "remotes_must_exist" : 1 }, "Dist::Zilla::Role::Git::Repo" : { "repo_root" : "." } }, "name" : "@Git/Push", "version" : "2.039" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":InstallModules", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":IncModules", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":TestFiles", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":ExtraTestFiles", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":ExecFiles", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":PerlExecFiles", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":ShareFiles", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":MainModule", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":AllFiles", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : ":NoFiles", "version" : "6.007" }, { "class" : "Dist::Zilla::Plugin::FinderCode", "name" : "@Starter/MetaProvides::Package/AUTOVIV/:InstallModulesPM", "version" : "6.007" } ], "zilla" : { "class" : "Dist::Zilla::Dist::Builder", "config" : { "is_trial" : 0 }, "version" : "6.007" } }, "x_serialization_backend" : "Cpanel::JSON::XS version 3.0217" } Catalyst-Controller-HTML-FormFu-2.02/META.yml000644 000765 000024 00000027743 13110553642 021027 0ustar00nigelstaff000000 000000 --- abstract: 'Catalyst integration for HTML::FormFu' author: - 'Carl Franks ' build_requires: Catalyst::Action::RenderView: '0' Catalyst::Plugin::Session: '0' Catalyst::Plugin::Session::State::Cookie: '0' Catalyst::Plugin::Session::Store::File: '0' Catalyst::View::TT: '0' ExtUtils::MakeMaker: '0' File::Spec: '0' Template: '0' Test::More: '0.92' Test::WWW::Mechanize: '1.16' Test::WWW::Mechanize::Catalyst: '0' configure_requires: ExtUtils::MakeMaker: '0' dynamic_config: 0 generated_by: 'Dist::Zilla version 6.007, CPAN::Meta::Converter version 2.150010' license: perl meta-spec: url: http://module-build.sourceforge.net/META-spec-v1.4.html version: '1.4' name: Catalyst-Controller-HTML-FormFu no_index: directory: - eg - examples - inc - share - t - xt provides: Catalyst::Controller::HTML::FormFu: file: lib/Catalyst/Controller/HTML/FormFu.pm version: '2.02' Catalyst::Controller::HTML::FormFu::Action::Form: file: lib/Catalyst/Controller/HTML/FormFu/Action/Form.pm version: '2.02' Catalyst::Controller::HTML::FormFu::Action::FormConfig: file: lib/Catalyst/Controller/HTML/FormFu/Action/FormConfig.pm version: '2.02' Catalyst::Controller::HTML::FormFu::Action::FormMethod: file: lib/Catalyst/Controller/HTML/FormFu/Action/FormMethod.pm version: '2.02' Catalyst::Controller::HTML::FormFu::Action::MultiForm: file: lib/Catalyst/Controller/HTML/FormFu/Action/MultiForm.pm version: '2.02' Catalyst::Controller::HTML::FormFu::Action::MultiFormConfig: file: lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormConfig.pm version: '2.02' Catalyst::Controller::HTML::FormFu::Action::MultiFormMethod: file: lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormMethod.pm version: '2.02' Catalyst::Controller::HTML::FormFu::ActionBase::Form: file: lib/Catalyst/Controller/HTML/FormFu/ActionBase/Form.pm version: '2.02' Catalyst::Helper::HTML::FormFu: file: lib/Catalyst/Helper/HTML/FormFu.pm version: '2.02' HTML::FormFu::Constraint::RequestToken: file: lib/HTML/FormFu/Constraint/RequestToken.pm version: '2.02' HTML::FormFu::Element::RequestToken: file: lib/HTML/FormFu/Element/RequestToken.pm version: '2.02' HTML::FormFu::Plugin::RequestToken: file: lib/HTML/FormFu/Plugin/RequestToken.pm version: '2.02' requires: Catalyst::Component::InstancePerContext: '0' Catalyst::Runtime: '5.71001' Config::Any: '0' File::Spec: '0' HTML::FormFu: '2.00' Moose: '1.00' Regexp::Assemble: '0' Scalar::Util: '0' Task::Weaken: '0' namespace::autoclean: '0' resources: homepage: https://github.com/fireartist/Catalyst-Controller-HTML-FormFu repository: https://github.com/fireartist/Catalyst-Controller-HTML-FormFu.git version: '2.02' x_Dist_Zilla: perl: version: '5.024000' plugins: - class: Dist::Zilla::Plugin::Prereqs config: Dist::Zilla::Plugin::Prereqs: phase: runtime type: requires name: Prereqs version: '6.007' - class: Dist::Zilla::Plugin::Prereqs config: Dist::Zilla::Plugin::Prereqs: phase: test type: requires name: TestRequires version: '6.007' - class: Dist::Zilla::Plugin::Test::Perl::Critic name: Test::Perl::Critic version: '3.000' - class: Dist::Zilla::Plugin::MetaTests name: MetaTests version: '6.007' - class: Dist::Zilla::Plugin::OurPkgVersion name: OurPkgVersion version: '0.10' - class: Dist::Zilla::Plugin::PodVersion name: PodVersion version: '6.007' - class: Dist::Zilla::Plugin::Test::Kwalitee config: Dist::Zilla::Plugin::Test::Kwalitee: filename: xt/release/kwalitee.t skiptest: [] name: Test::Kwalitee version: '2.12' - class: Dist::Zilla::Plugin::Test::EOL config: Dist::Zilla::Plugin::Test::EOL: filename: xt/author/eol.t finder: - ':InstallModules' trailing_whitespace: 1 name: Test::EOL version: '0.19' - class: Dist::Zilla::Plugin::Test::PAUSE::Permissions name: Test::PAUSE::Permissions version: '0.003' - class: Dist::Zilla::Plugin::GithubMeta name: GithubMeta version: '0.54' - class: Dist::Zilla::Plugin::NextRelease name: NextRelease version: '6.007' - class: Dist::Zilla::Plugin::Git::GatherDir config: Dist::Zilla::Plugin::GatherDir: exclude_filename: [] exclude_match: [] follow_symlinks: 0 include_dotfiles: 0 prefix: '' prune_directory: [] root: . Dist::Zilla::Plugin::Git::GatherDir: include_untracked: 0 name: Git::GatherDir version: '2.039' - class: Dist::Zilla::Plugin::Git::NextVersion config: Dist::Zilla::Plugin::Git::NextVersion: first_version: '0.001' version_by_branch: 0 version_regexp: (?^:^v(.+)$) Dist::Zilla::Role::Git::Repo: repo_root: . name: Git::NextVersion version: '2.039' - class: Dist::Zilla::Plugin::Git::CheckFor::CorrectBranch config: Dist::Zilla::Role::Git::Repo: repo_root: . name: Git::CheckFor::CorrectBranch version: '0.013' - class: Dist::Zilla::Plugin::Git::Remote::Check name: Git::Remote::Check version: 0.1.2 - class: Dist::Zilla::Plugin::PruneCruft name: '@Starter/PruneCruft' version: '6.007' - class: Dist::Zilla::Plugin::ManifestSkip name: '@Starter/ManifestSkip' version: '6.007' - class: Dist::Zilla::Plugin::MetaConfig name: '@Starter/MetaConfig' version: '6.007' - class: Dist::Zilla::Plugin::MetaProvides::Package config: Dist::Zilla::Plugin::MetaProvides::Package: finder_objects: - class: Dist::Zilla::Plugin::FinderCode name: '@Starter/MetaProvides::Package/AUTOVIV/:InstallModulesPM' version: '6.007' include_underscores: 0 Dist::Zilla::Role::MetaProvider::Provider: $Dist::Zilla::Role::MetaProvider::Provider::VERSION: '2.002003' inherit_missing: '1' inherit_version: '1' meta_noindex: '1' Dist::Zilla::Role::ModuleMetadata: Module::Metadata: '1.000031' version: '0.004' name: '@Starter/MetaProvides::Package' version: '2.004002' - class: Dist::Zilla::Plugin::MetaNoIndex name: '@Starter/MetaNoIndex' version: '6.007' - class: Dist::Zilla::Plugin::MetaYAML name: '@Starter/MetaYAML' version: '6.007' - class: Dist::Zilla::Plugin::MetaJSON name: '@Starter/MetaJSON' version: '6.007' - class: Dist::Zilla::Plugin::License name: '@Starter/License' version: '6.007' - class: Dist::Zilla::Plugin::ReadmeAnyFromPod config: Dist::Zilla::Role::FileWatcher: version: '0.006' name: '@Starter/ReadmeAnyFromPod' version: '0.161170' - class: Dist::Zilla::Plugin::ExecDir name: '@Starter/ExecDir' version: '6.007' - class: Dist::Zilla::Plugin::ShareDir name: '@Starter/ShareDir' version: '6.007' - class: Dist::Zilla::Plugin::PodSyntaxTests name: '@Starter/PodSyntaxTests' version: '6.007' - class: Dist::Zilla::Plugin::Test::ReportPrereqs name: '@Starter/Test::ReportPrereqs' version: '0.025' - class: Dist::Zilla::Plugin::Test::Compile config: Dist::Zilla::Plugin::Test::Compile: bail_out_on_fail: '0' fail_on_warning: author fake_home: 0 filename: xt/author/00-compile.t module_finder: - ':InstallModules' needs_display: 0 phase: develop script_finder: - ':PerlExecFiles' skips: [] name: '@Starter/Test::Compile' version: '2.054' - class: Dist::Zilla::Plugin::MakeMaker config: Dist::Zilla::Role::TestRunner: default_jobs: 1 name: '@Starter/MakeMaker' version: '6.007' - class: Dist::Zilla::Plugin::Manifest name: '@Starter/Manifest' version: '6.007' - class: Dist::Zilla::Plugin::TestRelease name: '@Starter/TestRelease' version: '6.007' - class: Dist::Zilla::Plugin::RunExtraTests config: Dist::Zilla::Role::TestRunner: default_jobs: 1 name: '@Starter/RunExtraTests' version: '0.029' - class: Dist::Zilla::Plugin::ConfirmRelease name: '@Starter/ConfirmRelease' version: '6.007' - class: Dist::Zilla::Plugin::UploadToCPAN name: '@Starter/UploadToCPAN' version: '6.007' - class: Dist::Zilla::Plugin::ReadmeAnyFromPod config: Dist::Zilla::Role::FileWatcher: version: '0.006' name: Pod_Readme version: '0.161170' - class: Dist::Zilla::Plugin::Git::Check config: Dist::Zilla::Plugin::Git::Check: untracked_files: die Dist::Zilla::Role::Git::DirtyFiles: allow_dirty: - Changes - README.pod - dist.ini allow_dirty_match: [] changelog: Changes Dist::Zilla::Role::Git::Repo: repo_root: . name: '@Git/Check' version: '2.039' - class: Dist::Zilla::Plugin::Git::Commit config: Dist::Zilla::Plugin::Git::Commit: add_files_in: [] commit_msg: 'v%v%t - %d%n%n%c' Dist::Zilla::Role::Git::DirtyFiles: allow_dirty: - Changes - README.pod - dist.ini allow_dirty_match: [] changelog: Changes Dist::Zilla::Role::Git::Repo: repo_root: . Dist::Zilla::Role::Git::StringFormatter: time_zone: local name: '@Git/Commit' version: '2.039' - class: Dist::Zilla::Plugin::Git::Tag config: Dist::Zilla::Plugin::Git::Tag: branch: ~ changelog: Changes signed: 0 tag: v2.02 tag_format: v%v%t tag_message: 'v%v%t - %d' Dist::Zilla::Role::Git::Repo: repo_root: . Dist::Zilla::Role::Git::StringFormatter: time_zone: local name: '@Git/Tag' version: '2.039' - class: Dist::Zilla::Plugin::Git::Push config: Dist::Zilla::Plugin::Git::Push: push_to: - origin remotes_must_exist: 1 Dist::Zilla::Role::Git::Repo: repo_root: . name: '@Git/Push' version: '2.039' - class: Dist::Zilla::Plugin::FinderCode name: ':InstallModules' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':IncModules' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':TestFiles' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':ExtraTestFiles' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':ExecFiles' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':PerlExecFiles' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':ShareFiles' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':MainModule' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':AllFiles' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: ':NoFiles' version: '6.007' - class: Dist::Zilla::Plugin::FinderCode name: '@Starter/MetaProvides::Package/AUTOVIV/:InstallModulesPM' version: '6.007' zilla: class: Dist::Zilla::Dist::Builder config: is_trial: '0' version: '6.007' x_serialization_backend: 'YAML::Tiny version 1.69' Catalyst-Controller-HTML-FormFu-2.02/README000644 000765 000024 00000032627 13110553642 020433 0ustar00nigelstaff000000 000000 NAME Catalyst::Controller::HTML::FormFu - Catalyst integration for HTML::FormFu VERSION version 2.02 SYNOPSIS package MyApp::Controller::My::Controller; use Moose; use namespace::autoclean; BEGIN { extends 'Catalyst::Controller::HTML::FormFu'; } sub index : Local { my ( $self, $c ) = @_; # doesn't use an Attribute to make a form # can get an empty form from $self->form() my $form = $self->form(); } sub foo : Local : Form { my ( $self, $c ) = @_; # using the Form attribute is equivalent to: # # my $form = $self->form; # # $form->process; # # $c->stash->{form} = $form; } sub bar : Local : FormConfig { my ( $self, $c ) = @_; # using the FormConfig attribute is equivalent to: # # my $form = $self->form; # # $form->load_config_filestem('root/forms/my/controller/bar'); # # $form->process; # # $c->stash->{form} = $form; # # so you only need to do the following... my $form = $c->stash->{form}; if ( $form->submitted_and_valid ) { do_something(); } } sub baz : Local : FormConfig('my_config') { my ( $self, $c ) = @_; # using the FormConfig attribute with an argument is equivalent to: # # my $form = $self->form; # # $form->load_config_filestem('root/forms/my_config'); # # $form->process; # # $c->stash->{form} = $form; # # so you only need to do the following... my $form = $c->stash->{form}; if ( $form->submitted_and_valid ) { do_something(); } } sub quux : Local : FormMethod('load_form') { my ( $self, $c ) = @_; # using the FormMethod attribute with an argument is equivalent to: # # my $form = $self->form; # # $form->populate( $c->load_form ); # # $form->process; # # $c->stash->{form} = $form; # # so you only need to do the following... my $form = $c->stash->{form}; if ( $form->submitted_and_valid ) { do_something(); } } sub load_form { my ( $self, $c ) = @_; # Automatically called by the above FormMethod('load_form') action. # Called as a method on the controller object, with the context # object as an argument. # Must return a hash-ref suitable to be fed to $form->populate() } You can also use specially-named actions that will only be called under certain circumstances. sub edit : Chained('group') : PathPart : Args(0) : FormConfig { } sub edit_FORM_VALID { my ( $self, $c ) = @_; my $form = $c->stash->{form}; my $group = $c->stash->{group}; $form->model->update( $group ); $c->response->redirect( $c->uri_for( '/group', $group->id ) ); } sub edit_FORM_NOT_SUBMITTED { my ( $self, $c ) = @_; my $form = $c->stash->{form}; my $group = $c->stash->{group}; $form->model->default_values( $group ); } METHODS form This creates a new HTML::FormFu object, passing as it's argument the contents of the "constructor" config value. This is useful when using the ConfigForm() or MethodForm() action attributes, to create a 2nd form which isn't populated using a config-file or method return value. sub foo : Local { my ( $self, $c ) = @_; my $form = $self->form; } Note that when using this method, the form's query method is not populated with the Catalyst request object. SPECIAL ACTION NAMES An example showing how a complicated action method can be broken down into smaller sections, making it clearer which code will be run, and when. sub edit : Local : FormConfig { my ( $self, $c ) = @_; my $form = $c->stash->{form}; my $group = $c->stash->{group}; $c->detach('/unauthorised') unless $c->user->can_edit( $group ); if ( $form->submitted_and_valid ) { $form->model->update( $group ); $c->response->redirect( $c->uri_for('/group', $group->id ) ); return; } elsif ( !$form->submitted ) { $form->model->default_values( $group ); } $self->_add_breadcrumbs_nav( $c, $group ); } Instead becomes... sub edit : Local : FormConfig { my ( $self, $c ) = @_; $c->detach('/unauthorised') unless $c->user->can_edit( $c->stash->{group} ); } sub edit_FORM_VALID { my ( $self, $c ) = @_; my $group = $c->stash->{group}; $c->stash->{form}->model->update( $group ); $c->response->redirect( $c->uri_for('/group', $group->id ) ); } sub edit_FORM_NOT_SUBMITTED { my ( $self, $c ) = @_; $c->stash->{form}->model->default_values( $c->stash->{group} ); } sub edit_FORM_RENDER { my ( $self, $c ) = @_; $self->_add_breadcrumbs_nav( $c, $c->stash->{group} ); } For any action method that uses a Form, FormConfig or FormMethod attribute, you can add extra methods that use the naming conventions below. These methods will be called after the original, plainly named action method. _FORM_VALID Run when the form has been submitted and has no errors. _FORM_SUBMITTED Run when the form has been submitted, regardless of whether or not there was errors. _FORM_COMPLETE For MultiForms, is run if the MultiForm is completed. _FORM_NOT_VALID Run when the form has been submitted and there were errors. _FORM_NOT_SUBMITTED Run when the form has not been submitted. _FORM_NOT_COMPLETE For MultiForms, is run if the MultiForm is not completed. _FORM_RENDER For normal Form base classes, this subroutine is run after any of the other special methods, unless $form->submitted_and_valid is true. For MultiForm base classes, this subroutine is run after any of the other special methods, unless $multi->complete is true. CUSTOMIZATION You can set your own config settings, using either your controller config or your application config. $c->config( 'Controller::HTML::FormFu' => \%my_values ); # or MyApp->config( 'Controller::HTML::FormFu' => \%my_values ); # or, in myapp.conf default_action_use_path 1 form_method Override the method-name used to create a new form object. See "form". Default value: form. form_stash Sets the stash key name used to store the form object. Default value: form. form_attr Sets the attribute name used to load the Catalyst::Controller::HTML::FormFu::Action::Form action. Default value: Form. config_attr Sets the attribute name used to load the Catalyst::Controller::HTML::FormFu::Action::Config action. Default value: FormConfig. method_attr Sets the attribute name used to load the Catalyst::Controller::HTML::FormFu::Action::Method action. Default value: FormMethod. form_action Sets which package will be used by the Form() action. Probably only useful if you want to create a sub-class which provides custom behaviour. Default value: Catalyst::Controller::HTML::FormFu::Action::Form. config_action Sets which package will be used by the Config() action. Probably only useful if you want to create a sub-class which provides custom behaviour. Default value: Catalyst::Controller::HTML::FormFu::Action::Config. method_action Sets which package will be used by the Method() action. Probably only useful if you want to create a sub-class which provides custom behaviour. Default value: Catalyst::Controller::HTML::FormFu::Action::Method. constructor Pass common defaults to the HTML::FormFu constructor. These values are used by all of the action attributes, and by the $self->form method. Default value: {}. config_callback Arguments: bool If true, a coderef is passed to $form->config_callback->{plain_value} which replaces any instance of __uri_for(URI)__ found in form config files with the result of passing the URI argument to "uri_for" in Catalyst. The form __uri_for(URI, PATH, PARTS)__ is also supported, which is equivalent to $c->uri_for( 'URI', \@ARGS ). At this time, there is no way to pass query values equivalent to $c->uri_for( 'URI', \@ARGS, \%QUERY_VALUES ). The second codeword that is being replaced is __path_to( @DIRS )__. Any instance is replaced with the result of passing the DIRS arguments to "path_to" in Catalyst. Don't use qoutationmarks as they would become part of the path. Default value: 1 default_action_use_name If set to a true value the action for the form will be set to the currently called action name. Default value: false. default_action_use_path If set to a true value the action for the form will be set to the currently called action path. The action path includes concurrent to action name additioal parameters which were code inside the path. Default value: false. Example: action: /foo/bar called uri contains: /foo/bar/1 # default_action_use_name => 1 leads to: $form->action = /foo/bar # default_action_use_path => 1 leads to: $form->action = /foo/bar/1 model_stash Arguments: \%stash_keys_to_model_names Used to place Catalyst models on the form stash. If it's being used to make a DBIx::Class schema available for "options_from_model" in HTML::FormFu::Model::DBIC, for Select and other Group-type elements - then the hash-key must be schema. For example, if your schema model class is MyApp::Model::MySchema, you would set model_stash like so: schema MySchema context_stash To allow your form validation packages, etc, access to the catalyst context, a weakened reference of the context is copied into the form's stash. $form->stash->{context}; This setting allows you to change the key name used in the form stash. Default value: context languages_from_context If you're using a L10N / I18N plugin such as Catalyst::Plugin::I18N which provides a languages method that returns a list of valid languages to use for the currect request - and you want to use formfu's built-in I18N packages, then setting "languages_from_context" localize_from_context If you're using a L10N / I18N plugin such as Catalyst::Plugin::I18N which provides it's own localize method, you can set localize_from_context to use that method for formfu's localization. request_token_enable If true, adds an instance of HTML::FormFu::Plugin::RequestToken to every form, to stop accidental double-submissions of data and to prevent CSRF attacks. request_token_field_name Defaults to _token. request_token_session_key Defaults to __token. request_token_expiration_time Defaults to 3600. DISCONTINUED CONFIG SETTINGS config_file_ext Support for this has now been removed. Config files are now searched for, with any file extension supported by Config::Any. config_file_path Support for this has now been removed. Use {constructor}{config_file_path} instead. CAVEATS When using the Form action attribute to create an empty form, you must call $form->process after populating the form. However, you don't need to pass any arguments to process, as the Catalyst request object will have automatically been set in $form->query. When using the FormConfig and FormMethod action attributes, if you make any modifications to the form, such as adding or changing it's elements, you must call $form->process before rendering the form. GITHUB REPOSITORY This module's sourcecode is maintained in a git repository at git://github.com/fireartist/Catalyst-Controller-HTML-FormFu.git The project page is https://github.com/fireartist/Catalyst-Controller-HTML-FormFu SEE ALSO HTML::FormFu, Catalyst::Helper::HTML::FormFu AUTHOR Carl Franks, cfranks@cpan.org COPYRIGHT AND LICENSE Copyright (C) 2007 by Carl Franks This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available. Catalyst-Controller-HTML-FormFu-2.02/t/000755 000765 000024 00000000000 13110553642 020004 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/xt/000755 000765 000024 00000000000 13110553642 020174 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/xt/author/000755 000765 000024 00000000000 13110553642 021476 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/xt/release/000755 000765 000024 00000000000 13110553642 021614 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/xt/release/distmeta.t000644 000765 000024 00000000172 13110553642 023613 0ustar00nigelstaff000000 000000 #!perl # This file was automatically generated by Dist::Zilla::Plugin::MetaTests. use Test::CPAN::Meta; meta_yaml_ok(); Catalyst-Controller-HTML-FormFu-2.02/xt/release/kwalitee.t000644 000765 000024 00000000275 13110553642 023612 0ustar00nigelstaff000000 000000 # this test was generated with Dist::Zilla::Plugin::Test::Kwalitee 2.12 use strict; use warnings; use Test::More 0.88; use Test::Kwalitee 1.21 'kwalitee_ok'; kwalitee_ok(); done_testing; Catalyst-Controller-HTML-FormFu-2.02/xt/release/pause-permissions.t000644 000765 000024 00000000454 13110553642 025472 0ustar00nigelstaff000000 000000 use strict; use warnings; # this test was generated with Dist::Zilla::Plugin::Test::PAUSE::Permissions 0.003 use Test::More; BEGIN { plan skip_all => 'Test::PAUSE::Permissions required for testing pause permissions' if $] < 5.010; } use Test::PAUSE::Permissions; all_permissions_ok(); Catalyst-Controller-HTML-FormFu-2.02/xt/author/00-compile.t000644 000765 000024 00000003402 13110553642 023527 0ustar00nigelstaff000000 000000 use 5.006; use strict; use warnings; # this test was generated with Dist::Zilla::Plugin::Test::Compile 2.054 use Test::More; plan tests => 13; my @module_files = ( 'Catalyst/Controller/HTML/FormFu.pm', 'Catalyst/Controller/HTML/FormFu/Action/Form.pm', 'Catalyst/Controller/HTML/FormFu/Action/FormConfig.pm', 'Catalyst/Controller/HTML/FormFu/Action/FormMethod.pm', 'Catalyst/Controller/HTML/FormFu/Action/MultiForm.pm', 'Catalyst/Controller/HTML/FormFu/Action/MultiFormConfig.pm', 'Catalyst/Controller/HTML/FormFu/Action/MultiFormMethod.pm', 'Catalyst/Controller/HTML/FormFu/ActionBase/Form.pm', 'Catalyst/Helper/HTML/FormFu.pm', 'HTML/FormFu/Constraint/RequestToken.pm', 'HTML/FormFu/Element/RequestToken.pm', 'HTML/FormFu/Plugin/RequestToken.pm' ); # no fake home requested my $inc_switch = -d 'blib' ? '-Mblib' : '-Ilib'; use File::Spec; use IPC::Open3; use IO::Handle; open my $stdin, '<', File::Spec->devnull or die "can't open devnull: $!"; my @warnings; for my $lib (@module_files) { # see L my $stderr = IO::Handle->new; my $pid = open3($stdin, '>&STDERR', $stderr, $^X, $inc_switch, '-e', "require q[$lib]"); binmode $stderr, ':crlf' if $^O eq 'MSWin32'; my @_warnings = <$stderr>; waitpid($pid, 0); is($?, 0, "$lib loaded ok"); shift @_warnings if @_warnings and $_warnings[0] =~ /^Using .*\bblib/ and not eval { require blib; blib->VERSION('1.01') }; if (@_warnings) { warn @_warnings; push @warnings, @_warnings; } } is(scalar(@warnings), 0, 'no warnings found') or diag 'got warnings: ', ( Test::More->can('explain') ? Test::More::explain(\@warnings) : join("\n", '', @warnings) ); Catalyst-Controller-HTML-FormFu-2.02/xt/author/critic.t000644 000765 000024 00000000435 13110553642 023142 0ustar00nigelstaff000000 000000 #!perl use strict; use warnings; use Test::More; use English qw(-no_match_vars); eval "use Test::Perl::Critic"; plan skip_all => 'Test::Perl::Critic required to criticise code' if $@; Test::Perl::Critic->import( -profile => "perlcritic.rc" ) if -e "perlcritic.rc"; all_critic_ok(); Catalyst-Controller-HTML-FormFu-2.02/xt/author/eol.t000644 000765 000024 00000001611 13110553642 022441 0ustar00nigelstaff000000 000000 use strict; use warnings; # this test was generated with Dist::Zilla::Plugin::Test::EOL 0.19 use Test::More 0.88; use Test::EOL; my @files = ( 'lib/Catalyst/Controller/HTML/FormFu.pm', 'lib/Catalyst/Controller/HTML/FormFu/Action/Form.pm', 'lib/Catalyst/Controller/HTML/FormFu/Action/FormConfig.pm', 'lib/Catalyst/Controller/HTML/FormFu/Action/FormMethod.pm', 'lib/Catalyst/Controller/HTML/FormFu/Action/MultiForm.pm', 'lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormConfig.pm', 'lib/Catalyst/Controller/HTML/FormFu/Action/MultiFormMethod.pm', 'lib/Catalyst/Controller/HTML/FormFu/ActionBase/Form.pm', 'lib/Catalyst/Helper/HTML/FormFu.pm', 'lib/HTML/FormFu/Constraint/RequestToken.pm', 'lib/HTML/FormFu/Element/RequestToken.pm', 'lib/HTML/FormFu/Plugin/RequestToken.pm' ); eol_unix_ok($_, { trailing_whitespace => 1 }) foreach @files; done_testing; Catalyst-Controller-HTML-FormFu-2.02/xt/author/pod-syntax.t000644 000765 000024 00000000252 13110553642 023770 0ustar00nigelstaff000000 000000 #!perl # This file was automatically generated by Dist::Zilla::Plugin::PodSyntaxTests. use strict; use warnings; use Test::More; use Test::Pod 1.41; all_pod_files_ok(); Catalyst-Controller-HTML-FormFu-2.02/t/00-report-prereqs.dd000644 000765 000024 00000005203 13110553642 023524 0ustar00nigelstaff000000 000000 do { my $x = { 'configure' => { 'requires' => { 'ExtUtils::MakeMaker' => '0' } }, 'develop' => { 'requires' => { 'File::Spec' => '0', 'IO::Handle' => '0', 'IPC::Open3' => '0', 'Test::CPAN::Meta' => '0', 'Test::EOL' => '0', 'Test::Kwalitee' => '1.21', 'Test::More' => '0.88', 'Test::PAUSE::Permissions' => '0', 'Test::Pod' => '1.41' } }, 'runtime' => { 'requires' => { 'Catalyst::Component::InstancePerContext' => '0', 'Catalyst::Runtime' => '5.71001', 'Config::Any' => '0', 'File::Spec' => '0', 'HTML::FormFu' => '2.00', 'Moose' => '1.00', 'Regexp::Assemble' => '0', 'Scalar::Util' => '0', 'Task::Weaken' => '0', 'namespace::autoclean' => '0' } }, 'test' => { 'recommends' => { 'CPAN::Meta' => '2.120900' }, 'requires' => { 'Catalyst::Action::RenderView' => '0', 'Catalyst::Plugin::Session' => '0', 'Catalyst::Plugin::Session::State::Cookie' => '0', 'Catalyst::Plugin::Session::Store::File' => '0', 'Catalyst::View::TT' => '0', 'ExtUtils::MakeMaker' => '0', 'File::Spec' => '0', 'Template' => '0', 'Test::More' => '0.92', 'Test::WWW::Mechanize' => '1.16', 'Test::WWW::Mechanize::Catalyst' => '0' } } }; $x; }Catalyst-Controller-HTML-FormFu-2.02/t/00-report-prereqs.t000644 000765 000024 00000012714 13110553642 023405 0ustar00nigelstaff000000 000000 #!perl use strict; use warnings; # This test was generated by Dist::Zilla::Plugin::Test::ReportPrereqs 0.025 use Test::More tests => 1; use ExtUtils::MakeMaker; use File::Spec; # from $version::LAX my $lax_version_re = qr/(?: undef | (?: (?:[0-9]+) (?: \. | (?:\.[0-9]+) (?:_[0-9]+)? )? | (?:\.[0-9]+) (?:_[0-9]+)? ) | (?: v (?:[0-9]+) (?: (?:\.[0-9]+)+ (?:_[0-9]+)? )? | (?:[0-9]+)? (?:\.[0-9]+){2,} (?:_[0-9]+)? ) )/x; # hide optional CPAN::Meta modules from prereq scanner # and check if they are available my $cpan_meta = "CPAN::Meta"; my $cpan_meta_pre = "CPAN::Meta::Prereqs"; my $HAS_CPAN_META = eval "require $cpan_meta; $cpan_meta->VERSION('2.120900')" && eval "require $cpan_meta_pre"; ## no critic # Verify requirements? my $DO_VERIFY_PREREQS = 1; sub _max { my $max = shift; $max = ( $_ > $max ) ? $_ : $max for @_; return $max; } sub _merge_prereqs { my ($collector, $prereqs) = @_; # CPAN::Meta::Prereqs object if (ref $collector eq $cpan_meta_pre) { return $collector->with_merged_prereqs( CPAN::Meta::Prereqs->new( $prereqs ) ); } # Raw hashrefs for my $phase ( keys %$prereqs ) { for my $type ( keys %{ $prereqs->{$phase} } ) { for my $module ( keys %{ $prereqs->{$phase}{$type} } ) { $collector->{$phase}{$type}{$module} = $prereqs->{$phase}{$type}{$module}; } } } return $collector; } my @include = qw( ); my @exclude = qw( ); # Add static prereqs to the included modules list my $static_prereqs = do 't/00-report-prereqs.dd'; # Merge all prereqs (either with ::Prereqs or a hashref) my $full_prereqs = _merge_prereqs( ( $HAS_CPAN_META ? $cpan_meta_pre->new : {} ), $static_prereqs ); # Add dynamic prereqs to the included modules list (if we can) my ($source) = grep { -f } 'MYMETA.json', 'MYMETA.yml'; if ( $source && $HAS_CPAN_META && (my $meta = eval { CPAN::Meta->load_file($source) } ) ) { $full_prereqs = _merge_prereqs($full_prereqs, $meta->prereqs); } else { $source = 'static metadata'; } my @full_reports; my @dep_errors; my $req_hash = $HAS_CPAN_META ? $full_prereqs->as_string_hash : $full_prereqs; # Add static includes into a fake section for my $mod (@include) { $req_hash->{other}{modules}{$mod} = 0; } for my $phase ( qw(configure build test runtime develop other) ) { next unless $req_hash->{$phase}; next if ($phase eq 'develop' and not $ENV{AUTHOR_TESTING}); for my $type ( qw(requires recommends suggests conflicts modules) ) { next unless $req_hash->{$phase}{$type}; my $title = ucfirst($phase).' '.ucfirst($type); my @reports = [qw/Module Want Have/]; for my $mod ( sort keys %{ $req_hash->{$phase}{$type} } ) { next if $mod eq 'perl'; next if grep { $_ eq $mod } @exclude; my $file = $mod; $file =~ s{::}{/}g; $file .= ".pm"; my ($prefix) = grep { -e File::Spec->catfile($_, $file) } @INC; my $want = $req_hash->{$phase}{$type}{$mod}; $want = "undef" unless defined $want; $want = "any" if !$want && $want == 0; my $req_string = $want eq 'any' ? 'any version required' : "version '$want' required"; if ($prefix) { my $have = MM->parse_version( File::Spec->catfile($prefix, $file) ); $have = "undef" unless defined $have; push @reports, [$mod, $want, $have]; if ( $DO_VERIFY_PREREQS && $HAS_CPAN_META && $type eq 'requires' ) { if ( $have !~ /\A$lax_version_re\z/ ) { push @dep_errors, "$mod version '$have' cannot be parsed ($req_string)"; } elsif ( ! $full_prereqs->requirements_for( $phase, $type )->accepts_module( $mod => $have ) ) { push @dep_errors, "$mod version '$have' is not in required range '$want'"; } } } else { push @reports, [$mod, $want, "missing"]; if ( $DO_VERIFY_PREREQS && $type eq 'requires' ) { push @dep_errors, "$mod is not installed ($req_string)"; } } } if ( @reports ) { push @full_reports, "=== $title ===\n\n"; my $ml = _max( map { length $_->[0] } @reports ); my $wl = _max( map { length $_->[1] } @reports ); my $hl = _max( map { length $_->[2] } @reports ); if ($type eq 'modules') { splice @reports, 1, 0, ["-" x $ml, "", "-" x $hl]; push @full_reports, map { sprintf(" %*s %*s\n", -$ml, $_->[0], $hl, $_->[2]) } @reports; } else { splice @reports, 1, 0, ["-" x $ml, "-" x $wl, "-" x $hl]; push @full_reports, map { sprintf(" %*s %*s %*s\n", -$ml, $_->[0], $wl, $_->[1], $hl, $_->[2]) } @reports; } push @full_reports, "\n"; } } } if ( @full_reports ) { diag "\nVersions for all modules listed in $source (including optional ones):\n\n", @full_reports; } if ( @dep_errors ) { diag join("\n", "\n*** WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING ***\n", "The following REQUIRED prerequisites were not satisfied:\n", @dep_errors, "\n" ); } pass; # vim: ts=4 sts=4 sw=4 et: Catalyst-Controller-HTML-FormFu-2.02/t/01basic-form.t000644 000765 000024 00000000446 13110553642 022360 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More tests => 3; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; $mech->get_ok('http://localhost/basic/form'); my ($form) = $mech->forms; ok($form); ok( $form->find_input('basic_form') ); Catalyst-Controller-HTML-FormFu-2.02/t/01basic-formconfig.t000644 000765 000024 00000001710 13110553642 023541 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More tests => 12; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; $mech->get_ok('http://localhost/basic/formconfig'); { # test __uri_for()__ set in config file like( $mech->response->content, qr{} ); } my ($form) = $mech->forms; ok($form); ok( $form->find_input('basic_formconfig') ); my $uri = $form->action; { $mech->post_ok( $uri, { unknown_field => 'foo' } ); $mech->content_contains('

not submitted, render

'); } { $mech->post_ok( $uri, { submit => 'foo' } ); $mech->content_contains('

submitted, not valid, render

'); } { $mech->post_ok( $uri, { basic_formconfig => '' } ); $mech->content_contains('

submitted, not valid, render

'); } { $mech->post_ok( $uri, { basic_formconfig => 'foo' } ); $mech->content_contains('

submitted, valid

'); } Catalyst-Controller-HTML-FormFu-2.02/t/01basic-formconfig_conf_ext.t000644 000765 000024 00000000466 13110553642 025435 0ustar00nigelstaff000000 000000 use strict; use Test::More tests => 3; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; $mech->get_ok('http://localhost/basic/formconfig_conf_ext'); my ($form) = $mech->forms; ok($form); ok( $form->find_input('basic_formconfig_conf_ext') ); Catalyst-Controller-HTML-FormFu-2.02/t/01basic-formmethod.t000644 000765 000024 00000000462 13110553642 023557 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More tests => 3; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; $mech->get_ok('http://localhost/basic/formmethod'); my ($form) = $mech->forms; ok($form); ok( $form->find_input('basic_formmethod') ); Catalyst-Controller-HTML-FormFu-2.02/t/01basic-token.t000644 000765 000024 00000003645 13110553642 022541 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; $mech->get_ok('http://localhost/token/form'); my ($form) = $mech->forms; ok( $form, 'Found form' ); ok( $form->find_input('basic_form'), 'found input field' ); ok( my $token = $form->find_input('_token'), 'found token field' ); $token = $token->value; like( $token, qr/^[a-z0-9]+$/, 'token value looks like a token' ); ok( my $res = $mech->submit_form( fields => { 'basic_form' => 1, '_token' => "123" } ), 'submit with different token' ); unlike( $res->as_string, qr/VALID/, 'form is not valid' ); $mech->get_ok('http://localhost/token/form'); ok( $res = $mech->submit_form( fields => { '_token' => $token } ), 'submit with token only' ); unlike( $res->as_string, qr/VALID/, 'basic_form is required' ); $mech->get_ok('http://localhost/token/form'); ok( $res = $mech->submit_form( fields => { 'basic_form' => 1, '_token' => $token } ), 'submit with valid token' ); like( $res->as_string, qr/VALID/, 'form is valid' ); $mech->get_ok( 'http://localhost/token/count_token', 'get token count' ); is( $mech->content, 4, "4 tokens" ); $mech->get_ok( 'http://localhost/tokenexpire/form', 'get token with negative expiration time' ); ($form) = $mech->forms; ok( $form, 'Found form' ); ok( $form->find_input('basic_form'), 'found input field' ); ok( $token = $form->find_input('token'), 'found token field' ); for(4..21) { $mech->get_ok('http://localhost/token/count_token'); is($mech->content, $_ > 20 ? 20 : $_); $mech->get_ok('http://localhost/token/form', 'get form #' . $_); } ($form) = $mech->forms; ok( $token = $form->find_input('_token'), 'found token field' ); ok( $res = $mech->submit_form( fields => { 'basic_form' => 1, '_token' => $token->value } ), 'submit with valid token' ); is( $mech->content, 'VALID', 'form is valid' ); done_testing;Catalyst-Controller-HTML-FormFu-2.02/t/02multiform-multiformconfig.t000644 000765 000024 00000002216 13110553642 025554 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More; eval { require HTML::FormFu::MultiForm; }; if ($@) { plan skip_all => 'HTML::FormFu::MultiForm required for MultiForm tests'; die $@; } plan tests => 13; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; # check the initial response $mech->get_ok('http://localhost/multiform/formconfig'); my ($form) = $mech->forms; ok($form); is( $form->attr('id'), 'formconfig' ); ok( $form->find_input('page1') ); # submit page 1 my $uri = $form->action; $mech->post_ok( $uri, { page1 => 'foo' } ); # get page 2's hidden value, to submit page 2 undef $form; ($form) = $mech->forms; ok($form); undef $uri; $uri = $form->action; is( $form->attr('id'), 'formconfig' ); ok( $form->find_input('page2') ); ok( $form->find_input('_multiform') ); my $hidden_value = $form->value('_multiform'); # submit page 2 $mech->post_ok( $uri, { _multiform => $hidden_value, page2 => 'bar', } ); # check final output $mech->content_contains('Complete'); $mech->content_contains('page1: foo'); $mech->content_contains('page2: bar'); Catalyst-Controller-HTML-FormFu-2.02/t/02multiform-multiformmethod.t000644 000765 000024 00000002216 13110553642 025567 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More; eval { require HTML::FormFu::MultiForm; }; if ($@) { plan skip_all => 'HTML::FormFu::MultiForm required for MultiForm tests'; die $@; } plan tests => 13; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; # check the initial response $mech->get_ok('http://localhost/multiform/formmethod'); my ($form) = $mech->forms; ok($form); is( $form->attr('id'), 'formmethod' ); ok( $form->find_input('page1') ); # submit page 1 my $uri = $form->action; $mech->post_ok( $uri, { page1 => 'foo' } ); # get page 2's hidden value, to submit page 2 undef $form; ($form) = $mech->forms; ok($form); undef $uri; $uri = $form->action; is( $form->attr('id'), 'formmethod' ); ok( $form->find_input('page2') ); ok( $form->find_input('_multiform') ); my $hidden_value = $form->value('_multiform'); # submit page 2 $mech->post_ok( $uri, { _multiform => $hidden_value, page2 => 'bar', } ); # check final output $mech->content_contains('Complete'); $mech->content_contains('page1: foo'); $mech->content_contains('page2: bar'); Catalyst-Controller-HTML-FormFu-2.02/t/02multiform-token.t000644 000765 000024 00000002127 13110553642 023471 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More; # short form of this appears to break the aggregate tests... plan skip_all => 'no multi form support yet'; use lib 't/lib'; use Test::WWW::Mechanize::Catalyst 'TestApp'; my $mech = Test::WWW::Mechanize::Catalyst->new; # check the initial response $mech->get_ok('http://localhost/multiformtoken/formconfig'); my ($form) = $mech->forms; ok($form); is( $form->attr('id'), 'formconfig' ); ok( $form->find_input('page1') ); # submit page 1 my $uri = $form->action; $mech->post_ok( $uri, { page1 => 'foo' } ); # get page 2's hidden value, to submit page 2 undef $form; ($form) = $mech->forms; ok($form); undef $uri; $uri = $form->action; is( $form->attr('id'), 'formconfig' ); ok( $form->find_input('page2') ); ok( $form->find_input('_multiform') ); my $hidden_value = $form->value('_multiform'); # submit page 2 $mech->post_ok( $uri, { _multiform => $hidden_value, page2 => 'bar', } ); # check final output $mech->content_contains('Complete'); $mech->content_contains('page1: foo'); $mech->content_contains('page2: bar'); Catalyst-Controller-HTML-FormFu-2.02/t/03instancepercontext.t000644 000765 000024 00000000263 13110553642 024255 0ustar00nigelstaff000000 000000 use strict; use warnings; use Test::More; use lib 't/lib'; use TestApp; eval { map { TestApp->controller($_) } TestApp->controllers; }; ok(!$@, 'lives ok'); done_testing;Catalyst-Controller-HTML-FormFu-2.02/t/btn_120x50_built.png000644 000765 000024 00000007362 13110553642 023423 0ustar00nigelstaff000000 000000 ‰PNG  IHDRx2 yïêgAMAÖØÔOX2tEXtSoftwareAdobe ImageReadyqÉe<PLTEÑÓÏ‹Š‰ôôó¤¢ÕÕÓÚÚÕ³‹þÞÞÜ¡¡ Ë0/ßàÞääâqqpÌŒŒûûûÚùùùuqlÉÿɦ¦ÎÏÎü87ùED>>>æçæ¶WVêêèÓÌËéæä®¯­ÍÎËœ™ê©¨áâàüôóþÉËǼ|{×ÙÕÿÿÿË““ôôôÝVUñëè丶ÙÚØ––•é[ZÓÓÓûýúWWW²²²×feÓuuëxwâäâ仹µâãâÕ×ÓÕ…„ìíë©©©Òº¸Ì³²ÊÆÅûûù‚}x```ññðÅÅÅäåã¾¾»êìéä<<õ××èèæÊÊÉʯ®SLFÞßܱ±°Î}|ÁÁÀ}~}ñó¸ØØ×ÈœõWVæèæôkkš™—ggg´µ´ý('ν¼ØÖÓÕ¬ª»¬«:2*ÊWVãÍÌNNNàààc]Wòìii«©¦ôwwÒÓÑîîîÛÞÛÏÐÌÚÜÙÐľfdÙCBíÍÌ­­©CCCíÜ܇‚}ÄÄÂàÝÝóóñäæâÞÛÚýûúéFFÝÞÛááÞ’‘Žîîìgb\jjjD=6¼¼¼ÞÞÚëÕÔëêêÚÚÚ|xtÏÊÊÄ”“ìììåÖÕµ´±åÄÃîñìÍb`¹·´ŠÐÒÐìÆÅýýû.&OIBÓÒϾ:9òòñ³°Øö ÑÑÏþ¯°¯Ì¸·®®­÷÷÷ËÌÉÛÜÚZTNÇÈÄsssææä»»º·¸¶¯¯­oke¬¬«²µ²ÊNM³²¯¦¦£ÄÿyuoÂÄÁäæärngÙÜØ××Ö˜–‘âàßõÄÄmgaMG@žŸ"ÚÛØÚÛÙÛÛÙÛÛØùù÷ñóñÚÚØÜÜÚÿÿýÜÜÛÜÜÙÜÝÛýÿýÝÝÛ÷ù÷ÚÚÙýýýô÷óóñðìîìÿýýÛÚØG?9ýÿÿùúùÿýÿÜÝÚÝÝÚ÷÷ùýýÿ½»¹ù÷÷±²±÷ôòæåäëãâ㄃àÜÛÛÚÙÓon÷áà嘘óå++òôòÑÉÈÕÚÆÂÝÜÛ÷ùùìîîÖÑÏçÈÆ·rqÿÿÿdŒ*ùtRNSÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿS÷% kIDATxÚìXkTSWNh¨Mškx¡bBZ. D(¢XÀ@A­¥ }@UQ *!mQÊô-T|L-Q(:Š¥-u”B¸„·¨(}ÚªÖ>œ5ãÔÙû$HèÃάeù5ß½gŸ½¿ýóÝGÂÊ‚uãwPœÌ~®M|㶃õ;}vás쀥 ÝÚ&Ö¸ÖM˜qÔÀYÄËXÇžPã¥UmÉ#>“2=¨lV¶ÍOðT^Ú¢Žn™î62qÆ…maSNl‰L(¨ÈËÛØ1aÆy…¼ÕžÃ~€È—«§Õÿ!Æl·_bafä3 hì7\q©Ííö¡0à¦1›ÝÖ|tˆÓ¦aQ”ðõ'?''§ëj$kǪ@ÁX#­Ì4›ÔŽ­IÊk^˜}ªE"¦ ´’Ã8e½¢S4-ÑBÿ#±8¢ö=ì,@p‡Dì›BŒy…Ó›Ršb|÷ÀS`U?ýôÌÐq˜ùÓÌjlA“•˪ÅMN=_µ§‰ÎÚ {ïÎeY÷TgÕìÞMÓ5 ¹,˜rYU4ý—Úê,º³¬S5H£q-KÒ„ÆŠuGvÆ$ÇKT*GÅáL9øîãc}<ôÝ=‚49c`“|†œf(a«"äœf•4]Eh•Ê·†Îâ€üYìûªTñ*t›ÑDsŒfþ4Uùb¤”bGiþÝÃzG)#…‘‘2Œ´Œ¦Ë¤ b@ö“ ;µ›É-U‘í³4ý ȧ!ɪ<kÀøI©”¢r“¬d% ý>á›ý“ö¿Þ«Ñ<ò`Ú’ÇöO‡õŸh¶Ã¡ÑlßqMo솒{x<¯{#w;ølán/ªýáZlÑ¡ÑpÐ4ûY:Ks¨¯°¦m;Yl‚Th¼”7ó±5Äáõû¿ÿnÝwqß7ž£Ëægët>|‚ ]¶Î^^ƒv:ÊÏ~˜¦u:þIx}º£`ÌçÁ÷ÑeŸ§΢'ëNdó?æü "÷ñáŸn㠔ǜ¾±ZÄÍ™·æ_—¬o¼æ} ~š„øŽ Èa'Aìw¬D€Q€Q[/”@ Ò’ |ò1°¦•tK¤ Ò¢$0nz}Þ<✮NOOw÷òг÷Kúmì¤{¥{y©áÆè‡ÏovÇ{À/Ö+éê*4PîYçñk£N‡^ºÚKÝßKíž à¨V'ÓÖü0nŒx1îåà0cí,ŠØŠØØµuvÆuóÂ+._};ÖãZ±›a;ú½Øãàšµ>-±‰`DÇöC¬©ÂVd …‹œë%ø‚ð»¸Ó£"$þË•¬KçÇ]Y;ËeÖÚ+®—õgõz½×«þ«FmWù_™4ëòÙm®/¿¦GœÍƒÐ¦ƒL6?OOèõdò懽–§? Âéõ(ÇÏðàO”º0Žþµ¼ôx|Ü’#]fù¿êÿ„ËŽèÎeÅÑ—]æî˜‹Ï`ÒŒ'6í;ã]·êß?Ì]å¿iÇÅg:—u"Š£á(&E4©‹ñ$Xvæ ËÎßϤì‡N —¦hXB–{иmaüüàmÛ\¯<à0$ É7-wõÞàõªÿ›††äC;\ê®îó^åêê:÷²ÜDC0ÉäX@‰aÒ¯`-VÐw€]†à•|€ TÛ ÿÊÂ%™ø'³,(³¶ÖSÕ)2כ͢Ï z»º.ŸûÔr—¹ÎfÑW+&­¨`Æ +Þ0›ÍëÍE"³ùâÅÏ` Ô˜ÿi€.ä"H 6çÔ°Qn¾X?€àˆd` ¯–ßP¸-}§¼Vååèìì¼Ë90j±÷]wy/F"*ï:×§fÔ-ÿ6p+»£¢wzkváPGíû!P K[ˆÚ×ÊÙ y¢3¦ˆrÞd`«3¤ËlÆ7n$5®ËMµœ;ÝwºÏÒ×g9m±XdZ.È ûüôiËbòÎ]î“]ÖòñiKß9Ð~Þ'#ê>qj¹B*æË>™ìci9E¶±@ë‚åc2[,},–s羄ûr3Ç~ÌN•Ý .äCþ·ßèÊå …¬\A)ÊyrU®¤xJE¹, B!v‘’'Sˆ#xõlJ!^òÙ™c?}nm¼uÕ-eĘ­X¤Q1¦”å`†°r…B!Æ”²ÿÉXö”íQÿ–1wR®xI¡ˆoJ¬°+ãÉd‹""°|)âçÆœ[ß·¢®Îu±ìö`ß8ãÙò[«¿½]¶2™ûìÌçFƒŠfO$2ÊF#‚xŠ CR@¡òæ}â+Nʲ÷Ÿ¨þoyÇßg—®vb¯[Pý@§Û¥~e„$BÉóµ"<@ãíã±{[xJ%îžo¬¸ê3Î,¾UÜ80 àÏÚÚ[Ô²âÎñ¶ðŠ:šÖ‚xbog´bS¢ÏXp¤c,5ÇŒùmt¯³W z¥0A,­Âu£Qw24HýThƒn»n{hî¤Ô³ÜÐÓ<(:fþ ´ªRÏŸq¤ÇT^^VV¾åÚ»£¯UT¼QÁ°·¬lo9¦ S¢¦(#|¤’€’Ê3)3R%êÜpW3Zó*Ÿñ…ÔÔÌä»=zMRmaØzìØV•ÊÛÀ›omè”y£žèæ3Q°ñÐÞ 321ç¾gùè±2…lk{3¹½=/Ï`ˆmnŽ®><Ôd%%-HÊÊJòdyÓÎ9ÇXű¾7ûºF£Ñj·i{¼èƒu·qwc£vw%ÈP«ÔTVj™=•ÚQ ¨Wj41¢mƒ xÙ¦Õ.á]ZÍ 0f˯[G’B²iÝg;Õ$$±CH ÄLr AOkVˆVM™2‚XC’„ˆÈ$!)#5Ay )‰ˆ™ŸÂ¹ër–¾ž;qȾ¿ŽîÛïÒçÏtpiú,>ŸŸÌON†±!$N·Yº`<ÌhVÐød1óóÑäéùhñdVóWàpÏ•³ž8øíssçnœýÞüù³!𲱟á”Õ`0X­°ä¢|u!×úûÄ64 ƒU°'÷ :hÅ1|5t /±S+BÖÓpîtœ•“: ø®ï7«û ó1âTM4Cõášhø‰pƒ¯r@5“åH!N¨Áq:ŸKäK¢«Š®£Õ/ÈYíë'´´LP™ZM¦¬AÁ˜aý/N˜¤Úa2© ;T2´þHŸ qí2$Sá¡EçµP‚ b‡i!J@Z‡c¥ w˜ÚáP9*0¾7<îÉððÖR½þ#ýÑÛSG÷ŸÖçbØ=P}-´·£v)²WáU€¤ö([oGv½þ„Æéõ„˜@ñ¥z) ªªôGsÁ8u󜊡ZXø×ß,®ûqЈpjYW?”PFÍj/FTM6’RRiʦ2 ¯£âÑ~ªN,E?¢¨ýRÀi,¾Aâ¦ÙÛhÚ†›ÙF»NÚ©¤ç½ÝçÃASÞr;iÚ¥´¹\63<›Ýn7M»]4­P:Í.§Ófs)Ì3Q¼BA»Ì4m6Óf¥ÍìR:é4æ–®•G>ÄåWû÷)|$9héó«‘!?'Þã–G/^îÇ÷?/Omi™ZØE|ÆÓÒt~ŠîµkçuÑW—61>46²[tÜû©—w+õÿ/…ÝÁ? ‘|À °M™IEND®B`‚ Catalyst-Controller-HTML-FormFu-2.02/t/elements/000755 000765 000024 00000000000 13110553642 021620 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/lib/000755 000765 000024 00000000000 13110553642 020552 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/root/000755 000765 000024 00000000000 13110553642 020767 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/root/form.tt000644 000765 000024 00000000111 13110553642 022274 0ustar00nigelstaff000000 000000 [% form %]

[% message.join(', ') %]

Catalyst-Controller-HTML-FormFu-2.02/t/root/forms/000755 000765 000024 00000000000 13110553642 022115 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/root/multiform.tt000644 000765 000024 00000000166 13110553642 023361 0ustar00nigelstaff000000 000000 [% IF multiform.complete %] Complete [% results %] [% ELSE %] [% multiform %] [% END %] Catalyst-Controller-HTML-FormFu-2.02/t/root/forms/basic/000755 000765 000024 00000000000 13110553642 023176 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/root/forms/multiform/000755 000765 000024 00000000000 13110553642 024133 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/root/forms/multiform/file_upload.yml000644 000765 000024 00000000304 13110553642 027136 0ustar00nigelstaff000000 000000 --- id: file-upload params_ignore_underscore: 1 crypt_args: -key: 'my secret' forms: - element: type: File name: image1 - element: type: File name: image2 Catalyst-Controller-HTML-FormFu-2.02/t/root/forms/multiform/formconfig.yml000644 000765 000024 00000000237 13110553642 027011 0ustar00nigelstaff000000 000000 --- id: formconfig params_ignore_underscore: 1 crypt_args: -key: 'my secret' forms: - element: name: page1 - element: name: page2 Catalyst-Controller-HTML-FormFu-2.02/t/root/forms/basic/formconfig.yml000644 000765 000024 00000000220 13110553642 026044 0ustar00nigelstaff000000 000000 --- elements: - name: basic_formconfig label: __uri_for(/uri_for)__ constraint: - Required - type: Submit name: submit Catalyst-Controller-HTML-FormFu-2.02/t/root/forms/basic/formconfig_conf_ext.yml000644 000765 000024 00000000062 13110553642 027735 0ustar00nigelstaff000000 000000 --- elements: - name: basic_formconfig_conf_ext Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/000755 000765 000024 00000000000 13110553642 022132 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp.pm000644 000765 000024 00000000631 13110553642 022470 0ustar00nigelstaff000000 000000 package TestApp; use strict; use warnings; use Catalyst::Runtime '5.70'; use FindBin; use Catalyst qw/ Session Session::State::Cookie Session::Store::File /; our $VERSION = '0.01'; __PACKAGE__->config( name => 'TestApp', home => "$FindBin::Bin/../t", 'Controller::HTML::FormFu' => { default_action_use_path => 1, }, ); __PACKAGE__->setup; 1; Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/Controller/000755 000765 000024 00000000000 13110553642 024255 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/View/000755 000765 000024 00000000000 13110553642 023044 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/View/TT.pm000644 000765 000024 00000000222 13110553642 023725 0ustar00nigelstaff000000 000000 package TestApp::View::TT; use strict; use base 'Catalyst::View::TT'; __PACKAGE__->config( INCLUDE_PATH => [ TestApp->path_to('root') ], ); 1; Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/Controller/Basic.pm000644 000765 000024 00000002365 13110553642 025642 0ustar00nigelstaff000000 000000 package TestApp::Controller::Basic; use strict; use warnings; use base 'Catalyst::Controller::HTML::FormFu'; sub basic : Chained : CaptureArgs(0) { my ( $self, $c ) = @_; $c->stash->{template} = 'form.tt'; } sub form : Chained('basic') : Args(0) : Form { my ( $self, $c ) = @_; my $form = $c->stash->{form}; $form->element( { name => 'basic_form' } ); } sub formconfig : Chained('basic') : Args(0) : FormConfig { } sub formconfig_FORM_NOT_SUBMITTED { my ( $self, $c ) = @_; push @{ $c->stash->{message} }, 'not submitted'; } sub formconfig_FORM_SUBMITTED { my ( $self, $c ) = @_; push @{ $c->stash->{message} }, 'submitted'; } sub formconfig_FORM_NOT_VALID { my ( $self, $c ) = @_; push @{ $c->stash->{message} }, 'not valid'; } sub formconfig_FORM_VALID { my ( $self, $c ) = @_; push @{ $c->stash->{message} }, 'valid'; } sub formconfig_FORM_RENDER { my ( $self, $c ) = @_; push @{ $c->stash->{message} }, 'render'; } sub formconfig_conf_ext : Chained('basic') : Args(0) : FormConfig('basic/formconfig_conf_ext') { } sub formmethod : Chained('basic') : Args(0) : FormMethod('_load_form') { } sub _load_form : Private { return { element => { name => 'basic_formmethod', } }; } 1; Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/Controller/MultiForm.pm000644 000765 000024 00000004024 13110553642 026531 0ustar00nigelstaff000000 000000 package TestApp::Controller::MultiForm; use strict; use warnings; use base 'Catalyst::Controller::HTML::FormFu'; sub multiform : Chained : CaptureArgs(0) { my ( $self, $c ) = @_; $c->stash->{template} = 'multiform.tt'; } sub formconfig : Chained('multiform') : Args(0) : MultiFormConfig { } sub formconfig_FORM_COMPLETE { my ( $self, $c ) = @_; my $multi = $c->stash->{multiform}; if ( $multi->complete ) { my $params = $multi->current_form->params; $c->stash->{results} = join "\n", map { sprintf "%s: %s", $_, $params->{$_} } keys %$params; $c->stash->{message} = 'Complete'; } } sub formmethod : Chained('multiform') : Args(0) : MultiFormMethod('_load_form') { } sub formmethod_FORM_COMPLETE { my ( $self, $c ) = @_; my $multi = $c->stash->{multiform}; if ( $multi->complete ) { my $params = $multi->current_form->params; $c->stash->{results} = join "\n", map { sprintf "%s: %s", $_, $params->{$_} } keys %$params; $c->stash->{message} = 'Complete'; } } sub _load_form : Private { return { id => 'formmethod', params_ignore_underscore => 1, crypt_args => { '-key' => 'my secret', }, forms => [ { element => { name => 'page1' }, }, { element => { name => 'page2' }, } ], }; } sub file_upload : Chained('multiform') : Args(0) : MultiFormConfig { } sub file_upload_FORM_COMPLETE { my ( $self, $c ) = @_; my $multi = $c->stash->{multiform}; if ( $multi->complete ) { my $params = $multi->current_form->params; $c->stash->{results} = ''; for ( keys %$params ) { my $upload = $params->{$_}; my $size = $upload->size; my $filename = $upload->filename; my $type = $upload->type; $c->stash->{results} .= <stash->{message} = 'Complete'; } } 1; Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/Controller/MultiFormToken.pm000644 000765 000024 00000002741 13110553642 027536 0ustar00nigelstaff000000 000000 package TestApp::Controller::MultiFormToken; use strict; use warnings; use base 'Catalyst::Controller::HTML::FormFu'; __PACKAGE__->config( { 'Controller::HTML::FormFu' => { request_token_enable => 1 } } ); sub multiformtoken : Chained : CaptureArgs(0) { my ( $self, $c ) = @_; $c->stash->{template} = 'multiform.tt'; } sub formconfig : Chained('multiformtoken') : Args(0) : MultiFormConfig('multiform/formconfig') { my ( $self, $c ) = @_; my $multi = $c->stash->{multiform}; $multi->action('/multiformtoken/formconfig'); if ( $multi->complete ) { my $params = $multi->current_form->params; $c->stash->{results} = join "\n", map { sprintf "%s: %s", $_, $params->{$_} } keys %$params; $c->stash->{message} = 'Complete'; } } sub file_upload : Chained('multiformtoken') : Args(0) : MultiFormConfig { my ( $self, $c ) = @_; my $multi = $c->stash->{multiform}; if ( $multi->complete ) { my $params = $multi->current_form->params; $c->stash->{results} = ''; for ( keys %$params ) { my $upload = $params->{$_}; my $size = $upload->size; my $length = length $upload->slurp; my $filename = $upload->filename; my $type = $upload->type; $c->stash->{results} .= <stash->{message} = 'Complete'; } } 1; Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/Controller/Root.pm000644 000765 000024 00000000302 13110553642 025531 0ustar00nigelstaff000000 000000 package TestApp::Controller::Root; use strict; use warnings; use base 'Catalyst::Controller::HTML::FormFu'; __PACKAGE__->config->{namespace} = ''; sub end : ActionClass('RenderView') { } 1; Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/Controller/Token.pm000644 000765 000024 00000001540 13110553642 025673 0ustar00nigelstaff000000 000000 package TestApp::Controller::Token; use strict; use warnings; use Data::Dumper; use base 'Catalyst::Controller::HTML::FormFu'; __PACKAGE__->config( { 'Controller::HTML::FormFu' => { request_token_enable => 1 } } ); sub token : Chained : CaptureArgs(0) { my ( $self, $c ) = @_; $c->stash->{template} = 'form.tt'; } sub form : Chained('token') : Args(0) : Form { my ( $self, $c ) = @_; my $form = $c->stash->{form}; $form->elements( [ { name => 'basic_form', constraint => ['Required'] }, { type => "Submit" } ] ); $form->process($c->req); if ( $form->submitted_and_valid ) { $c->res->body("VALID"); } } sub dump_session : Local { my ( $self, $c ) = @_; $c->res->body( Dumper $c->session ); } sub count_token : Local { my ( $self, $c ) = @_; $c->res->body( scalar @{ $c->session->{__token} || [] } ); } 1; Catalyst-Controller-HTML-FormFu-2.02/t/lib/TestApp/Controller/TokenExpire.pm000644 000765 000024 00000001451 13110553642 027051 0ustar00nigelstaff000000 000000 package TestApp::Controller::TokenExpire; use strict; use warnings; use Data::Dumper; use base 'Catalyst::Controller::HTML::FormFu'; __PACKAGE__->config( { 'Controller::HTML::FormFu' => { request_token_session_key => '_token', request_token_enable => 1, request_token_field_name => 'token', request_token_expiration_time => -10 } } ); sub tokenexpire : Chained : CaptureArgs(0) { my ( $self, $c ) = @_; $c->stash->{template} = 'form.tt'; } sub form : Chained('tokenexpire') : Args(0) : Form { my ( $self, $c ) = @_; my $form = $c->stash->{form}; $form->elements( [ { name => 'basic_form' }, { type => "Submit" } ] ); if ( $form->submitted_and_valid ) { $c->res->body("VALID"); } } 1; Catalyst-Controller-HTML-FormFu-2.02/t/elements/requesttoken.t000644 000765 000024 00000000752 13110553642 024542 0ustar00nigelstaff000000 000000 { package main; use strict; use warnings; use Test::More tests => 2; use HTML::FormFu; my $form = HTML::FormFu->new; $form->stash->{context} = new C::Fake; $form->load_config_file('t/elements/requesttoken.yml'); like( $form, qr/ ( is => 'rw', traits => ['FormFuChained'] ); has field_name => ( is => 'rw', traits => ['FormFuChained'] ); has session_key => ( is => 'rw', traits => ['FormFuChained'] ); has expiration_time => ( is => 'rw', traits => ['FormFuChained'] ); sub process { my ($self) = @_; return if $self->form->get_all_element( { name => $self->field_name } ); my $c = $self->form->stash->{'context'}; $self->form->elements( [ { type => 'RequestToken', name => $self->field_name, expiration_time => $self->expiration_time, context => $self->context, session_key => $self->session_key } ] ); return; } 1; Catalyst-Controller-HTML-FormFu-2.02/lib/HTML/FormFu/Element/RequestToken.pm000644 000765 000024 00000007645 13110553642 026645 0ustar00nigelstaff000000 000000 package HTML::FormFu::Element::RequestToken; use strict; our $VERSION = '2.02'; # VERSION use Moose; use MooseX::Attribute::FormFuChained; extends 'HTML::FormFu::Element::Text'; use HTML::FormFu::Util qw( process_attrs ); use Carp qw( croak ); has expiration_time => ( is => 'rw', traits => ['FormFuChained'], default => 3600 ); has session_key => ( is => 'rw', traits => ['FormFuChained'], default => '__token' ); has context => ( is => 'rw', traits => ['FormFuChained'], default => 'context' ); has limit => ( is => 'rw', traits => ['FormFuChained'], default => 20 ); has message => ( is => 'rw', traits => ['FormFuChained'], default => 'Form submission failed. Please try again.' ); after BUILD => sub { my $self = shift; $self->name('_token'); $self->constraints([qw(RequestToken Required)]); $self->field_type('hidden'); }; sub process_value { my ($self, $value) = @_; return $self->verify_token($value) ? $value : $self->value($self->get_token)->value; } sub verify_token { my ($self, $token) = @_; return unless($token); my $form = $self->form; croak "verify_token() can only be called if form has been submitted" if !$form->submitted; my $field_name = $self->name; my $c = $self->form->stash->{ $self->context }; for ( @{ $c->session->{ $self->session_key } || [] } ) { return 1 if ( $_->[0] eq $token ); } return; } sub expire_token { my ($self) = @_; my $c = $self->form->stash->{ $self->context }; my @token; for ( @{ $c->session->{ $self->session_key } || [] } ) { push( @token, $_ ) if ( $_->[1] > time ); } @token = splice(@token, -$self->limit, $self->limit) if(@token > $self->limit); $c->session->{ $self->session_key } = \@token; } sub get_token { my ($self) = @_; my $token; my $c = $self->form->stash->{ $self->context }; my @chars = ( 'a' .. 'z', 0 .. 9 ); $token .= $chars[ int( rand() * 36 ) ] for ( 0 .. 15 ); $c->session->{ $self->session_key } ||= []; push @{ $c->session->{ $self->session_key } }, [ $token, time + $self->expiration_time ]; $self->expire_token; return $token; } 1; __END__ =head1 NAME HTML::FormFu::Element::RequestToken - Hidden text field which contains a unique token =head1 VERSION version 2.02 =head1 SYNOPSIS my $e = $form->element( { type => 'Token' } ); my $p = $form->element( { plugin => 'Token' } ); =head1 DESCRIPTION This field can prevent CSRF attacks. It contains a random token. After submission the token is checked with the token which is stored in the session of the current user. See L for a convenient way how to use it. =head1 ATTRIBUTES =head2 context Value of the stash key for the Catalyst context object (C<< $c >>). Defaults to C. =head2 expiration_time Time to life for a token in seconds. Defaults to C<3600>. =head2 session_key Session key which is used to store the tokens. Defaults to C<__token>. =head2 limit Limit the number of tokens which are kept in the session. Defaults to 20. =head2 constraints Defaults to L and L. =head2 message Set the error message. =head1 METHODS =head2 expire_token This method looks in the session for expired tokens and removes them. =head2 get_token Generates a new token and stores it in the stash. =head2 verify_token Checks whether a given token is already in the session. Returns C<1> if it exists, C<0> otherwise. =head1 SEE ALSO L, L, L L =head1 AUTHOR Moritz Onken, C =head1 LICENSE This library is free software, you can redistribute it and/or modify it under the same terms as Perl itself. Catalyst-Controller-HTML-FormFu-2.02/lib/HTML/FormFu/Constraint/RequestToken.pm000644 000765 000024 00000000546 13110553642 027371 0ustar00nigelstaff000000 000000 package HTML::FormFu::Constraint::RequestToken; use strict; our $VERSION = '2.02'; # VERSION use Moose; extends 'HTML::FormFu::Constraint'; sub BUILD { my ( $self, $args ) = @_; $self->message($self->parent->message); return; } sub constrain_value { my ( $self, $value ) = @_; return $self->parent->verify_token( $value ); } 1; Catalyst-Controller-HTML-FormFu-2.02/lib/Catalyst/Controller/000755 000765 000024 00000000000 13110553642 024216 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/lib/Catalyst/Helper/000755 000765 000024 00000000000 13110553642 023312 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/lib/Catalyst/Helper/HTML/000755 000765 000024 00000000000 13110553642 024056 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/lib/Catalyst/Helper/HTML/FormFu.pm000644 000765 000024 00000004222 13110553642 025612 0ustar00nigelstaff000000 000000 package Catalyst::Helper::HTML::FormFu; use strict; use warnings; our $VERSION = '2.02'; # VERSION use File::Spec; use HTML::FormFu::Deploy; use Carp qw/ croak /; sub mk_stuff { my ( $self, $helper, $dir ) = @_; my @files = HTML::FormFu::Deploy::file_list(); my $form_dir = File::Spec->catdir( $helper->{base}, 'root', ( defined $dir ? $dir : 'formfu' ) ); $helper->mk_dir($form_dir) unless -d $form_dir; for my $filename (@files) { my $path = File::Spec->catfile( $form_dir, $filename ); my $data = HTML::FormFu::Deploy::file_source($filename); $helper->mk_file( $path, $data ); } return; } 1; __END__ =head1 NAME Catalyst::Helper::HTML::FormFu - Helper to deploy HTML::FormFu template files. =head1 VERSION version 2.02 =head1 SYNOPSIS script/myapp_create.pl HTML::FormFu =head1 DESCRIPTION As of version 0.02000, L doesn't use the TT template files by default - it uses in internal rendering engine. If you don't want to customise the generated markup, you don't need to use L at all. If you want to customise the generated markup, you'll need a local copy of the template files. To create the files in the default C directory, run: script/myapp_create.pl HTML::FormFu To create the files in a different subdirectory of C, pass the path as an argument. The following example would create the template files into the directory C. script/myapp_create.pl HTML::FormFu forms You'll also need to tell HTML::FormFu to use the TT renderer, this can be achieved with L, with the following Catalyst application YAML config: --- 'Controller::HTML::FormFu': constructor: render_method: tt =head1 SUPPORT IRC: Join #catalyst on irc.perl.org. Mailing Lists: http://lists.rawmode.org/cgi-bin/mailman/listinfo/html-widget =head1 SEE ALSO L, L =head1 AUTHOR Carl Franks, C =head1 LICENSE This library is free software . You can redistribute it and/or modify it under the same terms as perl itself. =cut Catalyst-Controller-HTML-FormFu-2.02/lib/Catalyst/Controller/HTML/000755 000765 000024 00000000000 13110553642 024762 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/lib/Catalyst/Controller/HTML/FormFu/000755 000765 000024 00000000000 13110553642 026160 5ustar00nigelstaff000000 000000 Catalyst-Controller-HTML-FormFu-2.02/lib/Catalyst/Controller/HTML/FormFu.pm000644 000765 000024 00000047427 13110553642 026534 0ustar00nigelstaff000000 000000 package Catalyst::Controller::HTML::FormFu; use strict; our $VERSION = '2.02'; # VERSION use Moose; use HTML::FormFu; use Config::Any; use Regexp::Assemble; use Scalar::Util qw/ isweak weaken /; use Carp qw/ croak /; use namespace::autoclean; # see https://rt.cpan.org/Ticket/Display.html?id=55780 BEGIN { extends 'Catalyst::Controller'; } with 'Catalyst::Component::InstancePerContext'; has _html_formfu_config => ( is => 'rw' ); sub build_per_context_instance { my ( $self, $c ) = @_; return $self unless(ref $c); $self->{c} = $c; weaken( $self->{c} ) if !isweak( $self->{c} ); return $self; } sub BUILD {} after BUILD => sub { my ( $self ) = @_; my $app = $self->_app; my $self_config = $self->config->{'Controller::HTML::FormFu'} || {}; my $parent_config = $app->config->{'Controller::HTML::FormFu'} || {}; my %defaults = ( request_token_enable => 0, request_token_field_name => '_token', request_token_session_key => '__token', request_token_expiration_time => 3600, form_method => 'form', form_stash => 'form', form_attr => 'Form', config_attr => 'FormConfig', method_attr => 'FormMethod', form_action => "Catalyst::Controller::HTML::FormFu::Action::Form", config_action => "Catalyst::Controller::HTML::FormFu::Action::FormConfig", method_action => "Catalyst::Controller::HTML::FormFu::Action::FormMethod", multiform_method => 'multiform', multiform_stash => 'multiform', multiform_attr => 'MultiForm', multiform_config_attr => 'MultiFormConfig', multiform_method_attr => 'MultiFormMethod', multiform_action => "Catalyst::Controller::HTML::FormFu::Action::MultiForm", multiform_config_action => "Catalyst::Controller::HTML::FormFu::Action::MultiFormConfig", multiform_method_action => "Catalyst::Controller::HTML::FormFu::Action::MultiFormMethod", context_stash => 'context', model_stash => {}, constructor => {}, multiform_constructor => {}, config_callback => 1, ); my %args = ( %defaults, %$parent_config, %$self_config ); my $local_path = $app->path_to( 'root', 'formfu' ); if ( !exists $args{constructor}{tt_args} || !exists $args{constructor}{tt_args}{INCLUDE_PATH} && -d $local_path ) { $args{constructor}{tt_args}{INCLUDE_PATH} = [$local_path]; } $args{constructor}{query_type} ||= 'Catalyst'; if ( !exists $args{constructor}{config_file_path} ) { $args{constructor}{config_file_path} = $app->path_to( 'root', 'forms' ); } # build regexp of file extensions my $regex_builder = Regexp::Assemble->new; map { $regex_builder->add($_) } Config::Any->extensions; $args{_file_ext_regex} = $regex_builder->re; # save config for use by action classes $self->_html_formfu_config( \%args ); # add controller methods no strict 'refs'; ## no critic (ProhibitNoStrict); *{"$args{form_method}"} = \&_form; *{"$args{multiform_method}"} = \&_multiform; }; sub _form { my $self = shift; my $config = $self->_html_formfu_config; my $form = HTML::FormFu->new( { %{ $self->_html_formfu_config->{constructor} }, ( @_ ? %{ $_[0] } : () ), } ); $self->_common_construction($form); if ( $config->{request_token_enable} ) { $form->plugins( { type => 'RequestToken', context => $config->{context_stash}, field_name => $config->{request_token_field_name}, session_key => $config->{request_token_session_key}, expiration_time => $config->{request_token_expiration_time} } ); } return $form; } sub _multiform { my $self = shift; require HTML::FormFu::MultiForm; my $multi = HTML::FormFu::MultiForm->new( { %{ $self->_html_formfu_config->{constructor} }, %{ $self->_html_formfu_config->{multiform_constructor} }, ( @_ ? %{ $_[0] } : () ), } ); $self->_common_construction($multi); return $multi; } sub _common_construction { my ( $self, $form ) = @_; croak "form or multi arg required" if !defined $form; $form->query( $self->{c}->request ); my $config = $self->_html_formfu_config; if ( $config->{config_callback} ) { $form->config_callback( { plain_value => sub { return if !defined $_; s{__uri_for\((.+?)\)__} { $self->{c}->uri_for( split( '\s*,\s*', $1 ) ) }eg if /__uri_for\(/; s{__path_to\(\s*(.+?)\s*\)__} { $self->{c}->path_to( split( '\s*,\s*', $1 ) ) }eg if /__path_to\(/; s{__config\((.+?)\)__} { $self->{c}->config->{$1} }eg if /__config\(/; } } ); weaken( $self->{c} ) if !isweak( $self->{c} ); } if ( $config->{languages_from_context} ) { $form->languages( $self->{c}->languages ); } if ( $config->{localize_from_context} ) { $form->add_localize_object( $self->{c} ); } if ( $config->{default_action_use_name} ) { my $action = $self->{c}->uri_for( $self->{c}->{action}->name ); $self->{c} ->log->debug( "FormFu - Setting default action by name: $action" ) if $self->{c}->debug; $form->action($action); } elsif ( $config->{default_action_use_path} ) { my $action = $self->{c}->{request}->base . $self->{c}->{request}->path; $self->{c} ->log->debug( "FormFu - Setting default action by path: $action" ) if $self->{c}->debug; $form->action($action); } my $context_stash = $config->{context_stash}; $form->stash->{$context_stash} = $self->{c}; weaken( $form->stash->{$context_stash} ); my $model_stash = $config->{model_stash}; for my $model ( keys %$model_stash ) { $form->stash->{$model} = $self->{c}->model( $model_stash->{$model} ); } return; } sub create_action { my $self = shift; my %args = @_; my $config = $self->_html_formfu_config; for my $type ( qw/ form config method multiform multiform_config multiform_method / ) { my $attr = $config->{"${type}_attr"}; if ( exists $args{attributes}{$attr} ) { $args{_attr_params} = delete $args{attributes}{$attr}; } elsif ( exists $args{attributes}{"$attr()"} ) { $args{_attr_params} = delete $args{attributes}{"$attr()"}; } else { next; } push @{ $args{attributes}{ActionClass} }, $config->{"${type}_action"}; last; } $self->SUPER::create_action(%args); } 1; __END__ =head1 NAME Catalyst::Controller::HTML::FormFu - Catalyst integration for HTML::FormFu =head1 VERSION version 2.02 =head1 SYNOPSIS package MyApp::Controller::My::Controller; use Moose; use namespace::autoclean; BEGIN { extends 'Catalyst::Controller::HTML::FormFu'; } sub index : Local { my ( $self, $c ) = @_; # doesn't use an Attribute to make a form # can get an empty form from $self->form() my $form = $self->form(); } sub foo : Local : Form { my ( $self, $c ) = @_; # using the Form attribute is equivalent to: # # my $form = $self->form; # # $form->process; # # $c->stash->{form} = $form; } sub bar : Local : FormConfig { my ( $self, $c ) = @_; # using the FormConfig attribute is equivalent to: # # my $form = $self->form; # # $form->load_config_filestem('root/forms/my/controller/bar'); # # $form->process; # # $c->stash->{form} = $form; # # so you only need to do the following... my $form = $c->stash->{form}; if ( $form->submitted_and_valid ) { do_something(); } } sub baz : Local : FormConfig('my_config') { my ( $self, $c ) = @_; # using the FormConfig attribute with an argument is equivalent to: # # my $form = $self->form; # # $form->load_config_filestem('root/forms/my_config'); # # $form->process; # # $c->stash->{form} = $form; # # so you only need to do the following... my $form = $c->stash->{form}; if ( $form->submitted_and_valid ) { do_something(); } } sub quux : Local : FormMethod('load_form') { my ( $self, $c ) = @_; # using the FormMethod attribute with an argument is equivalent to: # # my $form = $self->form; # # $form->populate( $c->load_form ); # # $form->process; # # $c->stash->{form} = $form; # # so you only need to do the following... my $form = $c->stash->{form}; if ( $form->submitted_and_valid ) { do_something(); } } sub load_form { my ( $self, $c ) = @_; # Automatically called by the above FormMethod('load_form') action. # Called as a method on the controller object, with the context # object as an argument. # Must return a hash-ref suitable to be fed to $form->populate() } You can also use specially-named actions that will only be called under certain circumstances. sub edit : Chained('group') : PathPart : Args(0) : FormConfig { } sub edit_FORM_VALID { my ( $self, $c ) = @_; my $form = $c->stash->{form}; my $group = $c->stash->{group}; $form->model->update( $group ); $c->response->redirect( $c->uri_for( '/group', $group->id ) ); } sub edit_FORM_NOT_SUBMITTED { my ( $self, $c ) = @_; my $form = $c->stash->{form}; my $group = $c->stash->{group}; $form->model->default_values( $group ); } =head1 METHODS =head2 form This creates a new L object, passing as it's argument the contents of the L config value. This is useful when using the ConfigForm() or MethodForm() action attributes, to create a 2nd form which isn't populated using a config-file or method return value. sub foo : Local { my ( $self, $c ) = @_; my $form = $self->form; } Note that when using this method, the form's L method is not populated with the Catalyst request object. =head1 SPECIAL ACTION NAMES An example showing how a complicated action method can be broken down into smaller sections, making it clearer which code will be run, and when. sub edit : Local : FormConfig { my ( $self, $c ) = @_; my $form = $c->stash->{form}; my $group = $c->stash->{group}; $c->detach('/unauthorised') unless $c->user->can_edit( $group ); if ( $form->submitted_and_valid ) { $form->model->update( $group ); $c->response->redirect( $c->uri_for('/group', $group->id ) ); return; } elsif ( !$form->submitted ) { $form->model->default_values( $group ); } $self->_add_breadcrumbs_nav( $c, $group ); } Instead becomes... sub edit : Local : FormConfig { my ( $self, $c ) = @_; $c->detach('/unauthorised') unless $c->user->can_edit( $c->stash->{group} ); } sub edit_FORM_VALID { my ( $self, $c ) = @_; my $group = $c->stash->{group}; $c->stash->{form}->model->update( $group ); $c->response->redirect( $c->uri_for('/group', $group->id ) ); } sub edit_FORM_NOT_SUBMITTED { my ( $self, $c ) = @_; $c->stash->{form}->model->default_values( $c->stash->{group} ); } sub edit_FORM_RENDER { my ( $self, $c ) = @_; $self->_add_breadcrumbs_nav( $c, $c->stash->{group} ); } For any action method that uses a C
, C or C attribute, you can add extra methods that use the naming conventions below. These methods will be called after the original, plainly named action method. =head2 _FORM_VALID Run when the form has been submitted and has no errors. =head2 _FORM_SUBMITTED Run when the form has been submitted, regardless of whether or not there was errors. =head2 _FORM_COMPLETE For MultiForms, is run if the MultiForm is completed. =head2 _FORM_NOT_VALID Run when the form has been submitted and there were errors. =head2 _FORM_NOT_SUBMITTED Run when the form has not been submitted. =head2 _FORM_NOT_COMPLETE For MultiForms, is run if the MultiForm is not completed. =head2 _FORM_RENDER For normal C base classes, this subroutine is run after any of the other special methods, unless C<< $form->submitted_and_valid >> is true. For C base classes, this subroutine is run after any of the other special methods, unless C<< $multi->complete >> is true. =head1 CUSTOMIZATION You can set your own config settings, using either your controller config or your application config. $c->config( 'Controller::HTML::FormFu' => \%my_values ); # or MyApp->config( 'Controller::HTML::FormFu' => \%my_values ); # or, in myapp.conf default_action_use_path 1 =head2 form_method Override the method-name used to create a new form object. See L. Default value: C
. =head2 form_stash Sets the stash key name used to store the form object. Default value: C. =head2 form_attr Sets the attribute name used to load the L action. Default value: C. =head2 config_attr Sets the attribute name used to load the L action. Default value: C. =head2 method_attr Sets the attribute name used to load the L action. Default value: C. =head2 form_action Sets which package will be used by the Form() action. Probably only useful if you want to create a sub-class which provides custom behaviour. Default value: C. =head2 config_action Sets which package will be used by the Config() action. Probably only useful if you want to create a sub-class which provides custom behaviour. Default value: C. =head2 method_action Sets which package will be used by the Method() action. Probably only useful if you want to create a sub-class which provides custom behaviour. Default value: C. =head2 constructor Pass common defaults to the L. These values are used by all of the action attributes, and by the C<< $self->form >> method. Default value: C<{}>. =head2 config_callback Arguments: bool If true, a coderef is passed to C<< $form->config_callback->{plain_value} >> which replaces any instance of C<__uri_for(URI)__> found in form config files with the result of passing the C argument to L. The form C<< __uri_for(URI, PATH, PARTS)__ >> is also supported, which is equivalent to C<< $c->uri_for( 'URI', \@ARGS ) >>. At this time, there is no way to pass query values equivalent to C<< $c->uri_for( 'URI', \@ARGS, \%QUERY_VALUES ) >>. The second codeword that is being replaced is C<__path_to( @DIRS )__>. Any instance is replaced with the result of passing the C arguments to L. Don't use qoutationmarks as they would become part of the path. Default value: 1 =head2 default_action_use_name If set to a true value the action for the form will be set to the currently called action name. Default value: C. =head2 default_action_use_path If set to a true value the action for the form will be set to the currently called action path. The action path includes concurrent to action name additioal parameters which were code inside the path. Default value: C. Example: action: /foo/bar called uri contains: /foo/bar/1 # default_action_use_name => 1 leads to: $form->action = /foo/bar # default_action_use_path => 1 leads to: $form->action = /foo/bar/1 =head2 model_stash Arguments: \%stash_keys_to_model_names Used to place Catalyst models on the form stash. If it's being used to make a L schema available for L, for C