NAME

CGI::PathInfo - A lightweight CGI processing package for using CGI PATH_INFO as if it was GET method form parameters

SYNOPSIS

use CGI::PathInfo;

my $path_info = CGI::PathInfo->new;
my ($form_field_value) = $path_info->param('some_field_name');

DESCRIPTION

Provides a micro-weight equivalent to the CPAN CGI.pm module that permits the use of the CGI environment variable 'PATH_INFO' as a functional equivalent to the GET method 'QUERY_STRING'. This lets you use 'extra' URL path information as CGI parameters.

For example, lets say you have a CGI script at URL http://localhost/cgi-bin/myscript

If you were to call it as:

http://localhost/cgi-bin/myscript/some-thing/another-something/

your webserver should place '/some-thing/another-thing/' into the PATH_INFO environment variable when your script is run. CGI::PathInfo lets you treat that information as if it were ordinary CGI form data.

An Example:

You call http://localhost/cgi-bin/myscript/some-thing/another-something/ on your webserver. 'myscript' contains:

#!/usr/bin/perl -Tw

use strict;
use CGI::PathInfo;

my $path_info = CGI::PathInfo->new;
my $some      = $path_info->param('some'};
my $another   = $path_info->param('another');

At this point '$some' should contain the value 'thing' and '$another' should contain the value 'something'.

This is independant of the use of ordinary CGI parameters. It is perfectly OK to use both the PATH_INFO and normal CGI parameters at the same time.

Example:

You call http://localhost/cgi-bin/myscript/some-thing/another-something/?a=b on your webserver. 'myscript' contains:

#!/usr/bin/perl -Tw

use strict;
use CGI::PathInfo;
use CGI::Minimal;

my $path_info = CGI::PathInfo->new;
my $some      = $path_info->param('some'};
my $another   = $path_info->param('another');

my $cgi       = CGI::Minimal->new;
my $a_value   = $cgi->param('a');

At this point '$some' should contain the value 'thing', '$another' should contain the value 'something'. and '$a_value' should contain the value 'b'.

Rather than attempt to address every possible need of a CGI programmer, it provides the _minimum_ functions needed for CGI such as parameter decoding, URL encoding and decoding.

The parameters decoding interface is somewhat compatible with the CGI.pm module. No provision is made for generating HTTP or HTML on your behalf - you are expected to be conversant with how to put together any HTML or HTTP you need.

CGI::PathInfo is compatible with ModPerl 1 in addition to normal CGI.

CHANGES

 1.05 2020.09.26     - Permissions fix for build tools (Build.PL / Makefile.PL)

 1.04 2020.09.26     - Maintainer update. Relicensed under the MIT License.
                       Minor tweaks to build process. Added meta_merge
                       information for GitHub. Added 'use warnings'.

 1.03 2008.07.22     - Updated for ModPerl2 compatibility

 1.02 2005.10.08     - Extended test coverage to 100% of code, fixed bug
                      with the 'stripleadingslash', 'striptrailingslash'
                      code, added documentation of all instantation parameters
                      to 'new' method, fixed missing 'Build.PL' declaration
                      in MANIFEST. Fixed mis-calls of 'croak' after delayed
                      load in error paths.

 1.01 2005.09.30    - Seperated POD into .pod file. Added more build tests.
                      Added Build.PL, META.yml, GPL_License.txt, 
                      Artistic_License.txt, LICENSE. Deferred loading
                      of Carp and HTML::Entities unless needed.
                      
                      Removed dependency on 'vars'.  Fixed error in output
                      HTML from the 'calling_parms_table' method.

                      Extended documentation to explain what the module
                      is used for more clearly.

 1.00 22 July 2000 - Initial public release.

METHODS

new;

Creates a new instance of the CGI::PathInfo object and decodes any 'PATH_INFO' parameters.

Example:

use CGI::PathInfo;

my $path_info = CGI::PathInfo->new;

The defaults are for the parameters to be seperated by '/' characters with name/value pairs linked by '-' and with leading or trailing '/' characters ignored.

Example:

 $ENV{'PATH_INFO'} = '/yesterday-monday/tomorrow-wednesday/';

 decodes to

  'yesterday' -> 'monday'

  'tomorrow'  -> 'wednesday'

Values are read using the 'param' method.

Any of the defaults may be overridden by specifying them in the invokation of 'new'.

Example:

my $path_info = CGI::PathInfo->new({  Eq                 => '=',
                                      SplitOn            => '&',
                                      StripLeadingSlash  => 0,
                                      StripTrailingSlash => 0,
              });

The Eq parameter declares the key/value seperator, SplitOn declares the parameter tuples seperator, StripLeadingSlash turns on (or off) the stripping of '/' characters from the front of the path, StripTrailingSlash does the same for the end of the path string.

It is probably a Bad Idea (tm) to set the Eq or SplitOn values to a letter or a number (A-Za-z0-9) unless you are a wizard at encodings.

The defaults were chosen to maximize the likelyhood that CGI backed URLs will be crawled by search engines and that MSIE won't try something stupid because of a '.tla' on a URL.

param([$fieldname]);

Called as $path_info->param(); it returns the list of all defined parameter fields in the same order they appear in the data in PATH_INFO.

Called as $path_info->param($fieldname); it returns the value (or array of values for multiple occurances of the same field name) assigned to that $fieldname. If there is more than one value, the values are returned in the same order they appeared in the data from user agent.

If called in a scalar context when several values are present for specified parameter, the *first* value will be returned.

Examples:

my (@form_fields) = $path_info->param;

my (@multi_pick_field) = $path_info->param('pick_field_name');

my ($form_field_value) = $path_info->param('some_field_name');

You can also use the param method to set param values to new values. These values will be returned by this CGI::PathInfo object as if they had been found in the originally processed PATH_INFO data. This will not affect a seperately created instance of CGI::PathInfo.

Examples:

$path_info->param( 'name' => 'Joe Shmoe' );

$path_info->param({ 'name' => 'Joe Shmoe', 'birth_date' => '06/25/1966' });

$path_info->param({ 'pick_list' => ['01','05','07'] });
calling_parms_table;

Returns a formatted HTML table containing all the PATH_INFO parameters for debugging purposes

Example:

print $path_info->calling_parms_table;
url_encode($string);

Returns a URL encoding of the input string. Anything except 0-9a-zA-Z is escaped to %xx form.

The idea is to reserve all other characters for potential use as parameter or key/value seperators.

Example:

my $url_encoded_string = $path_info->url_encode($string);
url_decode($string);

Returns URL *decoding* of input string (%xx substitutions are decoded to their actual values).

Example:

my $url_decoded_string = $path_info->url_decode($string);

BUGS

None known.

TODO

Extend build tests. Investigate ModPerl2 compatibility.

AUTHORS

Jerilyn Franz <cpan@jerilyn.info>

VERSION

1.05 - released 2020.09.26

COPYRIGHT

Copyright (c) Jerilyn Franz and FreeRun Technologies. All rights reserved.

LICENSE

MIT License

Copyright (c) 2020 Jerilyn Franz

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

DISCLAIMER

THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

Use of this software in any way or in any form, source or binary, is not allowed in any country which prohibits disclaimers of any implied warranties of merchantability or fitness for a particular purpose or any disclaimers of a similar nature.

IN NO EVENT SHALL I BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION (INCLUDING, BUT NOT LIMITED TO, LOST PROFITS) EVEN IF I HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE