System wiki web
- Toolbox
-
Users
-
Groups?
-
Index
-
Search
-
Changes
-
Notifications
-
RSS Feed
-
Statistics
-
Preferences
- User Reference
- BeginnersStartHere
- TextFormattingRules
- Macros
- FormattedSearch
- QuerySearch
- DocumentGraphics
- SkinBrowser
- InstalledPlugins
Reference Manual (Foswiki-1.0.9, Sun, 17 Jan 2010, build 6075)
This page contains all documentation topics as one long, complete reference sheet.On this page:
Related Topics: UserDocumentationCategory, AdminDocumentationCategory
- System Requirements
- Installation Guide
- Foswiki Upgrade Guide
- Overview
- Upgrading to a new patch release
- Upgrade procedure: upgrading to a new major or minor version, or upgrading from TWiki
- Additional steps when upgrading from TWiki Cairo
- Important changes since TWiki 4.0.5
- Important changes for the upgrader - since TWiki 4.1.0
- Important changes for the upgrader - since TWiki 4.1.2
- Important changes for the upgrader - since Foswiki 1.0.4
- Important changes for the upgrader - since Foswiki 1.0.5
- User Authentication
- Access Control
- Text Formatting
- Macros
- Formatted Search
- File Attachments
- Data Forms
- Template topics
- Skin Templates
- Foswiki Skins
- Meta data
- Add-Ons
- Foswiki Contribs
- Foswiki Plugins
- Installed Plugins
- Failed Plugins
- Developing Plugins
- CGI and Command Line Scripts
- Site Tools
- Managing Topics
- Managing Webs
- Manage Users
- Appendix A: Foswiki Development Time-line
- Foswiki Release 1.0.9 - 17 Jan 2010
- Foswiki Release 1.0.8 - 29 Nov 2009
- Foswiki Release 1.0.7 - 20 Sep 2009
- Foswiki Release 1.0.6 - 21 Jun 2009
- Foswiki Release 1.0.5 - 25 Apr 2009
- Foswiki Release 1.0.4 - 19 Mar 2009
- Foswiki Release 1.0.3 - 28 Feb 2009
- Foswiki Release 1.0.2 - 26 Feb 2009
- Foswiki Release 1.0.1 - 24 Feb 2009
- Foswiki Release 1.0.0 - 09 Jan 2009
- TWiki Release 4.2.1 (Freetown) released 2010-01-17T14:13:06Z
- TWiki Release 4.1 (Edinburgh), 16 Jan 2007
- TWiki Release 4.0.0 (Dakar), 01 Feb 2006
- 01-Sep-2004 Release (Cairo)
- 01-Feb-2003 Release (Beijing)
- 01-Dec-2001 Release (Athens)
- 01-Sep-2001 Release
- 01-Dec-2000 Release
- 01-May-2000 Release
- 01-Sep-1999 Release
- 01-Jul-1999 Release
- 1998 Releases
- Dev Flow
- Appendix B: Encode URLs With UTF8
- Appendix C: CSS
System Requirements
Server and client requirements Low client and server base requirements are core features that keep Foswiki widely deployable, particularly across a range of browser platforms and versions. Many extensions exist which enhance and expand Foswiki's capabilities; they may have additional requirements.Server Requirements
The code is written in Perl 5, and uses a number of shell commands from perl. The default package requires RCS (Revision Control System), a GNU Free Software package. Foswiki is developed in a basic Linux/Apache environment. It also works with Microsoft Windows, and should have no problem on any other platform that meets the requirements.| Resource | Required Server Environment * |
|---|---|
| Perl | 5.6.1 or higher (5.8.4 or higher is recommended) |
| RCS | 5.7 or higher (including GNU diff) Optional, Foswiki includes a pure perl implementation of RCS that can be used instead (although it's slower) |
GNU diff |
GNU diff 2.7 or higher is required when not using the all-Perl RcsLite. Install on PATH if not included with RCS (check version with diff -v) Must be the version used by RCS, to avoid problems with binary attachments - RCS may have hard-coded path to diff |
GNU patch |
For upgrades only: GNU patch is required when patching the code using patches in diff format submitted by the community. |
GNU fgrep, egrep |
Modify command line parameters in configure if you use non-GNU grep programs |
| Cron/scheduler | • Unix: cron • Windows: cron equivalents |
| Web server | Apache is well supported; see Foswiki:Support.InstallingOnSpecificPlatforms for alternative options. |
Perl Modules
A complete list of the required and optional Perl modules can be found inlib/DEPENDENCIES.
Most of them will probably already be available in your installation. You can check version numbers with the configure script, or if you're still trying to get to that point, check from the command line like this:
perl -e 'use FileHandle; print $FileHandle::VERSION."\n"'
Client Requirements
The standard installation has relatively low browser requirements:- HTML 4 compliant
- Cookies, if persistent sessions are required
Important note about Plugins
- Plugins can require just about anything - browser-specific functions, stylesheets (CSS), Java applets, cookies, specific Perl modules,... - check the individual Plugin specs.
Related Topics: AdminDocumentationCategory Back to top
Installation Guide
This guide describes the steps for manually installing Foswiki, with specific steps for installations on Linux with the Apache web server. If you are using a different web server or operating system, in addition to reviewing this document, check any additional information specific to your platform at Foswiki:Support.SupplementalDocuments. Foswiki:Support.SupplementalDocuments also has information for other scenarios, such as shared web hosting environments. These installation instructions are also available online at Foswiki:System.InstallationGuide, and are available within your Foswiki installation atSystem.InstallationGuide (the InstallationGuide topic in the System web).
For information on upgrades, please also refer to Foswiki:System.UpgradeGuide. A static HTML version of this document, UpgradeGuide.html, is included in the root of your Foswiki distribution.
System Requirements
Please see the section "Foswiki system requirements" for the server and client requirements to run Foswiki, including the Perl modules required on the server. If you need to install any Perl libraries from CPAN for use by Foswiki, see Foswiki:Support.HowToInstallCpanModules for more information.Preparing to install
Before attempting to install Foswiki, you are encouraged to review the Foswiki:System.AdminSkillsAssumptions. This guide assumes the person installing Foswiki has a basic knowledge of server administration on the system on which Foswiki is to be installed. While it is possible to install Foswiki with FTP access alone (for example, on a hosted site), it is tricky and may require additional support from your hosting service (for example, in setting file ownership and installing missing perl CPAN libraries). If you are upgrading from a previous Foswiki version or from a TWiki installation, please refer to Foswiki:System.UpgradeGuide. A static HTML version of this document,UpgradeGuide.html, is included in the root of your Foswiki distribution.
Verify that your server meets the Foswiki system requirements, including having the minimum required Perl version and all required Perl modules installed. If you need to install any Perl libraries from CPAN for use by Foswiki, see Foswiki:Support.HowToInstallCpanModules for more information.
If you need help, feel free to ask a question in the Foswiki:Support web or on Foswiki:Community.InternetRelayChat (irc.freenode.net, channel #foswiki).
Basic installation: getting Foswiki up and running
To install Foswiki, complete the following steps:- Download and unpack the Foswiki distribution.
- Set the file and directory permissions for the installation.
- Configure the locations of the Perl executable and the Foswiki modules.
- Configure the web server.
- Configure Foswiki.
- Enable authentication of users (if desired).
- Define the administrator users.
Download and unpack the Foswiki distribution
Download the Foswiki distribution from http://foswiki.org/Download Unpack the distribution file: Change to the directory where you want to place the Foswiki directory. Unzip or untar and gunzip the distribution; a new subdirectory called Foswiki-VERSION will be created. You can rename this subdirectory to a shorter name. For the rest of this document, this subdirectory is assumed to be at/path/to/foswiki. - Note: Foswiki does not support directory paths that contain spaces, so ensure that all of its directory paths do not contain any spaces (particularly on Windows).
Set the file and directory permissions for the installation
Set up access file and directory rights, as well as file ownership, as required by your web server configuration so that the web server user (the user used by the web server to run CGI programs) can read and write within thefoswiki directory tree.
Note: for more information on the appropriate permissions to ensure security for your Foswiki data, see Foswiki:Support.SecuringYourSite.
The default file and directory access permissions as set by the distribution define a reasonable security level that will work for many types of installations, including shared hosting. Nonetheless, you should verify that the web server user has read access to all files and directories beneath the foswiki directory, and execute access for all directories. Also verify that the data and pub directories and all the subdirectories and files beneath them allow write access for the web server user. - Warning: Do not just run a
chmod -R 770 foswiki. Providing execute access to all files is potentially dangerous. This is a common mistake made by Foswiki installers. See Foswiki:Support.SettingFileAccessRightsLinuxUnix for a sample set of Unix commands to set the file and directory permissions.
foswiki directory tree to the web server user, using the command chown -R user:group /path/to/foswiki. The web server username varies in different installations; here are some sample commands for various Linux distributions: - RedHat, Fedora, CentOS, Gentoo, Mandriva :
chown -R apache:apache /path/to/foswiki - debian/Ubuntu/Kubuntu :
chown -R www-data:www-data /path/to/foswiki - Suse :
chown -R wwwrun:www /path/to/foswiki
Configure the locations of the Perl executable and the Foswiki modules
Make sure the Foswiki scripts can be executed by the web server. The default location of Perl is/usr/bin/perl. If it's somewhere else, change the path to Perl in the first line of each script (you may have to give yourself write permission first) in the bin and tools directories. You can use the tools/rewriteshbang.pl script to do this; for example:cd /path/to/foswiki/bin /path/to/perl ../tools/rewriteshbang.pl # At the prompt, enter the full path to the perl executable, including # the full filename of the executable. You will be prompted twice for # this information in order to confirm it. cd /path/to/foswiki/tools /path/to/perl rewriteshbang.plSome web servers require a special extension on perl script files (e.g.
.cgi or .pl). This is not normally required with the Apache web server, though some hosted web servers are configured to require it. If the documentation for your web server indicates that a special extension is necessary, rename all the executable scripts in bin; that is, rename bin/view to bin/view.pl, and so on. When configuring Foswiki (see the section "Configure Foswiki"), set the ScriptSuffix option to the special extension.
Create the file LocalLib.cfg located at bin/LocalLib.cfg - In the
bindirectory, copy the template fileLocalLib.cfg.txttoLocalLib.cfg. Make sure the ownership and access rights of the copy are the same as LocalLib.cfg.txt. - Edit
bin/LocalLib.cfgso that$foswikiLibPathis set to the absolute file path of yourlibdirectory. For example:/path/to/foswiki/lib. - If you need to install additional CPAN modules, but can't update the main Perl installation files on the server, you can set
$CPANBASEto point to your personal CPAN install. Don't forget that the web server user has to be able to read those files as well.
Configure the web server
First choose the best configuration method for your web server. With Apache, there are two ways to configure it: a config file included from httpd.conf or .htaccess files.- Apache config file: The recommended method is using a config file. With a config file you can put the entire Foswiki configuration in ONE file (typically named
foswiki.conf). Performance is much better with a config file, and one file gives the best overview and ensures that you get a safe installation . However to use a config file you need root or sudo access to stop and start Apache. The Foswiki apache config file is included from the main Apache config file http.conf. Most distributions have a directory from which any file that ends with.confgets included when you restart Apache (Example RedHat/Fedora/Centos:/etc/httpd/conf.d). If you use a virtual host setup in Apache you should include thefoswiki.conffile from inside the desired virtual host config in your Apache configuration. - .htaccess files: This method should only be used when you cannot use a config file. Performance is slower as Apache must search through all applicable directories for any
.htaccessfiles on each page access. Normally this is the only way to control Apache in a shared host environment where you have no root or sudo privileges.
- The easiest and best way is to use the Foswiki:Support.ApacheConfigGenerator tool to generate a safe, working config file for your Foswiki installation, based on the options you choose in the tool.
- If you can't use the online configuration generator, a sample config file called
foswiki_httpd_conf.txtcan be found in the root of the foswiki installation. - Ensure that web access is denied to all Foswiki subdirectories other than
binandpub. The Foswiki:Support.ApacheConfigGenerator tool will generate the appropriate settings; thefoswiki_httpd_conf.txtfile also has examples of configuring Apache appropriately. - Ensure there is either a
ScriptAliasdirective for thebinsubdirectory, or anAliasdirective withSetHandler cgi-scriptandOptions ExecCGIdirectives for thebinsubdirectory, so that thebinscripts will be executed by Apache. - Note: you must restart Apache after making changes to your config files for the changes to take effect.
- In the root of the foswiki installation and in the
bindirectory, there are sample.htaccessfiles for various subdirectories in your installation. Each file has help text explaining how to modify it for your configuration. For more information, see Foswiki:Support.SupplementalDocuments.location and name of sample .htaccess file copy sample file to the following location foswiki/root-htaccess.txtfoswiki/.htaccessfoswiki/bin/.htaccess.txtfoswiki/bin/.htaccessfoswiki/pub-htaccess.txtfoswiki/pub/.htaccessfoswiki/subdir-htaccess.txt.htaccessin all other subdirectories belowfoswiki - Ensure that web access is denied to all Foswiki subdirectories other than
binandpub. The sample.htaccessfiles show how to configure Apache appropriately. - Ensure that the
foswiki/bin/.htaccessfiles contains the lineSetHandler cgi-scriptso that all scripts in thebindirectory will be executed by Apache.
pub directory. For example, most Linux distributions have a default Apache installation with PHP and server side include (SSI) enabled. This would allow PHP scripts uploaded as attachments to be executed, which is a security risk, so it should be disabled in the Apache configuration with php_admin_flag engine off.
Different script execution mechanisms are disabled in different ways; see your web server configuration and documentation for more details.
Protect the configure script: You should never leave the configure script open to the public. Limit access to the bin/configure script to either localhost, an IP address or a specific user using basic Apache authentication. The Foswiki:Support.ApacheConfigGenerator lets you setup who has access to the configure script. Also see the foswiki-httpd-conf.txt or bin/.htaccess.txt file for an example of the setting required to protect the configure script.
To limit access to a particular user, set up a .htpasswd file that contains the user name and password that Apache will use to authenticate the user: - Change to the
foswiki/datadirectory. - Issue the command
htpasswd -c .htpasswd <username>, where <username> is the name of the user you will use to access theconfigurescript. Choose the username with care: the username cannot be an existing login name for your Foswiki installation, nor can it be used later on to register in Foswiki. Enter a password when prompted.
configure web page will be protected using the user and password held in the data/.htpasswd file. The Apache config file or .htaccess file will have a Require user <username> directive to restrict access to the configure script. Ensure the user specified in the directive matches the <username> you used when creating the .htpasswd file.
Note: In addition to any web server security protection that you have set up, when saving any configuration settings for the first time on the configure web page, you will be prompted to set a configuration password. This password must be entered on all subsequent configuration changes, and is also used to log in via the internal admin link (see the section "Define the administrator user(s)"). Even after a configure password has been set, access to the configure page should still be restricted by the web server, in order to avoid revealing internal information to potential attackers.
For more information, refer to Foswiki:Support.ProtectingYourConfiguration.
Configure Foswiki
Run theconfigure script from your browser: enter http://yourdomain/foswiki/bin/configure into your browser address bar. - When you access the
configureweb page for the first time, you can only edit the sectionGeneral Path Settings. Make any required changes, and save the settings, whether or not you needed to make any changes. You will be prompted to set a password for theconfigurepage: this password must be entered for all subsequent configuration changes, and is also used to log in via the internal admin link (see the section "Define the administrator user(s)"). Note the configuration password is separate from any web server security you have set up for theconfigureweb page (see "Protect the configure script"). - Continue configuring Foswiki. Resolve any errors or warnings highlighted on the configure page.
- If your web server can be accessed by more than one domain name make sure to add the additional alternative URLs to
{PermittedRedirectHostUrls} - Setup the Mail and Proxies section. The
{WebMasterEmail}and{SMTP}{MAILHOST}settings must be defined so Foswiki can send registration emails. Many ISPs have introduced authentication when sending emails to fight spam so you may also have to set{SMTP}{Username}and{SMTP}{Password}. If you do not want to enable sending registration emails or want to enable it later you can uncheck{EnableEmail}. If your server is behind a firewall with a proxy, and you wish to install extensions viaconfigure, you may have to set{PROXY}{HOST}and{PROXY}{PORT}.
configure page, you can configure Foswiki manually.
Enable authentication of users
By enabling authentication, you can control access to your site and track the activity of your users. This is particularly important for sites that are publicly accessible on the web. You are strongly encouraged to read System.UserAuthentication and Foswiki:Support.UserAuthenticationSupplement for further information about managing users and access controls for your Foswiki site. The most common authentication methods used for public Foswiki installations are Template Login and Apache Login. They have the following relative advantages:- Template Login can be set up without any web server configuration, and users can log off without restarting the browser. As the login page is just a Wiki page, you can customize it to suit your needs.
- Apache Login allows you to use any Apache-module based authentication scheme, such as
mod_auth_ldapormod_auth_mysql. However, as your browser is caching your login, you must restart the browser to log out.
System.InstallationGuide into the "Jump" text box. By doing this instead of using the INSTALL.html file from the distribution, you will be able to use the embedded hyperlinks to jump directly to the referenced pages.
Template Login authentication
With Template Login enabled, when Foswiki needs to authenticate the user, it will redirect to a login web page. A list of all users is shown in theCM.WikiUsers topic.
To setup Template Login, perform the following steps:
- Configure Template Login. Under the
Security Settingspane of theconfigurepage:- Select
Foswiki::LoginManager::TemplateLoginfor{LoginManager}. - Select
Foswiki::Users::HtPasswdUserfor{PasswordManager}. - Select
Foswiki::Users::TopicUserMappingfor{UserMappingManager}. - Save your settings.
- Select
- Verify that registration works. Register yourself using the
System.UserRegistrationtopic in your Foswiki installation. Note if you are viewing this page via theINSTALL.htmlfile, then you can access the user registration page by enteringSystem.UserRegistrationinto the "Jump" text box at the top right of any Foswiki page in your installation.
Check that the password manager recognizes the new user by verifying that a new line is added to thefoswiki/data/.htpassswdfile, with the username and encrypted password. If the user and password information was not added, you probably got a path wrong, or the directory permissions onfoswiki/dataorfoswiki/data/.htpasswdmay not be set to allow the web server user to modify the file. - Check that authentication works. Edit a topic by clicking on the
Editlink at the top or bottom of a topic. If you have been authenticated, then you will see the edit page; otherwise, you will see an error message.
Apache Login authentication
With Apache Login enabled, when Foswiki needs to authenticate the user, the standard HTTP authentication mechanism is used: the browser itself will prompt for a user name and password. Note: Apache Login is required for Apache-based login methods such as mod_ldap. To setup Apache Login, perform the following steps:- Configure Apache Login. Under the
Security Settingspane of theconfigurepage:- Select
Foswiki::LoginManager::ApacheLoginfor{LoginManager}. - Select
Foswiki::Users::HtPasswdUserfor{PasswordManager}. - Select
Foswiki::Users::TopicUserMappingfor{UserMappingManager}. - Save your settings.
- Configure your Apache settings for HTTP authentication. Use the Foswiki:Support.ApacheConfigGenerator tool or the
foswiki/bin/.htaccessfile to set the following Apache directives on thebinscripts:<FilesMatch "(attach|edit|manage|rename|save|upload|mail|logon|rest|.*auth).*"> require valid-user </FilesMatch>You can also refer to the samplefoswiki_httpd_conf.txtandbin/.htaccess.txtfiles to see how the appropriate Apache directives are specified.
- Select
- Verify that registration works. Register yourself using the
System.UserRegistrationtopic in your Foswiki installation. Note if you are viewing this page via theINSTALL.htmlfile, then you can access the user registration page by enteringSystem.UserRegistrationinto the "Jump" text box at the top right of any Foswiki page in your installation.
Check that the password manager recognizes the new user by verifying that a new line is added to thefoswiki/data/.htpassswdfile, with the username and encrypted password. If the user and password information was not added, you probably got a path wrong, or the directory permissions onfoswiki/dataorfoswiki/data/.htpasswdmay not be set to allow the web server user to modify the file. - Check that authentication works. Edit a topic by clicking on the
Editlink at the top or bottom of a topic. If you have been authenticated, then you will see the edit page; otherwise, you will see an error message.
Choose search algorithm based on your platform
Under Store Settings in configure you will find the setting {RCS}{SearchAlgorithm}. By default it is set to Foswiki::Store::SearchAlgorithms::Forking which is what you should keep if you install Foswiki in Linux or any other Unix type operating system. If you install Foswiki on a Windows server, using an external grep program can create problems because of limitations in the length of command lines. You may be able to run with Forking in Windows if your directory path to Foswiki is kept short (short directory names and few levels). The safe setting for Windows is Foswiki::Store::SearchAlgorithms::PurePerl.Define the administrator user(s)
Administrators have read and write access to any topic, regardless of any access controls that have been applied to the topic or its web. After installing Foswiki, you should register a user that you will use to administer Foswiki. To make this user an administrator, add the WikiName for the user to theAdminGroup, defined in the CM.AdminGroup? topic in your Foswiki installation.
To make it easier to follow the instructions in this section, you can view this installation guide using your Foswiki site by entering System.InstallationGuide into the "Jump" text box. By doing this instead of using the INSTALL.html file from the distribution, you will be able to use the embedded hyperlinks to jump directly to the referenced pages.
To add an initial administrator to the AdminGroup, perform the following steps:
- If you are not already logged in with your WikiName, then login.
- Go to the
CM.AdminGroup?topic and select the "internal admin login" link. Login using the password you set on theconfigurepage. - After logging as the internal admin, edit the
CM.AdminGrouptopic. Follow the instructions on the page carefully and add your WikiName to the group. - Test that you have been added successfully: On the
CM.AdminGroup?page, select the "Logout link" and logout from being the internal admin. Select the "Edit" link for theCM.AdminGroup?page. If you successfully added yourself as an admin user, you should see the edit page.
AdminGroup is no longer empty, then any member of the group can add subsequent members — you do not have to use the internal admin login.
To more easily debug access control issues, you may want to have a regular Foswiki user account for daily use, and a special one that belongs to the AdminGroup that you use only for administering your Foswiki site. See Foswiki:System.AccessControl for more information on access controls and user groups.
Congratulations!
You now have a basic installation running. At this point you can just point your Web browser athttp://yourdomain.com/foswiki/bin/view and start using your Foswiki site.
In order to keep your user, group, and site configuration information separate from the actual content of your site, it is recommended that you create a new web in which your site's pages will reside. See Foswiki:System.ManagingWebs for more information on Wiki webs and how to create one.
Beyond the basic installation
Once you have Foswiki installed and running, you can perform one or more of the following steps to tailor your installation to your needs. Many of the references in this section refer to topics within your Foswiki installation. For example,System.Skins refers to the Skins topic in your System web. To go directly to a topic, enter the full topic name, such as System.Skins, into the "Jump" text box at the top right of any Foswiki page.
To make it easier to follow the instructions in this section, you can view this installation guide using your Foswiki site by entering System.InstallationGuide into the "Jump" text box. By doing this instead of using the INSTALL.html file from the distribution, you will be able to use the embedded hyperlinks to jump directly to the referenced pages.
All of the Foswiki documentation can also be found online in the Foswiki documentation section (the "System" web) of the Foswiki web site.
Note the configure page mentioned in this section is accessed by visiting http://yourdomain/foswiki/bin/configure your web browser.
Site configuration and maintenance
Set Foswiki Preferences
Preferences for customizing many aspects of Foswiki are set by editingMain.SitePreferences. If a given preference is not set in Main.SitePreferences, then a default value is picked up from System.DefaultPreferences, if present, or, for extensions, from the extension topics.
To simplify your upgrades, do not modify System.DefaultPreferences. Instead, copy any settings you want to change from System.DefaultPreferences to Main.SitePreferences.
To see the available preferences that can be set, look through System.DefaultPreferences.
If, for some reason, you wish to pick up default preferences from a different topic, you can set the location in the Miscellaneous settings pane of the configure page, in the {SitePrefsTopicName} setting (visible when Expert mode is enabled). It is recommended that you leave this setting to its default value, DefaultPreferences.
Select the desired security level
Foswiki has a many security features that can be enabled/disabled and adjusted to suit your needs. In many cases enabling a security feature prevents other features. It is a balance that the administrator has to choose depending on the purpose of the Foswiki installation (confidential vs public knowledge), the type of installation (intranet vs internet), and your type of business. A new administrator is encouraged to read Foswiki:Support.SecurityFeatures which gives a walkthrough of the different security aspects and how to set the appropriate configuration settings. Note that that some security settings are only visible in configure in "expert mode" which you enter by clicking the "Yes, I've read all the documentation" button at the top of the configure screen.Enable Email Notification
Each web has an automatic email notification service that sends you an email with links to all of the topics modified since the last alert. To enable this service:- Confirm the Mail and Proxies settings on the
configurepage. - Setup a cron job (or equivalent) to call the
tools/mailnotifyscript, as described in the System.MailerContrib topic.
Automate removal of expired sessions and lease files
By default Foswiki cleans out expired session and lease files each time any topic is viewed, but this has a performance cost. Instead you may wish to schedule a cron job (or equivalent) to run thetools/tick_foswiki.pl script, and set a negative value on the configure page for {Sessions}{ExpireAfter}. For more details, read System.CommandAndCGIScripts#tick_foswiki_pl.
Enable WebStatistics
You can manually or automatically generate a listing of the most popular pages for each web, based on number of visits. For information on setting up this feature, see the System.SiteTools topic.Enable Localisation
Foswiki supports displaying national (non-ASCII) characters, and using different languages for its basic interface elements. To configure localisation, modify theLocalisation section of the configure page. For more information, see Foswiki:Support.InternationalizationSupplement.
Customizing your site
Customize pages for managing personal information
If you are not using Foswiki to manage your users' passwords or email addresses, or would just like to enhance the default pages, then modify the following topics accordingly with information appropriate for your site:Customize the user topic for new users
When a new user registers on your Foswiki site, a topic with a name corresponding to the user's WikiName is created in the CM web: this topic is the user's user topic. The user topic is based on theCM.NewUserTemplate topic; if it is not present, then System.NewUserTemplate (and its associated System.UserForm) is used as a default. If you want to customize the user topic for your users, copy System.NewUserTemplate to CM.NewUserTemplate, and System.UserForm to CM.UserForm?, and make your changes to CM.NewUserTemplate and CM.UserForm?. (See Foswiki:System.ManagingTopics#CopyTopic for instructions on copying a topic.)
You can edit these topics to suit your needs, such as the following: - Customize the user topic for your site.
- Add an
ALLOWTOPICCHANGEpreference setting toCM.NewUserTemplateso only the user can edit their own user topic. In particular, on a public Foswiki site, restricting edit access will avoid vandalism and spam. - Add and remove fields defined in the
CM.UserForm?.
CM.UserRegistration? to match (copy over the contents from System.UserRegistration to CM.UserRegistration when creating it).
Customize the appearance of your Foswiki site
The real power of Foswiki lies in its flexibility to be customized to meet your needs. To change the look of the default skin, PatternSkin, please refer to System.PatternSkin and System.PatternSkinCustomization. At the Foswiki website you can find more resources. A good place to start exploring is the Foswiki:Support.AdministratorsCookBook which offers tips and tricks for customizing your Foswiki site. Many of these are best done before any content has been added to your site, so immediately after installation is a good time to consider the possibilities.Left, Top and Bottom Bars with PatternSkin
The top bar and bottom bar are common across all webs. To customize the top bar, copySystem.WebTopBarExample to System.WebTopBar?, and make your desired changes to System.WebTopBar.
To customize the bottom bar, copy System.WebBottomBarExample to System.WebBottomBar?, and make your desired changes to System.WebBottomBar.
The side bar can be customized on a per web basis. To customize the side bar, copy the WebLeftBarExample topic in the given web to WebLeftBar, and make your desired changes to WebLeftBar. If you would like to move the side bar to the right of the page, see System.PatternSkin for more details.
Copyright, License and Classification Statements
At the bottom of each topic, there is a copyright statement that is set in theWEBCOPYRIGHT preference. Its default is the following: Copyright © by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
If your Foswiki site is used in an environment without public access you should replace this with your normal copyright notice. You should also consider adding a security classification (e.g., For Internal Use Only) so people do not have to add this manually to every new topic.
If your Foswiki site is publicly accessible, you need to decide which copyright and license you wish to apply to all contributions. For open source applications, licenses such as the GNU Free Documentation License, FreeBSD Documentation License, and one of the various Creative Commons licenses are possible licenses to consider. Remember that once people have started contributing, you cannot retroactively change the license (unless it has a provision for this).
To change the copyright statement, perform the following steps:
- Copy the
WEBCOPYRIGHTpreference setting fromSystem.DefaultPreferencestoMain.SitePreferences. Change the value to your desired text. This value will be your new default across all webs. - You can create a unique message for a specific web by setting the
WEBCOPYRIGHTpreference in theWebPreferencestopic for the given web. For example, you could add a confidential classification to a web that has restricted access. - The
WEBCOPYRIGHTpreference setting inSystem.WebPreferencescovers the documentation that comes with Foswiki, and should not be changed.
WYSIWYG vs Raw Edit
In Foswiki, the WYSIWYG editor is used by default in edit mode. An Edit Raw link is available for those who prefer to edit the raw topic text. If you prefer to use the raw text editor by default and have a separate WYSIWYG button, as in TWiki 4.1, then you can modify the templates that define the edit screen as described in Foswiki:Support.FaqHowToMakeRawEditDefault.Installing extensions
Foswiki:Extensions is an extensive library of plugins for Foswiki that enhance functionality in a huge number of ways. A few plugins are pre-installed in the Foswiki distribution. In the Extensions section of theconfigure page, you can select the Find More Extensions button to download and install additional plugins from the foswiki.org website. If you are behind a firewall or your server has no access to the Internet, you can also install plugins manually. Installation instructions for each plugin are located in its corresponding topic on http://foswiki.org/. Additional documentation on Foswiki plugins can be found at Foswiki:Support.PluginsSupplement.
Plugins are activated in the Plugins section of the configure page. In addition, some plugins are also configured in this section.
TWiki Compatibility
Foswiki is 100% backwards compatible with TWiki® markup up to and including TWiki 4.2.4. Existing TWiki webs, topics and attachments can be used with Foswiki without requiring any changes. To support a seamless upgrade from TWiki, Foswiki ships with a plugin calledTWikiCompatibilityPlugin. This plugin enables most TWiki extensions to work with Foswiki, without modifications. It also maps requests for legacy TWiki web topics to their Foswiki equivalents, as defined in Foswiki:Development.TopicNameMappingTable. The TWIKIWEB and MAINWEB TWiki variables are also mapped to the new Foswiki macros SYSTEMWEB and USERSWEB.
If you are not upgrading an existing TWiki installation and do not plan to install plugins from the TWiki web site, it is recommended that you disable the TWikiCompatibilityPlugin in the Plugins Section on the configure page.
If a plugin exists both in a TWiki version and a Foswiki version, it is strongly recommended that you use the Foswiki version, as this is coded to work optimally with Foswiki. As part of the Foswiki project, the Foswiki community is evaluating all of the extensions that are available for TWiki, and porting them over to the Foswiki name space. Many of them are being enhanced through the removal of bugs and security vulnerabilities, resulting in better, more functional extensions for Foswiki.
Troubleshooting
Re-run theconfigure script and make sure you have resolved all errors and are satisfied that you understand any warnings.
Failing that, consult the topics at Foswiki:Support.SupplementalDocuments and Foswiki:Support.AskedQuestions.
If you need help, ask a question in the Foswiki:Support web or on Foswiki:Community.InternetRelayChat (irc.freenode.net, channel #foswiki).
Foswiki system requirements
Foswiki is capable of running on a variety of operating systems and supporting a wide range of browsers, due to its minimal client and server requirements.Server requirements
Foswiki is written in Perl 5, which is supported on Microsoft Windows as well as Unix and Unix-like systems (including Linux and OSX), on which it uses a number of shell commands and RCS (Revision Control System), a GNU Free Software package. It should be able to run on any server platform that meets the following requirements.| Resource | Required Server Environment |
|---|---|
| Perl | 5.8.4 or higher is recommended. Foswiki will run in perl 5.6.1 but only with Wysiwyg editor disabled. Wysiwyg requires Unicode support which is provided by perl 5.8.1 onwards. |
| RCS | 5.7 or higher (including GNU diff) Optional. Foswiki includes a pure perl implementation of RCS (RcsLite) that can be used instead, at the cost of performance |
| GNU diff | GNU diff 2.7 or higher is required when not using the all-Perl RcsLite. Install within the PATH if not included with RCS (check version with diff -v) Must be the version used by RCS, to avoid problems with binary attachments - RCS may have hard-coded path to diff |
| Other external programs | fgrep, egrep |
| Cron/scheduler | • Unix: cron • Windows: cron equivalents |
| Web server | Apache is well supported; for information on other servers, see Foswiki:Support.InstallingOnSpecificPlatforms. |
Required CPAN modules
Most of the CPAN libraries listed below are part of a standard Perl installation. See Foswiki:Support.HowToInstallCpanModules for detailed information on how to install any CPAN libraries not present in your installation. The following Perl CPAN modules are used by Foswiki:| Module | Preferred version |
|---|---|
| Algorithm::Diff (included with Foswiki) | |
| CGI | Versions 2.89 and 3.37 must be avoided. Most version from 3.15 and onwards should work. |
| CGI::Carp | >=1.26 |
| CGI::Session | >=4.30 (included with Foswiki) Versions 4.20 and before have Foswikitask:Item1306 |
| Config | >=0 |
| Cwd | >=3.05 |
| Data::Dumper | >=2.121 |
| Error (included) | |
| File::Copy | >=2.06 |
| File::Find | >=1.05 |
| File::Spec | >=3.05 |
| FileHandle | >=2.01 |
| IO::File | >=1.10 |
| Text::Diff (included with Foswiki) | |
| Time::Local | >=1.11 |
perl -le 'use ModuleName; print "ModuleName"->VERSION'
Optional CPAN modules
The following Perl modules may be used by Foswiki. See Foswiki:Support.HowToInstallCpanModules for detailed information on how to install CPAN libraries.| Module | Preferred version | Description |
|---|---|---|
| Archive::Tar | May be required by the Extensions Installer in configure if command line tar or unzip is not available | |
| CGI::Cookie | >=1.24 | Used for session support |
| Digest::base | ||
| Digest::SHA1 | ||
| Jcode | Used for I18N support with perl 5.6 | |
| Locale::Maketext::Lexicon | >=0 | Used for I18N support |
| Net::SMTP | >=2.29 | Used for sending mail |
| Unicode::Map | Used for I18N support with perl 5.6 | |
| Unicode::Map8 | Used for I18N support with perl 5.6 | |
| Unicode::MapUTF8 | Used for I18N support with perl 5.6 | |
| Unicode::String | Used for I18N support with perl 5.6 | |
| URI | Used for configure |
configure script, or if you're still trying to get to that point, check from the command line (replace "ModuleName" with the name of the module):
perl -e 'use ModuleName; print $ModuleName::VERSION."\n"'
Client requirements
Browser clients must support the following capabilities:- HTML 3.2
- Cookie support enabled, if persistent sessions are required
Uploading the Foswiki distribution to your web server host
If you cannot unpack the Foswiki distribution directly in your installation directory, you can unpack the distribution on your local computer, manually create the directory structure on your host server and upload the files as follows:- Using the table below, create a directory structure on your host server
- Upload the Foswiki files by FTP (transfer as text except for the image files in
pubdirectory.) - Note: Don't worry if you are not able to put the
libdirectory at the same level as thebindirectory. You can create this directory elsewhere and configure thebin/setlib.cfgfile.Foswiki dir: What it is: Where to copy: Example: foswikistart-up pages root Foswiki dir /home/smith/public_html/foswiki/foswiki/binCGI bin CGI-enabled dir /home/smith/public_html/foswiki/binfoswiki/liblibrary files same level as bin/home/smith/public_html/foswiki/libfoswiki/localelanguage files dir secure from public access /home/smith/public_html/foswiki/localefoswiki/pubpublic files htdoc enabled dir /home/smith/public_html/foswiki/pubfoswiki/datatopic data dir secure from public access /home/smith/public_html/foswiki/datafoswiki/templatesweb templates dir secure from public access /home/smith/public_html/foswiki/templatesfoswiki/toolsFoswiki utlilities dir secure from public access /home/smith/public_html/foswiki/toolsfoswiki/workingTemporary and internal files dir secure from public access /home/smith/public_html/foswiki/working
Configuring Foswiki manually (without using the configure page)
It is highly recommended that you configure Foswiki by using your browser to access the configure page. However, if you are unable to get the configure page to display (for example, if a dependency is missing), or for some reason you do not wish to use the configure page, then you can configure Foswiki manually
Perform the following steps to manually configure Foswiki: - Copy the file
lib/Foswiki.spectolib/LocalSite.cfg - Remove the # in front of the following settings, and ensure that they are set to the correct values:
$Foswiki::cfg{DefaultUrlHost} $Foswiki::cfg{ScriptUrlPath} $Foswiki::cfg{PubUrlPath} $Foswiki::cfg{PubDir} $Foswiki::cfg{TemplateDir} $Foswiki::cfg{DataDir} $Foswiki::cfg{LocalesDir} $Foswiki::cfg{OS} - Make sure the following settings are defined:
$Foswiki::cfg{LoginManager} $Foswiki::cfg{WebMasterEmail} $Foswiki::cfg{SMTP}{MAILHOST} $Foswiki::cfg{SMTP}{SENDERHOST}
Foswiki Upgrade Guide
This guide covers upgrading from a previous version of Foswiki or TWiki (such as Cairo or TWiki4.0) to Foswiki 1.0Overview
Foswiki is a fork from TWiki 4.2.3. Upgrades from all TWiki versions and earlier Foswiki versions are supported. Foswiki is designed to be 100% compatible with the content of TWiki sites, using the same markup language and supporting the same plugin API (through the use of aTWikiCompatibilityPlugin), thereby enabling a smooth transition from TWiki to Foswiki.
Upgrade requirements
- Please review the Foswiki:System.AdminSkillsAssumptions before you upgrade your site.
- To upgrade from an old TWiki Release to the latest Foswiki production release, follow the instructions below.
- Before upgrading, you may wish to make a backup of your topics.
- Once the upgrade has been applied, an existing earlier installation will still be able to read all the topics, but should not be used to write.
- Some TWiki plugins are not compatible with Foswiki (usually ones that use a private API or execute helper scripts); you may need to migrate to the equivalent extension in the Foswiki:Extensions repository.
Upgrading from TWiki to Foswiki
You are strongly advised to read the Foswiki:System.ReleaseNotes01x00 (also available in an HTML file in the root of your installation), which contains a list of changes from TWiki 4.2.3 to Foswiki 1.0. A number of system topics and macros (formerly known as TWiki variables) have been renamed, to better describe their purpose and, where appropriate, to rebrand to the Foswiki name.Upgrading to a new patch release
To upgrade to a new patch release — for example, from Foswiki 1.0.0 to 1.0.3 — an upgrade package can be used that will not overwrite any of your customizations. For patch releases you will find a brief upgrade procedure on the download page for the release. Follow this procedure to upgrade to the patch release. It may contain important steps that are unique to each patch release (for example, some configure settings may need to be changed).Upgrade procedure: upgrading to a new major or minor version, or upgrading from TWiki
The following is a high level view of the upgrade procedure:- Prepare for all upgrade steps.
- Install the new Foswiki version and configure it with the same settings as the old version.
- Install any additional extensions (Plugins) used by your old installation. Make sure to use the latest Foswiki versions.
- Copy all the non-default webs from the old installation to the new one.
- Copy the users, groups, and site customizations from the old installation to the
CMweb in the new installation, including all user topics. - Apply preferences from the old installation.
- Apply your site customizations: skin, logos, menu bars, forms for personal information, and so forth.
- Validate your Wiki applications and other key functionality.
- Switch your production site from the old installation to the new installation.
-
<oldwiki>refers to the directory in which the old installation is located -
<newwiki>refers to the directory in which the new installation is located; it is assumed to be immediately below the root directory of your web server -
<old_users_web>refers to the web in which the user topics are located in the old installation. The default value is the CM web. The web is specified in theStore settingspane of theconfigurepage, in the {UsersWebName} setting (visible when Expert mode is enabled). -
<old_system_web>refers to the web used for documentation and default preferences in the old installation. In Foswiki, the default value is the System web; in TWiki, the default value is the TWiki web. The web is specified in theStore settingspane of theconfigurepage, in the {SystemWebName} setting (visible when Expert mode is enabled).
configure page mentioned in this document is accessible via your web browser at http://yourdomain/<newwiki>/bin/configure .
Prepare for all upgrade steps
Read the Foswiki:System.ReleaseNotes01x00 and learn about the differences between your old installation and the new release to which you are upgrading. Take note of any areas that affect your site and what special steps you may need to take. Check that all the extensions (plugins, contribs, skins) used by your old installation are available with the new release. Familiarize yourself with any new behaviour that you will have to adapt to or any configuration changes you will have to perform. If you are using authentication, prepare a test plan to verify that your authentication mechanism is working correctly. Make sure you are able to test logins by a sufficient sample of users to cover all categories of users of your site. For example, users of various groups may need to be tested. In particular, ensure you test that non-admin users cannot access topics restricted to admins. Identify all essential Wiki topics and Wiki applications that must be fully functional upon completion of the upgrade. Prepare a test plan to verify their functionality. If you are using access controls, ensure that the test plan will adequately test all categories and groups of users of your site. If your testing will require a test environment to be set up, ensure that it is ready, with any required support infrastructure (for example, testbed authentication servers). If you need to be able to login with different users in different categories and groups, ensure that you have the required login information ready, or you have testers from those groups available to perform the required test cases. Download the Foswiki distribution from the following location: http://foswiki.org/Download — if you are installing your extensions manually, also download them from the repository where they are stored.Installation
Follow the installation instructions in INSTALL.html, located in the root of the new installation. Install the new release in a new directory. Do not install on top of the old release.- For public or otherwise sensitive installations, ensure that your web server configuration is set to deny access to the new Foswiki installation for anyone except you.
- Configure Foswiki using the
configurepage.- If you are upgrading from an older Foswiki release, first copy your
<oldwiki>/lib/LocalSite.cfgfile to<newwiki>/lib/LocalSite.cfgin order to preserve your existing configuration settings. Alternatively, you can reconfigure the new installation from scratch (you can use your oldLocalSite.cfgfile as a reference). - If you are upgrading from a TWiki site, you must reconfigure your Foswiki installation from scratch. You cannot copy over your old
LocalSite.cfgfile (though you can use it as a reference). Runconfigureand set the configuration values in the new installation to match those of the old installation. - Verify all of the configuration settings on the
configurepage, including any new settings added in the new version. Save the configuration after you have completed your changes. - To wipe out all your settings and start configuring from a fresh installation, just delete the
<newwiki>/lib/LocalSite.cfgfile and runconfigure.
- If you are upgrading from an older Foswiki release, first copy your
- Additional resources
System.UpgradeGuide into the "Jump" text box on the top right of any topic. By doing this instead of using the UpgradeGuide.html file from the distribution, you will be able to use the embedded hyperlinks to jump directly to the referenced pages.
Install extensions
Install all of the extensions that were installed in your old site. In particular, start with any extensions required for the authentication and authorization methods you use (if any). You can use the Find more extensions button in the Extensions section of theconfigure page to install and configure extensions from the Foswiki:Extensions repository. You can also install extensions manually; see the instructions on the extension's web page from where you obtained the extension (for Foswiki extensions, on foswiki.org).
- Note: some TWiki extensions may not work with Foswiki. By default, the
TWikiCompatibilityPluginis installed to provide backwards compatible support for TWiki plugins. However if the TWiki plugin calls private APIs or invokes helper scripts, it may still not work correctly. Check for an upgraded Foswiki version of the extension in the Foswiki:Extensions repository and install it instead.
Main.SitePreferences topic in your new Foswiki site, prefixing each setting with the name of the plugin in uppercase followed by an underscore. For example, to copy over the DEFAULT_TYPE setting from the CommentPlugin topic in the old site to the new site, copy the value to a COMMENTPLUGIN_DEFAULT_TYPE setting in the Main.SitePreferences topic in the new site.
Commonly-customized plugin settings include the following: -
CommentPlugin- DEFAULT_TYPE -
EditTablePlugin- CHANGEROWS, QUIETSAVE, EDITBUTTON -
InterwikiPlugin- RULESTOPIC -
InterWikis- If you added your own rules, make sure you copy over the rules to the new installation. -
SlideShowPlugin- If you changed the embedded 'Default Slide Template', then copy your customed template to the topic in the new installation. You should prefer creating your own slide show template in a separate topic, so you will not have to take special steps over upgrades to preserve your modifications to the default slide template. -
SmiliesPlugin- If you added your own smileys, make sure you copy over your customizations to the topic in the new installatin. -
TablePlugin- TABLEATTRIBUTES
configure.
Copy content from non-default webs in old installation to the new installation
If you are upgrading from TWiki Cairo or earlier, it may be necessary to unlock the rcs files in data and pub directories from the old installation using the following shell commands:-
find data -name '*,v' -exec rcs -u -M '{}' \; -
find pub -name '*,v' -exec rcs -u -M '{}' \;
- Make sure the data and pub directories, as well as the files within them, are readable and writeable by the web server user.
- Note: Foswiki's
WebChangestopics depend on the file timestamp. If you touch the .txt files make sure to preserve the timestamp, or change them in the same chronological order as the old file timestamps.
Copy users, user topics, and site customizations to CM web
Copy all topics and attachments from <old_users_web>: copy all files from <oldwiki>/data/<old_users_web>/ to <newwiki>/data/CM/, and copy all files from <oldwiki>/pub/<old_users_web>/ to <newwiki>/pub/CM/ . Do not overwrite any topics already present in the <newwiki>/data/CM/ directory. - In addition to all the user topics, if you have created
<old_users_web>.NewUserTemplatein the old installation, this step will copy over your template for user topics to the new installation. - Ensure that the topic defining the admin group in your old installation is copied over. The admin group is defined in the
Security setuppane of theconfigurepage, in the {SuperAdminGroup} setting (visible when Expert mode is enabled). You can do either of the following:- Set the {SuperAdminGroup} setting in your new installation to the old admin group.
- Move the contents of the old admin group to the new admin group. To avoid having to change all references to the old admin group, you must still keep the old admin group defined: set it so its only member is the new admin group, and the new admin group is the only user who can change or rename the old admin group topic.
- The default admin group with Foswiki is AdminGroup and the default admin group with TWiki is TWikiAdminGroup. So if you are upgrading from TWiki and are using the default admin groups, then in the new installation, you must copy all members from TWikiAdminGroup to AdminGroup, and change TWikiAdminGroup so its only member is AdminGroup and so it can only be modified or renamed by AdminGroup.
- If your old installation did not customize {LocalSitePreferences} on the
configurepage, or if you did customize {LocalSitePreferences} but kept your site preferences within the <old_users_web> web, then this step will also copy over your site preferences to the new installation.
- Manually merge all users from the
<old_users_web>.WikiUserstopic in the old installation to theCM.WikiUserstopic in the new installation. If the new installation does not yet have an initialCM.WikiUserstopic, then copy<oldwiki>/data/<old_users_web>/WikiUsers.txtto<newwiki>/data/CM/WikiUsers.txt. - Verify that the following default users are present in the
CM.WikiUserstopic:- ProjectContributor - the Foswiki documentation is attributed to this user
- RegistrationAgent - special user used during the new user registration process
- UnknownUser - used where the author of a previously stored piece of data can't be determined
- WikiGuest - guest user; used as a fallback if the user can't be identified
- If any of the default users are missing, then add them in manually to
CM.WikiUsers, using the corresponding entries in Foswiki:System.UsersTemplate as an example. - If you use
data/.htpasswdfor authentication, copy this file from the old installation to the new one. - If you have customized
<old_system_web>.UserRegistration, then either copy over<oldwiki>/data/<old_system_web>/UserRegistration.txtand<oldwiki>/data/<old_system_web>/UserRegistration.txt,vto the<newwiki>/data/System/directory, or modifySystem.UserRegistrationin the new installation to contain your customizations.
- Manually merge all users from the
<old_users_web>.TWikiUserstopic in the old installation to theCM.WikiUserstopic in the new installation. If the new installation does not yet have an initialCM.WikiUserstopic, then copy<oldwiki>/data/<old_users_web>/TWikiUsers.txtto<newwiki>/data/CM/WikiUsers.txt, and manually add the required default users (see the next steps). - Verify that the following default users are present in the
CM.WikiUserstopic:- ProjectContributor - the Foswiki documentation is attributed to this user
- RegistrationAgent - special user used during the new user registration process
- UnknownUser - used where the author of a previously stored piece of data can't be determined
- WikiGuest - guest user; used as a fallback if the user can't be identified
- If any of the default users are missing, then add them in manually to
CM.WikiUsers, using the corresponding entries in Foswiki:System.UsersTemplate as an example. - If you use
data/.htpasswdfor authentication, copy this file from the old installation to the new one. - If you are upgrading from Cairo and are using the Htpasswd login manager, run the
tools/upgrade_emails.plscript to move the user emails out of the user topics and into the password file. - If you have customized
<old_system_web>.TWikiRegistration, then modifySystem.UserRegistrationin the new installation to contain your customizations.
<oldwiki>/data/Sandbox/ to <newwiki>/data/Sandbox and from <oldwiki>/pub/Sandbox/ to <newwiki>/pub/Sandbox . Some pages you may wish to preserve are the WebHome topic and the WebLeftBar topic (if you had created it in the old wiki installation). The Sandbox web often contains work-in-progress topics that users will want to keep.
Make sure the data and pub directories, as well as the files within them, are readable and writeable by the web server user.
Execute your test plans for authentication and authorization. Test that users that you have transferred from the old installation can login with any problems, and that access controls work appropriately: check that users are able to view and edit pages for which they have access, and are denied permission to view or edit pages for which they do not have access. Also check that pages restricted to the admin group are not accessible by non-admin users, and that administrators continue to have access.
Apply preferences from old installation
If you have not already set your desired site-wide preferences, as described in the section "Set Foswiki Preferences" in the System.InstallationGuide, then set your preferences. The location of your site preferences is specified in theMiscellaneous settings pane of the configure page, in the {LocalSitePreferences} setting (visible when Expert mode is enabled) — the default location is CM.SitePreferences. Copy any customized preferences from the site preferences topic in your old installation to the site preferences topic in the new installation. (Note you may have already copied over your customized preferences when you transfered the contents of the <old_users_web> web.)
If, in your old installation, you customized the default preferences in <old_system_web>.DefaultPreferences, then transfer your customizations from this topic to the site preferences topic instead (i.e. the topic specified in your {LocalSitePreferences} setting), so that your customizations will not get overwritten on the next upgrade.
If you are upgrading from TWiki, note that the default location of the default preferences in TWiki is <old_system_web>.TWikiPreferences, and the default location of the site preferences is Main.TWikiPreferences. Transfer any customized preferences from these topics to the site preferences topic in your new installation.
Apply additional site customizations
Modify skin with customizations for your site
If you did not already customize the appearance of your new installation, as described in the section "Customize the appearance of your Foswiki site" in the System.InstallationGuide, then reapply the customizations from your old installation to the new one. Ensure you transfer over any skin templates — .tmpl files, or topics referred to using VIEW_TEMPLATE or EDIT_TEMPLATE preferences — you need. Also ensure you transfer any style sheets or Javascript files required. If you are upgrading from the Cairo version of TWiki: note that the skins from this release do not work well with Foswiki. Starting from TWiki 4.0.2, the default PatternSkin has been fairly stable and so your customizations should continue to work.Customize pages for managing personal information
In your new installation, default copies of the following topics were installed: If you customized these topics in your old installation, transfer the changes to these topics in the new installation. Use the corresponding files in the<oldwiki>/<old_system_web>/ directory as a reference.
Validate your Wiki applications and other key functionality
Execute your test plan to validate the Wiki applications and other key functionality that need to be up and running after the upgrade.Switch your production site from the old installation to the new installation
If you had been running your old installation in parallel with the new one during a test phase, then disable your old installation, and repeat the step "Copy content from non-default webs in old installation to the new installation". Change your web server configuration so that the new installation is accessible to all of your users, and so the old installation is no longer accessible. Change your web server configuration so that the new installation is accessible using the same URL prefix as your old installation. For purposes of discussion, assume that your old installation is accessible fromhttp://yourdomain/wiki/. You can use one of the following approaches to make the new installation accessible using the same URL prefix: - You can rename your
<newwiki>/directory towiki/(renaming the directory of your old installation if necessary). - If your operating system supports links to other directories and your web server is configured to follow links, then you can create a link called
wiki/that points to<newwiki>/(renaming the directory of your old installation if necessary). - You can configure your web server so that requests to
/wiki/are served from your<newwiki>/directory.
Additional steps when upgrading from TWiki Cairo
Favicon
The favicon is now configurable as a site preference or per-web preference. SeeSystem.DefaultPreferences for a description of the FAVICON preference. To set it for your site, add the FAVICON preference to your site preferences topic, CM.SitePreferences (or the topic you configured in your {LocalSitePreferences} setting in the Miscellaneous settings pane on the configure page). To set it for a web, add the FAVICON preference to the WebPreferences topic for that web.
Important changes since TWiki 4.0.5
Supported Perl version
To use Foswiki, you must use Perl 5.8 or higher. Foswiki no longer supports Perl version 5.6.x (the minimum version required for TWiki 4.0.5).Template spec changed
Until TWiki 4.0.5, any text inside template definition blocks for SkinTemplates (formerly called TWikiTemplates) — that is, between %TMPL:DEF{"block"}% and %TMPL:END% — was stripped of leading and trailing white space, including newlines. This made it difficult for skin developers to include a newline before or after a block of text. From TWiki 4.1.0 onwards, and in Foswiki 1.0, this has changed so that white space is no longer stripped. Skins like PatternSkin and NatSkin have been updated so that they work with the new behavior. If you use an older skin or have written your own you will most likely need to make some adjustments. In general, if you get mysterious blank lines in your skin, the newline after the %TMPL:DEF{"block"}% needs to be removed: the content of the block must follow on the same line as the TMPL:DEF. CommentPlugin templates also must be modified to remove extraneous newlines — in particular, any newline immediately after the TMPL:DEF. See theSystem.CommentPluginTemplate for examples of how comment template definitions should look like in TWiki 4.1.x.
Example: a CommentPlugin template that adds a row to a table. With versions of TWiki prior to 4.1, the following syntax can be used:
%TMPL:DEF{OUTPUT:tabletest}%%POS:BEFORE%
|%URLPARAM{"comment"}%| -- %WIKIUSERNAME% - %DATE% |
%TMPL:END%
Starting in TWiki 4.1 and continuing with Foswiki 1.0, the newline before the start of the table row must be removed:
%TMPL:DEF{OUTPUT:tabletest}%%POS:BEFORE%|%URLPARAM{"comment"}%| -- %WIKIUSERNAME% - %DATE% |
%TMPL:END%
Important changes for the upgrader - since TWiki 4.1.0
New location for session and other temporary files
The directory for passthrough and session files have been replaced by a common directory for temporary files used by Foswiki. Previously the two configure settings{PassthroughDir} and {Sessions}{Dir} were set by default to /tmp. These config settings have been eliminated: Foswiki creates a tmp directory and other temporary directories under the directory defined by the configure setting {WorkingDir}.
Important changes for the upgrader - since TWiki 4.1.2
New WYSIWYG editor
Foswiki now ships with a new WYSIWYG editor based on TinyMCE that replaces the Kupu-based editor. When TinyMCEPlugin is enabled, the Edit button will initiate WYSIWYG editing mode. A Raw Edit link has been added for users to edit the topic markup directly. The WYSIWYG button has been removed.NEWTOPICLINKSYMBOL removed
The NEWTOPICLINKSYMBOL preference that was deprecated in TWiki 4.1 is no longer supported. To control the appearance of new links, set the NEWLINKFORMAT preference in CM.SitePreferences (see System.DefaultPreferences for more information on NEWLINKFORMAT).UserForm and NewUserTemplate customization
When a new user registers on Foswiki his user topic is created based on theNewUserTemplate and UserForm in the CM web, if they exist. If the topic does not exist in the CM web, then the default version from System is used. Thus on upgrades, any customizations you made to NewUserTemplate or UserForm in the CM web will be preserved.
In previous TWiki versions, only System.NewUserTemplate and System.UserForm are used; you cannot override them by creating your own version in the CM web.
WikiUsers no longer distributed
TheCM.WikiUsers topic contains all the registered users. It is not included in the Foswiki distribution, so that your list of users will not be overwritten on upgrades. When the first user is registered in Foswiki, the CM.WikiUsers topic is created on demand.
New working directory
The configuration setting {WorkingDir} in the General path settings pane on the configure page defines the location of a working directory for various subdirectories for use by Foswiki. The default value for this setting is the working subdirectory within the installation root directory for the Foswiki installation.
The subdirectories within the working directory include the following:
-
registration_approvals— previously located in the data/ directory -
tmp— avoids security issues with using the /tmp directory -
work_areas— previously located in the pub/ directory.
working/tmp/ subdirectory.
New internal admin login
Foswiki has a new internal admin login feature that lets you login as a temporary administrator, using "admin" as your user name and the password for theconfigure page. The internal admin username can be configured in the {AdminUserLogin} setting in the Security setup pane on the configure page.
In order to add an initial user to the default {SuperAdminGroup}, CM.AdminGroup?, you must login as the internal admin user using the link on the CM.AdminGroup? page.
Important changes for the upgrader - since Foswiki 1.0.4
An additional security feature has been added to Foswiki 1.0.5 so that saving data now requires the http method POST. This means that it is no longer possible to store data via an "<a href=..." link or img tag. It also means that if you have an application with an HTML form that creates new topics you must specify in the form tag method="post". This change is done to further tighten the security of Foswiki.
<form name="new" action="%SCRIPTURLPATH{save}%/Sandbox/" method="post">
...
</form>
The template webs _default and _empty are frequent targets for spammers because these webs are normally not monitored very carefully by the community around a Foswiki installation. These webs are now write protected so on an administrator can edit topics in these webs. When an administrator creates a new web it is important to remember to remove the access restriction from the WebPreferences in the new web.
Important changes for the upgrader - since Foswiki 1.0.5
Foswiki 1.0.6 introduces a major security enhancement, protecting against Cross-Site Request Forgery. The extra safe "double submit" algorithm, as recommended by the Open Web Application Security Project (OWASP) project has been used. This is the same algorithm used by several major banks and other security-conscious institutions, and requires that users have Javascript enabled. See Foswiki:Support.SecurityFeatures for more information on these, and other, Foswiki security features. This is recommended reading for all Foswiki administrators. If these new countermeasures against CSRF creates problems for your users and your applications, you can alter the way the protection works or disable it. These are the configure parameters you need to visit (note that some are expert settings).- {Validation}{Method} is by default "strikeone" which is the highest level of security and requires that users have Javascript enabled. You can lower this setting to "embedded" which uses a less safe validation method but does not require javascript. If you want to disable CSRF protection set it to "none". It is highly recommended to keep it at "strikeone".
- {Validation}{ValidForTime} is the time the validation key is valid. It is by default 1 hour. If your users often edit pages longer you can increase this time. Your users can still save pages with an expired validation key but they will be asked to confirm the saving.
- {Validation}{MaxKeysPerSession} is the maximum number of validation keys to store in a session. There is one key stored for each page rendered. If the number of keys exceeds this number, the oldest keys will be force-expired to bring the number down. If you have users that are very fast at editing pages and experience expired keys, you can increase this number. The default is 1000 and should be much higher than any normal person will experience.
- {Validation}{ExpireKeyOnUse} defines if validation keys expire when they are used for storing data. This prevents an attacker from evesdropping communication between server and browser and reuse keys. Unfortunately it also means that if a user edits a page, saves it, uses the back button of the browser, corrects his previous editing, and then saves again, he is asked to confirm that he intended to save the topic. Another use case is if you create an application with multiple forms and multiple submit buttons on a topic and you submit multiple times from this topic without navigating away from it, you will be asked to confirm the submission each time. If this is not acceptable to your use of Foswiki, you can turn off {Validation}{ExpireKeyOnUse}.
User Authentication
Controlling who can access your siteOverview
Authentication, or "login", is the process by which a user lets Foswiki know who they are. Authentication isn't just to do with access control. Foswiki uses authentication to keep track of who made changes, and manage a wide range of personal settings. With authentication enabled, users can personalise Foswiki and contribute as recognised individuals, instead of shadows. Foswiki authentication is very flexible, and can either stand alone or integrate with existing authentication schemes. You can set up Foswiki to require authentication for every access, or only for changes. Authentication is also essential for access control. Quick Authentication Test - Use the %USERINFO% macro to return your current identity:- You are guest, CM.WikiGuest,
Password Management
As shipped, Foswiki supports the Apache 'htpasswd' password manager. This manager supports the use of.htpasswd files on the server. These files can be unique to Foswiki, or can be shared with other applications (such as an Apache webserver). A variety of password encodings are supported for flexibility when re-using existing files. See the descriptive comments in the Security Settings section of the configure interface for more details.
You can easily plug in alternate password management modules to support interfaces to other third-party authentication databases.
The password manager is selected using the {PasswordManager} setting in configure.
User Mapping
Usually when you are using an external authentication method, you want to map from an unfriendly "login name" to a more friendly WikiName. Also, an external authentication database may well have user information you want to import to Foswiki, such as user groups. By default, Foswiki supports mapping of usernames to wikinames, and supports Foswiki groups internal to Foswiki. If you want, you can plug in an alternate user mapping module to support import of groups etc. The user mapping manager is selected using the {UserMappingManager} setting inconfigure.
User Registration
New user registration uses the password manager to set and change passwords and store email addresses. It is also responsible for the new user verification process. the registration process supports single user registration via the UserRegistration page, and bulk user registration via the BulkRegistration page (for admins only). The registration process is also responsible for creating user topics, and setting up the mapping information used by the User Mapping support.Login Management
Login management controls the way users have to log in. There are three basic options; no login, login via a Foswiki login page, and login using the webserver authentication support. the login manager is selected using the {LoginManager} setting inconfigure.
No Login (select none)
Does exactly what it says on the tin. Forget about authentication to make your site completely public - anyone can browse and edit freely, in classic Wiki style. All visitors are given the CM.WikiGuest default identity, so you can't track individual user activity.
Template Login (select Foswiki::LoginManager::TemplateLogin)
Template Login asks for a username and password in a web page, and processes them using whatever Password Manager you choose. Users can log in and log out. Client Sessions are used to remember users. Users can choose to have their session remembered so they will automatically be logged in the next time they start their browser.
Enabling Template Login
- Use the configure interface to
- select the
Foswiki::LoginManager::TemplateLoginlogin manager (on the Security Settings pane). - select the appropriate password manager for your system, or provide your own.
-
there is also an EXPERT configure setting {TemplateLogin}{PreventBrowserRememberingPassword}that you can set to prevent Browsers from remembering username and passwords if you are concerned about public terminal usage.
- select the
- Register yourself in the UserRegistration topic.
Check that the password manager recognises the new user. If you are using .htpasswdfiles, check that a new line with the username and encrypted password is added to the.htpasswdfile. If not, you probably got a path wrong, or the permissions may not allow the webserver user to write to that file. - Create a new topic to check if authentication works.
- Edit the CM.AdminGroup topic in the CM web to include users with system administrator status.
This is a very important step, as users in this group can access all topics, independent of Foswiki access controls.
pub area, unless they are only accessed through the viewfile script. If your pub directory is set up in the webserver to allow open access you may want to add .htaccess files in there to restrict access.
name="" parameter of the input tags must start with: "Twk0..." (if this is an optional entry), or "Twk1..." (if this is a required entry). This ensures that the fields are carried over into the user home page correctly. Do not modify the version of UserRegistration shipped with Foswiki, as your changes will be overwritten next time you upgrade.
Apache Login (select Foswiki::LoginManager::ApacheLogin)
Using this method Foswiki does not authenticate users internally. Instead it depends on the REMOTE_USER environment variable, which is set when you enable authentication in the webserver.
The advantage of this scheme is that if you have an existing website authentication scheme using Apache modules such as mod_auth_ldap or mod_auth_mysql you can just plug in directly to them.
The disadvantage is that because the user identity is cached in the browser, you can log in, but you can't log out again unless you restart the browser.
Foswiki maps the REMOTE_USER that was used to log in to the webserver to a WikiName using the table in CM.WikiUsers. This table is updated whenever a user registers, so users can choose not to register (in which case their webserver login name is used for their signature) or register (in which case that login name is mapped to their WikiName).
The same private .htpasswd file used in Foswiki Template Login can be used to authenticate Apache users, using the Apache Basic Authentication support.
Warning: Do not use the Apache htpasswd program with .htpasswd files generated by Foswiki! htpasswd wipes out email addresses that Foswiki plants in the info fields of this file.
Enabling Apache Login using mod_auth
You can use any other Apache authentication module that sets REMOTE_USER. - Use configure to select the
Foswiki::LoginManager::ApacheLoginlogin manager. - Use configure to set up Foswiki to create the right kind of
.htpasswdentries. - Create a
.htaccessfile in thebindirectory.
There is an template for this file in bin/.htaccess.txtthat you can copy and change. The comments in the file explain what need to be done.
If you got it right, the browser should now ask for login name and password when you click on the Edit. If .htaccessdoes not have the desired effect, you may need to "AllowOverride All" for the directory inhttpd.conf(if you have root access; otherwise, e-mail web server support)
At this time AccessControls do not control access to files in the pubarea, unless they are only accessed through theviewfilescript. If yourpubdirectory is set up to allow open access you may want to add.htaccessfiles in there as well to restrict access - You can create a custom version of the UserRegistration form by copying the default topic, and then deleting or adding input tags in your copy. The
name=""parameter of the input tags must start with:"Twk0..."(if this is an optional entry), or"Twk1..."(if this is a required entry). This ensures that the fields are carried over into the user home page correctly. Do not modify the version of UserRegistration shipped with Foswiki, as your changes will be overwritten next time you upgrade.
The default new user template page is in System.NewUserTemplate. The same macros get expanded as in the template topics. You can create a custom new user home page by creating the CM.NewUserTemplate topic, which will then override the default. - Register yourself in the UserRegistration topic.
Check that a new line with the username and encrypted password is added to the .htpasswdfile. If not, you may have got a path wrong, or the permissions may not allow the webserver user to write to that file. - Create a new topic to check if authentication works.
- Edit the CM.AdminGroup topic in the CM web to include users with system administrator status.
This is a very important step, as users in this group can access all topics, independent of Foswiki access controls.
Logons via bin/logon
Any time a user requests a page that needs authentication, they will be forced to log on. It may be convenient to have a "logon" link as well, to give the system a chance to identify the user and retrieve their personal settings. It may be convenient to force them to log on. Thebin/logon script enables this. If you are using Apache Login, the bin/logon script must be setup in the bin/.htaccess file to be a script which requires a valid user. Once authenticated, it will redirect the user to the view URL for the page from which the logon script was linked.
Sessions
Foswiki uses the CPAN:CGI::Session and CPAN:CGI::Cookie modules to track sessions. These modules are de facto standards for session management among Perl programmers. If you can't use Cookies for any reason, CPAN:CGI::Session also supports session tracking using the client IP address. You don't have to enable sessions to support logins in Foswiki. However it is strongly recommended. Foswiki needs some way to remember the fact that you logged in from a particular browser, and it uses sessions to do this. If you don;t enable sessions, Foswiki will try hard to remember you, but due to limitations in the browsers it may also forget you (and then suddenly remember you again later!). So for the best user experience, you should enable sessions. There are a number of macros available that you can use to interrogate your current session. You can even add your own session variables to the Foswiki cookie. Session variables are referred to as "sticky" variables.Getting, Setting, and Clearing Session Variables
You can get, set, and clear session variables from within Foswiki web pages or by using script parameters. This allows you to use the session as a personal "persistent memory space" that is not lost until the web browser is closed. Also note that if a session variable has the same name as a Foswiki preference, the session variables value takes precedence over the Foswiki preference. This allows for per-session preferences. To make use of these features, use the tags:
%SESSION_VARIABLE{ "varName" }%
%SESSION_VARIABLE{ "varName" set="varValue" }%
%SESSION_VARIABLE{ "varName" clear="" }%
Note that you cannot override access controls preferences this way.
Cookies and Transparent Session IDs
Foswiki normally uses cookies to store session information on a client computer. Cookies are a common way to pass session information from client to server. Foswiki cookies simply hold a unique session identifier that is used to look up a database of session information on the Foswiki server. For a number of reasons, it may not be possible to use cookies. In this case, Foswiki has a fallback mechanism; it will automatically rewrite every internal URL it sees on pages being generated to one that also passes session information.Username vs. Login Username
This section applies only if you are using authentication with existing login names (i.e. mapping from login names to WikiNames). Foswiki internally manages two usernames: Login Username and Foswiki Username.- Login Username: When you login to the intranet, you use your existing login username. This name is normally passed to Foswiki by the
REMOTE_USERenvironment variable, and used internally. Login Usernames are maintained by your system administrator.
- Foswiki Username: Your name in WikiNotation, ex:
JohnSmith, is recorded when you register using UserRegistration; doing so also generates a personal home page in the CM web.
NOTE: To correctly enter a WikiName - your own or someone else's - be sure to include the CM web name in front of the Wiki username, followed by a period, and no spaces, for exampleCM.WikiUsernameor%USERSWEB%.WikiUsername. This pointsWikiUsernameto the CM web, where user home pages are located, no matter which web it's entered in. Without the web prefix, the name appears as a NewTopic everywhere but in the CM web.
Changing Passwords
If your {PasswordManager} supports password changing, you can change and reset passwords using forms on regular pages.- The ChangePassword form (
Foswiki/ChangePassword) - The ResetPassword form (
Foswiki/ResetPassword)
Changing E-mail Addresses
If the active {PasswordManager} supports storage and retrieval of user e-mail addresses, you can change your e-mail using a regular page. As shipped, this is true only for the Apache 'htpasswd' password manager.- The ChangeEmailAddress form (
Foswiki/ChangeEmailAddress)
Controlling access to individual scripts
You may want to add or remove scripts from the list of scripts that require authentication. The method for doing this is different for each of Template Login and Apache Login.- For Template Login, update the {AuthScripts} list using configure
- For Apache Login, add/remove the script from
.htaccess
How to choose an authentication method
One of the key features of Foswiki is that it is possible to add HTML to topics. No authentication method is 100% secure on a website where end users can add HTML, as there is always a risk that a malicious user can add code to a topic that gathers user information, such as session IDs. The Foswiki developers have been forced to make certain tradeoffs, in the pursuit of efficiency, that may be exploited by a hacker. This section discusses some of the known risks. You can be sure that any potential hackers have read this section as well! At one extreme, the most secure method is to use Foswiki via SSL (Secure Sockets Layer), with a login manager installed and Client Sessions turned off. Using Foswiki with sessions turned off is a pain, though, as with all the login managers there are occasions where Foswiki will forget who you are. The best user experience is achieved with sessions turned on. As soon as you allow the server to maintain information about a logged-in user, you open a door to potential attacks. There are a variety of ways a malicious user can pervert Foswiki to obtain another users session ID, the most common of which is known as a cross-site scripting attack. Once a hacker has an SID they can pretend to be that user. To help prevent these sorts of attacks, Foswiki supports IP matching, which ensures that the IP address of the user requesting a specific session is the same as the IP address of the user who created the session. This works well as long as IP addresses are unique to each client, and as long as the IP address of the client can't be faked. Session IDs are usually stored by Foswiki in cookies, which are stored in the client browser. Cookies work well, but not all environments or users permit cookies to be stored in browsers. So Foswiki also supports two other methods of determining the session ID. The first method uses the client IP address to determine the session ID. The second uses a rewriting method that rewrites local URLs in Foswiki pages to include the session ID in the URL. The first method works well as long as IP addresses are unique to each individual client, and client IP addresses can't be faked by a hacker. If IP addresses are unique and can't be faked, it is almost as secure as cookies + IP matching, so it ranks as the fourth most secure method. If you have to turn IP matching off, and cookies can't be relied on, then you may have to rely on the second method, URL rewriting. This method exposes the session IDs very publicly, so should be regarded as "rather dodgy". Most Foswiki sites don't use SSL, so, as is the case with most sites that don't use SSL, there is always a possibility that a password could be picked out of the aether. Browsers do not encrypt passwords sent over non-SSL links, so using Apache Login is no more secure than Template Login. Of the two shipped login managers, Apache Login is probably the most useful. It lets you do this sort of thing: wget --http-user=RogerRabbit --http-password=i'mnottelling http://www.example.com/bin/save/Sandbox/StuffAUTOINC0?text=hohoho,%20this%20is%20interesting i.e. pass in a user and password to a request from the command-line. However it doesn't let you log out. Template Login degrades to url re-writing when you use a client like dillo that does not support cookies. However, you can log out and back in as a different user. Finally, it would be really neat if someone was to work out how to use certificates to identify users..... See Foswiki:Support.SupplementalDocuments for more information. Back to topAccess Control
Restricting read and write access to topics and webs, by users and groups Access Control allows you restrict access to single topics and entire webs, by individual user and by user Groups. Access control, combined with UserAuthentication, lets you easily create and manage an extremely flexible, fine-grained privilege system.An important control consideration
Open, freeform editing is the essence of WikiCulture - what makes Foswiki different and often more effective than other collaboration tools. For that reason, it is strongly recommended that decisions to restrict read or write access to a web or a topic are made with great care - the more restrictions, the less Wiki in the mix. Experience shows that unrestricted write access works very well because:- Peer influence is enough to ensure that only relevant content is posted.
- Peer editing - the ability for anyone to rearrange all content on a page - keeps topics focused.
- In Foswiki, content is transparently preserved under revision control:
- Edits can be undone by the administrator (per default a member of CM.AdminGroup; see #ManagingGroups).
- Users are encouraged to edit and refactor (condense a long topic), since there's a safety net.
- Create broad-based Groups (for more and varied input), and...
- Avoid creating view-only Users (if you can read it, you should be able to contribute to it).
Permissions settings of the webs on this Foswiki site
| Web | Sitemap | VIEW | CHANGE | RENAME | |||
|---|---|---|---|---|---|---|---|
| Listed | DENY | ALLOW | DENY | ALLOW | DENY | ALLOW | |
| |
on | ||||||
| |
on | CM.AdminGroup | CM.AdminGroup | ||||
| |
on | ||||||
| |
on | ||||||
- A blank in the the above table may mean either the corresponding control is absent or commented out or that it has been set to a null value. The two conditions have dramatically different and possibly opposed semantics.
- CM.WikiGuest is the guest account - used by unauthenticated users.
- The web must not deny view to CM.WikiGuest; otherwise, people will not be able to register.
Authentication vs. Access Control
Authentication: Identifies who a user is based on a login procedure. See UserAuthentication. Access control: Restrict access to content based on users and groups once a user is identified.Users and groups
Access control is based on the familiar concept of users and groups. Users are defined by their WikiNames. They can then be organized in unlimited combinations by inclusion in one or more user Groups. For convenience, Groups can also be included in other Groups.Managing Users
A user can create an account in UserRegistration. The following actions are performed:- WikiName and encrypted password are recorded using the password manager if authentication is enabled.
- A confirmation e-mail is sent to the user.
- A user home page with the WikiName of the user is created in the CM web.
- The user is added to the CM.WikiUsers topic.
Managing Groups
The following describes the standard Foswiki support for groups. Your local Foswiki may have an alternate group mapping manager installed. Check with your Wiki administrator if you are in doubt. Groups are defined by group topics located in theCM web. To create a new group, visit CM.WikiGroups and enter the name of the new group ending in Group into the "new group" form field. This will create a new group topic with two important settings: -
Set GROUP = < list of users and/or groups > -
Set ALLOWTOPICCHANGE = < list of users and/or groups >
-
Set GROUP = CM.SomeUser, CM.OtherUser, CM.SomeGroup
-
Set ALLOWTOPICCHANGE = CM.KasabianGroup
The Super Admin Group
A number of Foswiki functions (for example, renaming webs) are only available to administrators. Administrators are simply users who belong to the SuperAdminGroup. This is a standard user group, the name of which is defined by {SuperAdminGroup} setting in configure. The default name of this group is theAdminGroup. The system administrator may have chosen a different name for this group if your local Foswiki uses an alternate group mapping manager but for simplicity we will use the default name AdminGroup in the rest of this topic.
You can create new administrators simply by adding them to the CM.AdminGroup topic. For example, -
Set GROUP = CM.ElizabethWindsor, CM.TonyBlair
Restricting Access
You can define who is allowed to read or write to a web or a topic. Note that some plugins may not respect access permissions.- Restricting VIEW blocks viewing and searching of content. When you restric VIEW to a topic or web, this also restricts INCLUDE and Formatted SEARCH from showing the content of the topics.
- Restricting CHANGE blocks creating new topics, changing topics or attaching files.
- Restricting RENAME prevents renaming of topics within a web.
Controlling access to a Web
You can define restrictions on who is allowed to view a Foswiki web. You can restrict access to certain webs to selected users and groups, by:- authenticating all webs and restricting selected webs: Topic access in all webs is authenticated, and selected webs have restricted access.
- authenticating and restricting selected webs only: Provide unrestricted viewing access to open webs, with authentication and restriction only on selected webs.
- You can define these settings in the WebPreferences topic, preferable towards the end of the topic:
-
Set DENYWEBVIEW = < comma-delimited list of users and groups > -
Set ALLOWWEBVIEW = < comma-delimited list of users and groups > -
Set DENYWEBCHANGE = < comma-delimited list of users and groups > -
Set ALLOWWEBCHANGE = < comma-delimited list of users and groups > -
Set DENYWEBRENAME = < comma-delimited list of users and groups > -
Set ALLOWWEBRENAME = < comma-delimited list of users and groups >
-
ALLOWWEBVIEW set, this will also apply to the subweb. Also note that you will need to ensure that the parent web's FINALPREFERENCES does not include the access control settings listed above. Otherwise you will not be able override the parent web's access control settings in sub-webs.
Creation and renaming of sub-webs is controlled by the WEBCHANGE setting on the parent web (or ROOTCHANGE for root webs). Renaming is additionally restricted by the setting of WEBRENAME in the web itself.
Controlling access to a topic
- You can define these settings in any topic, preferable towards the end of the topic:
-
Set DENYTOPICVIEW = < comma-delimited list of users and groups > -
Set ALLOWTOPICVIEW = < comma-delimited list of users and groups > -
Set DENYTOPICCHANGE = < comma-delimited list of users and groups > -
Set ALLOWTOPICCHANGE = < comma-delimited list of users and groups > -
Set DENYTOPICRENAME = < comma-delimited list of users and groups > -
Set ALLOWTOPICRENAME = < comma-delimited list of users and groups >
-
-
Set ALLOWTOPICVIEW =
This means the same as not setting it at all. (This was documented wrong in versions 4.0.X, 4.1.0 and 4.1.1)
-
Set DENYTOPICVIEW =
This means do not deny anyone the right to view this topic. If DENYTOPICVIEW is set to an empty value anyone has access even if ALLOWTOPICVIEW or ALLOWWEBVIEW is defined. This allows you to have very restrictive default access rights to an entire web and still allow individual topics to have more open access.
Controlling access to attachments
Attachments are referred to directly, and are not normally indirected via Foswiki scripts. This means that the above instructions for access control will not apply to attachments. It is possible that someone may inadvertently publicise a URL that they expected to be access-controlled. The easiest way to apply the same access control rules for attachments as apply to topics is to use the Apachemod_rewrite module, and configure your webserver to redirect accesses to attachments to the Foswiki viewfile script. For example,
ScriptAlias /foswiki/bin/ /filesystem/path/to/bin/
Alias /foswiki/pub/ /filesystem/path/to/pub/
RewriteEngine on
RewriteCond %{REQUEST_URI} !^/+foswiki/+pub/+System/+.+
RewriteRule ^/+foswiki/+pub/+([^/]+)((/+([^/]+))+)/+(.+) /foswiki/bin/viewfile/$1/$2?filename=$5 [L,PT]
That way all the controls that apply to the topic also apply to attachments to the topic. Other types of webserver have similar support.
viewfile script.
Controlling who can manage top-level webs
Top level webs are a special case, because they don't have a parent web with a WebPreferences. So there has to be a special control just for the root level.- You can define these settings in the CM.DefaultPreferences topic, preferable towards the end of the topic:
-
Set DENYROOTCHANGE = < comma-delimited list of users and groups > -
Set ALLOWROOTCHANGE = < comma-delimited list of users and groups >
-
ROOTCHANGE access to rename an existing top-level web. You just need WEBCHANGE in the web itself.
How Foswiki evaluates ALLOW/DENY settings
When deciding whether to grant access, Foswiki evaluates the following rules in order (read from the top of the list; if the logic arrives at PERMITTED or DENIED that applies immediately and no more rules are applied). You need to read the rules bearing in mind that VIEW, CHANGE and RENAME access may be granted/denied separately.- If the user is an administrator
- access is PERMITTED.
- If DENYTOPIC is set to a list of wikinames
- people in the list will be DENIED.
- If DENYTOPIC is set to empty ( i.e. Set DENYTOPIC = )
- access is PERMITTED i.e no-one is denied access to this topic.
Attention: Use this with caution. This is deprecated and will likely change in the next release.
- access is PERMITTED i.e no-one is denied access to this topic.
- If ALLOWTOPIC is set
- people in the list are PERMITTED
- everyone else is DENIED
- If DENYWEB is set to a list of wikinames
- people in the list are DENIED access
- If ALLOWWEB is set to a list of wikinames
- people in the list will be PERMITTED
- everyone else will be DENIED
- If you got this far, access is PERMITTED
Access control and INCLUDE
ALLOWTOPICVIEW and ALLOWTOPICCHANGE only applies to the topic in which the settings are defined. If a topic A includes another topic B, topic A does not inherit the access rights of the included topic B. Examples: Topic A includes topic B- If the included topic B has ALLOWTOPICCHANGE set to block editing for a user, it does not prevent editing the including topic A.
- If the included topic B has ALLOWTOPICVIEW set to block view for a user, the user can still view topic A but he cannot see the included topic B. He will see a message No permission to view B
Access control quick recipes
Obfuscating webs
Another way of hiding webs is to keep them hidden by not publishing the URL and by preventing theall webs search option from accessing obfuscated webs. Do so by enabling the NOSEARCHALL setting in WebPreferences: -
Set NOSEARCHALL = on
Restrict Access to a whole Foswiki site
For a firewalled Foswiki, e.g. an intranet wiki or extranet wiki, you want to allow only invited people to access your Foswiki. In this case, enable user authentication with ApacheLogin and lock down access to the wholebin and pub directories to all but valid users. In the Apache .htaccess file or the appropriate .conf file, replace the <FilesMatch "(attach|edit|... section with this:
<FilesMatch ".*">
require valid-user
</FilesMatch>
If needed, you can further restrict access to selected webs with ALLOWWEBVIEW and other access control settings.
Authenticate all webs and restrict selected webs
Use the following setup to authenticate users for topic viewing in all webs and to restrict access to selected webs. Requires UserAuthentication to be enabled.- The simple way is to add this to
WebPreferencesin all webs.-
Set DENYWEBVIEW = WikiGuest
-
- Restrict view access to selected users and groups. Set one or both of these settings in its WebPreferences topic:
-
Set ALLOWWEBVIEW = < list of users and groups > - Note:
DENYWEBVIEWis evaluated beforeALLOWWEBVIEW. Access is denied if the authenticated person is in theDENYWEBVIEWlist, or not in theALLOWWEBVIEWlist. Access is granted ifDENYWEBVIEWandALLOWWEBVIEWare not defined.
-
- Set
require valid-useron yourviewscript in .htaccess or the appropriate Apache .conf file. This looks like:FilesMatch "(attach|edit|manage|rename|save|view|upload|mail|logon|.*auth).*"(normallyviewis not in that list).
Authenticate and restrict selected webs only
Use the following setup to provide unrestricted viewing access to open webs, with authentication only on selected webs. Requires UserAuthentication to be enabled.- Restrict view access to selected users and groups. Set one or both of these settings in its WebPreferences topic:
-
Set DENYWEBVIEW = < list of users and groups > -
Set ALLOWWEBVIEW = < list of users and groups > - Note:
DENYWEBVIEWis evaluated beforeALLOWWEBVIEW. Access is denied if the authenticated person is in theDENYWEBVIEWlist, or not in theALLOWWEBVIEWlist. Access is granted ifDENYWEBVIEWandALLOWWEBVIEWare not defined.
-
Hide control settings
Edit topic preference settings under More topic actions menu. Preferences set in this manner are not visible in the topic text, but take effect nevertheless. Access control settings added as topic preference settings are stored in the topic meta data and they override settings defined in the topic text.
Alternatively, place them in HTML comment markers, but this exposes the access setting during ordinary editing.
Back to top<!--
* Set DENYTOPICCHANGE = CM.SomeGroup
-->
Text Formatting
Working in Foswiki is as easy as typing in text. You don't need to know HTML, though you can use it if you prefer. Links to topics are created automatically when you enter WikiWords. And Foswiki shorthand gives you all the power of HTML with a simple coding system that takes no time to learn. It's all laid out below.Editing Shorthand
| Formatting Command: | You write: | You get: | |||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Paragraphs: Blank lines will create new paragraphs. |
1st paragraph 2nd paragraph | 1st paragraph 2nd paragraph | |||||||||||||||||||||||||
|
Headings: Three or more dashes at the beginning of a line, followed by plus signs and the heading text. One plus creates a top level heading, two pluses a second level heading, etc. The maximum heading depth is 6. You can create a table of contents with the %TOC% macro. If you want to exclude a heading from the TOC, put !! after the ---+.
|
---++ Sushi ---+++ Maguro ---+++!! Not in TOC |
SushiMaguroNot in TOC |
|||||||||||||||||||||||||
|
Bold Text: Words get shown in bold by enclosing them in * asterisks.
|
*Bold* | Bold | |||||||||||||||||||||||||
|
Italic Text: Words get shown in italic by enclosing them in _ underscores.
|
_Italic_ | Italic | |||||||||||||||||||||||||
|
Bold Italic: Words get shown in bold italic by enclosing them in __ double-underscores.
|
__Bold italic__ | Bold italic | |||||||||||||||||||||||||
|
Fixed Font: Words get shown in fixed font by enclosing them in = equal signs.
|
=Fixed font= |
Fixed font
|
|||||||||||||||||||||||||
|
Bold Fixed Font: Words get shown in bold fixed font by enclosing them in double equal signs.
|
==Bold fixed== |
Bold fixed
|
|||||||||||||||||||||||||
* _ __ = ==) indicator
with normal punctuation, such as commas and full stops.
|
_This works_, _this does not _ |
This works, _this does not _ |
|||||||||||||||||||||||||
|
Verbatim (Literal) Text: Surround code excerpts and other formatted text with <verbatim> and </verbatim> tags.verbatim tags disable HTML code. Use <pre> and </pre> tags instead if you want the HTML code within the tags to be interpreted. |
<verbatim>
class CatAnimal {
void purr() {
<code here>
}
}
</verbatim>
|
class CatAnimal {
void purr() {
<code here>
}
}
|
|||||||||||||||||||||||||
|
Separator (Horizontal Rule): Three or more three dashes at the beginning of a line.. |
------- |
|
|||||||||||||||||||||||||
|
Bulleted List: Multiple of three spaces, an asterisk, and another space. |
* level 1
* level 2
* back on 1
* A bullet
broken over
three lines
* last bullet
|
|
|||||||||||||||||||||||||
|
Numbered List: Multiple of three spaces, a type character, a dot, and another space. Several types are available besides a number:
|
1. Sushi 1. Dim Sum 1. Fondue A. Sushi A. Dim Sum A. Fondue i. Sushi i. Dim Sum i. Fondue |
|
|||||||||||||||||||||||||
|
Definition List: Three spaces, a dollar sign, the term, a colon, a space, followed by the definition. |
$ Sushi: Japan $ Dim Sum: S.F. |
|
|||||||||||||||||||||||||
|
Table: Each row of the table is a line containing of one or more cells. Each cell starts and ends with a vertical bar '|'. Any spaces at the beginning of a line are ignored.
|^| multiple-span row functionality and additional rendering features
|
| *L* | *C* | *R* | | A2 | B2 | C2 | | A3 | B3 | C3 | | multi span ||| | A5-7 | 5 | 5 | |^| six | six | |^| seven | seven | | split\ | over\ | 3 lines | | A9 | B9 | C9 | |
|
|||||||||||||||||||||||||
|
WikiWord Links: CapitalizedWordsStuckTogether (or WikiWords) will produce a link automatically if preceded by whitespace or parenthesis. Otherweb.TopicName. To link to a topic in a subweb write Otherweb.Subweb.TopicName.'.' are used to separate webs and subwebs from topic names and therefore cannot be used in topic names.
It's generally a good idea to use the macros %SYSTEMWEB% and %USERSWEB% instead of System and CM.
|
WebStatistics Sandbox.WebNotify Sandbox.WebHome Sandbox.Subweb.TopicName | WebStatistics Sandbox.WebNotify Sandbox.WebHome TopicName | |||||||||||||||||||||||||
|
Anchors: You can define a reference inside a topic (called an anchor name) and link to that. To define an anchor write #AnchorName at the beginning of a line. The anchor name must be a WikiWord of no more than 32 characters. To link to an anchor name use the [[MyTopic#MyAnchor]] syntax. You can omit the topic name if you want to link within the same topic.
|
[[WikiWord#NotThere]] [[#MyAnchor][Jump]] #MyAnchor To here | WikiWord#NotThere Jump To here | |||||||||||||||||||||||||
|
Forced Links: You can create a forced internal link by enclosing words in double square brackets. Text within the brackets may contain optional spaces; the topic name is formed by capitalizing the initial letter and by removing the spaces; for example, [[wiki syntax]] links to topic WikiSyntax. You can also refer to a different web and use anchors.
|
[[wiki syntax]] [[Sandbox.My unspaced topic]] escaped: ![[wiki syntax]] | wiki syntax CM.Wiki groups? escaped: [[wiki syntax]] | |||||||||||||||||||||||||
|
Specific Links: You can create a link where you specify the link text and the URL separately using nested square brackets [[reference][text]]. Internal link references (e.g. WikiSyntax) and URLs (e.g. http://foswiki.org/) are both supported.
The rules described under Forced Links apply for internal link references.
|
[[WikiSyntax][wiki syntax]] [[http://gnu.org][GNU]] | wiki syntax GNU | |||||||||||||||||||||||||
|
Prevent a Link: Prevent a WikiWord from being linked by prepending it with an exclamation point. |
!SunOS | SunOS | |||||||||||||||||||||||||
|
Disable Links: You can disable automatic linking of WikiWords by surrounding text with <noautolink> and </noautolink> tags. |
<noautolink> RedHat & SuSE </noautolink> | RedHat & SuSE | |||||||||||||||||||||||||
|
Mailto Links: E-mail addresses are linked automatically. To create e-mail links that have more descriptive link text, specify subject lines or message bodies, or omit the e-mail address, you can write [[mailto:user@domain][descriptive text]].
|
a@b.com [[mailto:a@b.com]\ [Mail]] [[mailto:?subject=\ Hi][Hi]] | a@b.com Mail Hi | |||||||||||||||||||||||||
|
Literal content: Foswiki generates HTML code from TML shorthand. Experts surround anything that must be output literally in the HTML code, without the application of shorthand rules, with <literal>..</literal> tags. |
<literal> | Not | A | Table | </literal> |
| Not | A | Table | | |||||||||||||||||||||||||
|
Protected content: Experts protect text from mangling by WYSIWYG editors using <sticky>..</sticky> tags. Sticky tags don't have any effect on normal
topic display; they are only relevant when content has to be
protected from a WYSIWYG editor (usually because it isn't well-formed HTML, or because it
is HTML that WYSIWYG would normally filter out or modify). Protected
content appears as plain text in the WYSIWYG editor.
|
<sticky> <div> This div is required </div> </sticky> |
This div is required
|
|||||||||||||||||||||||||
Using HTML
You can use most HTML tags in topics without a problem. This is useful where you want to add some content that is formatted in a way that is not supported using shorthand, for example, you can write<strike>deleted text</strike> to get - On collaboration pages, it's better not to use HTML, but to use shorthand instead - this keeps the text uncluttered and easy to edit using the plaintext editor.
- If you must use HTML, use XHTML 1.0 Transitional syntax.
- Use
<literal>..</literal>tags around blocks of HTML to avoid accidental interpretation of shorthand within the HTML. -
Script tags may be filtered out, at the discretion of your Wiki administrator.
- Copy only text between
<body>and</body>tags. - Remove all empty lines. Foswiki inserts
<p />paragraph tags on empty lines, which causes problems if done between HTML tags that do not allow paragraph tags, like for example between table tags. - Remove leading spaces. Foswiki might interpret some text as lists.
- Do not span a tag over more than one line. Foswiki requires that the opening and closing angle brackets -
<...>- of a HTML tag are on the same line, or the tag will be broken. - In your HTML editing program, save without hard line breaks on text wrap.
Hyperlinks
Being able to create links without any special formatting is a core Foswiki feature, made possible with WikiWords and inline URLs.Internal Links
- GoodStyle is a WikiWord that links to the GoodStyle topic located in the current web.
- NotExistingYet is a topic waiting to be written. Create the topic by clicking on the ?. (Try clicking, but then, Cancel - creating the topic would wreck this example!)
External Links
- Protocols matching the configuration parameter
LinkProtocolPattern, which by default is set to(file|ftp|gopher|https|http|irc|mailto|news|nntp|telnet), are linked automatically. You might change this setting to add more protocols (such as smb). Thus, all lines containing:-
file://... -
ftp://... -
gopher://... -
https://... -
http://... -
irc://... -
mailto:...@... -
news://... -
nntp://... -
telnet://...are linked automatically.
-
- E-mail addresses like
name@domain.comare linked automatically.
-
[[Square bracket rules]]let you easily create non-WikiWord links.- You can also write
[[http://yahoo.com Yahoo home page]]as an easier way of doing external links with descriptive text for the link, such as Yahoo home page.
- You can also write
Macros
Macros are names enclosed in percent signs that are that are expanded to some other text when the topic is displayed. For example,%TOPIC% is expanded to MacrosQuickStart, the title of this topic.
Some macros can take arguments in curly braces - for example, %INCLUDE{"OtherTopic" ARG="arg"}%.
Many macro definitions are built-in, and others (preference settings) are predefined for your convenience. You can also define your own
preference settings at the entire site, individual web, or individual topic level. For more information, see Macros
Macros are fully expanded before any of the text formatting rules are applied.
Documentation Graphics: There are many graphics available to use in your topics. Use %ICON{"help"}%, %ICON{"tip"}%, and %ICON{"warning"}% to get: !%SOMEMACRO% to get: %SOMEMACRO%.
Plugin Formatting Extensions
Plugins can extend the functionality of Foswiki into many other areas. There are a huge number of plugins available from the foswiki site?. Currently enabled plugins on this installation, as listed by%PLUGINDESCRIPTIONS%:
- System.TWikiCompatibilityPlugin (Foswiki-1.0.9, $Rev: 6017 (2010-01-11) $): add TWiki personality to Foswiki
- System.SpreadSheetPlugin (10 Nov 2009, $Rev: 5484 (2009-11-10) $): Add spreadsheet calculations like "$SUM($ABOVE())" to Foswiki tables and other topic text
- System.BlackListPlugin (20 Mar 2009, $Rev: 3279 (2009-03-26) $): Utility to keep malicious users away from a public Foswiki site
- System.CommentPlugin (24 Feb 2010, $Rev: 6512 (2010-02-24) $): Quickly post comments to a page without an edit/save cycle
- System.EditTablePlugin (4.34, $Rev: 5854 (2009-12-23) $): Edit tables using edit fields, date pickers and drop down boxes
- System.InterwikiPlugin (20 Sep 2009, $Rev: 5022 (2009-09-20) $): Link ExternalSite:Page text to external sites based on aliases defined in a rules topic
- System.NewUserPlugin (v2.00, $Rev: 3642 (2009-04-23) $): Create a user topic if it does not exist yet
- System.PreferencesPlugin (20 Sep 2009, $Rev: 5037 (2009-09-20) $): Allows editing of preferences using fields predefined in a form
- System.SlideShowPlugin (02 Aug 2008, $Rev: 2742 (2009-02-26) $): Create web based presentations based on topics with headings.
- System.SmiliesPlugin (20 Sep 2009, $Rev: 5046 (2009-09-20) $): Render smilies like
as icons - System.TablePlugin (1.046, $Rev: 6733 (2010-03-13) $): Control attributes of tables and sorting of table columns
- System.TinyMCEPlugin (26 Feb 2010, $Rev: 6527 (2010-02-26) $): Integration of the Tiny MCE WYSIWYG Editor
- System.TwistyPlugin (1.5.4, $Rev: 6281 (2010-02-12) $): Twisty section Javascript library to open/close content dynamically
- System.WysiwygPlugin (17 Jan 2010, $Rev: 6068 (2010-01-17) $): Translator framework for Wysiwyg editors
Common Editing Errors
Foswiki formatting rules are fairly simple to use and quick to type. However, there are some things to watch out for:- Q: Text enclosed in angle brackets like
<filename>is not displayed. How can I show it as it is?- A: The
'<'and'>'characters have a special meaning in HTML, they define HTML tags. You need to escape them, so write'<'instead of'<', and'>'instead of'>'.
Example: Type'prog <filename>'to get'prog <filename>'.
- A: The
- Q: Why is the
'&'character sometimes not displayed?- A: The
'&'character has a special meaning in HTML, it starts a so called character entity, i.e.'©'is the©copyright character. You need to escape'&'to see it as it is, so write'&'instead of'&'.
Example: Type'This & that'to get'This & that'.
- A: The
Macros
Special text strings expand on the fly to display user data or system info Macros are text strings -%MACRONAME% or %MACRONAME{ parameter="value" }% - that expand into content whenever a topic is rendered for viewing. There are two types of macros: - Preference settings: Can be defined and changed by the user
- Predefined macros: Defined by the system or by Plugins (for example, the SpreadSheetPlugin introduces a
%CALC{}%macro)
Using Macros
To use a macro type its name. For example,- type
%T%to get
(a preference settings)
- type
%TOPIC%to getMacros(a predefined macro?) - type
%CALC{ "$UPPER(Text)" }%to getTEXT(a macro? defined by a Plugin)
- To leave a macro unexpanded, precede it with an exclamation point, e.g. type
!%TOPIC%to get%TOPIC% - Macros are expanded relative to the topic they are used in, not the topic they are defined in
- Type
%ALLVARIABLES%to get a full listing of all macros defined for a particular topic
Macro Names
Macro names must start with a letter. The following characters can be letters, numbers and the underscore '_'. You can use both upper-case and lower-case letters and you can mix the characters. E.g.%MYVAR%, %MyVar%, %My2ndVar%, and %My_Var% are all valid macro names. Macros are case sensitive. %MyVAR% and %MYVAR% are not the same macro.
By convention all settings, predefined macros and macros used by plugins are always UPPER-CASE.
Preferences
Preferences settings are simple macros that do not accept parameters, and are defined in topics. A lot of the macros you will encounter are of this type. Preferences can be defined by the user in various places.Setting Preferences
You can set macros in all the following places:- default level in System.DefaultPreferences (not recommended)
- plugin topics (see Plugins)
- local site level in Main.SitePreferences
- user level in individual user topics in CM web
- web level in WebPreferences of a parent web
- web level in WebPreferences of the web
- topic level in topics in webs
- session macros (if sessions are enabled)
Preview will show the wrong thing, and you must Save the topic to see it correctly.
The syntax for setting macros is the same anywhere: [multiple of 3 spaces] * [space] Set [space] MACRONAME [space] = [space] value
Examples:Spaces between the = sign and the value will be ignored. You can split a value over several lines by indenting following lines with spaces - as long as you don't try to use * as the first character on the following line.
Set MACRONAME = value
Set MACRONAME = value
Example:
* Set MACRONAME = value starts here
and continues here
Whatever you include in your Macro will be expanded on display, exactly as if it had been entered directly.
Example: Create a custom logo macroYou can also set preference settings in a topic by clicking the link
- To place a logo anywhere in a web by typing
%MYLOGO%, define the preference settings on the web's WebPreferences topic, and upload a logo file, ex:mylogo.gif. You can upload by attaching the file to WebPreferences, or, to avoid clutter, to any other topic in the same web, e.g.LogoTopic. Sample preference setting in WebPreferences:
Set MYLOGO = %PUBURL%/%WEB%/LogoTopic/mylogo.gif
Edit topic preference settings under More topic actions. Preferences set in this manner are not visible in the topic text, but take effect nevertheless.
Access Control Settings
These are special types of preference settings to control access to content. AccessControl explains these security settings in detail.Local values for preferences
Certain topics (a users home topic, web site and default preferences topics) have a problem; macros defined in those topics can have two meanings. For example, consider a user topic. A user may want to use a double-height edit box when they are editing their home topic - but only when editing their home topic. The rest of the time, they want to have a normal edit box. This separation is achieved usingLocal in place of Set in the macro definition. For example, if the user sets the following in their home topic:
* Set EDITBOXHEIGHT = 10 * Local EDITBOXHEIGHT = 20Then when they are editing any other topic, they will get a 10 high edit box. However when they are editing their home topic, they will get a 20 high edit box.
Local can be used wherever a preference needs to take a different value depending on where the current operation is being performed.
Use this powerful feature with great care! %ALLVARIABLES% can be used to get a listing of the values of all macros in their evaluation order, so you can see macro scope if you get confused.
Predefined Macros
Most predefined macros return values that were either set in the configuration when Foswiki was installed, or taken from server info (such as current username, or date and time). Some, like%SEARCH%, are powerful and general tools.
-
Predefined macros can be overridden by preference settings (except TOPIC and WEB)
-
Plugins may extend the set of predefined macros (see individual Plugins topics for details)
-
Take the time to thoroughly read through ALL preference macros. If you actively configure your site, review macros periodically. They cover a wide range of functions, and it can be easy to miss the one perfect macro for something you have in mind. For example, see %BASETOPIC%,%INCLUDE%, and the mighty%SEARCH%.
ACTIVATEDPLUGINS -- list of currently activated plugins
- Syntax:
%ACTIVATEDPLUGINS% - Expands to: System.TWikiCompatibilityPlugin, System.SpreadSheetPlugin, System.BlackListPlugin, System.CommentPlugin, System.EditTablePlugin, System.InterwikiPlugin, System.NewUserPlugin, System.PreferencesPlugin, System.SlideShowPlugin, System.SmiliesPlugin, System.TablePlugin, System.TinyMCEPlugin, System.TwistyPlugin, System.WysiwygPlugin
- Related: PLUGINDESCRIPTIONS, FAILEDPLUGINS, PLUGINVERSION
ADDTOHEAD
You can write%ADDTOHEAD{...}% in a topic or template. This variable accepts the following parameters: -
_DEFAULToptional, id of the head block. Used to generate a comment in the output HTML. -
textoptional, text to use for the head block. Mutually exclusive withtopic. -
topicoptional, full Foswiki path name of a topic that contains the full text to use for the head block. Mutually exclusive withtext. Example:topic="System.MyTopic". -
requiresoptional, comma-separated list of id's of other head blocks this one depends on.
%ADDTOHEAD% expands in-place to the empty string, unless there is an error in which case the variable expands to an error string.
Use %RENDERHEAD% to generate the sorted head tags.
ALLVARIABLES -- list of currently defined macros
- Syntax:
%ALLVARIABLES% - Expands to: a table showing all defined macros in the current context
AQUA -- start aqua colored text
-
AQUAis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%AQUA% aqua text %ENDCOLOR% - Expands to: aqua text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
ATTACHURL -- full URL for attachments in the current topic
- Syntax:
%ATTACHURL% - Expands to:
http://www.cmcrossroads.com/cmwiki/pub/System/VarATTACHURL - Example: If you attach a file you can refer to it as
%ATTACHURL%/image.gif - Related: ATTACHURLPATH, PUBURL, PUBURLPATH, SCRIPTURL, SCRIPTURLPATH, FileAttachments
ATTACHURLPATH -- path of the attachment URL of the current topic
- Syntax:
%ATTACHURLPATH% - Expands to:
/cmwiki/pub/System/VarATTACHURLPATH - Related: ATTACHURL, PUBURL, PUBURLPATH, SCRIPTURL, SCRIPTURLPATH, FileAttachments
AUTHREALM -- authentication realm
- String defined as {AuthRealm} in configure. This is used in certain password encodings, and in login templates as part of the login prompt.
- Syntax:
%AUTHREALM% - Expands to: Enter your System.LoginName. (Typically First name and last name, no space, no dots, capitalized, e.g. JohnSmith, unless you chose otherwise). Visit System.UserRegistration if you do not have one.
- Related: UserAuthentication, SESSIONID, SESSIONVAR, LOGIN, LOGOUT, SESSION_VARIABLE
BASETOPIC -- base topic where an INCLUDE started
- The name of the topic where a single or nested INCLUDE started - same as
%TOPIC%if there is no INCLUDE - This is the name of the topic requested by the user.
- Syntax:
%BASETOPIC% - Related: BASEWEB, INCLUDINGTOPIC, INCLUDE, TOPIC
BASEWEB -- base web where an INCLUDE started
- The web name where the includes started, e.g. the web of the first topic of nested includes. Same as
%WEB%in case there is no include. - This is the name of the web requested by the user.
- Syntax:
%BASEWEB% - Related: BASETOPIC, INCLUDINGWEB, INCLUDE, WEB
BB -- bullet with line break
- Line break and bullet without indentation.
- Current value: BB =
• - Related: BR, BULLET, BB2, BB3, BB4, CARET, VBAR
BB2 -- level 2 bullet with line break
BB3 -- level 3 bullet with line break
BB4 -- level 4 bullet with line break
BLACK -- start black colored text
-
BLACKis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%BLACK% black text %ENDCOLOR% - Expands to: black text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
BLUE -- start blue colored text
-
BLUEis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%BLUE% blue text %ENDCOLOR% - Expands to: blue text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
BR -- line break
BROWN -- start brown colored text
-
BROWNis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%BROWN% brown text %ENDCOLOR% - Expands to: brown text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
BULLET -- bullet character
CALC{"formula"} -- add spreadsheet calculations to tables and outside tables
- The
%CALC{"formula"}%macro is handled by the SpreadSheetPlugin. There are around 90 formulae, such as$ABS(),$EXACT(),$EXISTS(),$GET()/$SET(),$IF(),$LOG(),$LOWER(),$PERCENTILE(),$TIME(),$VALUE(). - Syntax:
%CALC{"formula"}% - Examples:
-
%CALC{"$SUM($ABOVE())"}%returns the sum of all cells above the current cell -
%CALC{"$EXISTS(Web.SomeTopic)"}%returns1if the topic exists -
%CALC{"$UPPER(Collaboration)"}%returnsCOLLABORATION
-
- Related: IF, SpreadSheetPlugin
CARET -- caret symbol
- The CARET macro is useful in TML tables.
- Current value: CARET = ^
- Related: BR, BULLET, BB, BB2, BB3, BB4, VBAR
COMMENT{ attributes } -- insert an edit box into the topic to easily add comments.
- A
%COMMENT%without parameters shows a simple text box. - The following standard attributes are recognized
Name Description Default typeThis is the name of the template to use for this comment. Comment templates are defined in a Foswiki template - see Customisation, below. If this attribute is not defined, the type is whatever is defined by COMMENTPLUGIN_DEFAULT_TYPE, either in this topic or in your WebPreferences. belowdefaultDefault text to put into the textarea of the prompt. targetName of the topic to add the comment to the current topic locationRegular expression specifying the comment location in the target topic. Read carefully the CommentPlugin documentation! modeFor compatibility with older versions only, synonymous with typenonotifySet to "on" to disable change notification for target topics offnoformSet to "on" to disable the automatic form that encloses your comment block - remember to insert <form>tags yourself! See CommentPluginExamples#noform for an example.offnopostSet to "on" to disable insertion of the posted text into the topic. offremoveSet to "on" to remove the comment prompt after the first time it is clicked. offbuttonButton label text Add comment
- See CommentPlugin for more information
DATE -- signature format date
- Syntax:
%DATE% - Expands to:
09 Feb 2012 - Date format defined as {DefaultDateFormat} in configure
-
When used in a template topic, this variable will be expanded when the template is used to create a new topic. See TemplateTopics#TemplateTopicsVars for details.
- Related: DISPLAYTIME, GMTIME{"format"}, SERVERTIME
DISPLAYTIME{"format"} -- formatted display time
- Formatted time - either GMT or Local server time, depending on {DisplayTimeValues} setting in configure. Same format qualifiers as
%GMTIME% - Syntax:
%DISPLAYTIME%OR%DISPLAYTIME{"format"}% -
%DISPLAYTIME%The time is shown as hh:mm (24 hour clock)- Expands to:
09 Feb 2012 - 11:43
- Expands to:
- Example:
%DISPLAYTIME{"$hou:$min"}%expands to11:43 - Related: GMTIME, SERVERTIME
EDITACTION -- Selects an edit template
- The EDITACTION preference setting lets you define the use of an editaction template instead of the standard edit. If EDITACTION is defined as
text, then hide the form. If EDITACTION is defined asformhide the normal text area and only edit the form. - Syntax: Set EDITACTION = text|form
- Expands to: %EDITACTION%
- Related: CommandAndCGIScripts#edit
-
When EDITACTION is defined as text or form the Edit and Edit Raw buttons simply add ;action=textor;action=formto the URL for the edit script. If you have defined an EDITACTION preference setting you can still edit the topic content or the form by removing the;action=formor;action=textfrom the edit URL in the browser and reload.
EDITTABLE{ attributes } -- edit tables using edit fields and other input fields
- The
%EDITTABLE{}%macro is handled by the EditTablePlugin - Syntax:
%EDITTABLE{ attributes }%
- Supported attributes:
Attribute Comment Default headerSpecify the header format of a new table like "|*Food*|*Drink*|". Useful to start a table with only a button(no header) formatThe format of one column when editing the table. A cell can be a text input field, or any of these edit field types:
• Text input field (1 line):
| text, <size>, <initial value> |
• Textarea input field:
| textarea, <rows>x<columns>, <initial value> |
• Drop down box:
| select, <size>, <option 1>, <option 2>, etc* |
*only one item can be selected
• Radio buttons:
| radio, <size*>, <option 1>, <option 2>, etc |
*size indicates the number of buttons per line in edit mode
• Checkboxes:
| checkbox, <size*>, <option 1>, <option 2>, etc |
*size indicates the number of checkboxes per line in edit mode
• Fixed label:
| label, 0, <label text> |
• Row number:
| row, <offset> |
• Date:
| date, <size>, <initial value>, <DHTML date format> |(see Date Field Type)"text, 16"
for all cellschangerowsRows can be added and removed if "on"
Rows can be added but not removed if"add"
Rows cannot be added or removed if"off"CHANGEROWS
plugin settingquietsaveQuiet Save button is shown if "on", hidden if"off"QUIETSAVE
plugin settingincludeOther topic defining the EDITTABLEparameters. The first%EDITTABLE%in the topic is used. This is useful if you have many topics with the same table format and you want to update the format in one place. Usetopicorweb.topicnotation.(none) helptopicTopic name containing help text shown below the table when editing a table. The %STARTINCLUDE% and %STOPINCLUDE% macros can be used in the topic to specify what is shown. (no help text) headerislabelTable header cells are read-only (labels) if "on"; header cells can be edited if"off"or "0""on"editbuttonSet edit button text, e.g. "Edit this table"; set button image with alt text, e.g."Edit table, %PUBURL%/%SYSTEMWEB%/DocumentGraphics/edittopic.gif"; hide edit button at the end of the table with"hide"(Note: Button is automatically hidden if an edit button is present in a cell)EDITBUTTON
plugin settingbuttonrowSet to topto put the edit buttons above the table.bottomjavascriptinterfaceUse javascript to directly move and delete row without page refresh. Enable with "on", disable with"off".JAVASCRIPTINTERFACE
plugin setting
- Example:
%EDITTABLE{ format="| text, 20 | select, 1, one, two, three |" changerows="on" }%
| *Name* | *Type* |
| Foo | two | - Related: See EditTablePlugin for more details
ENCODE{"string"} -- encodes a string to HTML entities
- Encode "special" characters to HTML numeric entities. Encoded characters are:
- all non-printable ASCII characters below space, except newline (
"\n") and linefeed ("\r") - HTML special characters
"<",">","&", single quote (') and double quote (") - TML special characters
"%","[","]","@","_","*","="and"|"
- all non-printable ASCII characters below space, except newline (
- Syntax:
%ENCODE{"string"}% - Supported parameters:
Parameter: Description: Default: "string"String to encode required (can be empty) type="entity"
type="safe"
type="html"
type="quotes"
type="url"Control how special characters are encoded
entity: Encode special characters into HTML entities, like a double quote into". Does not encode\nor\r.
safe: Encode characters'"<>%into HTML entities.
html: Astype="entity"except it also encodes\nand\r
quotes: Escape double quotes with backslashes (\"), does not change other characters
url: Encode special characters for URL parameter use, like a double quote into%22(this is the default)type="url" - Example:
%ENCODE{"spaced name"}%expands tospaced%20name -
Values of HTML input fields must be entity encoded.
Example:<input type="text" name="address" value="%ENCODE{ "any text" type="entity" }%" /> -
Double quotes in strings must be escaped when passed into other macros.
Example:%SEARCH{ "%ENCODE{ "string with "quotes"" type="quotes" }%" noheader="on" }% -
ENCODE can be used to filter user input from URL parameters and similer to protect against cross-site scripting. The safest approach is to use type="entity". This can however prevent an application from fully working. You can then usetype="safe"which encodes only the characters'"<>%into HTML entities (same as encode="safe"). When ENCODE is passing a string inside another macro always use double quotes ("") type="quote". For maximum security against cross-site scripting you are adviced to install the Foswiki:Extensions.SafeWikiPlugin.
- Related: URLPARAM
ENDCOLOR -- end colored text
-
ENDCOLORis a shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%RED% red text %ENDCOLOR% - Expands to: red text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: VarAQUA, VarBLACK, VarBLUE, VarBROWN, VarGRAY, VarGREEN, VarLIME, VarMAROON, VarNAVY, VarOLIVE, VarORANGE, VarPINK, VarPURPLE, VarRED, VarSILVER, VarTEAL, VarWHITE, VarYELLOW, DefaultPreferences, StandardColors
ENDSECTION{"name"} -- marks the end of a named section within a topic
- Syntax:
%ENDSECTION{"name"}% - Syntax:
%ENDSECTION{type="include"}% - Supported parameter:
Parameter: Description: "name"Name of the section. type="..."Type of the section being terminated; supported types "section","include","expandvariables","templateonly". - If the
STARTSECTIONis named, the correspondingENDSECTIONmust also be named with the same name. If theSTARTSECTIONspecifies a type, then the correspondingENDSECTIONmust also specify the same type. If the section is unnamed,ENDSECTIONwill match with the nearest unnamed%STARTSECTION%of the same type above it. - Related: STARTSECTION
ENV{"varname"} -- inspect the value of an environment variable
- Returns the current value of the environment variable in the CGI (Common Gateway Interface) environment. This is the environment that the CommandAndCGIScripts are running in.
- Note: For security reasons, only those environment variables whose names match the regular expression in
{AccessibleENV}in the Security Settings/Miscellaneous section ofconfigurecan be displayed. Any other variable will just be shown as an empty string, irrespective of its real value. - Example:
%ENV{MOD_PERL}%displays as: not set - If an environment variable is undefined (as against being set to the empty string) it will be returned as
not set. - Related: HTTP_HOST, REMOTE_ADDR, REMOTE_PORT, REMOTE_USER
FAILEDPLUGINS -- debugging for plugins that failed to load, and handler list
- Syntax:
%FAILEDPLUGINS% - Expands to: See Plugins#FAILEDPLUGINS
- Related: PLUGINDESCRIPTIONS, ACTIVATEDPLUGINS, PLUGINVERSION
FORMFIELD{"fieldname"} -- renders a field in the form attached to some topic
- Syntax:
%FORMFIELD{"fieldname"}% - Supported parameters:
Parameter: Description: Default: "fieldname"The name of a Data form field required topic="..."Topic where form data is located. May be of the form Web.TopicNameCurrent topic format="..."Format string. $valueexpands to the field value, and$nameexpands to the field name,$titleto the field title,$formto the name of the form the field is in. The standard format tokens are also expanded."$value"default="..."Text shown if the field is defined in the topic, but the field value is empty. For example, a text field for which all the content has been deleted. ""alttext="..."Text shown if the field is not defined in the topic (even if it is specified in the form definition). For example, this is used when a field exists in the form definition, but the referring topic hasn't been edited since it was added. "" - Example:
%FORMFIELD{"ProjectName" topic="Projects.SushiProject" default="(no project name given)" alttext="ProjectName field not found in form"}% - Related: SEARCH
GMTIME{"format"} -- formatted GM time
- Syntax:
%GMTIME%OR%GMTIME{"format"}% -
%GMTIME%uses the default date format defined by the {DefaultDateFormat} setting in configure- expands to 09 Feb 2012 - 11:43
- Supported special format tokens:
Token: Unit: Example $secondsseconds 59 $minutesminutes 59 $hourshours 23 $dayday of month 31 $wdayday of the Week (Sun, Mon, Tue, Wed, Thu, Fri, Sat) Thu $dowday of the week (Sun = 0) 2 $weeknumber of week in year (ISO 8601) 34 $monthshort name of month Dec $mo2 digit month 12 $year4 digit year 1999 $ye2 digit year 99 $tzeither "GMT" (if set to gmtime), or "Local" (if set to servertime) GMT $isoISO format timestamp 2012-02-09T11:43:57Z $rcsRCS format timestamp 2012/02/09 11:43:57 $httpE-mail & http format timestamp Thu, 09 Feb 2012 11:43:57 GMT $epochNumber of seconds since 00:00 on 1st January, 1970 1328787837 - Tokens can be shortened to 3 characters
- Example:
%GMTIME{"$day $month, $year - $hour:$min:$sec"}%expands to09 Feb, 2012 - 11:43:57 -
When used in a template topic, this macro will be expanded when the template is used to create a new topic. See TemplateTopics#TemplateTopicsVars for details.
- Related: GMTIME, REVINFO, SERVERTIME
GRAY -- start gray colored text
-
GRAYis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%GRAY% gray text %ENDCOLOR% - Expands to: gray text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
GREEN -- start green colored text
-
GREENis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%GREEN% green text %ENDCOLOR% - Expands to: green text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
GROUPS -- a formatted list of groups
- Expands to a formatted list of user groups in your Foswiki.
- Syntax:
%GROUPS% - The macro is intended to be used in CM.WikiGroups, to allow a group listing for various user mapping managers.
- Related: REMOTE_USER, USERINFO, USERNAME, WIKIUSERNAME, WIKIUSERSTOPIC
H -- help icon
HOMETOPIC -- home topic in each web
- Syntax:
%HOMETOPIC% - Expands to:
WebHome, renders as WebHome - Related: NOTIFYTOPIC, STATISTICSTOPIC, TOPIC
HTTP -- get HTTP headers
- Called with the name of an HTTP header field, returns its value. Capitalization and the use of hyphens versus underscores are not significant.
- Syntax:
%HTTP% - Syntax:
%HTTP{"Header-name"}% - Examples:
%HTTP%%HTTP{"Accept-language"}%en-us,en;q=0.5 %HTTP{"User-Agent"}%CCBot/1.0 (+http://www.commoncrawl.org/bot.html) -
You can see the HTTP headers your browser sends to the server on a number of sites e.g. http://www.ericgiguere.com/tools/http-header-viewer.html
- Related: HTTPS, REMOTE_ADDR, REMOTE_PORT, REMOTE_USER
HTTP_HOST -- environment variable
- Syntax:
%HTTP_HOST% - Expands to:
www.cmcrossroads.com - Related: ENV, REMOTE_ADDR, REMOTE_PORT, REMOTE_USER
HTTPS -- get HTTPS headers
- The same as
%HTTP%but operates on the HTTPS environment variables present when the SSL protocol is in effect. Can be used to determine whether SSL is turned on. - Syntax:
%HTTPS% - Syntax:
%HTTPS{"Header-name"}% - Related: HTTP, REMOTE_ADDR, REMOTE_PORT, REMOTE_USER
I -- idea icon
ICON{"name"} -- small documentation graphic or icon of common attachment types
- Generates the HTML img tag of a small graphic image attached to DocumentGraphics. Images typically have a 16x16 pixel size. You can select a specific image by name, or you can give a full filename, in which case the type of the file will be used to select one of a collection of common file type icons.
- Syntax:
%ICON{"name"}% - Examples:
-
%ICON{"flag-gray"}%returns
-
%ICON{"pdf"}%returns
-
%ICON{"smile.pdf"}%returns
-
%ICON{"/dont/you/dare/smile.pdf"}%returns
-
%ICON{"http://trunk.foswiki.org/pub/System/DocumentGraphics/xsl.gif"}%returns
-
- Graphic samples:
arrowbright,
bubble,
choice-yes,
hand - File type samples:
bmp,
doc,
gif,
hlp,
html,
mp3,
pdf,
ppt,
txt,
xls,
xml,
zip - Related: ICONURL, ICONURLPATH, DefaultPreferences, FileAttachments, DocumentGraphics
ICONURL{"name"} -- URL of small documentation graphic or icon
- Generates the full URL of a DocumentGraphics image, which Foswiki renders as an image. The related
%ICON{"name"}%generates the full HTML img tag. Specify image name or full filename (see ICON for details on filenames.) - Syntax:
%ICONURL{"name"}% - Examples:
-
%ICONURL{"arrowbright"}%returns http://www.cmcrossroads.com/cmwiki/pub/System/DocumentGraphics/arrowbright.gif -
%ICONURL{"novel.pdf"}%returns http://www.cmcrossroads.com/cmwiki/pub/System/DocumentGraphics/pdf.gif -
%ICONURL{"/queen/boheme.mp3"}%returns http://www.cmcrossroads.com/cmwiki/pub/System/DocumentGraphics/mp3.gif
-
- Related: ICONURLPATH, ICON, DefaultPreferences, FileAttachments, DocumentGraphics
ICONURLPATH{"name"} -- URL path of small documentation graphic or icon
- Generates the URL path of a DocumentGraphics image, typically used in an HTML img tag. Specify image name or full filename (see ICON for details on filenames.)
- Syntax:
%ICONURLPATH{"name"}% - Examples:
-
%ICONURLPATH{"locktopic"}%returns /cmwiki/pub/System/DocumentGraphics/locktopic.gif -
%ICONURLPATH{"eggysmell.xml"}%returns /cmwiki/pub/System/DocumentGraphics/xml.gif -
%ICONURLPATH{"/doc/xhtml.xsl"}%returns /cmwiki/pub/System/DocumentGraphics/xsl.gif
-
- Related: ICONURL, ICON, DefaultPreferences, FileAttachments, DocumentGraphics
IF{"condition" ...} -- simple conditionals
- Evaluate a condition and show one text or another based on the result. See details in IfStatements
- Syntax:
%IF{"CONDITION" then="THEN" else="ELSE"}%shows"THEN"if"CONDITION"evaluates toTRUE, otherwise"ELSE"will be shown - Example:
%IF{"defined FUNFACTOR" then="FUNFACTOR is defined" else="FUNFACTOR is not defined"}%renders asFUNFACTOR is not defined - Related: $IF() of SpreadSheetPlugin
INCLUDE{"page"} -- include other topic or web page
- Syntax:
%INCLUDE{"page" ...}% - Supported parameters:
Parameter: Description: Default: "SomeTopic"The name of a topic located in the current web, i.e. %INCLUDE{"WebNotify"}%"Web.Topic"A topic in another web, i.e. %INCLUDE{"System.SiteMap"}%"http://..."A full qualified URL, i.e. %INCLUDE{"http://foswiki.org:80/index.html"}%. Supported content types aretext/htmlandtext/plain.
if the URL resolves to an attachment file on the server this will automatically translate to a server-side include. "doc:Foswiki::..." level="3"Generates the embedded documentation in the given perl module. The optional =level parameter lets you define the base level for headings in the included text. pattern="..."Include a subset of a topic or a web page. Specify a RegularExpression that scans from start ( '^') to end and contains the text you want to keep in parenthesis, e.g.,pattern="^.*?(from here.*?to here).*". IncludeTopicsAndWebPages has more.none rev="2"Include a previous topic revision; N/A for URLs top revision raw="on"When a page is included, normally Foswiki will process it, doing the following: 1) Alter relative links to point back to originating host, 2) Remove some basic HTML tags (html, head, body, script) and finally 3) Remove newlines from HTML tags spanning multiple lines. If you prefer to include exactly what is in the source of the originating page set this to on.
raw="on"is short fordisableremoveheaders="on",disableremovescript="on",disableremovebody="on",disablecompresstags="on"anddisablerewriteurls="on".disabled literal="on"While using the rawoption will indeed include the raw content, the included content will still be processed and rendered like regular topic content. To disable parsing of the included content, set theliteraloption to"on".disabled disableremoveheaders="on"Bypass stripping headers from included HTML (everything until first </head>tag)disabled disableremovescript="on"Bypass stripping all <script>tags from included HTMLdisabled disableremovebody="on"Bypass stripping the </body>tag and everything around over and below itdisabled disablecompresstags="on"Bypass replacing newlines in HTML tags with spaces. This compression step rewrites unmatched <'s into <entities unless bypasseddisabled disablerewriteurls="on"Bypass rewriting relative URLs into absolute ones disabled warn="off"Warn if topic include fails: Fail silently (if off); output default warning (if set toon); else, output specific text (use$topicfor topic name)%INCLUDEWARNING%preferences settingsection="name"Includes only the specified named section, as defined in the included topic by the STARTSECTION and ENDSECTION macros. Nothing is shown if the named section does not exists. section=""is equivalent to not specifying a sectionPARONE="val 1"
PARTWO="val 2"Any other parameter will be defined as a macro within the scope of the included topic. The example parameters on the left will result in %PARONE%and%PARTWO%being defined within the included topic. -
JavaScript in included webpages is filtered out as a security precaution per default (disable filter with disableremovescriptparameter) - Examples: See IncludeTopicsAndWebPages
- Related: BASETOPIC, BASEWEB, INCLUDINGTOPIC, INCLUDINGWEB, STARTINCLUDE, STOPINCLUDE, STARTSECTION, ENDSECTION
INCLUDINGTOPIC -- name of topic that includes current topic
- The name of the topic that includes the current topic - same as
%TOPIC%in case there is no include - If a topic is used in a chain of INCLUDEs, INCLUDINGTOPIC is set to the topic directly INCLUDing this one, NOT the topic that has been requested by the user (which is set in BASETOPIC)
- WARNING: While this Macro may appear to work, unless you require the subtle difference between INCLUDINGTOPIC and BASETOPIC, you probably should use BASETOPIC.
- Syntax:
%INCLUDINGTOPIC% - Related: BASETOPIC, INCLUDINGWEB, INCLUDE, TOPIC
INCLUDINGWEB -- web that includes current topic
- The web name of the topic that includes the current topic - same as
%WEB%if there is no INCLUDE. - If a topic is used in a chain of INCLUDEs, INCLUDINGWEB is set to the topic directly INCLUDing this one, NOT the web that has been requested by the user (which is set in BASEWEB)
- WARNING: While this Macro may appear to work, unless you require the subtle difference between INCLUDINGWEB and BASEWEB, you probably should use BASEWEB.
- Syntax:
%INCLUDINGWEB% - Related: BASEWEB, INCLUDINGTOPIC, INCLUDE, WEB
LANGUAGE -- current user's language
- Returns the language code for the language used as the current user. This is the language actually used by Foswiki (e.g. in user interface).
- The language is detected from the user's browser, unless some site/web/user/session-defined setting overrides it:
- If the
LANGUAGEpreference is set, it's used as user's language instead of any language detected from the browser. - Avoid defining
LANGUAGEat a non per-user way, so each user can choose his/her preferred language.
- If the
- Related: LANGUAGES
LANGUAGES -- list available languages
- List the languages available (as
POfiles). These are the languages in which the user interface is available. - Syntax:
%LANGUAGES{...}% - Supported parameters:
Parameter: Description: Default: formatformat for each item. See below for format tokens available in the format string. " * $langname"separatorseparator between items. "\n"(newline)marker="selected"Text for $markerif the item matchesselection"selected"selection="%LANGUAGE%"Current language to be selected in list (none) -
formattokens:Token Meaning $langnamelanguage's name, as informed by the translators $langtaglanguage's tag. Ex: en,pt-br, etc. - Example:
<select>%LANGUAGES{format="<option $marker value='$langtag'>$langname</option>" selection="%LANGUAGE%"}%</select>creates an option list of the available languages with the current language selected
LIME -- start lime colored text
-
LIMEis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%LIME% lime text %ENDCOLOR% - Expands to: lime text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
LOCALSITEPREFS -- web.topicname of site preferences topic
- The full name of the local site preferences topic. These local site preferences overload the system level preferences defined in System.DefaultPreferences.
- Syntax:
%LOCALSITEPREFS% - Expands to:
Main.SitePreferences, renders as Main.SitePreferences
LOGIN -- present a full login link
- Syntax:
%LOGIN% - Expand to: Log In
- Related: UserAuthentication, SESSIONID, SESSIONVAR, LOGOUT, SESSION_VARIABLE
LOGOUT -- present a full logout link
- Syntax:
%LOGOUT% - Expand to:
- Related: UserAuthentication, SESSIONID, SESSIONVAR, LOGIN, SESSION_VARIABLE
M -- moved to... icon
MAINWEB -- synonym for USERSWEB
-
Deprecated. Please use %USERSWEB% instead.
MAKETEXT -- creates text using Foswiki's I18N infrastructure
- Syntax:
%MAKETEXT{"string" args="..."}% - Supported parameters:
Parameter Description Default "text"orstring="text"The text to be displayed. none args="param1, param2"a comma-separated list of arguments to be interpolated in the string, replacing the [_N]placeholders in it.none - Examples:
-
%MAKETEXT{string="Notes:"}%
expands to
Notes: -
%MAKETEXT{"If you have any questions, please contact [_1]." args="%WIKIWEBMASTER%"}%
expands to
If you have any questions, please contact noreply@cmcrossroads.com. -
%MAKETEXT{"Did you want to [[[_1]][reset [_2]'s password]]?" args="%SYSTEMWEB%.ResetPassword,%WIKIUSERNAME%"}%
expands to
Did you want to reset CM.WikiGuest's password?
-
- Notes:
- Foswiki will translate the
stringto the current user's language only if it has such string in its translation table for that language. - Amperstands (
&) followed by one letter (one of a...z, A...Z) (say,X) in the translatable string will be translated to<span class='foswikiAccessKey'>X</span>. This is used to implement access keys. If you want to write an actual amperstand that stays just before a letter, write two consecutive amperstands (&&): they will be transformed in just one. - translatable string starting with underscores (
_) are reserved. You cannot use translatable phrases starting with an underscore. - Make sure that the translatable string is constant. Specially, do not include
%MACROS%inside the translatable strings (since they will get expanded before the%MAKETEXT{...}%itself is handled).
- Foswiki will translate the
MAROON -- start maroon colored text
-
MAROONis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%MAROON% maroon text %ENDCOLOR% - Expands to: maroon text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
META -- displays meta-data
- Provided mainly for use in templates, this macro generates the parts of the topic view that relate to meta-data (attachments, forms etc.) The
formfielditem is the most likely to be useful to casual users. - Syntax:
%META{ "item" ...}% - Parameters:
Item Options Description "formfield"name="...": name of the field. The field value can be shortened as described in System.FormattedSearch for$formfield
newline="...": by default, each newline character will be rewritten to<br />to allow metadata that contains newlines to be used in tables, etc.$nindicates a newline character.
bar="...": by default, each vertical bar is rewritten to an HTML entity so as to not be mistaken for a table separator.Show a single form field "form"none Generates the table showing the form fields. See Form Definition "attachments"all="on"to show hidden attachments.
title="..."to show a title - only if attachments are displayed.
template="..."to use a custom template for the rendering of attachments; defaultattachtablesis used.Generates the list of attachments "moved"none Details of any topic moves "parent"dontrecurse="on": By default recurses up tree, this has some cost. Equivalent todepth=1
depth="...": Return only the specified ancestor.
nowebhome="on": Suppress WebHome.
prefix="...": Prefix that goes before parents, but only if there are parents, default"".
format="...": Format string used to display each parent topic where$webexpands to the web name, and$topicexpands to the topic name; default:"[[$web.$topic][$topic]]"
suffix="...": Suffix, only appears if there are parents; default"".
separator="...": Separator between parents; default" > ".Generates the parent link - Related: METASEARCH
METASEARCH -- special search of meta data
- Syntax:
%METASEARCH{...}% - Supported parameters:
Parameter: Description: Default: type="topicmoved"What sort of search is required?
"topicmoved"if search for a topic that may have been moved
"parent"if searching for topics that have a specific parent i.e. its children
"field"if searching for topics that have a particular form field value (use thenameandvalueparameters to specify which field to search)Required web="%WEB%"Wiki web to search: A web, a list of webs separated by whitespace, or allwebs.Current web topic="%TOPIC%"The topic the search relates to, for topicmovedandparentsearchesAll topics in a web nameform field to search, for fieldtype searches. May be a regular expression (see SEARCH).valueform field value, for fieldtype searches. May be a regular expression (see SEARCH).title="Title"Text that is prefixed to any search results empty format="..."Custom format results. Supports same format strings as SEARCH. See FormattedSearch for usage & examples Results in table default="none"Default text shown if no search hit Empty - Example:
%METASEARCH{type="topicmoved" web="%WEB%" topic="%TOPIC%" title="This topic used to exist and was moved to: "}% - Example: You may want to use this in WebTopicViewTemplate and WebTopicNonWikiTemplate:
%METASEARCH{type="parent" web="%WEB%" topic="%TOPIC%" title="Children: "}% - Example:
%METASEARCH{type="field" name="Country" value="China"}% - Related: SEARCH, META
-
METASEARCH is deprecated in favour of the new and much more powerful query type search. See SEARCH and QuerySearch.
N -- "new" icon
NAVY -- start navy blue colored text
-
NAVYis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%NAVY% navy text %ENDCOLOR% - Expands to: navy text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
NOP -- template text not to be expanded in instantiated topics
- Syntax:
%NOP%- In normal topic text, expands to <nop>, which prevents expansion of adjacent macros and wikiwords
- When the topic containing this is used as a template for another topic, it is removed.
- Syntax:
%NOP{...}%deprecated- In normal topic text, expands to whatever is in the curly braces (if anything).
-
This is deprecated. Do not use it. Use %STARTSECTION{type="templateonly"}%..%ENDSECTION{type="templateonly"}%instead (see TemplateTopics for more details).
- Related: STARTSECTION, TemplateTopics
NOTIFYTOPIC -- name of the notify topic
- Syntax:
%NOTIFYTOPIC% - Expands to:
WebNotify, renders as WebNotify - Related: HOMETOPIC, STATISTICSTOPIC, TOPIC
OLIVE -- start olive green colored text
-
OLIVEis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%OLIVE% olive text %ENDCOLOR% - Expands to: olive text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
ORANGE -- start orange colored text
-
ORANGEis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%ORANGE% orange text %ENDCOLOR% - Expands to: orange text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
P -- pencil icon
PINK -- start pink colored text
-
PINKis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%PINK% pink text %ENDCOLOR% - Expands to: pink text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
PLUGINDESCRIPTIONS -- list of plugin descriptions
- Syntax:
%PLUGINDESCRIPTIONS% - Expands to:
- System.TWikiCompatibilityPlugin (Foswiki-1.0.9, $Rev: 6017 (2010-01-11) $): add TWiki personality to Foswiki
- System.SpreadSheetPlugin (10 Nov 2009, $Rev: 5484 (2009-11-10) $): Add spreadsheet calculations like "$SUM($ABOVE())" to Foswiki tables and other topic text
- System.BlackListPlugin (20 Mar 2009, $Rev: 3279 (2009-03-26) $): Utility to keep malicious users away from a public Foswiki site
- System.CommentPlugin (24 Feb 2010, $Rev: 6512 (2010-02-24) $): Quickly post comments to a page without an edit/save cycle
- System.EditTablePlugin (4.34, $Rev: 5854 (2009-12-23) $): Edit tables using edit fields, date pickers and drop down boxes
- System.InterwikiPlugin (20 Sep 2009, $Rev: 5022 (2009-09-20) $): Link ExternalSite:Page text to external sites based on aliases defined in a rules topic
- System.NewUserPlugin (v2.00, $Rev: 3642 (2009-04-23) $): Create a user topic if it does not exist yet
- System.PreferencesPlugin (20 Sep 2009, $Rev: 5037 (2009-09-20) $): Allows editing of preferences using fields predefined in a form
- System.SlideShowPlugin (02 Aug 2008, $Rev: 2742 (2009-02-26) $): Create web based presentations based on topics with headings.
- System.SmiliesPlugin (20 Sep 2009, $Rev: 5046 (2009-09-20) $): Render smilies like
as icons - System.TablePlugin (1.046, $Rev: 6733 (2010-03-13) $): Control attributes of tables and sorting of table columns
- System.TinyMCEPlugin (26 Feb 2010, $Rev: 6527 (2010-02-26) $): Integration of the Tiny MCE WYSIWYG Editor
- System.TwistyPlugin (1.5.4, $Rev: 6281 (2010-02-12) $): Twisty section Javascript library to open/close content dynamically
- System.WysiwygPlugin (17 Jan 2010, $Rev: 6068 (2010-01-17) $): Translator framework for Wysiwyg editors
- Related: ACTIVATEDPLUGINS, FAILEDPLUGINS, PLUGINVERSION
PLUGINVERSION -- the version of a Foswiki Plugin, or the Foswiki Plugins API
- Syntax:
%PLUGINVERSION{"name"}%to get the version of a specific plugin - Example:
%PLUGINVERSION{"InterwikiPlugin"}%expands to$Rev: 5022 (2009-09-20) $ - Syntax:
%PLUGINVERSION%to get the version of the API - Expands to:
2.0 - Related: WIKIVERSION, ACTIVATEDPLUGINS, FAILEDPLUGINS, PLUGINDESCRIPTIONS
PUBURL -- the base URL of attachments
- Syntax:
%PUBURL% - Expands to:
http://www.cmcrossroads.com/cmwiki/pub - Example: You can refer to a file attached to another topic with
%PUBURL%/%WEB%/OtherTopic/image.gif - Related: ATTACHURL, ATTACHURLPATH, PUBURLPATH, SCRIPTURL, SCRIPTURLPATH, FileAttachments
PUBURLPATH -- the base URL path of attachments
- Syntax:
%PUBURLPATH% - Expands to:
/cmwiki/pub - Related: ATTACHURL, ATTACHURLPATH, PUBURL, SCRIPTURL, SCRIPTURLPATH, FileAttachments
PURPLE -- start purple colored text
-
PURPLEis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%PURPLE% purple text %ENDCOLOR% - Expands to: purple text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
Q -- question icon
QUERYPARAMS -- show paramaters to the query
- Expands the parameters to the query that was used to display the page.
- Syntax:
%QUERYPARAMS{...}% - Supported parameters:
Parameter: Description: Default: format="..."Format string for each entry $name=$valueseparator="..."Separator string separator="$n"(newline)encoding="entity"
encoding="safe"
encoding="html"
encoding="quotes"
encoding="url"Control how special characters are encoded. If this parameter is not given, "safe" encoding is performed which HTML entity encodes the characters '"<>%.
entity: Encode special characters into HTML entities, like a double quote into". Does not encode\nor\r.
safe: Encode characters'"<>%into HTML entities. (this is the default)
html: Astype="entity"except it also encodes\nand\r
quotes: Escape double quotes with backslashes (\"), does not change other characters
url: Encode special characters for URL parameter use, like a double quote into%22type="safe"
- The following escape sequences are expanded in the format string:
Sequence: Expands To: $nameName of the parameter $valueString value of the parameter. Multi-valued parameters will have a "row" for each value. $nor$n()New line. Use $n()if followed by alphanumeric character, e.g. writeFoo$n()Barinstead ofFoo$nBar$nopor$nop()Is a "no operation". This token gets removed; useful for nested search $quotDouble quote ( ") (\" also works)$percntPercent sign ( %)$dollarDollar sign ( $)$ltLess than sign ( <)$gtGreater than sign ( >)$ampAmpersand ( &)
- Example:
-
%QUERYPARAMS{format="<input type='hidden' name='$name' value='$value' encoding="entity" />"}%
-
-
Security warning!
Using QUERYPARAMS can easily be misused for cross-site scripting unless specific characters are entity encoded. By default QUERYPARAMS encodes the characters'"<>%into HTML entities (same as encoding="safe") which is relatively safe. The safest is to use encoding="entity". When passing QUERYPARAMS inside another macro always use double quotes ("") combined with using QUERYPARAMS with encoding="quote". For maximum security against cross-site scripting you are adviced to install the Foswiki:Extensions.SafeWikiPlugin. - See also QUERYSTRING, URLPARAM
QUERYSTRING -- full, unprocessed string of parameters to this URL
- String of all the URL parameters that were on the URL used to get to the current page. For example, if you add ?name=Samantha;age=24;eyes=blue to this URL you can see this in action. This string can be appended to a URL to pass parameter values on to another page.
-
URLs built this way are typically restricted in length, typically to 2048 characters. If you need more space than this, you will need to use an HTML form and %QUERYPARAMS%. - Syntax:
%QUERYSTRING% - Expands to:
- Related: QUERYPARAMS, URLPARAM
RED -- start red colored text
-
REDis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%RED% red text %ENDCOLOR% - Expands to: red text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%.
REMOTE_ADDR -- environment variable
- Syntax:
%REMOTE_ADDR% - Expands to:
38.107.179.228 - Related: ENV, HTTP_HOST, REMOTE_PORT, REMOTE_USER
REMOTE_PORT -- environment variable
- Syntax:
%REMOTE_PORT% - Expands to:
- Related: ENV, HTTP_HOST, REMOTE_ADDR, REMOTE_USER
REMOTE_USER -- environment variable
- Syntax:
%REMOTE_USER% - Expands to:
- Related: ENV, HTTP_HOST, REMOTE_ADDR, REMOTE_PORT, USERNAME, WIKINAME, WIKIUSERNAME
RENDERLIST -- render bullet lists in a variety of formats
- The
%RENDERLIST%macro is handled by the RenderListPlugin - Syntax:
%RENDERLIST% - Syntax:
%RENDERLIST{ "org" focus="Sales.WestCoastTeam" }% - Example:
%RENDERLIST{ "org" }%
* [[Eng.WebHome][Engineering]]
* [[Eng.TechPubs][Tech Pubs]]
* [[Sales.WestCoastTeam][Sales]]
* [[Sales.EastCoastTeam][East Coast]]
* [[Sales.WestCoastTeam][West Coast]] - Related: RenderListPlugin
REVINFO -- revision information of current topic
- Syntax:
- Date format defined as {DefaultDateFormat} in configure
REVINFO{"format"} -- formatted revision information of topic
- Syntax:
%REVINFO%OR%REVINFO{"format"}% -
%REVINFO%is equivalent to%REVINFO{format="r1.$rev - $date - $wikiusername"}%- Expands to:
r1 - 09 Jan 2009 - 12:00:00 - CM.ProjectContributor
- Expands to:
- Supported parameters:
Parameter: Description: Default: "format"Format of revision information, see supported formatting tokens below "r1.$rev - $date - $wikiusername"web="..."Name of web Current web topic="..."Topic name Current topic rev="1.5"Specific revision number Latest revision - Supported formatting tokens:
Token: Unit: Example $webName of web Current web $topicTopic name Current topic $revRevision number. Prefix r1.to get the usualr1.5format5$usernameLogin username of revision jsmith$wikinameWikiName of revision JohnSmith$wikiusernameWikiName with CM web prefix CM.JohnSmith$dateRevision date. Actual date format defined as {DefaultDateFormat} in configure 21 Sep 2006$timeRevision time 23:24:25$isoRevision date in ISO date format 2006-09-22T06:24:25Z$min,$sec, etc.Same date format qualifiers as GMTIME{"format"} - Example:
%REVINFO{"$date - $wikiusername" rev="1.1"}%returns revision info of first revision - Related: GMTIME{"format"}, REVINFO
S -- red star icon
SCRIPTNAME -- name of current script
- The name of the current script is shown, including script suffix, if any (for example
viewauth.cgi) - Syntax:
%SCRIPTNAME% - Expands to:
view - Related: SCRIPTSUFFIX, SCRIPTURL, SCRIPTURLPATH
SCRIPTSUFFIX -- script suffix
- Some Foswiki installations require a file extension for CGI scripts, such as
.plor.cgi - Syntax:
%SCRIPTSUFFIX% - Expands to:
- Related: SCRIPTNAME, SCRIPTURL, SCRIPTURLPATH
SCRIPTURL{"script"} -- URL of script
- Syntax:
%SCRIPTURL%OR%SCRIPTURL{"script"}% -
%SCRIPTURL%returns the base URL of scripts - expands to http://www.cmcrossroads.com/cgi-bin/cmwiki - Expands to:
http://www.cmcrossroads.com/cgi-bin/cmwiki/script - Example: To get the authenticated version of the current topic you can write
%SCRIPTURL{"viewauth"}%/%WEB%/%TOPIC%which expands tohttp://www.cmcrossroads.com/cgi-bin/cmwiki/viewauth/System/Macros -
In most cases you should use %SCRIPTURLPATH{"script"}%instead, as it works with URL rewriting much better -
The editscript should always be used in conjunction with?t=%GMTIME{"$epoch"}%to ensure pages about to be edited are not cached in the browser - Related: PUBURL, SCRIPTNAME, SCRIPTSUFFIX, SCRIPTURLPATH
SCRIPTURLPATH{"script"} -- URL path of script
- As
%SCRIPTURL{"script"}%, but doesn't include the protocol and host part of the URL - Syntax:
%SCRIPTURL%OR%SCRIPTURLPATH{"script"}% - Expands to:
/cgi-bin/cmwiki/script -
The editscript should always be used in conjunction with?t=%GMTIME{"$epoch"}%to ensure pages about to be edited are not cached in the browser - Related: PUBURLPATH, SCRIPTNAME, SCRIPTSUFFIX, SCRIPTURL
SEARCH{"text"} -- search content
- Inline search, shows a search result embedded in a topic
- Syntax:
%SEARCH{"text" ...}% - Supported parameters:
Parameter: Description: Default: "text"Search term. Is a keyword search, literal search, regular expression search, or query, depending on the typeparameter. SearchHelp has morerequired search="text"(Alternative to above) N/A web="Name"
web="CM, Know"
web="all"Comma-separated list of webs to search. You can specifically exclude webs from an allsearch using a minus sign - for example,web="all,-Secretweb". The special wordallmeans all webs that do not have theNOSEARCHALLpreference set toonin their WebPreferences. Note that AccessControls are respected when searching webs; it is much better to use them thanNOSEARCHALL.Current web topic="WebPreferences"
topic="*Bug"Limit search to topics: A topic, a topic with asterisk wildcards, or a list of topics separated by comma. Note this is a list of topic names and must not include web names. All topics in a web excludetopic="Web*"
excludetopic="WebHome, WebChanges"Exclude topics from search: A topic, a topic with asterisk wildcards, or a list of topics separated by comma. Note this is a list of topic names and must not include web names. None scope="topic"
scope="text"
scope="all"Search topic name (title); the text (body) of topic; or all (title and body) "text"type="keyword"
type="word"
type="literal"
type="regex"
type="query"Control how the search is performed when scope="text"orscope="all"
keyword: use Google-like controls as insoap "web service" -shampoo; searches word parts: using the example, topics with "soapsuds" will be found as well, but topics with "shampoos" will be excluded
word: identical tokeywordbut searches whole words: topics with "soapsuds" will not be found, and topics with "shampoos" will not be excluded
literal: search for the exact string, likeweb service
regex: use a RegularExpression search likesoap;web service;!shampoo; to search on whole words use\bsoap\b
query: query search of form fields and other meta-data, like(Firstname='Emma' OR Firstname='John') AND Lastname='Peel'%SEARCHVAR- DEFAULTTYPE%preferences setting (literal)order="topic"
order="created"
order="modified"
order="editby"
order=
"formfield(name)"Sort the results of search by the topic names, topic creation time, last modified time, last editor's WikiName, or named field of DataForms. The sorting is done web by web; if you want to sort across webs, create a formatted table and sort it with TablePlugin's initsort. Note that dates are sorted most recent date last (i.e at the bottom of the table). Sort by topic name limit="all"
limit="16"Limit the number of topics from which results will be returned. This is done after sorting if orderis specified. Note that this does not limit the number of hits from the same topic when you have multiple="on".All results date="..."limits the results to those pages with latest edit time in the given time interval. All results reverse="on"Reverse the direction of the search Ascending search casesensitive="on"Case sensitive search Ignore case bookview="on"BookView search, e.g. show complete topic text. Very resource demanding. Use only with small result sets Show entire topic content. nonoise="on"Shorthand for nosummary="on" nosearch="on" nototal="on" zeroresults="off" noheader="on" noempty="on"Off nosummary="on"Show topic title only Show topic summary nosearch="on"Suppress search string Show search string noheader="on"Suppress default search header
Topics: Changed: By: , unless aheaderis explicitly specifiedShow default search header, unless search is inline and a format is specified (Cairo compatibility) nototal="on"Do not show number of topics found Show number zeroresults="off"Suppress all output if there are no hits zeroresults="on", displays: "Number of topics: 0"noempty="on"Suppress results for webs that have no hits. Show webs with no hits header="..."
format="..."
footer="..."Custom format results: see FormattedSearch for usage & examples Results in table expandvariables="on"Expand embedded macros before applying a FormattedSearch on a search hit. Useful to show the expanded text, e.g. to show the result of a SpreadSheetPlugin %CALC{}%instead of the formulaRaw text multiple="on"Multiple hits per topic. Each hit can be formatted. The last token is used in case of a regular expression ";" and search Only one hit per topic nofinalnewline="on"If on, the search variable does not end in a line by itself. Any text continuing immediately after the SEARCH macro on the same line will be rendered as part of the table generated by the search, if appropriate.offrecurse="on"Recurse into subwebs, if subwebs are enabled. offseparator=", "Line separator between search hits "$n"(Newline)newline="%BR%"Line separator within a search hit. Useful if you want to put multi-line content into a table cell, for example if the format="" parameter contains a $pattern() that captures more than one line, or contains a $formfield() that returns a multi-line textfield. "$n"(Newline) - Example:
%SEARCH{"wiki" web="CM" scope="topic"}% - Example with format:
%SEARCH{"FAQ" scope="topic" nosearch="on" nototal="on" header="| *Topic: * | *Summary: * |" format="| $topic | $summary |"}%(displays results in a table with header - details) -
If the Foswiki:Extensions.TablePlugin is installed, you may put a %TABLE{}%macro just before the%SEARCH{}%to alter the output of a search. Example:%TABLE{ tablewidth="90%" }% - Related: METASEARCH, TOPICLIST, WEBLIST, FormattedSearch, QuerySearch, SearchHelp, SearchPatternCookbook, RegularExpression
SERVERTIME{"format"} -- formatted server time
- Same format qualifiers as
%GMTIME% - Syntax:
%SERVERTIME%OR%SERVERTIME{"format"}% -
%SERVERTIME%uses the Date format defined as {DefaultDateFormat} in configure - Example:
%SERVERTIME{"$hou:$min"}%expands to06:43 -
Note: When used in a template topic, this macro will be expanded when the template is used to create a new topic. See TemplateTopics#TemplateTopicsVars for details.
- Related: GMTIME, SERVERTIME
SESSIONID -- unique ID for this session
- Syntax:
%SESSIONID% - Expand to: 4e17902bad1cf7e6c4bb55da98c41712
- Related: UserAuthentication, AUTHREALM, SESSIONVAR, LOGIN, LOGOUT, SESSION_VARIABLE
SESSIONVAR -- name of CGI and session variable that stores the session ID
- Syntax:
%SESSIONVAR% - Expand to: FOSWIKISID
- Related: UserAuthentication, AUTHREALM, SESSIONID, LOGIN, LOGOUT, SESSION_VARIABLE
SESSION_VARIABLE -- get, set or clear a session variable
- Syntax:
%SESSION_VARIABLE{"name"}% - Syntax:
%SESSION_VARIABLE{"name" set="value"}% - Syntax:
%SESSION_VARIABLE{"name" clear=""}% -
The users ID is in the AUTHUSERsession variable, and is read-only - Related: UserAuthentication, AUTHREALM, SESSIONID, SESSIONVAR, LOGIN, LOGOUT
SILVER -- start silver colored text
-
SILVERis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%SILVER% silver text %ENDCOLOR% - Expands to: silver text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
SLIDESHOWEND -- end slideshow
- The
%SLIDESHOWEND%macro is handled by the SlideShowPlugin - Syntax:
%SLIDESHOWEND% - Example: See SLIDESHOWSTART
- Related: SLIDESHOWSTART, SlideShowPlugin
SLIDESHOWSTART -- convert a topic with headings into a slideshow
- The
%SLIDESHOWSTART%macro is handled by the SlideShowPlugin - Syntax:
%SLIDESHOWSTART% - Syntax:
%SLIDESHOWSTART{ template="MyOwnSlideTemplate" }% - Example:
%SLIDESHOWSTART%
---++ Sample Slide 1
* Bullet 1
* Bullet 2
---++ Sample Slide 2
* Bullet 1
* Bullet 2
%SLIDESHOWEND% - Related: SLIDESHOWEND, SlideShowPlugin
SPACEDTOPIC -- topic name, spaced and URL-encoded deprecated
- The current topic name with added URL-encoded spaces, for use in regular expressions that search for backlinks to the current topic
- Syntax:
%SPACEDTOPIC% - Expands to:
Var%20*SPACEDTOPIC -
This is a deprecated macro. It can be duplicated with %ENCODE{%SPACEOUT{"%TOPIC%" separator=" *"}%}% - Related: SPACEOUT, TOPIC, ENCODE
SPACEOUT{"string"} -- renders string with spaces inserted in sensible places
- Inserts spaces after lower case letters that are followed by a digit or a capital letter, and after digits that are followed by a capital letter.
- Useful for spacing out WikiWords
- Syntax:
%SPACEOUT{ "%TOPIC%" }% - Expands to:
Macros - Supported parameters:
Parameter: Description: Default: separatorThe separator to put between words e.g. %SPACEOUT{"DogsCatsBudgies" separator=", "}% -> Dogs, Cats, Budgies ' ' -
Spaced out WikiWords are not automatically linked. To SPACEOUT a WikiWord but preserve the link use "double bracket" format. For example, [[WebHome][%SPACEOUT{"WebHome"}%]]expands to Web Home - Related: SPACEDTOPIC, $PROPERSPACE() of SpreadSheetPlugin
STARTINCLUDE -- start position of topic text if included
- If present in included topic, start to include text from this location up to the end, or up to the location of the
%STOPINCLUDE%macro. A normal view of the topic shows everything exept the%STARTINCLUDE%macro itself. -
If you want more than one part of the topic included, use %STARTSECTION{type="include"}%instead - Syntax:
%STARTINCLUDE% - Related: INCLUDE, STARTSECTION, STOPINCLUDE
STARTSECTION -- marks the start of a section within a topic
- Section boundaries are defined with
%STARTSECTION{}%and%ENDSECTION{}%. - Sections may be given a name to help identify them, and/or a type, which changes how they are used.
-
type="section"- the default, used for a generic section, such as a named section used by INCLUDE. -
type="include"- like%STARTINCLUDE%...%STOPINCLUDE%except that you can have as many include blocks as you want (%STARTINCLUDE%is restricted to only one). -
type="expandvariables"- all macros inside an "expandvariables" type section gets expanded when a new topic based on the template topic is created. See TemplateTopics for more information. -
type="templateonly"- start position of text to be removed when a template topic is used. This is used to embed text that you do not want expanded when a new topic based on the template topic is created. See TemplateTopics for more information.
-
- Syntax:
%STARTSECTION{"name"}% ................... %ENDSECTION{"name"}% - Syntax:
%STARTSECTION{type="include"}% ........... %ENDSECTION{type="include"}% - Syntax:
%STARTSECTION{type="expandvariables"}% ... %ENDSECTION{type="expandvariables"}% - Syntax:
%STARTSECTION{type="templateonly"}% ...... %ENDSECTION{type="templateonly"}%
- Supported parameters:
Parameter: Description: Default "name"Name of the section. Must be unique inside a topic. Generated name type="..."Type of the section; type "section","expandvariables","include"or"templateonly""section" -
If a section is not given a name, it will be assigned one. Unnamed sections are assigned names starting with _SECTION0for the first unnamed section in the topic,_SECTION1for the second, etc.. -
You can define nested sections. It is not recommended to overlap sections, although it is valid in Foswiki. Use named sections to make sure that the correct START and ENDs are matched. Section markers are not displayed when a topic is viewed.
- Related: ENDSECTION, INCLUDE, NOP, STARTINCLUDE, STOPINCLUDE
STATISTICSTOPIC -- name of statistics topic
- Syntax:
%STATISTICSTOPIC% - Expands to:
WebStatistics, renders as WebStatistics - Related: HOMETOPIC, NOTIFYTOPIC, TOPIC
STOPINCLUDE -- end position of topic text if included
- If present in included topic, stop to include text at this location and ignore the remaining text. A normal view of the topic shows everyting exept the
%STOPINCLUDE%macro itself. - Syntax:
%STOPINCLUDE% - Related: INCLUDE, STARTINCLUDE
SYSTEMWEB -- name of documentation web
- The web containing all documentation and default preference settings
- Syntax:
%SYSTEMWEB% - Expands to:
System - Related: USERSWEB
T -- tip icon
TABLE{ attributes } -- control attributes of tables and sorting of table columns
- The
%TABLE{}%macro is handled by the TablePlugin - Syntax:
%TABLE{ attributes }%
- Supported attributes:
Argument Comment Default value Example sortSet table sorting by clicking headers "on"or"off".unspecified sort="on"initsortColumn to sort initially ( "1"to number of columns).unspecified initsort="2"initdirectionInitial sorting direction for initsort, set to"up"(descending) or"down"(ascending).unspecified initdirection="up"disableallsortDisable all sorting, both initsort and header sort. This is mainly used by plugins such as the EditTablePlugin to disable sorting in a table while editing the table. unspecified disableallsort="on"headerbgHeader cell background colour. "#6b7f93"headerbg="#999999"headerbgsortedHeader cell background colour of a sorted column. the value of headerbgheaderbgsorted="#32596c"headercolorHeader cell text colour. "#ffffff"headercolor="#0000cc"databgData cell background colour, a comma separated list. Specify "none"for no colour, that is to use the colour/background of the page the table is on."#edf4f9,#ffffff"databg="#f2f2f2,#ffffff"databgsortedData cell background colour of a sorted column; see databg.the values of databgdatabgsorted="#d4e8e4,#e5f5ea"datacolorData cell text colour, a comma separated list. unspecified datacolor="#0000CC, #000000"tableborderTable border width (pixels). "1"tableborder="2"tableframeTable frame, set to "void"(no sides),"above"(the top side only),"below"(the bottom side only),"hsides"(the top and bottom sides only),"lhs"(the left-hand side only),"rhs"(the right-hand side only),"vsides"(the right and left sides only),"box"(all four sides),"border"(all four sides).unspecified tableframe="hsides"tablerulesTable rules, set to "none"(no rules),"groups"(rules will appear between row groups and column groups only),"rows"(rules will appear between rows only),"cols"(rules will appear between columns only),"all"(rules will appear between all rows and columns).unspecified tablerules="rows"cellpaddingCell padding (pixels). "0"cellpadding="0"cellspacingCell spacing (pixels). "0"cellspacing="3"cellborderCell border width (pixels). unspecified cellborder="0"valignVertical alignment of cells and headers, set to "top","middle","bottom"or"baseline".unspecified valign="top"headervalignVertical alignment of header cells; overrides valign.unspecified headervalign="top"datavalignVertical alignment of data cells; overrides valign.unspecified datavalign="top"headeralignHeader cell alignment, one value for all columns, or a comma separated list for different alignment of individual columns. Set to "left","center","right"or"justify". Overrides individual cell settings.unspecified headeralign="left,right"dataalignData cell alignment, one value for all columns, or a comma separated list for different alignment of individual columns. Set to "left","center","right"or"justify". Overrides individual cell settings.unspecified dataalign="center"tablewidthTable width: Percentage of window width, or absolute pixel value. unspecified tablewidth="100%"columnwidthsColumn widths: Comma delimited list of column widths, percentage or absolute pixel value. unspecified columnwidths="80%,20%"headerrowsNumber of header rows to exclude from sort. (will be rendered in a HTML theadsection)"1"headerrows="1"footerrowsNumber of footer rows to exclude from sort. (will be rendered in a HTML tfootsection)"0"footerrows="1"idUnique table identifier string, used for targeting a table with CSS. tableN(where N is the table order number on the page)id="userTable"summaryTable summary used by screenreaders: A summary of what the table presents. It should provide an orientation for someone who listens to the table. unspecified summary="List of subscribed users"captionTable caption: A title that will be displayed just above the table. unspecified caption="Users"
- Example:
%TABLE{ tableborder="0" cellpadding="4" cellspacing="3" cellborder="0" }%
| *A1* | *B1* |
| A2 | B2 | - Related: See TablePlugin for more details
TEAL -- start teal colored text
-
TEALis one of the shortcut macros predefined in DefaultPreferences. See the section shortcut macros in that topic for a complete list of colors. - Syntax:
%TEAL% teal text %ENDCOLOR% - Expands to: teal text
-
%<color>%text must end with%ENDCOLOR%. If you want to switch from one color to another one you first need to end the active color with%ENDCOLOR%, e.g. write%RED% some text %ENDCOLOR% %GREEN% more text %ENDCOLOR%. - Related: ENDCOLOR, DefaultPreferences, StandardColors
TOC{"Topic"} -- table of contents
- Table of Contents. Shows a TOC that is generated automatically based on headings of a topic. Headings in WikiSyntax (
"---++ text") and HTML ("<h2>text</h2>") are taken into account. Any heading text after"!!"is excluded from the TOC; for example, write"---+!! text"if you do not want to list a header in the TOC - Syntax:
%TOC%OR%TOC{"SomeTopic" ...}% - Supported parameters:
Parameter: Description: Default: "TopicName"topic name Current topic web="Name"Name of web Current web depth="2"Limit depth of headings shown in TOC 6 title="Some text"Title to appear at top of TOC none - Example:
%TOC{depth="2"}% - Example:
%TOC{"CompleteDocumentation" web="System" title="Contents:"}% - Example: see Foswiki:Sandbox.TestTopicInclude
-
TOC will add an HTML anchor called foswikiTOCjust before the table of contents. This enables adding a link from within a topic back to the table of contents to ease navigation. Example[[#foswikiTOC][Back to TOC]]creates Back to TOC. -
If multiple headers have the exact same text, the anchors for the 2nd, 3rd etc will be suffixed by _AN1, _AN2 etc so the anchors become unique.
TOPIC -- name of current topic
-
%TOPIC%expands to the name of the topic. If you are looking at the text of an included topic, it is the name of the included topic. - Syntax:
%TOPIC% - Expands to:
Macros, renders as Macros - Related: BASETOPIC, INCLUDINGTOPIC, TOPICLIST, WEB
TOPICLIST{"format"} -- topic index of a web
- List of all topics in a web. The "format" defines the format of one topic item. It may include formatting tokens: The
$topictoken gets expanded to the topic name,$markertomarkerparameter where topic matchesselection, and$webto the name of the web, or any of the standard FormatTokens. - Syntax:
%TOPICLIST{"format" ...}% - Supported parameters:
Parameter: Description: Default: "format"Format of one line, may include $web(name of web),$topic(name of the topic),$marker(which expands tomarkerfor the item matchingselectiononly)"$topic"format="format"(Alternative to above) "$topic"separator=", "line separator "$n"(new line)marker="selected"Text for $markerif the item matchesselection"selected"selection="TopicA, TopicB"Current value to be selected in list (none)web="Name"Name of web Current web - Example:
%TOPICLIST{" * $web.$topic"}%creates a bullet list of all topics - Example:
%TOPICLIST{separator=", "}%creates a comma separated list of all topics - Example:
%TOPICLIST{" <option>$topic</option>"}%creates an option list (for drop down menus) - Example:
<select>%TOPICLIST{" <option $marker value='$topic'>$topic</option>" separator=" " selection="%TOPIC%"}%</select>creates an option list of web topics with the current topic selected - Related: SEARCH, WEBLIST
TOPICURL -- shortcut to viewing the current topic
- This macro always expands to an url pointing to the current base topic.
- Current value: TOPICURL = http://www.cmcrossroads.com/cgi-bin/cmwiki/view/System/CompleteDocumentation
TWIKIWEB -- synonym for SYSTEMWEB
-
Deprecated. Please use %SYSTEMWEB%instead.
U -- "updated" icon
URLPARAM{"name"} -- get value of a URL parameter
- Returns the value of a URL parameter.
- Syntax:
%URLPARAM{"name"}% - Supported parameters:
Parameter: Description: Default: "name"The name of a URL parameter required default="..."Default value in case parameter is empty or missing empty string newline="<br />"Convert newlines in textarea to other delimiters no conversion encode="off"
encode="entity"
encode="safe"
encode="url"
encode="quote"Control how special characters are encoded
off: No encoding. Avoid using this when possible. See the security warning below.
entity: Encode special characters into HTML entities. See ENCODE for more details.
safe: Encode characters'"<>%into HTML entities.
url: Encode special characters for URL parameter use, like a double quote into%22
quote: Escape double quotes with backslashes (\"), does not change other characters; required when feeding URL parameters into other macros."safe" multiple="on"
multiple="[[$item]]"If set, gets all selected elements of a <select multiple="multiple">tag. A format can be specified, with$itemindicating the element, e.g.multiple="Option: $item"first element separator=", "Separator between multiple selections. Only relevant if multiple is specified "\n"(new line) - Example:
%URLPARAM{"skin"}%returnsprintfor a.../view/System/Macros?skin=printURL -
Notes: - URL parameters passed into HTML form fields must be entity ENCODEd.
- Double quotes in URL parameters must be escaped when passed into other macros.
Example:%SEARCH{ "%URLPARAM{ "search" encode="quote" }%" noheader="on" }% - When used in a template topic, this macro will be expanded when the template is used to create a new topic. See TemplateTopics#TemplateTopicsVars for details.
- Watch out for internal parameters, such as
rev,skin,template,topic,web; they have a special meaning in Foswiki. Common parameters and view script specific parameters are documented at CommandAndCGIScripts. - If you have
%URLPARAM{in the value of a URL parameter, it will be modified to%<nop>URLPARAM{. This is to prevent an infinite loop during expansion. - Security warning! Using URLPARAM can easily be misused for cross-site scripting unless specific characters are entity encoded. By default URLPARAM encodes the characters
'"<>%into HTML entities (same as encode="safe") which is relatively safe. The safest is to use encode="entity". When passing URLPARAM inside another macro always use double quotes ("") combined with using URLPARAM with encode="quote". For maximum security against cross-site scripting you are adviced to install the Foswiki:Extensions.SafeWikiPlugin.
- Related: ENCODE, SEARCH, FormattedSearch, QUERYSTRING
USERINFO{"name"} -- retrieve details about a user
- Syntax:
%USERINFO% - Expands to:
guest, CM.WikiGuest,(comma-separated list of the username, wikiusername, and emails) - With formatted output, using tokens
$emails,$username,$wikiname,$wikiusername,$groupsand$admin($admin returns 'true' or 'false'):- Example:
%USERINFO{ format="$username is really $wikiname" }% - Expands to:
guest is really WikiGuest
- Example:
- Retrieve information about another user:
- Example:
%USERINFO{ "WikiGuest" format="$username is really $wikiname" }% - Expands to:
guest is really WikiGuest -
The parameter should be the wikiname of a user. You can also pass a login name. You can only get information about another user if the {AntiSpam}{HideUserDetails}configuration option is not enabled, or if you are an admin. (User details are hidden in this site)
- Example:
- Related: USERNAME, WIKINAME, WIKIUSERNAME, UserAuthentication, ChangeEmailAddress
USERNAME -- your login username
- Foswiki makes names available in three formats: USERNAME like
jsmith, WIKINAME likeJohnSmithand WIKIUSERNAME likeCM.JohnSmith. Un-authenticated users are all CM.WikiGuest. - Syntax:
%USERNAME% - Expands to:
guest -
When used in a template topic, this macro will be expanded when the template is used to create a new topic. See TemplateTopics#TemplateTopicsVars for details.
- Related: REMOTE_USER, USERINFO, WIKINAME, WIKIUSERNAME, UserAuthentication
USERSWEB -- name of users web
- The web containing individual user topics, CM.WikiGroups, and customised site-wide preferences.
- Syntax:
%USERSWEB% - Expands to:
CM - Related: SYSTEMWEB
VAR{"NAME" web="Web"} -- get a preference value from another web
- Syntax:
%VAR{"NAME" web="Web"}% - Example: To get
%WEBBGCOLOR%of the CM web write%VAR{"WEBBGCOLOR" web="CM"}%, which expands to#FFFED5 - Related: WEBPREFSTOPIC
VBAR -- vertical bar
- The vertical bar macro can be used in TML tables.
- Current value: VBAR = |
- Related: BR, BULLET, BB, BB2, BB3, BB4, CARET
WEB -- name of current web
-
%WEB%expands to the name of the web where the topic is located. If you are looking at the text of an included topic, it is the web where the included topic is located. - Syntax:
%WEB% - Expands to:
System - Related: BASEWEB,

CompleteDocumentation