Syntax of elogd.cfg
The configuration file elogd.cfg
contains entries which define
the structure of logbooks and the behavior of elogd. The file has a simple ASCII
format. Each logbook is defined by a [<name>]
section
where <name> is the name of the logbook. The [global]
section is used for settings common to all logbooks. Each line contains a setting
name, followed by an equal sign and the value for this setting. Lines starting with
";" are treated as comments.
Here is a simple example, which define two logbooks "Linux" and "PC":
[global]
Logbook tabs = 1
Tab cellpadding = 2
SMTP host = mailsend.your.domaine
[Linux]
Theme = default
Comment = General linux tips and tricks
Data dir = /usr/local/elog/linux
Attributes = Author, Type, Category, Subject
Options Type = Routine, Software Installation, Problem Fixed, Configuration, Other
Options Category = General, Hardware, Software, Network, Account, Other
Options Author = Stefan, Linus, unknown
Required Attributes = Author
[PC]
Comment = Database PC installations
Data dir = /usr/local/elog/pc
Attributes = Location, OS, Owner
Options Location = Building1, Building2
Options OS = Linux, Windows ME, Windows 2000
Required Attributes = Location, Owner
Email All = name@address, othername@otheraddress
Mail Subject = Location
Global options
Following options are possible in the [global]
section:
Language = <name>
The language setting determines the language of the elogd output. Not affected by this
setting are the configuration file options (they are always in English) and the
attribute names as well as the optional Menu commands. They have to be
translated manually in the configuration file.
If a language name is given (currently only "german" and "french" are supported by now),
the system searches for a translation file eloglang.<name> which contains
string translations from English into that language. If new languages are added by
someone, please send it back to the author so it can be included in future
distributions.
The online help for elogd is contained in the file eloghelp_xx.html where
xx are the first two letters of the language (like "en", "ge" and "fr"). For
new languages, a new file of that type has to be created as well.
Tab cellpadding
Specifies the empty space between the name in the logbook tab and its frame in pixel.
Logbook Tabs = 0/1
This flag controls the display of "tabs" on top of the logbook page with which
one can quickly switch between logbooks.
Main Tab = <string>
If this option is present, an additional first tab is displayed which takes you back
to the main logbook selection page. The string
is used for the
contents of the tab.
Welcome Title
This optional HTML code gets displayed in the title of the logbook selection
page. It can contain images via <img src="welcome.gif">
.
These images must be present in the same directory as the elodg.cfg file.
Following line is an example Welcome Title:
Welcome title = <img src="welcome.jpg"><p><font size=5 color=white>Welcome to our Elog</font>
This displays an image and a text below.
Page title = <string>
The string specified here is used for the title of the logbook selection page. It is also
used by most browsers for bookmark names.
Selection page = <file>
When this option is present, a user defined file is displayed instead of the logbook
selection page. This file has to be present in the same directory as the elogd.cfg
file. It can be completely customized in order to conatin logos etc. As a template,
the standard selection page produced by elogd can be used.
SMTP host
This defines the SMTP host needed to send automatic email notifications. The host
name you can get from your email program or your local system administrator.
Individual logbook options
For each logbook, there is a section with the logbook name in square brackets, so that each
logbook can have different options. If an option is not present in a logbook section, then the
system tries to locate that option in the [global]
section. Thus if the
following options are placed in the [global]
section, they are defaults for
all logbooks. If they are present in the [global]
and in the logbook
section, the logbook option is used.
Following options are available:
General options
Data dir
Each logbook has a separate directory where the logbook entries are stored, which
is controlled by the this statement. Note that the directories must exist and must
be writable by the elogd program.
Number Attachments
The number of attachments which can be submitted in one entry. May be zero if no
attachments are needed. Maximum is defined by MAX_ATTACHMENTS in elogd.c
(10 by default).
Comment
The comment is displayed on the logbook selection list. The selection list is
displayed if more than one logbook is defined on a host and no logbook is
explicitly specified in the URL.
Theme
A theme determines which layout and colors are used for a logbook, similar to
skins in other programs. The theme option points to a subdirectory
under the directory of the configuration file, which contains all files for
that theme. The format of these files is described under the Themes
section.
Date format = <string>
This option determines how the date of a logbook entry is displayed. The format
of the string is the same as the C function
strftime, so a string of %A, %B %d, %Y yields in a display of
Thursday, November 15, 2001 for example.
Welcome Page = <file>
By default, the last entry of a logbook is displayed when the logbook is selected.
This can be overridden with this option, which causes a HTML file to be shown
instead of the last message. This file can contain further links for new logbook
messages of for logbook queries. Here is a simple example of such a file:
<h1>Welcome to the test logbook</h1>
<ul>
<li><a href="?cmd=new">Enter</a> a new message
<li><a href="?cmd=find">Search</a> the logbook
</ul>
The file has to be present in the same direcotry as the elogd.cfg file.
Submit Page = <file>
This optional page can be displayed when a new message was submitted in a logbook.
Here is an example:
<h1>You successfully submitted a message</h1>
<a href="linux">Back</a> to the logbook<p>
<a href="linux?cmd=new">Enter</a> another message
The reference "linux" in this case corresponds to the logbook name.
The file has to be present in the same direcotry as the elogd.cfg file.
Message comment
This optional comment is displayed on top of the text entry field when submitting
a new message. It can contain a sentence like "Please enter your message here:".
Menu commands = <list>
This option specifies the menu commands displayed on top of the logbook page. For
certain installations, it can be useful to disable some commands. Following
commands are possible:
- New - Enter new logbook entry
- Edit - Edit current logbook entry
- Delete - Delete current logbook entry
- Reply - Submit a reply to current entry
- Find - Search entries in logbooks
- Last day - Display entries from last day
- Last 10 - Display last 10 entries
- Move to - Move entry to other logbook
- Copy to - Copy entry to other logbook
- Config - Edit elogd.cfg
- Change password - Change password for current user (if "Password file is given")
- Logout - Logout current user (if "Password file" is given)
- Help - General help
If this option is not present, following default is used:
Menu commands = New, Edit, Delete, Reply, Find, Last day, Last 10, Config, Help
Find Menu commands = <list>
This option specifies the menu commands displayed on top of the listing page
resulting from a "find" command. Although all commands from a above are possible,
only the commands New, Find, Back, Last, Last day, Last 10, config, Change
password, Logout
and Help
make sense. There is one
special command in addition to the above commands: The command Last x
gets expanded to "Last 2 days", "Last 4 days" or "Last 20 entries", "Last 40
entries" and so on, similar to the standard behaviour without the "Find Menu
commands" option.
Bottom text = <file>
If this option is present, the HTML contents of file
is displayed at
the bottom of an Elog page instead of the little Elog home page link. It can contain for
example a link back to the main logbook selection page like:
<center><a href="/">Main page</a></center>
Or it can contain other useful links. The file has to be present in the same directory
as the elogd.cfg file.
Help URL
This URL is used for the Help button. By default, the file eloghelp.html is
returned with the contents of the help page. One can either edit this file directly to
add site-specific help for all logbooks. Alternatively, one can use the Help URL
option to specify different help pages for different logbooks.
It can point to a site-specific help page via
http://...
or to a local file like
file://c:/tmp/config.html
. Alternatively, a HTML file can be
directly specified, which must be present in the same directory as the elogd.cfg file.
Attributes
Attributes = <list>
Define a number of attributes for the logbook. A maximum of 20 attributes can be
defined. Typical values are "Author", "Subject" or "Type".
Options <attribute> = <list>
Usually, an text field is used for an attribute, where the user can fill in
text of up to 100 characters. If instead a drop-down box with preset items is
better for a given attribute, these items can be defined with this statement.
Up to 100 items can be defined, separated by commas.
MOptions <attribute> = <list>
This list allows for "Multiple Options", meaning that an attribute can have
several values simultaneously. When entering an entry with MOptions, each value
from the list is represented by a checkbox. Unlike with nowmal options, multiple
checkboxes can be ckecked for an entry. The attribue value then becomes
<value1> | <value2> | ...
In the "find" page only one of these values can be specified, which is then
treated as a substring in the search filter.
Options <attribute> = boolean
If an attribute is marked "boolean" this way, a checkbox is displayed for
this attribute.
Preset <attribute> = <string>
This option uses a preset string for an attribute. The string can contain
subsitutions like the ones described under the "Subst <attribute>"
command. One possible application is to use the login name for the author
field like:
Preset Author = $long_name
If the attribute should be locked at the Web submission, use the
"Locked Attributes = ..." option. If a preset value is given for an
attribute which has an options list, the preset value is selected in the drop
down box by default.
Preset text = <string> or <file>
This preset value is used for the main body text. It can be a string or a file,
which has to be present in the same directory as the elogd.cfg file.
Locked Attributes = <list>
The attributes specified here cannot be modified when a new entry is submitted.
This makes only sense for preset attributes.
Required Attributes = <list>
The attributes specified here are required when a new entry is submitted. The
attribute names are marked with * on the entry form.
Page title = <string>
The string specified here is used for the title of the web page. It is also
used by most browsers for bookmark names. The string can contain substitutions
as described unter the "Subst <attribute>" option.
Display search = <list>
The display of attributes in a search result table can be restricted only to
certain attributes listed here. This can be helpful is many attributes are defined
in a logbook, which usually makes the table too big to fit in the browser.
Subst <attribute> = <string>
When submitting logbook entries, attribute values can be substituted by some
text. This text can contain arbitrary fixed text and following values:
- $<attribute>: The entered value of the attribute itself
- $host: The host name where elogd is running
- $remote_host: The host name of the host from with the entry was submitted
- $short_name: The login name (if password file is present)
- $long_name: The full name (if password file is present)
- $logbook: The name of the current logbook
- $date: The current date, formatted via "Date format"
Following example use this feature to add the remote host name to the author:
Subst Author = $author from $remote_host
Remove on reply = <list>
This option clears one or more (separated by commata) attribute values from an logbook
entry when one enters a reply to that entry. This can make sense for example for
the author, since the author of a reply can be different from the original author.
Reading and writing into logbooks can be constraind using two different access methods,
either with global passwords for read, write and admin (config, delete), or with user-
level passwords. For these two schemes to work properly, cookies have to be turned
on in your browser. Please consult your browser documentation about how to do that.
Read password
Write password
Admin password
Write password expiration = <hours>
Admin password expiration = <hours>
The optional password statements contain passwords for reading and writing to the
logbook, to delete entries in the lobgook and to configure a logbook via the config
menu. The passwords are stored in an encoded form. To change them, one can use elogd
directly with the -r
, -w
and -a
flags. To set the write password of logbook "linux" to "test", on would
enter:
The read password is queried by the browser with a pop-up window and usually stays
active for the entire browser session. The write and admin passwords are stored in
cookies on the browser side and have an expiration time of 24h. After that time, the
passwords have to be re-submitted. This time can be changed with the statement
Write Password Expriation = x
or Admin Password Expriation
= x
, where x is the expiration time in hours. It should be noted
that on some systems the daylight saving time is calculated incorrectly, which can
cause time offsets of one hour between a server PC and a client PC. In this case one
hour has to be added to the expiration time. If the expiration is set to "0", the
passwords are kept for the current browser session only. When the browser is restarted,
the password has to be re-entered.
Password file = <file>
Login expiration = <hours>
An alternative to the read/write/admin passwords is the user level access with a
password file. This file contains user names and passwords in following format:
<login name1>:<password1>:<full name1>
<login name2>:<password2>:<full name2>
<login name3>:<password3>:<full name3>
...
The passwords are encoded. To create or change them, one can use the "Change
Password" menu point. To creat a new user, one has to edit the password file
manually and use an empty password (like "<login name>::<full name>"),
which can then be changed via the "Change password" menu point.
The presence of a password file requires all users to "log in" using their name and
password. An additional advantage of this method is that the user name can be used as
an attribute value for creating logbook entries. To do so, following line can be
added to the configuration file in order to use the username for the author
attribute:
Options author = $long_name from $remote_host
Since the author name cannot be changed then during logbook entry, this ensures that
the original user name is contained in the entry. For a full listing of substitutions,
see the "Subst " option.
The user name and password are stores as cookies on the user side. They expire after 24
hours by default, which can be changed with the Login expriation
options. If the expiration is set to "0", the passwords are kept for the current browser
session only. When the browser is restarted, the password has to be re- entered.
Allow <command> = <user list>
Commands can be restricted to certain login names (separated by commata). For
each command from the list defined with the "Menu commands" option, a list of
user names can be specified, which are allowed to execute this command. If the
allow option is not present, all users may execute that command by default.
Hosts allow = <list>
Hosts deny = <list>
These two settings can be used to restrict the access to the logbook to certain
computers. It is similar to the UNIX hosts.allow and hosts.deny files.
The list can consist of individual host names or IP numbers, subnet masks like
123.213.
(note the trailing '.') or .mit.edu
,
or the word All
. Following rules are applied:
- Access will be granted when a host matches a pattern in "hosts allow".
- Otherwise, access will be denied when a host matches a pattern in "hosts deny".
- Otherwise, access will be granted.
These rules are applied before any password is checked. In case of problems,
one can start elogd with the "-v" flag, in which case the rule checking is printed
on the screen.
EMail notification
Flags
Show text = 0/1
This flag controls if logbook entries contain a body text. If an installation
only requires attributes, this flag can be set to 0. Default is
1.
Show attachments = 0/1
This flag controls the display of attachments such as images on normal
logbook pages. For logbooks with large images, this flag can be turned off,
so that attachments are only displayed when they are clicked on. Default
is 1.
Summary on default = 0/1
If this flag is 1, the buttons "Last day" and "Last 10"
produce summary listings instead displaying full messages. In the "Find"
page, the "Summary only" check box is checked by default.
Summary lines = x
This specifies the number of text lines displayed in a summary page. Zero displays
no text at all. The default is 3.
Reverse sort = 0/1
If this flag is 1, the result of the "last day" and "last 10" queries
is sorted in reverse order (newest entry down to oldest). Default is
0.
Enable browsing = 0/1
If this flag is 1, browsing (hitting the next/previous button) is enabled.
For some rare occations it might be necessary to disable browsing. Default is
1.
Filtered browsing = 0/1
If this flag is 1, browsing (hitting the next/previous button) can be
filtered by individual attributes. If the checkbox next to an attribute is checked,
only messages with the same attribute value are displayed. Default is 1.
HTML default = 0/1/2
This specifies the default state of the "Submit as HTML text" button on the
new message entry from. For installations where entries are nomally submitted
as HTML, the default can be set to 1. If this value is set to 2
, the check box is not displayed at all, so that only text submissions
are possible. The default is 0.
Suppress default = 0/1/2
This specifies the default state of the "Suppress Email notification" button on the
new message entry from. For installations where normally a Email notification is
not necessary, the default can be set to 1. Only if an urgent message is
entered, the users can then uncheck the suppress box. If this value is set to 2
, the suppress box is not displayed at all, so that an email notification is
always produced. The default is 0.
Resubmit default = 0/1/2
This specifies the default state of the "Resubmit as new entry" button on the
edit message entry from. If this button is checked, the current message is removed
from its current position in the database and submitted as a new message. This
can for example be useful for applications where one wants to see which records
have been updated recently. If this value is set to 2, the resubmit box
is not displayed at all. The default is 0.
Display Email recipients = 0/1
If this flag is 1, the email recipients are displayed when a logbook
entry is entered which produces an email notification. Setting this flag to 0
can suppress this display, in case one does not want that users to see that
email is actually sent and to whom. The default is 1.
Email message body = 0/1
If this flag is 1, the email notification send by elog contains the
full message body in addition to the attributes. The default is 0.
Back to main = 0/1
If this flag is 1, the "Back" button takes you back to the logbook
selection page instead to the last entry of the current logbook.
The default is 0.
Themes
Themes are layout and color schemes which determine the look and feel of a logbook.
Each theme resides in a separate subdirectory and is specified with the
theme = <dir>
option in the configuration file. The directory
contains the file theme.cfg
and a couple of images, which are used
for the title banner and the browse buttons. A default theme is contained in the
distribution. If new themes are developed by users, they can send them back to the author,
so they can be included in future releases.
Most of the options in the theme.cfg
are self-explanatory, the colors
are coded as #RRGGBB, where RR is a 8-bit hexadecimal value for the red part, GG for the
green and BB for the blue part, repectively. Since theme configuration files are re-read
at each access, the elogd daemon does not have to be restarted after a change in the
theme configuration file.
Following two images display the same logbook page using different themes:
Wishlist
Here are items requested by users. I will work down the list when I have time. If you find
a feature you find useful on the list, there is a good chance that you get it in a
future release. You can vote for a feature by sending me an email.
Feature | Votes |
Get message from standard input in elog submission program | 1 |
Users can only edit their own entries | 1 |
Make user file editable through web interface | 1 |
Implement groups of users | 1 |
Add email address field to user file, so that user name can be
specified for "Email <attribute> <value> =" option
which gets automatically substituted by email address | 1 |
Change internal database format from offset oriented to
index oriented (lots of work, need also conversion program) | 2 |
Implement new listing mode in between "summary only" and "full listing"
where a few text lines are displayed below the attribute fields | 1 |
Back to Elog home page
Stefan Ritt, May 23rd, 2001