The DCC and other man pages describe the features, operating modes, required data files, and other characteristics of the DCC. Also see the DCC FAQ or list of frequently answered questions.
Sendmail must have the
Mail Filter API or Milter enabled.
Some systems such a FreeBSD 4.6 and newer are shipped with
Milter enabled and the library installed by default.
If your system comes with the Milter interface turn on,
then skip to the next step.
Otherwise, the Milter interface must be explicitly enabled
by adding lines like those in
misc/site.config.m4
to your sendmail/devtools/Site/site.config.m4 file or equivalent.
Then build sendmail as described in the INSTALL file distributed with sendmail.
You must build libmilter
separately by something like
cd libmilter sh ./Build
After sendmail has been rebuilt if necessary it will need to be restarted. That should be done at the end of the next step.
See the installation considerations in the DCC man page.
Most DCC files are in a "home directory" such as /var/lib/dcc. DCC programs such as cdcc and dccproc are run by end users and should be installed in a directory such as /usr/bin. They must also be set-UID to the UID that can change the DCC data files. DCC programs that do not need to be run by end users are installed by default in the libexec subdirectory of the DCC home directory. See the table of configure script and makefile parameters. Omit any parameters you don't need change and usually use:
./configure; make install
End users installing only dccproc
can install it in their private
~/bin
directories and use private directories for their DCC
home directories.
In this case, the DCC programs that would otherwise need to be set-UID
need not be.
./configure --disable-sys-inst --disable-server --disable-dccm --disable-dccifd
--homedir=$HOME/dir --bindir=$HOME/bin
to build dccproc
for an individual user.
The sendmail interface, dccm, must be built with the sendmail source and object tree. By default, the makefiles look for a native sendmail libraries (e.g. on FreeBSD 4.6), an installed "package" (e.g. on FreeBSD), or a directory named sendmail parallel to the DCC source and object tree. Those who regularly build new versions of sendmail may find it convenient to make a symbolic link there to their current sendmail. Otherwise configure the dccm makefile with
./configure --with-sendmail=/some/where/sendmail
If dccm does not build because it cannot find libmilter,
check that libmilter was compiled with sendmail
in the previous step.
To connect the sendmail Milter interface to dccm,
copy or "sym-link" misc/dcc.m4
and misc/dccdnsbl.m4 to
your sendmail/cf/feature directory and
add FEATURE(dcc)
lines to your sendmail.mc configuration file.
Then rebuild and reinstall your sendmail.cf file, and restart sendmail.
It is best to use remote servers until the DCC client, dccm or dccproc, is stable. Then
The DCC works better as more mailboxes participate, and "flooding" or exchanging checksums with other servers is the most effective way to get more participants. Flooding requires that every server participating in a network of DCC servers have a unique server-ID and know about all of the other server-IDs. That means that if your server might join a network of DCC servers, you should contact people involved in the network to obtain server-IDs for your servers. For now, server-IDs known to the public network of DCC server can be obtained by contacting Vernon Schryver.
After you have an official server-ID,
Greylisting uses a modified DCC server to maintain a database of checksums of familiar mail senders, their addressees, and the IP addresses of their SMTP clients. Larger sites can use more than one greylist server, with the greylist servers flooding checksums just like DCC servers.
To configure greylisting:
Client-IDs and matching passwords must be used by clients of greylist servers such as dccm and dccifd. The client-IDs must be in the /var/lib/dcc/map file on the client system. Greylist client- and server-IDs must be in the /var/lib/dcc/ids file on the greylist server. When a system hosts both DCC and greylist servers, it is convenient for clients to use the same client-ID and password for both. It is also convenient for a greylist server and a DCC server on a system to share a common server-ID and password.
If the cdcc "info" command does not show the greylist server, add it with something like
cdcc "add localhost greylist 32768 secret"
Systems older than 1.2.0 should copy local parameters to the homedir/dcc_conf file generated by the ./configure script and then install the result in the DCC home directory.
Sites with more than one greylist server should arrange to flood data among them by adding lines to /var/lib/dcc/grey_flod files in the same format as /var/lib/dcc/flod files. Flooding among greylist servers uses port 6276 by default, and so that port may need to be opened in firewalls.
The DCC sendmail milter interface dccm should be started before sendmail. That commonly requires changing an /etc/rc script or configuration file. The distributed file /var/lib/dcc/libexec/start-dccm is a shell script that can be used to start dccm as the user "dcc." It requires local configuration parameters in the dcc_conf file in the DCC home directory. The rc script /var/lib/dcc/libexec/rcDCC for starting dccd can be used with some versions of FreeBSD, Linux, and Solaris.
The general MTA interface dccifd usually must be started before the MTA that uses it.
It is best to only mark mail with X-DCC SMTP headers before changing procmail or dccm to reject mail. Configure dccm with DCCM_LOG_AT in dcc_conf to log bulk mail with somewhat lower counts than
There are several installation configuration parameters that can set to suit individual preferences and systems.
configure option | env name or make variable | used by | default value | use |
---|---|---|---|---|
--homedir=HOMEDIR | configure | /var/lib/dcc/ | DCC home directory with most DCC files. | |
--with-installroot=DIR | configure | prefix all installation directories to build binary tarball | ||
--libexecdir=DIR | configure | --homedir/libexec | directory containing most DCC programs. | |
--bindir=DIR | configure | /usr/bin3 | installation directory for DCC user commands including cdcc and dccproc | |
--mandir=DIR |   | configure | /usr/man3 | installation directory for man pages |
NOMAN | make1 | unset3 | do not install man pages when set | |
--disable-sys-inst3 | configure | enabled | disable system installation or chmod, chgrp, and SUID | |
--with-uid=UID | configure | root | user name for DCC programs and data | |
DCC_SUID | make1 | --with-uid or current3 | set-UID for dccproc, cdcc, and dccsight. | |
DCC_OWN | make1 | bin, daemon on OS X, or current3 | owner of most installed files | |
DCC_GRP | make1 | bin, daemon on OS X, or current3 | group of most installed files | |
DCC_MODE | make1 | 555 | mode of most installed programs | |
MANOWN | make1 | DCC_OWN or current3 | owner of installed man pages | |
MANGRP | make1 | DCC_GRP or current3 | group of installed man pages | |
--disable-server | configure | do not build server | ||
--disable-dccifd | configure | do not build program interface | ||
--disable-dccm | configure | do not build sendmail interface | ||
--with-sendmail=DIR | configure | ../sendmail or /usr/ports/mail/... | directory containing sendmail milter header files | |
--with-cgibin=DIR | configure | --homedir/cgi-bin | directory for DCC white list CGI scripts | |
--with-rundir=DIR | configure | /var/run/dcc | "run" directory for PIDs and sockets | |
CFLAGS | both1 | compiler options such as -g or -O2 | ||
DCC_CFLAGS | configure2 | depends on target | compiler options | |
PTHREAD_CFLAGS | configure2 | depends on target | compiler options for compiling with pthreads | |
LDFLAGS | both1 | linker options | ||
DCC_LDFLAGS | configure2 | depends on target | linker options | |
PTHREAD_LDFLAGS | configure2 | depends on target | linker options for compiling with pthreads | |
LIBS | configure2 | additional libraries to be configured in makefiles. | ||
PTHREAD_LIBS | configure2 | depends on target | libraries for pthreads | |
CC | both | cc | C compiler such as "gcc" or "/opt/SUNWspro/SC6.1/bin/cc" | |
INSTALL | make1 | ./autoconf/install-sh | installation script | |
DCCD_MAX_FLOODS | make1 | 32 | maximum DCC server flooding peers | |
--with-db-memory=MB | configure | 64 | minimum server database buffer size MB between 8 and 3072 MByte | |
--with-max-log-size=KB | configure | 32 | maximum dccifd and dccm log file size in KBytes; 0=no limit | |
--with-bad-locks | configure | without | work around broken fcntl() locking | |
--without-IPv6 | configure | IPV6 on if supported | turn off IPv6 support | |
--with-socks[=lib] | configure | location of SOCKS client library | ||
--with-DCC-MD5 | configure | use MD5 code in DCC source instead of any local library |
The DCC is thought to work on several UNIX-like systems including:
If your system has enough RAM to hold most of the database, adding -F to DBCLEAN_ARGS in dcc_conf can make the daily use of dbclean twice as fast and much less of a load on the system.
While building the sendmail milter library, consider using _FFR_USE_POLL to avoid problems with large file descriptors and select().
./configure --with-db-memory
must be used
Those system names include trademarks. Please don't abuse them.
Much of the DCC list of frequently asked questions concerns troubleshooting DCC installations. Many of the messages in the archive of the DCC mailing list are also troubleshooting questions and answers.
Dccm and sendmail can be configured to report the checksums of unsolicited bulk mail so that other DCC clients can reject later copies of the same unsolicited bulk mail sent from other sources. Such mechanisms are commonly called spam traps.
The sendmail "feature file"
misc/dccdnsbl.m4 used as
FEATURE(dccdnsbl)
causes mail from blacklisted sources to be reported as extremely bulky
to the DCC server as well as rejected.
For example, the following would both reject and report mail
from RSS entries:
FEATURE(dccdnsbl, `relays.mail-abuse.org',
`"Mail from " $`'&{client_addr} " reject to DCC - see http://www.mail-abuse.org/rss/"')
Entries in a sendmail access_db can also be rejected or discarded while they are reported to the DCC server by dccm. The script misc/hackmc modifies the output of sendmail .mc files to tell dccm about some undesirable mail. The script accepts one or more .mc files and generates the corresponding slightly modified .cf files. If the access_db entry starts with the string "DCC:", the message is reported by dccm to the DCC server as extremely bulky. Otherwise the message is rejected as usual. The remainder of the the access_db entry after "DCC:" consists of the optional string "DISCARD" followed by an optional SMTP status message. If the string "DISCARD" is present, the message is discarded instead of rejected. This is important to keep senders of unsolicited bulk mail from discovering and removing "spam trap" addresses from their lists.
For example, a line like the following in an access_db can discard all mail from example.com while reporting it to the DCC server as extremely bulky. Note the quotes (").
example.com DCC: "DISCARD spam"
It is also possible to route mail from a spam trap address to dccproc as described in the dccproc man page
The DCC client and server programs can be built to use the SOCKS protocol. The --with-socks configure parameter configures the DCC client library and the DCC server to use common SOCKS network library functions. If the SOCKS library is in a standard place, something like --with-socks=socks should be sufficient. Setting the environment variable DCC_LDFLAGS to something like -L/usr/lib is sometimes helpful. Otherwise, using --with-socks without specifying the library name and setting LIBS to the full pathname of the library might work.
DCC client programs including dccproc and dccm that use the DCC client library must be told to use the SOCKS5 protocol with the SOCKS on operation of cdcc. SOCKS5 is required instead of SOCKS4 because DCC clients communicate with DCC servers using UDP.
DCC servers can use SOCKS4 or SOCKS5 when exchanging floods of reports of checksums. Links between individual pairs of peers are configured with the passive and SOCKS flags in the flod file described in the dccd man page. In both cases, the SOCKS library code must be configured, often in the files /etc/socks.conf and /etc/socksd.conf.
When the DCC software is built with SOCKS, IPv6 name resolution is turned off.
The DCC server and client programs have been tested with the DANTE library and server. The DANTE SOCKS implementation is also one of the FreeBSD "ports" or packages.
Note that if a connection fails repeatedly, Dante will disable the rule that failed and will eventually try the underlying connect() call. This fails in almost every SOCKS environment because there is no available route for an ordinary connect(). Dante by default won't re-enable the failing rule. To fix this, change BADROUTE_EXPIRE from the default of 0*60 to 5 in include/config.h in the Dante source and recompile.
The NEC SOCKS implementation should be similar.
This document describes DCC version 1.2.53.