man tcpquotad (Administration système) - tcpquotad - The TCPQuota daemon.
NAME
tcpquotad - The TCPQuota daemon.
SYNOPSIS
tcpquotad [options]
DESCRIPTION
This is the engine of the TCPQuota system. It checks the files in '/proc/net/' for connects to the outside world and the mSQL tables 'allowed' and 'masq'. The daemon closes a host if it is not listed in the mSQL table 'masq', it kills a users processes if the user is not allowed to use the TCP link _OR_ if the user have gone below the minimum quota value.
NOTES
The following signals have the specified effect when sent to the server process using the kill(1) command:
SIGHUP
Causes server to reload the configuration file.
SIGTERM
SIGINT
SIGQUIT
SIGKILL
Causes the server to clean the firewall entries
and the masquerading table from entries, and to
exit cleanly
SIGUSR1
Turns on debugging
SIGUSR2
Turns off debugging
MSQL TABLES
tcptab
- This is the main quota table in the database, this contains
the columns: name and quota.
name
- contains the username of the user allowed
quota
- contains the quota points of the user allowed
This is measured in seconds.
allowed
- This is the table that holds the username of the users
that are allowed to use the 'Net link.
A user can exist in the
tcptab
table
without
being registered here. This is so that one can turn off a
user, without removing it's points.
It only contain one column: name.
name
- contains the username of the user allowed
periodtab
- xx
masq
- This is the table that holds the information on which
host's and user's that the firewall is opened for.
If one, for example executes the program
openfw
without parameters, it checks the file
/etc/tcpquota/tcpquota.cf
for the lines:
GROUPS=GROUP1
GROUP1=xxx yyy zzz
Which means that there are one computer group (GROUP1)
which contains the host's
xxx, yyy
and
zzz.
If you have logged in on the firewall from host
zzz
it opens the host's xxx, yyy and zzz for 'Net access
for free (it depits the TCPQuota user 'free', which
does not need to be an existing system user). This
user can go under any value you set for
MIN_QUOTA
in the config file. This table contains the columns:
host, name, cnts, tic, counter, open and free
host
- Is the IP nummer of the host that the firewall is
opened for.
name
- Is the username of the user that have opened the
firewall for the specified host.
cnts
- Number of connects for the specified host
tic
- Number of ticks since the table was uppdated
counter
- ....
open
- This is for used by the support programs,
openfw
and
openhost
to trigger the opening/closing of the firewall.
If the support programs write a:
3
- means that the firewall should be closed.
2
- means that it should be opened.
And the daemon writes a:
1
- the firewall is opened.
0
- the firewall is closed.
free - This is 1 if the user is allowed free access to the link and 0 if not...
logging
- Contains the logging about who have changed the TCPQuota
database when...
This table contains the columns:
when, user and action
when
- Is the date when the database administrator have
added/removed/changed quota points for another user
user
- The name of the database administrator that have
changed the database
action
- What have the administrator done?
logging_openfw
- Contains the logging about who have opened/closed
the firewall for free/admin access when...
This table contains the columns:
when, user and action
when
- Is the date when the database administrator have
opened/closed the firewall for access...
user
- The name of the person that have opened/closed
the firewall
action
- What have the administrator done (opened/closed,
which set of computers)?
MSQL EXAMPLE
Running msql (1) one can do:
SELECT quota FROM tcptab WHERE name LIKE 'free'\\g
And you'll get something like this:
+----------+ | quota | +----------+ | -1008888 | +----------+
This is the number of quota points the user have left to spend... (In this perticular example, you'll get a negative value, which means that this is how much the user have spend...)
SELECT masq.host, tcptab.name, tcptab.quota FROM tcptab, masq WHERE masq.host LIKE '42.42.40.66 AND tcptab.name LIKE 'free'\\g
You'll get an output something like this:
+-----------------+----------------------+----------+ | host | name | quota | +-----------------+----------------------+----------+ | 42.42.40.66 | free | -1008888 | +-----------------+----------------------+----------+
This means that the user free is allowed free access from host 42.42.40.66 and have accumulated a negative quota value of 1008888 points (seconds).
You naturally have to exchange the IP number and username to your values... For more information on how to use mSQL can be found in the manual page for msql.
FILES
/etc/tcpquota/tcpquota.cf - Main configuration file for the whole TCPQuota system
/etc/tcpquota/tcpquota.cf.debug - Configuration file used when started in debug mode
/etc/init.d/tcpquota.init - Used to start and stop the daemon at boot time
/etc/cron.weekly/tcpquotad - Cron script to rotate the tcpquota log files
/var/log/tcpquotad.log - Log file for the daemon
OPTIONS
- --debug
- Run the daemon in debug mode, do not fork, print extra debug output.
SEE ALSO
AUTHOR
Turbo Fredriksson, <turbo@tripnet.se>
Martin Budsjoe, <marbud@tripnet.se>