CGI-Auth-Basic
view release on metacpan or search on metacpan
lib/CGI/Auth/Basic.pm view on Meta::CPAN
Printing HTTP Headers for the module' s GUI.
=back
If you don't use/need a C<CGI> object in your program, set the
parameter to C<AUTOLOAD_CGI>:
$obj = CGI::Auth::Basic->new(cgi_object => 'AUTOLOAD_CGI' ...)
Then, C<CGI::Auth::Basic> will load the CGI module itself and create
a C<CGI> object, which you can not access (however, you can access
with the related object table -- but this'll be weird. Create a C<CGI>
object yourself, if you need one and pass it to the module).
If you don't want to use the C<CGI> class, then you have to
give the module a similar object which has these methods:
C<param>, C<cookie>, C<header> and C<url>. They have to work as
the same as C<CGI> object's methods. If this object does not
match this requirement, your program may die or does not function
properly. Also pass C<ihacloaiwtui> parameter with a true value
to C<new()>:
$obj = CGI::Auth::Basic->new(cgi_object => $my_other_object,
ihacloaiwtui => 1, ... )
This string is the short form of
C<i_have_another_cgi_like_object_and_i_want_to_use_it>.
Yes, this parameter' s name is I<weird> (and silly), but I
couldn't find a better one.
=item ihacloaiwtui
See C<cgi_object>.
=item password
You need a password to validate the user. If you set this parameter,
it'll be used as the encoded password string. Note that; it B<MUST>
be a crypt()ed string. You must encode it with Perl's C<crypt()>
function. You can not login with a plain password string.
=item file
If you can't provide a password to the module, set this parameter's
value to a valid file path. It'll be your password file and will be
updated (change your password) if necessary. The module will use
this file to store/fetch password string. If the file does not exist,
the module will exit with an error. If the file is empty and you set
the C<setup_pfile> parameter to a true value, you'll be prompted to
enter a password for the first time.
You can not use C<password> and C<file> parameters together. You must
select one of them to use.
Note that: you must protect your password file(s). Put it above your
web root if you can. Also, giving it a I<.cgi> extension can be
helpful; if a web server tries to execute it, you'll get a 500 ISE,
not the source (you can get the source however; it depends on your
server software, OS and configuration). You can also put it in
a hard-to-guess named directory. But don't put it in your program
directory.
Also note that: these are I<just> suggestions and there is no
guarantee that any of this will work for you. Just test and see
the results.
=item setup_pfile
If your "I<password file>" is empty and you set this parameter to a
true value, then the module will ask you to enter a password for the
first time and will update the password file. Note that: someone
that runs the program will set the default value. Also, if you
forgot your password, set this parameter. You can replace your password
file with an empty file and run the program to set the password. You
can turn off this option after the password is set.
=item cookie_id
The name of the cookie and the name of the password area name
in the login form. Default value is I<password>.
=item http_charset
If you are using custom templates and changed the interface language,
set this to a correct value. Defaut is C<ISO-8859-1> (english).
=item logoff_param
Default value is C<logoff>. If the user is logged-in, you can show him/her
a logoff link (see L<logoff_link|/logoff_link> method). With the default value,
You'll get this link:
<your_program>?logoff=1
If you set it to C<logout>, you'll get:
<your_program>?logout=1
Just a cosmetic option, but good for translation.
=item cookie_timeout
When the user sends the correct password via the login form, the
module will send a password cookie to the user. Set this parameter
if you want to alter the module's setting. Default is an empty string
(means; cookie is a session cookie, it'll be deleted as soon as the user
closes all browser windows)
=item changep_param
Form area name for password change. Same as C<logoff_param>. Cosmetic
option.
=item chmod_value
Password file's chmod value. Default value is C<0777>. Change this value
if you get file open/write errors or want to use different level of
permission. Takes octal numbers like C<0777>.
=item use_flock
( run in 0.554 second using v1.01-cache-2.11-cpan-39bf76dae61 )