| Resource | Required Server Environment |
|---|---|
| Perl | 5.8.8 or higher. A minimum of perl 5.12 is recommended. |
| External programs | GNU diff 2.7 or higher, fgrep, and egrep (not required on Windows) |
| Web server | Apache, Nginx and Lighttpd are all well supported; Apache sample configs are provided. For information on other servers, see Foswiki:Support.InstallingOnSpecificPlatforms. |
configure script is run, but start from your expected default "view" URL, so that Foswiki can figure out your URL scheme.
Use either the bin/configure web interface, or the tools/configure perl script, to configure Foswiki. This will explore and test critical dependencies and alert you when any are missing. For a detailed report, See PerlDependencyReport.
Prior versions of Foswiki shipped with the important CPAN modules, for use as a "last resort". Since they are needed only in rare situations,
they were put into an optional extension. See Foswiki:Extensions.CpanContrib. Install this extension into your Foswiki installation directory if you cannot install Perl modules otherwise.
You can check the dependencies before Foswiki is fully operational with the following command. It will list all potentially missing dependencies. Not all listed dependences are required on all installations, Refer to the usage message that accompanies each missing dependency in the report.
cd /path/to/foswiki perl tools/dependencies
apt-get install apache2 rcs
| Perl Module | Package to install | Notes |
|---|---|---|
| Algorithm::Diff | libalgorithm-diff-perl |
|
| Archive::Tar | libarchive-tar-perl |
|
| Authen::SASL | libauthen-sasl-perl |
note, broken on Ubuntu 11.10 x64. Install using CPAN! |
| CGI | libcgi-pm-perl |
|
| CGI::Session | libcgi-session-perl |
|
| Crypt::PasswdMD5 | libcrypt-passwdmd5-perl |
|
| Digest::SHA | libdigest-sha-perl |
*First shipped in perl 5.9.3 |
| Encode | libencode-perl |
|
| Error | liberror-perl |
|
| FCGI | libfcgi-perl |
Optional, needed for fastcgi / fcgi apache modules |
| File::Copy::Recursive | libfile-copy-recursive-perl |
|
| HTML::Parser | libhtml-parser-perl |
|
| HTML::Tree | libhtml-tree-perl |
|
| IO::Socket::IP | libio-socket-ip-perl |
First shipped perl 5.19.8 |
| IO::Socket::SSL | libio-socket-ssl-perl |
|
| JSON | libjson-perl |
|
| Locale::Maketext::Lexicon | liblocale-maketext-lexicon-perl |
Optional, needed for internationalization |
| Locale::Msgfmt | liblocale-msgfmt-perl |
Optional, needed for internationalization |
| LWP | libwww-perl |
|
| URI | liburi-perl |
|
| version | libversion-perl |
First shipped perl 5.10.1, must be version 0.77 or newer |
apt-get install libalgorithm-diff-perl libarchive-tar-perl libauthen-sasl-perl libcgi-pm-perl libcgi-session-perl libcrypt-passwdmd5-perl libdigest-sha-perl libencode-perl liberror-perl libfcgi-perl libfile-copy-recursive-perl libhtml-parser-perl libhtml-tree-perl libio-socket-ip-perl libio-socket-ssl-perl libjson-perl liblocale-maketext-lexicon-perl liblocale-msgfmt-perl libwww-perl liburi-perl libversion-perl
After expanding the Foswiki archive, change the ownership of the files: chown -R www-data:www-data /path/to/foswiki
a2enmod cgi a2enmod access_compat | Perl Module | Package to install | Notes |
|---|---|---|
| Algorithm::Diff | perl-Algorithm-Diff |
|
| Archive::Tar | perl-Archive-Tar |
*First shipped in perl 5.9.3 |
| Authen::SASL | perl-Authen-SASL |
|
| CGI | perl-CGI |
|
| CGI::Session | perl-CGI-Session |
|
| Crypt::PasswdMD5 | perl-Crypt-PasswdMD5 |
|
| Digest::SHA | perl-Digest-SHA |
*First shipped in perl 5.9.3 |
| Encode | perl-Encode |
|
| Error | perl-Error |
|
| File::Copy::Recursive | perl-File-Copy-Recursive |
|
| HTML::Parser | perl-HTML-Parser |
|
| HTML::Tree | perl-HTML-Tree |
|
| IO::Socket::IP | perl-IO-Socket-IP |
First shipped perl 5.19.8 |
| IO::Socket::SSL | perl-IO-Socket-SSL |
|
| JSON | perl-JSON |
|
| Locale::Maketext::Lexicon | perl-Locale-Maketext-Lexicon |
Optional, needed for internationalization |
| Locale::Msgfmt | perl-Locale-Msgfmt |
Optional, needed for internationalization |
| LWP | perl-libwww-perl |
|
| version | perl-Perl-Version |
Must be version 0.77 or newer |
| Digest::SHA | perl-Digest-SHA |
|
| URI | perl-URI |
chown -R wwwrun:www /path/to/foswiki
www-servers/apache, dev-vcs/rcs, and dev-lang/perl
| Perl Module | Package to install | Notes |
|---|---|---|
| Algorithm::Diff | dev-perl/Algorithm-Diff |
|
| Archive::Tar | perl-Archive-Tar |
*First shipped in perl 5.9.3 |
| Authen::SASL | dev-perl/Authen-SASL |
Optional, needed for authenticated SMTP |
| CGI | perl-core/CGI |
|
| CGI::Session | dev-perl/CGI-Session |
|
| Crypt::PasswdMD5 | dev-perl/Crypt-PasswdMD5 |
|
| Digest::SHA | perl-core/Digest-SHA |
Included with perl |
| Error | dev-perl/Error |
|
| Encode | perl-core/Encode |
|
| File::Copy::Recursive | dev-perl/File-Copy-Recursive |
|
| HTML::Parser | dev-perl/HTML-Parser |
|
| HTML::Tree | dev-perl/HTML-Tree |
|
| IO::Socket::IP | dev-perl/IO-Socket-IP |
|
| IO::Socket::SSL | dev-perl/IO-Socket-SSL |
Optional, support encrypted email connection: STARTTLS or SSL |
| JSON | dev-perl/JSON |
|
| Locale::Maketext::Lexicon | dev-perl/locale-maketext-lexicon |
Optional, needed for internationalization |
| Locale::Msgfmt | dev-perl/Locale-Msgfmt |
Optional, needed for internationalization |
| LWP | dev-perl/libwww-perl |
|
| version | perl-core/version |
Must be version 0.77 or newer, included with perl |
| URI | dev-perl/URI |
perl-core/ generally are installed with perl. May be directly installed if updated versions are available.
After expanding the Foswiki archive, change the ownership of the files: chown -R apache:apache /var/www/path-to-foswiki
cpanm, aka App::cpanminus. On most unix* systems, cpanminus can bootstrap itself using curl or wget.
If run as root, the modules will be installed in the System perl. Otherwise they are installed into the users local environment.
curl -L http://cpanmin.us | perl - App::cpanminus (optional - install cpanminus if not available ) cpanm Algorithm::Diff Archive::Tar Authen::SASL CGI CGI::Session Crypt::PasswdMD5 Digest::SHA Error Encode File::Copy::Recursive HTML::Parser HTML::Tree IO::Socket::IP IO::Socket::SSL JSON Locale::Maketext::Lexicon Locale::Msgfmt LWP version URIIf you want to install the dependendencies into a specified location, add the
"-l" option to cpanm, and add the lib path to bin/LocalLib.cfg. The dependencies will be installed under the specified location, in the lib/perl5 subdirectory.
Example: User "foswiki" logs in and installs the libraries locally under the foswikideps directory:
cpanm -l foswikideps Algorithm::Diff Archive::Tar ... (install libraries into =/home/foswiki/foswikideps=)
/path/to/foswiki/bin/LocalLib.txt is then edited, and the commented line is modified:
# @localPerlLibPath = ( '/path/to/dir', '/path/to/another/dir', ); @localPerlLibPath = ( '/home/foswiki/foswikideps/lib/perl5', );Foswiki will now run using the libraries installed by cpanm.