| Table of Contents
 | 
There are usually two changes that people want to make as to how the URL to a Horde component appears in the browser. If only offering one component -- say, IMP -- then one often wants to have a url of
http://webmail.example.com/instead of
http://webmail.example.com/horde/imp/If offering multiple Horde components -- say, IMP and Kronolith -- one often wants to have
http://horde.example.com/mail/and
http://horde.example.com/calendar/instead of the longer versions with the /horde/ component.
To make a single Horde component appear at the root directory of the webserver, add aliases to your webserver's configuration file for the /horde/ directory, make the /horde/componentname/ the server's document root, and restart your web server.
For example, to make IMP appear at the root directory with Apache, add the following to the httpd.conf:
Alias /horde/ /usr/local/apache/htdocs/horde/
DocumentRoot  /usr/local/apache/htdocs/horde/imp(substituting your own directory names for the defaults above). Then, make sure links within Horde are correct as follows:
Modify the $this->applications['imp'] array in horde/config/registry.php and change the value of the webroot as follows:
<?php $this->applications['imp'] = array( 'fileroot' => dirname(__FILE__) . '/../imp', 'webroot' => '', 'icon' => '/graphics/imp.gif', 'name' => _("Mail"), ?>
With the above settings, going to http://yourserver.example.com/ will take the user right to the IMP login screen.
In the case where one wants to run more than one Horde component but omit the /horde/ part of the URL, configure the webserver to treat the /horde/ directory as the root document directory, and add an alias to make sure links into it still succeed. In Apache:
DocumentRoot /usr/local/apache/htdocs/horde(substituting directory names as appropriate). Then, if the automatic webroot detection doesn't work, make sure links within Horde are correct as follows:
Modify the $this->applications['horde'] array in horde/config/registry.php and change the value of the webroot as follows:
<?php $this->applications['horde'] = array( 'fileroot' => dirname(__FILE__) . '/..', 'webroot' => '', 'initial_page' => 'login.php', 'name' => _("Horde"), ?>
Finally, change the Horde configuration in the General tab of the setup interface to change the cookie path from '/horde' to '/'.
If you want to change the name "Horde" on the login screen ("Welcome to Horde"), the above file is the place to do it.
Change the value from:
<?php 'name' => _("Horde"), ?>
to
<?php 'name' => _("Whatever"), ?>
See Doc/Dev/Layout and Doc/Dev/Themes.
You can add Horde modules to the left navigation bar by modifying /horde/config/registry.php.
You can modify the components' navigation bars (at the top of screen) by adding menu entries through the Setup Interface, or modifying the /horde/componentname/config/menu.php files. Follow the instructions in the comments found in the file. This provides a very easy way to add links to the various Horde component navigation menus.
You may wish to alter some of the text in an existing language -- to match the terminology used locally, for instance.
You change strings by changing them in the locale files for the desired language(s). To change the US English translation, you will need to create a new US English (en_US) locale, as one normally does not exist, and modify the translations in that file. See the following FAQ entry for information on creating a new locale file.
To change the translation for a locale, you must first change the locale files and then recompile them. Find the appropriate files in /horde/po/, named by the locale name. Edit the translation(s) in this file to suite your needs. Then compile the locale files as described in your version's /horde/po/README file. For other components, follow the same steps using the /horde/componentname/po files.
If you are having difficulty finding the file which contains the phrase you want to change, the following Unix command may be of assistance:
grep -rli  'Your Phrase' horde/where horde/ is the root directory of your Horde installation.
To make your search case sensitive remove the -i.
To see the match rather than just the file name remove the -l.
Note: The following question may also be of help to you if you are changing the locale files.
Horde uses GNU gettext for internationalization (i18n) and localization (l10n). See horde/po/README and horde/docs/TRANSLATIONS for more information.
Horde comes with a problem-reporting form. You can control who sees it, and what is done with problem reports, by going to the Problem Reporting tab of the Horde setup interface.
PHP's safe_mode is not officially supported by Horde, although we work around its restrictions wherever we can. Many have tried to use it, and have reported various levels of success. To run in safe_mode you will need to modify the PHP safe_mode settings. You may also have to change some code in Horde or other Horde components in order to make things work properly. Some of the known issues are not being able to set PHP maximum execution time, problems with spell checking, not being able to use Sendmail (without modifying the php safe_mode configuration), and problems with any sort of file uploads (adding attachments in IMP, file uploads in Gollem, etc).
If you run the Apache web server with virtual hosts and with PHP's safe_mode enabled by default, you can use the Apache PHP module configuration command php_admin_value in your main Apache configuration file to remove safe_mode for the Horde virtual host. For example:
<VirtualHost ...>
...
  <Directory ...>
    ....
    <IfModule mod_php4.c>
       php_admin_value safe_mode Off
       ...
    </IfModule>
    ...
  </Directory>
  ...
</VirtualHost>Remember to test for module mod_php5.c or similar if you are running PHP 5 or any other version.
It has been reported that Horde, IMP, and Turba, with safe_mode enabled, are working fine with this apache configuration:
    <Directory /path/to/horde>
        php_admin_value open_basedir "/path/to/horde:/path/to/pear/lib/:/path/to/logfile/dir"
        php_admin_flag file_uploads On
        php_admin_value upload_tmp_dir /path/to/horde/tmp
        <FilesMatch "smime\.php">
            php_admin_value safe_mode_exec_dir "/path/to/openssl/bin"
            php_admin_value open_basedir "/path/to/horde:/path/to/pear/lib/:/path/to/logfile/dir:/var/tmp"
        </FilesMatch>
    </Directory>With this configuration, it is possible to import private keys, to sign and encrypt mails, to add attachment files, and to set languages. The $conf['tmpdir'] setting must be set to /path/to/horde/tmp in the Horde setup. It is used for uploads (IMP attachments) and to generate temporary files when you are signing and/or encrypting mails. A special configuration is set for the smime.php file so it can run the openssl command to encrypt and decrypt the private key when it is imported in the database. To enable the private key import, /var/tmp must be added to the the open_basedir list (why?).
This configuration has been tested with a direct access to the SMTP server (no local sendmail).
There is no warranty that everything works fine but the most important features (like sending, receiving, attaching files, signing, encrypting) are working fine.
You can add content to the top of every page in a Horde component by adding appropriate code to the file templates/common-header.inc for that component. You can add content to the bottom of every page in all Horde components by adding appropriate code to the file horde/templates/common-footer.inc.
Any user preferences already set and stored in the preference storage container will overrule any newly locked preferences that may be set by the administrator. This is because the administrator may want to lock a preference, but create a different value for some users. The administrator controls the preferences container, so we trust the preferences container.
Thus if users select and save their own values for an unlocked preference, and then the administrator decides to lock that preference value, any previously set user values would overrule the new locked value set by the administrator.
Therefore, if when locking a preference for which users have already set values you wish that all users conform to the new locked setting, you must empty out the stored preference values in the preference storage container for all users. Horde includes a script in horde/scripts/remove_prefs.php to aid in doing this. In Horde 3.2 and above, this script is in the administrator tools package (http://pear.horde.org/index.php?package=admintools).
This is a function of some web browsers called AutoComplete. It can be disabled in the browser or via the html code on the server. Horde does not currently disable this via HTML code as the method for doing so is not XHTML 1.0 compliant.
This is best done by disabling the feature in your web browser. How to do this depends on your browser. See the documentation for your browser for information on how to accomplish this.
Some browsers let you selectively erase your AutoComplete data. How to do this would vary depending on your browser. For example, in Microsoft's Internet Explorer you can use the following sequence to erase all your stored AutoComplete data: From the menu bar at the top of your browser, choose: Tools -> Internet Options -> Content Tab -> AutoComplete Button -> Clear Forms.
You can also selectively delete individual items. For example, in Internet Explorer, while the cursor is in a form element, put in at least one letter so that the AutoComplete responses are made visible. Using your arrow keys, scroll down to highlight the response you want to erase. Push the Delete key on your keyboard.
If you wish to disable this for your site, you can do so by modifying the HTML code. This may make upgrading your installation more difficult, so think twice about this before doing it.
You can edit the source code for the login form and add autocomplete="off" to the form to disable AutoComplete for all fields in the form. For example:
<form method="post" action="/path" autocomplete="off">You can also use the attribute in individual form fields to disable AutoComplete only for that field. For example:
Password: <input type="password" name="pass" autocomplete="off" />You can also disable it in a form, and then enable it for certain fields in a form, or vice versa, by using the above techniques and setting the autocomplete attribute to "on" or "off" where desired.
Horde is very flexible in how it can authenticate users, allowing for many different types of authentication. Because of this, there is no single answer for how you authenticate users; the answer will depend on your particular setup and needs.
In most cases, you will want to use an existing user database. If not, you will need to create a new user database of some sort on your own.
Once you know what type of user database you want to use, you must configure Horde and possibly some other Horde applications (like IMP, gollem, etc) to use that authentication source. For Horde, you do this in the Authentication tab of the setup interface. If you choose to use IMP to authenticate users (e.g. by having IMP log into the IMAP or POP3 server) you must configure horde/imp/config/servers.php appropriately also.
Some special notes for some of the authentication methods are:
There are none. Since Horde supports a broad variety of different authentication backends and you are free to choose any of them for your Horde installation, the selected backend decides which are valid login credentials. And we didn't add an authentication independent backdoor to Horde, for obvious reasons.
Instead, you can turn any valid and authenticated user into an administrator by adding his user name to the administrator list in Horde's configuration. Make sure to use user names exactly like they are used inside Horde, i.e. with or without a domain name, and considering any user name hooks that you enabled.
You probably locked yourself out as an administrator because you properly configured an authentication backend for Horde, but forgot to add yourself as an administrator in the Horde configuration - see the paragraph above. If you don't want to start from scratch by copying conf.php.dist to conf.php again, you need to change the configuration file horde/config/conf.php manually. Edit the $conf['auth']['admins'] setting and add your username, e.g. $conf['auth']['admins'] = array('joe'); or $conf['auth']['admins'] = array('joe@example.com');. You can add several administrators using a comma separated list.
You may have noticed within the Horde configuration an option to fix certain portal blocks on the Portal screen. The next question is often "how are those blocks to be configured?" The answer lies within the Horde Preferences system. The Horde preference that controls the layout of the portal blocks and their settings is the 'portal_layout' preference. This preference is stored as a serialized array of data containing all the information required to display the Portal. However this format can be tricky to come up with manually. The easiest way to generate the value is to set up your own portal view as you would like your users to experience it. Once you have done so, and saved the setting, the preference will be saved to your configured Horde_Prefs backend. At this point you can either consult the Horde_Prefs backend directly (ie. pull the value directly from SQL or the Base64 encoded value from LDAP) or you can use Horde's built-in PHP Shell, accessible from the "Administration" menu. To get your current preference value, type the following into the PHP Shell text box:
echo $GLOBALS['prefs']->getValue('portal_layout');This value can then be pasted into the file horde/config/prefs.php as the default value of the 'portal_layout' preference.
If you have your web server set up to answer requests from multiple domains, you can use those virtual hosts to ensure that mail is sent with the appropriate From: header. In other words, when someone goes to
http://example.com/webmail/mail will be sent from username@example.com, and when they go to
http://example.net/webmail/mail will be sent from username@example.net.
You can check the IMP mailing list archives for information.
There are a number of IMP features and functions which can be disabled in IMP's setup interface and in the file /horde/imp/config/prefs.php. See the comments in the interface and this file for more information.
When changing settings in /horde/imp/config/prefs.php you can set the "value" field for a preference to set the default value of that preference. If you want to force users to use that value, and not allow them to change it, you must also set the 'locked' field to true.
You may need to make changes to any or all of the following settings: PHP, Apache, database, and Mail Transfer Agent. Settings in each of these parts may affect overall attachment size and you will likely want any value that deals with size to be set to the same value of whatever maximum size you want to support.
By default, PHP limits uploaded files to 2 MB, and this limit applies to attachments on messages sent from IMP. To change this value, edit the following value in your php.ini:
upload_max_filesize = number of bytes
post_max_size = number of bytes + size of form data, e.g. message textOther limits that might affect the maximum size of attachments that PHP is able to handle:
max_execution_time = 30 ;may need to be higher
memory_limit = -1 ;removes the memory limit for phpYou will need to restart your web server after this change and logout/login back into horde to see your new configured values in effect.
A few of these settings can also be changed through Horde's setup interface and override the default PHP settings.
It is also possible that web server settings may limit the size of attachments. For example, the Apache setting LimitRequestBody will limit the size also. In some Linux distributions (e.g. Red Hat Enterprise Linux 3), this is set very low in a distribution-created /etc/httpd/conf.d/php.conf file. Again, you will need to restart your web server after changing web server configuration settings.
Your database server may impose limits on the maximum size of files that can be uploaded. Check your database server documentation to see what this limit may be. For MySQL, this limit is controlled by the max_allowed_packet configuration directive.
Finally, your MTA may impose size limits for the overall size of messages that it will handle. Check your MTA configuration to see if there are settings to limit overall message size.
To add custom SMTP headers to mail sent from IMP, place the headers in /horde/imp/config/header.txt (/horde/imp/config/header.php in IMP 4.1 or higher). Make sure that your header is the last line in the file!
[IMP 4.0]: You can include PHP variables by enclosing them in percent signs ("%"). One useful header is
X-Originating-IP: %REMOTE_ADDR%which follows a de-facto standard adhered to by Hotmail, Yahoo Mail, and Dejanews (to name but a few) of listing the address of the computer at which the mail message was composed.
[IMP 4.1+]: You can enter any valid PHP expressions.
Note that these are email headers, not body text. If you want to add an advertisement for your webmail service, or a similar announcement, to outgoing mail, put it at the bottom of the message (which is the standard location) by placing the text in /horde/imp/config/tailer.txt.
Oxford University's archive provides wordlists for the languages in IMP's spellcheck (and many more!), as does the International ispell Home Page.
All of the above are transparent to the IMAP protocol itself, and are thus transparent to IMP. If you can tell your IMAP server to serve the type of folders that you want to serve, then IMP can read them.
Both Maildir and shared folders are supported by Courier-IMAP, although it does not support standard mbox format mailboxes. MH folders are supported by UW-IMAP.
Note that you can not use folders with POP3 as the POP3 protocol does not contain any support for folders. If you want to use folders then you must configure IMP to use IMAP rather than POP3 access.
IMP is capable of showing certain attachments inline (i.e., in the message body, rather than appearing in a new window on request), but in some cases it risks exposing the user to a security problem in the browser: by enabling inline HTML, any JavaScript? (ActiveX, Java, etc.) in the attachment might be executed by the browser. We try to filter out any active content, but just like with any filter, it might not be perfect and let some code through. Enabling inline HTML attachments is discouraged.
Of course, this will only work for elements that could be part of a regular HTML page. In particular, images cannot be part of in a regular HTML page (they have to be a separate file with an <IMG> tag to include them in an HTML page), and can thus not be inlined.
Edit the files horde/config/mime_drivers.php and horde/imp/config/mime_drivers.php to enable inline support for the mime types you wish to have displayed inline. Simply set the 'inline' array element for that mime type to true to enable a type. As noted above, not all mime types can be shown inline; if there is no 'inline' array element for a mime type than that type can not be viewed inline.
For example, to enable inline HTML support you would set:
<?php $mime_drivers['imp']['html']['inline'] = true; ?>
IMP has no built-in address book, but instead uses the Horde module Turba for an address book. See the Turba FAQ section for information on configuring Turba for LDAP support. You must have Turba installed and working before you configure IMP to use it for address books.
To configure IMP to use one or more Turba directories by default, you modify the file horde/imp/config/prefs.php to set the value of the $_prefs['search_sources'] array. The 'value' field of this array needs to be set to a tab delimited set of Turba directory sources. IMP will then use these sources for directory lookups.
IMP does not include support for changing passwords. You can download a separate Horde module called Passwd to add this functionality.
There is some signup functionality in Horde that requires an authentication backend that can be managed through Horde. Signups have to be enabled in the Horde setup interface.
[IMP 3.0]: You need to disable each maintenance function individually. You can do so by editing the file horde/imp/config/prefs.php. You need to locate the stanzas for rename_sentmail_monthly, delete_sentmail_monthly, delete_sentmail_monthly_keep, purge_trash, purge_trash_interval, and purge_trash_keep.
For each stanza, set the 'value' field to 0 (zero) and the 'locked' field to true.
[IMP 3.1+]: To disable the maintenance functions by default for all users (but still allow individual users to choose to turn it back on) edit horde/imp/config/prefs.php, locate the stanza for $_prefs['do_maintenance'], and set the 'value' field to 0 (zero).
To prevent maintenance functions completely (so even individual users can not enable it for themselves), simply edit horde/imp/config/prefs.php, locate the stanza for $_prefs['do_maintenance'], and set the 'value' field to 0 (zero) and the 'locked' field to true.
In order for the Options button to show up, you need to make sure you have created a preferences storage container. This means you must have either a database or LDAP backend in place and configured. For more information see the file horde/docs/INSTALL.
You will also have to configure Horde to use the preferences container. This is done in the Preference System Settings section of the file horde/config/horde.php.
Horde and IMP can support SMTP authentication, but only if the SMTP server take the same authentication credentials as the POP/IMAP server (which would generally be the case). Simply edit the Horde configuration as per the comments in the Mailer tab of the setup interface.
IMP automatically appends the content of the file horde/imp/config/trailer.txt to each email it sends. You can disable this by disabling the according configuration option (Setup -> Mail (Imp)... -> Compose -> Should we append the contents...) in IMP's setup interface. If enabled, you can change the message by simply editing the contents of horde/imp/config/trailer.txt to suit your needs. Please note that this is a text file, and should not contain HTML or PHP code but only normal text.
You need to modify horde/turba/config/sources.php to specify your LDAP server and its attributes. The documentation in the file is pretty complete, and there are some examples using public LDAP directories.
[Turba 2.1+]: You can enable shared address book support for a source that supports this by adding 'use_shares' => true to the source's stanza in horde/turba/config/sources.php. This allows users to create and delete new address books as well as manage permissions on the address books that they own. Permissions for shared address books should be set through the My Address Books interface in Turba and not through the administration interface. Choose the menu item My Address Books and then select the address book you want to share from the drop down menu in the Edit Address Book section then click Edit Permissions.