2004-02-09 05:11:05 +00:00
|
|
|
<?php
|
|
|
|
|
2004-11-15 14:46:15 +00:00
|
|
|
// MORE WORK IS NEEDED ON THIS IMPORTANT FILE. THE DEPRECATED <FOO/> ELEMENTS SHOULD BE CHANGED TO <FOO> 1 </FOO>.
|
|
|
|
// MANY OF THE TAGS BELOW ARE NOT EXPLAINED IN THE DOCUMENTATION, AND THE LIST HERE IS PROBABLY NOT COMPLETE.
|
|
|
|
|
2004-02-09 05:11:05 +00:00
|
|
|
require_once("docutil.php");
|
|
|
|
|
2004-11-15 14:46:15 +00:00
|
|
|
|
2004-02-09 05:11:05 +00:00
|
|
|
page_head("The project configuration file");
|
2004-11-15 15:50:47 +00:00
|
|
|
echo "<!-- \$Id$ -->\n";
|
2004-02-09 05:11:05 +00:00
|
|
|
|
|
|
|
echo"
|
|
|
|
A project is described by a configuration file
|
|
|
|
named <b>config.xml</b> in the project's directory.
|
|
|
|
A config.xml file looks like this:
|
|
|
|
<pre>",
|
|
|
|
htmlspecialchars("
|
|
|
|
<boinc>
|
|
|
|
<config>
|
2004-11-15 14:46:15 +00:00
|
|
|
<host> project.hostname.ip </host>
|
|
|
|
<db_name> databasename </db_name>
|
|
|
|
<db_host> database.host.ip </db_host>
|
|
|
|
<db_user> database_user_name </db_user>
|
|
|
|
<db_passwd> database_password </db_passwd>
|
|
|
|
<shmem_key> shared_memory_key </shmem_key>
|
|
|
|
<download_url> http://A/URL </download_url>
|
|
|
|
<download_dir> /path/to/directory </download_dir>
|
2004-12-02 22:56:49 +00:00
|
|
|
<download_dir_alt> /path/to/directory </download_dir_alt>
|
|
|
|
<uldl_dir_fanout> N </uldl_dir_fanout>
|
2004-11-15 14:46:15 +00:00
|
|
|
<upload_url> http://A/URL </upload_url>
|
|
|
|
<upload_dir> /path/to/directory </upload_dir>
|
|
|
|
<cgi_url> http://A/URL </cgi_url>
|
|
|
|
<stripchart_cgi_url> http://A/URL </stripchart_cgi_url>
|
|
|
|
<log_dir> /path/to/directory </log_dir>
|
|
|
|
|
2005-10-07 19:19:07 +00:00
|
|
|
[ <disable_account_creation/> ]
|
|
|
|
[ <profile_screening/> ]
|
|
|
|
[ <show_results/> ]
|
|
|
|
[ <one_result_per_user_per_wu/> ]
|
|
|
|
[ <max_wus_to_send> N </max_wus_to_send> ]
|
|
|
|
[ <min_sendwork_interval> N </min_sendwork_interval> ]
|
|
|
|
[ <daily_result_quota> N </daily_result_quota> ]
|
|
|
|
[ <ignore_delay_bound/> ]
|
|
|
|
[ <dont_generate_upload_certificates/> ]
|
|
|
|
[ <locality_scheduling/> ]
|
|
|
|
[ <locality_scheduling_wait_period> N </locality_scheduling_wait_period> ]
|
|
|
|
[ <min_core_client_version> N </min_core_client_version ]
|
|
|
|
[ <choose_download_url_by_timezone/> ]
|
|
|
|
[ <cache_md5_info/> ]
|
2005-02-09 04:38:19 +00:00
|
|
|
[ <min_core_client_version_announced> N </min_core_client_version_announced> ]
|
2005-10-07 19:19:07 +00:00
|
|
|
[ <min_core_client_upgrade_deadline> N </min_core_client_upgrade_deadline> ]
|
|
|
|
[ <choose_download_url_by_timezone> N </choose_download_url_by_timezone> ]
|
|
|
|
[ <cache_md5_info> N </cache_md5_info> ]
|
|
|
|
[ <nowork_skip> N </nowork_skip> ]
|
|
|
|
[ <sched_lockfile_dir> path </sched_lockfile_dir> ]
|
|
|
|
[ <min_passwd_length> N </min_passwd_length> ]
|
|
|
|
[ <client_account_creation_disabled/> ]
|
2005-12-17 04:53:48 +00:00
|
|
|
[ <fp_benchmark_weight> X </fp_benchmark_weight> ]
|
|
|
|
[ <default_disk_max_used_gb> X </default_disk_max_used_gb> ]
|
|
|
|
[ <default_disk_max_used_pct> X </default_disk_max_used_pct> ]
|
|
|
|
[ <default_disk_min_free_gb> X </default_disk_min_used_pct> ]
|
|
|
|
[ <sched_disk_space_check_hardcoded/> ]
|
2006-02-25 07:09:50 +00:00
|
|
|
[ <max_claimed_credit>X</max_claimed_credit ]
|
|
|
|
[ <grant_claimed_credit/> ]
|
2005-02-09 04:38:19 +00:00
|
|
|
|
2004-11-15 14:46:15 +00:00
|
|
|
|
2004-02-09 05:11:05 +00:00
|
|
|
<!-- optional; defaults as indicated: -->
|
2004-11-15 14:46:15 +00:00
|
|
|
<project_dir> ../ </project_dir> <!-- relative to location of 'start' -->
|
|
|
|
<bin_dir> bin </bin_dir> <!-- relative to project_dir -->
|
|
|
|
<cgi_bin_dir> cgi-bin </cgi_dir> <!-- relative to project_dir -->
|
2004-02-09 05:11:05 +00:00
|
|
|
</config>
|
2004-11-15 14:46:15 +00:00
|
|
|
|
2004-02-09 05:11:05 +00:00
|
|
|
<daemons>
|
|
|
|
<daemon>
|
2004-11-15 14:46:15 +00:00
|
|
|
<cmd> feeder -d 3 </cmd>
|
|
|
|
[ <host> hostname.ip </host> ]
|
|
|
|
[ <disabled> 1 </disabled> ]
|
|
|
|
</daemon>
|
|
|
|
<daemon>
|
|
|
|
...
|
2004-02-09 05:11:05 +00:00
|
|
|
</daemon>
|
|
|
|
</daemons>
|
2004-11-15 14:46:15 +00:00
|
|
|
|
2004-02-09 05:11:05 +00:00
|
|
|
<tasks>
|
|
|
|
<task>
|
2004-11-15 14:46:15 +00:00
|
|
|
<cmd> get_load </cmd>
|
|
|
|
<output> get_load.out </output>
|
|
|
|
<period> 5 min </period>
|
|
|
|
[ <host> host.ip </host> ]
|
|
|
|
[ <disabled> 1 </disabled> ]
|
|
|
|
[ <always_run> 1 </always_run> ]
|
2004-02-09 05:11:05 +00:00
|
|
|
</task>
|
|
|
|
<task>
|
2004-11-15 14:46:15 +00:00
|
|
|
<cmd> echo \"HI\" | mail root@example.com </cmd>
|
|
|
|
<output> /dev/null </output>
|
|
|
|
<period> 1 day </period>
|
2004-02-09 05:11:05 +00:00
|
|
|
</task>
|
2004-11-15 14:48:21 +00:00
|
|
|
<task>
|
2004-11-15 14:46:15 +00:00
|
|
|
...
|
2004-11-15 14:48:21 +00:00
|
|
|
</task>
|
2004-02-09 05:11:05 +00:00
|
|
|
</tasks>
|
2004-11-15 14:46:15 +00:00
|
|
|
|
2004-02-09 05:11:05 +00:00
|
|
|
</boinc>
|
|
|
|
"),
|
|
|
|
"</pre>
|
2004-05-31 18:13:01 +00:00
|
|
|
";
|
2004-11-15 14:46:15 +00:00
|
|
|
|
|
|
|
echo "<b>The general project configuration elements are:</b>";
|
2004-05-31 18:13:01 +00:00
|
|
|
list_start();
|
2005-10-07 19:19:07 +00:00
|
|
|
list_item("host",
|
|
|
|
"name of project's main host, as given by Python's socket.hostname().
|
|
|
|
Daemons and tasks run on this host by default."
|
|
|
|
);
|
2004-11-15 14:46:15 +00:00
|
|
|
list_item("db_name", "Database name");
|
|
|
|
list_item("db_host", "Database host machine");
|
|
|
|
list_item("db_user", "Database user name");
|
|
|
|
list_item("db_passwd", "Database password");
|
2004-05-31 18:13:01 +00:00
|
|
|
list_item("shmem_key", "ID of scheduler shared memory. Must be unique on host.");
|
|
|
|
list_item("download_url", "URL of data server for download");
|
|
|
|
list_item("download_dir", "absolute path of download directory");
|
2004-12-02 22:56:49 +00:00
|
|
|
list_item("download_dir_alt",
|
|
|
|
"absolute path of old download directory
|
|
|
|
(see <a href=hier_dir.php>Hierarchical upload/download directories</a>)"
|
|
|
|
);
|
2004-05-31 18:13:01 +00:00
|
|
|
list_item("upload_url", "URL of file upload handler");
|
2004-12-02 22:56:49 +00:00
|
|
|
list_item("uldl_dir_fanout", "fan-out factor of upload and download directories
|
|
|
|
(see <a href=hier_dir.php>Hierarchical upload/download directories</a>)"
|
|
|
|
);
|
2004-05-31 18:13:01 +00:00
|
|
|
list_item("upload_dir", "absolute path of upload directory");
|
|
|
|
list_item("cgi_url", "URL of scheduling server");
|
2004-11-15 14:46:15 +00:00
|
|
|
list_item("stripchart_cgi_url", "URL of stripchart server");
|
|
|
|
list_item("log_dir", "Path to the directory where the assimilator, feeder, transitioner and
|
|
|
|
cgi output logs are stored. This allows you to change the default log
|
|
|
|
directory path. If set explicitly, you can also use the 'grep logs'
|
|
|
|
features on the administrative pages. Note: enabling 'grep logs' with
|
|
|
|
very long log files can hang your server, since grepping GB files can
|
|
|
|
take a long time. If you enable this feature, be sure to rotate the
|
|
|
|
logs so that they are not too big.");
|
2005-06-06 19:18:01 +00:00
|
|
|
list_item("sched_lockfile_dir",
|
|
|
|
"Enables scheduler locking (recommended) and specifies
|
|
|
|
directory where scheduler lockfiles are stored.
|
2006-03-21 06:52:30 +00:00
|
|
|
Must be writable to the Apache user.
|
2005-06-06 19:18:01 +00:00
|
|
|
");
|
2005-09-26 20:01:01 +00:00
|
|
|
list_item("profile_screening",
|
|
|
|
"If present, don't show profile pictures until they've been
|
|
|
|
screened and approved by project admins."
|
|
|
|
);
|
2004-11-15 14:46:15 +00:00
|
|
|
list_end();
|
|
|
|
|
2004-12-02 22:56:49 +00:00
|
|
|
echo "
|
|
|
|
<b>The following control features that you may or may not want
|
|
|
|
available to users.</b>
|
|
|
|
";
|
2004-11-15 14:46:15 +00:00
|
|
|
list_start();
|
2004-12-02 22:56:49 +00:00
|
|
|
list_item("disable_account_creation",
|
|
|
|
"If present, disallow account creation"
|
|
|
|
);
|
|
|
|
list_item("show_results",
|
|
|
|
"Enable web site features that show results (per user, host, etc.)"
|
|
|
|
);
|
2004-05-31 18:13:01 +00:00
|
|
|
list_end();
|
2004-11-15 14:46:15 +00:00
|
|
|
|
2004-12-02 22:56:49 +00:00
|
|
|
echo "
|
|
|
|
<b>The following control the way in which results are scheduled, sent,
|
|
|
|
and assigned to users and hosts.</b>
|
|
|
|
";
|
2004-11-15 14:46:15 +00:00
|
|
|
list_start();
|
2004-12-02 22:56:49 +00:00
|
|
|
list_item("one_result_per_user_per_wu",
|
|
|
|
"If present, send at most one result of a given workunit to a given user.
|
|
|
|
This is useful for checking accuracy/validity of results.
|
|
|
|
It ensures that the results for a given workunit are generated by
|
|
|
|
<b>different</b> users.
|
|
|
|
If you have a validator that compares different results
|
|
|
|
for a given workunits to ensure that they are equivalent,
|
|
|
|
you should probably enable this.
|
|
|
|
Otherwise you may end up validating results from a given user
|
|
|
|
with results from the <b>same</b> user."
|
|
|
|
);
|
|
|
|
list_item("max_wus_to_send",
|
|
|
|
"Maximum results sent per scheduler RPC. Helps prevent hosts with
|
|
|
|
trouble from getting too many results and trashing them. But you
|
|
|
|
should set this large enough so that a host which is only connected to
|
|
|
|
the net at intervals has enough work to keep it occupied in between
|
|
|
|
connections."
|
|
|
|
);
|
|
|
|
list_item("min_sendwork_interval",
|
|
|
|
"Minimum number of seconds to wait after sending results to a given
|
|
|
|
host, before new results are sent to the same host. Helps prevent
|
|
|
|
hosts with download or application problems from trashing lots of
|
|
|
|
results by returning lots of error results. But don't set it to be so
|
|
|
|
long that a host goes idle after completing its work, before getting
|
|
|
|
new work."
|
|
|
|
);
|
|
|
|
list_item("daily_result_quota",
|
2005-02-17 22:01:28 +00:00
|
|
|
"Maximum number of results (per CPU) sent to a given host in a 24-hour
|
2004-12-02 22:56:49 +00:00
|
|
|
period. Helps prevent hosts with download or application problems from
|
|
|
|
returning lots of error results. Be sure to set it large enough that
|
|
|
|
a host does not go idle in a 24-hour period, and can download enough
|
2005-02-17 22:01:28 +00:00
|
|
|
work to keep it busy if disconnected from the net for a few days. The
|
|
|
|
maximum number of CPUS is bounded at four."
|
2004-12-02 22:56:49 +00:00
|
|
|
);
|
2005-02-16 01:21:41 +00:00
|
|
|
list_item("ignore_delay_bound",
|
|
|
|
"By default, results are not sent to hosts too slow to complete them within delay bound.
|
|
|
|
If this flag is set, this rule is not enforced."
|
2004-12-02 22:56:49 +00:00
|
|
|
);
|
2005-07-17 19:52:44 +00:00
|
|
|
list_item("dont_generate_upload_certificates",
|
|
|
|
"Don't put upload certificates in results.
|
|
|
|
This makes result generation a lot faster,
|
|
|
|
since no encryption is done,
|
|
|
|
but you lose protection against DoS attacks
|
|
|
|
on your upload servers."
|
|
|
|
);
|
2005-01-09 08:50:08 +00:00
|
|
|
list_item("locality_scheduling",
|
|
|
|
"When possible, send work that uses the same files that the host
|
|
|
|
already has. This is intended for projects which have large data
|
|
|
|
files, where many different workunits use the same data file. In
|
|
|
|
this case, to reduce download demands on the server, it may be
|
|
|
|
advantageous to retain the data files on the hosts, and send
|
|
|
|
them work for the files that they already have.
|
2005-03-23 06:26:19 +00:00
|
|
|
See <a href=sched_locality.php>Locality Scheduling</a>."
|
2005-01-09 08:50:08 +00:00
|
|
|
);
|
|
|
|
list_item("locality_scheduling_wait_period",
|
|
|
|
"This element only has an effect when used in conjunction with the
|
|
|
|
previous locality scheduling element. It tells the scheduler to
|
|
|
|
use 'trigger files' to inform the project that more work is
|
|
|
|
needed for specific files. The period is the number of seconds
|
|
|
|
which the scheduler will wait to see if the project can create
|
|
|
|
additional work. Together with project-specific daemons or
|
|
|
|
scripts this can be used for 'just-in-time' workunit
|
2005-03-23 06:26:19 +00:00
|
|
|
creation. See <a href=sched_locality.php>Locality Scheduling</a>."
|
2005-01-09 08:50:08 +00:00
|
|
|
);
|
2005-01-19 21:53:46 +00:00
|
|
|
list_item("min_core_client_version",
|
|
|
|
"If the scheduler gets a request from a client with
|
|
|
|
a version number less than this,
|
|
|
|
it returns an error message and doesn't do any other processing."
|
|
|
|
);
|
2005-02-02 18:13:00 +00:00
|
|
|
list_item("choose_download_url_by_timezone",
|
|
|
|
"When the scheduler sends work to hosts, it replaces the download
|
|
|
|
URL appearing in the data and executable file descriptions with
|
|
|
|
the download URL closest to the host's timezone. The project
|
|
|
|
must provide a two-column file called 'download_servers' in the
|
|
|
|
project root directory. This is a list of all download servers
|
|
|
|
that will be inserted when work is sent to hosts. The first column
|
|
|
|
is an integer listing the server's offset in seconds from UTC.
|
|
|
|
The second column is the server URL in the format such as
|
|
|
|
http://einstein.phys.uwm.edu. The download servers must
|
|
|
|
have identical file hierarchies and contents, and the path to
|
|
|
|
file and executables must start with '/download/...' as in
|
|
|
|
'http://einstein.phys.uwm.edu/download/123/some_file_name'."
|
|
|
|
);
|
2005-02-02 21:57:11 +00:00
|
|
|
list_item("cache_md5_info",
|
|
|
|
"When creating work, keep a record (in files called foo.md5) of the
|
|
|
|
file length and md5 sum of data files and executables. This can
|
|
|
|
greatly reduce the time needed to create work, if (1) these files
|
|
|
|
are re-used, and (2) there are many of these files, and (3) reading
|
|
|
|
the files from disk is time-consuming."
|
|
|
|
);
|
2005-02-09 04:38:19 +00:00
|
|
|
list_item("min_core_client_version_announced",
|
|
|
|
"Announce a new version of the BOINC core client, which in the future
|
|
|
|
will be the minimum required version. In conjunction with the next
|
|
|
|
tag, you can warn users with version below this to upgrade by a
|
|
|
|
specified deadline. Example value: 419."
|
|
|
|
);
|
|
|
|
list_item("min_core_client_upgrade_deadline",
|
|
|
|
"Use in conjunction with the previous tag. The value given here is the
|
|
|
|
Unix epoch returned by time(2) until which hosts can update their
|
|
|
|
core client. After this time, they may be shut out of the project.
|
|
|
|
Before this time, they will receive messages warning them to upgrade."
|
|
|
|
);
|
2005-03-13 20:10:03 +00:00
|
|
|
list_item("nowork_skip",
|
|
|
|
"If the scheduling server has no work,
|
|
|
|
it replies to RPCs without doing any database access
|
|
|
|
(e.g., without looking up the user or host record).
|
|
|
|
This reduces DB load, but it fails to update
|
|
|
|
preferences when users click on Update.
|
|
|
|
Use it if your server DB is overloaded."
|
|
|
|
);
|
2005-10-07 19:19:07 +00:00
|
|
|
list_item("min_passwd_length",
|
|
|
|
"Minimum length of user passwords. Default is 6."
|
|
|
|
);
|
|
|
|
list_item("client_account_creation_disabled",
|
|
|
|
"If set, this project doesn't support the web RPCs for
|
|
|
|
looking up and creating accounts.
|
|
|
|
This is a temporary kludge as we transition from
|
|
|
|
version 4 to version 5 software.
|
|
|
|
It should be removed by 12/2005 or so."
|
|
|
|
);
|
2005-11-02 23:47:25 +00:00
|
|
|
list_item("fp_benchmark_weight",
|
|
|
|
"The weighting given to the Whetstone benchmark
|
|
|
|
in the calculation of claimed credit.
|
|
|
|
Must be in [0 .. 1].
|
|
|
|
Projects whose applications are floating-point intensive should use 1;
|
|
|
|
pure integer applications, 0.
|
|
|
|
Choosing an appropriate value will reduce the disparity
|
|
|
|
in claimed credit between hosts.
|
|
|
|
The script html/ops/credit_study.php,
|
|
|
|
run against the database of a running project,
|
|
|
|
will suggest what value to use."
|
|
|
|
);
|
2005-10-07 19:19:07 +00:00
|
|
|
|
2005-12-17 04:53:48 +00:00
|
|
|
list_item("default_disk_max_used_gb", "Sets the default value for
|
|
|
|
the disk_max_used_gb preference so its consistent between the
|
|
|
|
scheduler and web pages. The scheduler uses it when a request
|
|
|
|
for work doesn't include preferences, or the preference is set
|
|
|
|
to zero. The web page scripts use it to set the initial value
|
|
|
|
when displaying or editing preferences the first time, or when
|
|
|
|
the user never saved them. Default is 100.
|
|
|
|
");
|
|
|
|
|
|
|
|
list_item("default_disk_max_used_pct", "Sets the default value for
|
|
|
|
the disk_max_used_pct preference so its consistent between the
|
|
|
|
scheduler and web pages. The scheduler uses it when a request
|
|
|
|
for work doesn't include preferences, or the preference is set
|
|
|
|
to zero. The web page scripts use it to set the initial value
|
|
|
|
when displaying or editing preferences the first time, or when
|
|
|
|
the user never saved them. Default is 50.
|
|
|
|
");
|
|
|
|
|
|
|
|
list_item("default_disk_min_free_gb", "Sets the default value for
|
|
|
|
the disk_min_free_gb preference so its consistent between the
|
|
|
|
scheduler and web pages. The scheduler uses it when a request
|
|
|
|
for work doesn't include preferences. The web page scripts use
|
|
|
|
it to set the initial value when displaying or editing
|
|
|
|
preferences the first time, or when the user never saved them.
|
|
|
|
Also, the scheduler uses this setting to override any smaller
|
2006-03-21 06:52:30 +00:00
|
|
|
preference from the host, it enforces a 'minimum free disk space'
|
2005-12-17 04:53:48 +00:00
|
|
|
to keep from filling up the drive. Recommend setting this no
|
|
|
|
smaller than .001 (1MB or 1,000,000 bytes). Default is .001.
|
|
|
|
");
|
|
|
|
|
|
|
|
list_item("sched_disk_space_check_hardcoded", "Controls how the
|
|
|
|
above three settings are interpreted by the web page php scripts.
|
|
|
|
This setting is for projects that updated the php scripts to
|
|
|
|
get the default disk space usage settings from config.xml, but
|
|
|
|
haven't updated their scheduler to do the same.
|
|
|
|
");
|
|
|
|
|
2006-02-25 07:09:50 +00:00
|
|
|
list_item("max_claimed_credit",
|
|
|
|
"If a result claims more credit than this, mark it as invalid."
|
|
|
|
);
|
|
|
|
list_item("grant_claimed_credit",
|
|
|
|
"If set, grant the claimed credit,
|
|
|
|
regardless of what other results for this workunit claimed.
|
|
|
|
These is useful for projects where
|
|
|
|
different instances of the same job
|
|
|
|
can do much different amounts of work.
|
|
|
|
"
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
2004-11-15 14:46:15 +00:00
|
|
|
list_end();
|
|
|
|
|
|
|
|
// THE INFORMATION BELOW NEEDS TO BE ORGANIZED AND PUT INTO TABLES OR SOME OTHER LESS CRAMPED FORM
|
2004-05-31 18:13:01 +00:00
|
|
|
echo "
|
2004-02-09 05:11:05 +00:00
|
|
|
<b>Tasks</b> are periodic, short-running jobs.
|
2004-02-12 01:13:47 +00:00
|
|
|
<cmd> and <period> are required.
|
2004-02-09 05:11:05 +00:00
|
|
|
OUTPUT specifies the file to output and by default is COMMAND_BASE_NAME.out.
|
2004-02-12 01:13:47 +00:00
|
|
|
Commands are run in the <bin_dir> directory
|
|
|
|
which is a path relative to <project_dir> and output to <log_dir>.
|
2004-02-09 05:11:05 +00:00
|
|
|
|
|
|
|
<p>
|
|
|
|
<b>Daemons</b> are continuously-running programs.
|
2004-02-12 01:13:47 +00:00
|
|
|
The process ID is recorded in the <pid_dir> directory
|
2004-02-09 05:11:05 +00:00
|
|
|
and the process is sent a SIGHUP in a DISABLE operation.
|
|
|
|
<p>
|
|
|
|
Both tasks and daemons can run on a different host (specified by <host>).
|
|
|
|
The default is the project's main host, which is specified in config.host
|
2004-05-31 18:13:01 +00:00
|
|
|
A daemon or task can be turned off by adding the <disabled> element.
|
2004-10-27 21:10:28 +00:00
|
|
|
As well, there may be some tasks you wish to run via cron regardless of
|
|
|
|
whether or not the project is enabled (for example, a script that logs the
|
|
|
|
current CPU load of the host machine). You can do so by adding the
|
|
|
|
<always_run> element (<disabled> takes precedence over <always_run>).
|
2004-02-09 05:11:05 +00:00
|
|
|
";
|
|
|
|
page_tail();
|
|
|
|
?>
|