[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
3.1 General Configuration Questions | General questions about GNATS configuration | |
3.2 Gnatsd, the GNATS Daemon | Configuration of the GNATS daemon | |
3.3 E-Mail Issues | Problems with the e-mail interface | |
3.4 Miscellaneous Configuration Issues | Other configuration problems |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
3.1.1 How do I add a new database? | How to create a new database | |
3.1.2 How do I rename a category? | How to rename categories | |
3.1.3 How do I add, remove, or rename a PR field? | Add, remove, or rename a PR field |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A: (GNATS 3.1xx) (Please consider upgrading to GNATS 4.0 or greater.)
Note that there must be a category named pending
. It is
used when no category is given in a report, and when a report names an
invalid category.
Also note that each database needs its own mail address for submissions (see also step 8 below), and that you must enter it in the file ‘config’.
Run the program gen-index
to create the index file
(see (gnats)gen-index section ‘Regenerating the index’ in Keeping Track).
Find the greatest report number and put it (or any larger number) into ‘/usr/local/gnats/db2/gnats-adm/current’.
Caution: E-mail updates to the PRs you moved to the new database may still arrive at the old database. You may want to contact everybody who knows about these PRs, asking them to use the mail address of the new database when sending a follow-up.
/usr/local/gnats/db2:GreatNewDB
Gnatsd reads it on startup (and as it is started by inetd, this means it becomes effective with the next connection to gnatsd). Gnatsweb (see Gnatsweb) learns the database list from gnatsd, so it will offer you the new database "GreatNewDB" when it is invoked next time.
If you do not know where ‘gnats-db.conf’ lives, run:
‘strings /where/ever/gnatsd | grep gnats-db.conf’
‘/usr/local/lib/gnats/queue-pr -d /usr/local/gnats/db2 -r’
or, if you prefer the long options,
‘/usr/local/lib/gnats/queue-pr --directory=/usr/local/gnats/db2 --run’
GreatNewDB-bugs: "|/usr/local/lib/gnats/queue-pr -d /usr/local/gnats/db2 -q" GreatNewDB-query: "|/usr/local/lib/gnats/mail-query -d /usr/local/gnats/db2" |
If you do not want to allow querying the database by mail, omit the ‘GreatNewDB-query’ alias.
You usually need the cooperation of a system administrator for this step (if you are not a system administrator yourself, of course).
Make sure that ‘/usr/local/gnats/db2/gnats-adm/config’ gives the correct mail addresses for GNATS_ADDR (this must be different for each database) and for GNATS_ADMIN (this is probably the same for all databases).
GNATS_ADDR="GreatNewDB-bugs@bugs.example.com" GNATS_ADMIN="gnats-admin@bugs.example.com" |
If your GNATS sits behind a firewall and needs to exchange mails with the outside world, see also Outgoing mail bounces.
A: (GNATS 4.x) With version 4, this has become much easier (see (gnats)mkdb section ‘Adding another database’ in Keeping Track):
GreatNewDB:Our great tools:/usr/local/gnats/db2
Then, as the GNATS user, run ‘mkdb GreatNewDB’ to create the database. Make sure that the directory (in our example, ‘/usr/local/gnats/db2’) can be created by the GNATS user.
(Note that there must be a database named default
. It
is used as a fallback by some tools if no database is specified. You
need not use it actively, but you should have run ‘mkdb default’.)
Gnatsd reads the file ‘databases’ on startup (and as it is started by inetd, this means it becomes effective with the next connection to gnatsd). Gnatsweb (see Gnatsweb) learns the database list from gnatsd, so it will offer you the new database "GreatNewDB" when it is invoked next time.
If you do not know where ‘databases’ lives, run:
‘strings /where/ever/gnatsd | grep databases’
mkcat
anymore in order to
create new category directories in your database—GNATS 4
creates them automatically when they are missing. See (gnats)dbconfig file section ‘The dbconfig
file’ in Keeping Track, for details.
‘/usr/local/libexec/gnats/queue-pr -d GreatNewDB -r’
or, if you prefer the long options,
‘/usr/local/libexec/gnats/queue-pr --database=GreatNewDB --run’
GreatNewDB-bugs: "|/usr/local/libexec/gnats/queue-pr -d GreatNewDB -q" GreatNewDB-query: "|/usr/local/libexec/gnats/mail-query -d GreatNewDB" |
If you are updating from GNATS 3.1xx, note that the ‘-d’ option has changed its meaning: it does not give the directory of the database, but its name. (In case you prefer the long form of the option, it is now ‘--database’ instead of ‘--directory’.)
If your GNATS sits behind a firewall and needs to exchange mails with the outside world, see also Outgoing mail bounces.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Renaming a category requires to touch every PR in that category, because each report contains the name of its category.
To rename category A
to B
, proceed as follows:
B
.
A
, changing its category to
B
.
This can be done with any GNATS client; check the archives
of the HELP-GNATS mailing list for hints about automating
this step.
gen-index
(see (gnats)gen-index section ‘Regenerating the index’ in Keeping Track) to refresh the ‘index’ file.
A
. When a follow-up to an
existing PR arrives via e-mail, GNATS 4.x checks that both
the category and the PR number indicated in the mail exist (this
is a sanity check).
To reduce the risk of new reports being filed to category
A
, change its description in the ‘categories’ file to
something like ‘obsolete, use category B
instead’.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A: (GNATS 3.1xx) The fields and their names are fixed in GNATS 3.1xx, so this is not possible.
A: (GNATS 4.x) Edit the file ‘dbconfig’ to reflect your changes.
Note that the PR fields with the builtin-names severity
,
priority
and state
are required if you want automatic
reminders (notify-about-expired-prs = true
). In this case, the
file ‘submitters’ must also contain a response time.
The severity
field is checked for values critical
and
serious
, and priority
for value high
.
This is currently not configurable.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
3.2.1 Gnatsd Port Number | How to connect to gnatsd | |
3.2.2 How to Start Gnatsd | How to make gnatsd accept connections | |
3.2.3 Gnatsd Messages | Some error messages and what they mean |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
In 3.xxx versions, gnatsd uses port 1529 by default; as this port is officially assigned to another application (see the list of port numbers maintained by the Internet Assigned Numbers Authority) it will probably change in 4.x.
If you want/need to run gnatsd on another port, you can change the
default port at compile time (call configure --help
to learn
about compile time configuration options). Most clients also accept
an option or configuration variable to change the port. Don’t forget
to tell inetd (or xinetd, or whatever super-server you use) to start
gnatsd on the other port.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Gnatsd is intended to be started by some "super server", like
inetd
or xinetd
. ("Super servers" are sometimes also
called "super daemons".)
This is also described in the GNATS manual; see (gnats)Installing the daemon section ‘Installing the daemon’ in Keeping Track.
• inetd configuration | The traditional super server | |
• xinetd configuration | Another widespread super server |
If your gnatsd will be started by inetd (the "internet daemon"), add the following entry to your ‘/etc/inetd.conf’:
# port userid program support stream tcp nowait gnats /usr/local/libexec/gnats/gnatsd gnatsd |
and to ‘/etc/services’:
support 1529/tcp # GNATS |
(You may need to use tabulator characters to separate the fields of
‘/etc/services’.) Then send inetd a hangup signal
(kill -HUP pid-of-inetd
).
You may want to use another port instead of 1529 (see section Gnatsd Port Number).
If your gnatsd will be started by xinetd (the "extended internet daemon"), create a file ‘/etc/xinetd.d/support’ with the following lines (see (gnats)Installing the daemon section ‘Installing the daemon’ in Keeping Track):
|
or add theses lines to your ‘xinetd.conf’ file, whatever is appropriate. The equal signs seem to need spaces around them with some versions of xinetd.
You need to add
support 1529/tcp # GNATS |
to ‘/etc/services’ (it may be necessary to use tabulator
characters to separate the fields), and to tell xinetd to reread its
configuration (kill -HUP pid-of-xinetd
).
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
• No host access for stdin | Error when starting gnatsd manually | |
• No host access for remote | Cannot connect from another machine |
Q: When starting gnatsd manually (on the command line), I get ‘520 You are not on the host access list: stdin (stdin)’.
A: (GNATS 3.1xx) Gnatsd is not intended to be started manually, but via inetd, xinetd, or a similar "super server". When gnatsd is started this way, its stdin and stdout (standard input and standard output streams) are connected to a so called "TCP socket" (one end of the network connection), and from this socket gnatsd learns the IP address of the remote end (and from this it derives the remote host name). When you start gnatsd from the command line, its stdin and stdout are connected to the terminal, and thus gnatsd gets a nonsense value.
You usually need ‘root’ privileges in order to change the configuration of your "super server". If you don’t have them, contact your system administrator.
See How to Start Gnatsd for inetd and xinetd configuration.
A: (GNATS 4.0) This error message should not occur with gnatsd 4.0 anymore, because gnatsd can be started from the command line. However, this probably only makes sense for debugging and diagnosing problems. Furthermore, you need to play the part of the client program yourself (i.e., you must "speak" the gnatsd client protocol).
Q: Gnatsd rejects connections from a remote host with the error message ‘520 You are not on the host access list’.
A: Check the file ‘gnatsd.host_access’; if you are using the default locations, this is ‘/usr/local/etc/gnats/gnatsd.host_access’. (If you are still using GNATS 3.xxx, the file is named ‘gnatsd.conf’; its default place is ‘/usr/local/etc/gnatsd.conf’.)
Each line of the file names a host and its access level, separated by colons. Gnatsd tries the lines in turn to match the remote host, and the first line that matches wins.
The first field specifies the host(s); it may be a host name (like ‘goedel.example.com’), a partial domain (like ‘*.example.com’), an IP address (like ‘192.168.1.5’), or a partial IP address (like ‘192.168.*’). If it is only ‘*’, it matches all hosts.
Depending on how IP addresses are mapped to hostnames on your gnatsd machine, you may be able to omit the domain (like in ‘goedel’). You may even need to omit the domain for some hosts.
The second field is the access level granted to the remote host. This is usually increased by the access level granted to the user as soon as (s)he logs in.
The third field is currently not used; just leave it empty (but supply the colon between the second and the third field).
Example:
|
The format is described in detail in the comments at the beginning of the file.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
• queue-pr not available | Sendmail refuses to run queue-pr | |
• Outgoing mail bounces | Mail system complains on outgoing mail |
Your sendmail installation uses ‘smrsh’ to check programs that are invoked from a mail alias. ‘smrsh’ only allows the execution of programs of which it is told that they are save. To tell it that ‘queue-pr’ is save, create a symbolic link in the directory ‘/etc/smrsh’ to ‘queue-pr’, like this:
mkdir /etc/smrsh # if it does not yet exist
cd /etc/smrsh
ln -s /usr/local/libexec/gnats/queue-pr queue-pr
|
Replace ‘/usr/local/libexec/gnats/queue-pr’ by the real path to ‘queue-pr’.
You are getting bounce mails like this:
----- Transcript of session follows ----- ... while talking to mail.example.com.: >>> MAIL From:<gnats@mymachine.subdomain.example.com> SIZE=334 <<< 501 5.1.8 <gnats@mymachine.subdomain.example.com>... Domain of sender address gnats@mymachine.subdomain.example.com does not exist |
Probably your GNATS sits behind a firewall, but it needs to exchange mails with the world outside the firewall. Make sure that GNATS_ADDR is valid outside.
This is what probably happens behind the scenes: On its way to the
outside world, the sender address of the mail gets rewritten to
something "official" (like Hans-Albert.Schneider@example.com
, as
opposed to me@mymachine.subdomain.example.com
). This is
especially necessary if the internal hosts are not visible outside. If
your outgoing mail gateway still sees the internal address, it complains
with a message like the above (it has probably checked
mymachine.subdomain.example.com
with your organization’s external
DNS server, which does not know mymachine
).
To solve this problem, get an "official" address for your GNATS system, e.g., tool-bugs@example.com, and use that one for GNATS_ADDR.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
• No New Reports | New reports do not show up in the database | |
• Initially Assign Field Values | If you want to set additional fields when entering a report |
Q: When entering a new PR, I want to assign a value to some field
(e.g., Responsible
) which is normally assigned by GNATS.
A: (GNATS 3.1xx) This is not possible in GNATS 3.1xx.
A: (GNATS 4.x) This is done by adding the field name (in this
example, Responsible
) to the initial-entry
item at
the very end of the ‘dbconfig’ file. Gnatsweb will pick this up
and add a Responsible
field to the Create PR form.
[ << ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This document was generated by Chad Walstrom on March 3, 2015 using texi2html 1.82.